lsp_log_tests.rs

  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// }