lsp_log_tests.rs

  1use std::sync::Arc;
  2
  3use crate::lsp_log::LogMenuItem;
  4
  5use super::*;
  6use futures::StreamExt;
  7use gpui::{Context, TestAppContext, VisualTestContext};
  8use language::{tree_sitter_rust, FakeLspAdapter, Language, LanguageConfig, LanguageServerName};
  9use project::{FakeFs, Project};
 10use serde_json::json;
 11use settings::SettingsStore;
 12
 13#[gpui::test]
 14async 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_executor.clone());
 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.new_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 window = cx.add_window(|cx| LspLogView::new(project.clone(), log_store.clone(), cx));
 66    let log_view = window.root(cx).unwrap();
 67    let mut cx = VisualTestContext::from_window(*window, 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.executor().run_until_parked();
 74
 75    log_view.update(&mut 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()
 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
 98fn init_test(cx: &mut gpui::TestAppContext) {
 99    cx.update(|cx| {
100        let settings_store = SettingsStore::test(cx);
101        cx.set_global(settings_store);
102        theme::init(theme::LoadThemes::JustBase, cx);
103        release_channel::init("0.0.0", cx);
104        language::init(cx);
105        client::init_settings(cx);
106        Project::init_settings(cx);
107        editor::init_settings(cx);
108    });
109}