lsp_log_tests.rs

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