From dc99ad912a692d63d551aeabd5d2a9e1e217856b Mon Sep 17 00:00:00 2001 From: hkalbasi Date: Sat, 9 Mar 2024 01:20:43 +0330 Subject: [PATCH] Some minor changes in the test explorer lsp extension --- crates/flycheck/src/test_runner.rs | 1 + crates/rust-analyzer/src/lsp/ext.rs | 4 +-- crates/rust-analyzer/src/lsp/to_proto.rs | 8 +++--- crates/rust-analyzer/src/main_loop.rs | 1 + docs/dev/lsp-extensions.md | 31 +++++++++++++++++++----- editors/code/src/lsp_ext.ts | 9 +++++-- editors/code/src/test_explorer.ts | 6 ++++- 7 files changed, 45 insertions(+), 15 deletions(-) diff --git a/crates/flycheck/src/test_runner.rs b/crates/flycheck/src/test_runner.rs index b7d966989b..6dac5899ee 100644 --- a/crates/flycheck/src/test_runner.rs +++ b/crates/flycheck/src/test_runner.rs @@ -14,6 +14,7 @@ use crate::command::{CommandHandle, ParseFromLine}; pub enum TestState { Started, Ok, + Ignored, Failed { stdout: String }, } diff --git a/crates/rust-analyzer/src/lsp/ext.rs b/crates/rust-analyzer/src/lsp/ext.rs index 842e765d9d..86ab652f8e 100644 --- a/crates/rust-analyzer/src/lsp/ext.rs +++ b/crates/rust-analyzer/src/lsp/ext.rs @@ -171,7 +171,7 @@ pub struct DiscoverTestParams { #[derive(Deserialize, Serialize, Debug)] #[serde(rename_all = "camelCase")] -pub enum TestItemIcon { +pub enum TestItemKind { Package, Module, Test, @@ -182,7 +182,7 @@ pub enum TestItemIcon { pub struct TestItem { pub id: String, pub label: String, - pub icon: TestItemIcon, + pub kind: TestItemKind, pub can_resolve_children: bool, pub parent: Option, pub text_document: Option, diff --git a/crates/rust-analyzer/src/lsp/to_proto.rs b/crates/rust-analyzer/src/lsp/to_proto.rs index f0bb7d8af3..e2b55f4a5c 100644 --- a/crates/rust-analyzer/src/lsp/to_proto.rs +++ b/crates/rust-analyzer/src/lsp/to_proto.rs @@ -1506,10 +1506,10 @@ pub(crate) fn test_item( lsp_ext::TestItem { id: test_item.id, label: test_item.label, - icon: match test_item.kind { - ide::TestItemKind::Crate => lsp_ext::TestItemIcon::Package, - ide::TestItemKind::Module => lsp_ext::TestItemIcon::Module, - ide::TestItemKind::Function => lsp_ext::TestItemIcon::Test, + kind: match test_item.kind { + ide::TestItemKind::Crate => lsp_ext::TestItemKind::Package, + ide::TestItemKind::Module => lsp_ext::TestItemKind::Module, + ide::TestItemKind::Function => lsp_ext::TestItemKind::Test, }, can_resolve_children: matches!( test_item.kind, diff --git a/crates/rust-analyzer/src/main_loop.rs b/crates/rust-analyzer/src/main_loop.rs index 99c00d0384..bca6db19dc 100644 --- a/crates/rust-analyzer/src/main_loop.rs +++ b/crates/rust-analyzer/src/main_loop.rs @@ -779,6 +779,7 @@ impl GlobalState { flycheck::CargoTestMessage::Test { name, state } => { let state = match state { flycheck::TestState::Started => lsp_ext::TestState::Started, + flycheck::TestState::Ignored => lsp_ext::TestState::Skipped, flycheck::TestState::Ok => lsp_ext::TestState::Passed, flycheck::TestState::Failed { stdout } => { lsp_ext::TestState::Failed { message: stdout } diff --git a/docs/dev/lsp-extensions.md b/docs/dev/lsp-extensions.md index 17e2eb5da5..af5b4e51ef 100644 --- a/docs/dev/lsp-extensions.md +++ b/docs/dev/lsp-extensions.md @@ -1,5 +1,5 @@