1// todo!("TODO kb")
2// use std::sync::Arc;
3
4// use crate::lsp_log::LogMenuItem;
5
6// use super::*;
7// use futures::StreamExt;
8// use gpui::{serde_json::json, TestAppContext};
9// use language::{tree_sitter_rust, FakeLspAdapter, Language, LanguageConfig, LanguageServerName};
10// use project::{FakeFs, Project};
11// use settings::SettingsStore;
12
13// #[gpui::test]
14// async fn test_lsp_logs(cx: &mut TestAppContext) {
15// if std::env::var("RUST_LOG").is_ok() {
16// env_logger::init();
17// }
18
19// init_test(cx);
20
21// let mut rust_language = Language::new(
22// LanguageConfig {
23// name: "Rust".into(),
24// path_suffixes: vec!["rs".to_string()],
25// ..Default::default()
26// },
27// Some(tree_sitter_rust::language()),
28// );
29// let mut fake_rust_servers = rust_language
30// .set_fake_lsp_adapter(Arc::new(FakeLspAdapter {
31// name: "the-rust-language-server",
32// ..Default::default()
33// }))
34// .await;
35
36// let fs = FakeFs::new(cx.background());
37// fs.insert_tree(
38// "/the-root",
39// json!({
40// "test.rs": "",
41// "package.json": "",
42// }),
43// )
44// .await;
45// let project = Project::test(fs.clone(), ["/the-root".as_ref()], cx).await;
46// project.update(cx, |project, _| {
47// project.languages().add(Arc::new(rust_language));
48// });
49
50// let log_store = cx.add_model(|cx| LogStore::new(cx));
51// log_store.update(cx, |store, cx| store.add_project(&project, cx));
52
53// let _rust_buffer = project
54// .update(cx, |project, cx| {
55// project.open_local_buffer("/the-root/test.rs", cx)
56// })
57// .await
58// .unwrap();
59
60// let mut language_server = fake_rust_servers.next().await.unwrap();
61// language_server
62// .receive_notification::<lsp::notification::DidOpenTextDocument>()
63// .await;
64
65// let log_view = cx
66// .add_window(|cx| LspLogView::new(project.clone(), log_store.clone(), cx))
67// .root(cx);
68
69// language_server.notify::<lsp::notification::LogMessage>(lsp::LogMessageParams {
70// message: "hello from the server".into(),
71// typ: lsp::MessageType::INFO,
72// });
73// cx.foreground().run_until_parked();
74
75// log_view.read_with(cx, |view, cx| {
76// assert_eq!(
77// view.menu_items(cx).unwrap(),
78// &[LogMenuItem {
79// server_id: language_server.server.server_id(),
80// server_name: LanguageServerName("the-rust-language-server".into()),
81// worktree_root_name: project
82// .read(cx)
83// .worktrees(cx)
84// .next()
85// .unwrap()
86// .read(cx)
87// .root_name()
88// .to_string(),
89// rpc_trace_enabled: false,
90// rpc_trace_selected: false,
91// logs_selected: true,
92// }]
93// );
94// assert_eq!(view.editor.read(cx).text(cx), "hello from the server\n");
95// });
96// }
97
98// fn init_test(cx: &mut gpui::TestAppContext) {
99// cx.foreground().forbid_parking();
100
101// cx.update(|cx| {
102// cx.set_global(SettingsStore::test(cx));
103// theme::init((), cx);
104// language::init(cx);
105// client::init_settings(cx);
106// Project::init_settings(cx);
107// editor::init_settings(cx);
108// });
109// }