From d07b448932ca8c714eff744d8582b7b0de1163fd Mon Sep 17 00:00:00 2001 From: Peefy Date: Fri, 31 May 2024 18:03:39 +0800 Subject: [PATCH 1/2] fix: list and config if expr error recovery in the parser (#1384) Signed-off-by: peefy --- kclvm/parser/src/parser/expr.rs | 6 + kclvm/parser/src/tests/error_recovery.rs | 30 ++++ ...sts__error_recovery__list_recovery_13.snap | 90 +++++++++++ ...sts__error_recovery__list_recovery_14.snap | 87 +++++++++++ ...sts__error_recovery__list_recovery_15.snap | 89 +++++++++++ ...sts__error_recovery__list_recovery_16.snap | 140 ++++++++++++++++++ ...sts__error_recovery__list_recovery_17.snap | 137 +++++++++++++++++ ...sts__error_recovery__list_recovery_18.snap | 126 ++++++++++++++++ 8 files changed, 705 insertions(+) create mode 100644 kclvm/parser/src/tests/snapshots/kclvm_parser__tests__error_recovery__list_recovery_13.snap create mode 100644 kclvm/parser/src/tests/snapshots/kclvm_parser__tests__error_recovery__list_recovery_14.snap create mode 100644 kclvm/parser/src/tests/snapshots/kclvm_parser__tests__error_recovery__list_recovery_15.snap create mode 100644 kclvm/parser/src/tests/snapshots/kclvm_parser__tests__error_recovery__list_recovery_16.snap create mode 100644 kclvm/parser/src/tests/snapshots/kclvm_parser__tests__error_recovery__list_recovery_17.snap create mode 100644 kclvm/parser/src/tests/snapshots/kclvm_parser__tests__error_recovery__list_recovery_18.snap diff --git a/kclvm/parser/src/parser/expr.rs b/kclvm/parser/src/parser/expr.rs index 9283f2d28..b1e0067a4 100644 --- a/kclvm/parser/src/parser/expr.rs +++ b/kclvm/parser/src/parser/expr.rs @@ -1163,6 +1163,7 @@ impl<'a> Parser<'a> { // elif ... let mut elif_list = Vec::new(); loop { + let marker = self.mark(); if !self.token.is_keyword(kw::Elif) { break; } @@ -1188,6 +1189,7 @@ impl<'a> Parser<'a> { x, self.sess.struct_token_loc(token, self.prev_token), ))); + self.drop(marker); } if let TokenKind::Newline = self.token.kind { @@ -1259,6 +1261,7 @@ impl<'a> Parser<'a> { let mut body = Vec::new(); loop { + let marker = self.mark(); self.validate_dedent(); if matches!(self.token.kind, TokenKind::Dedent(VALID_SPACES_LENGTH)) { break; @@ -1270,6 +1273,7 @@ impl<'a> Parser<'a> { self.bump(); } self.skip_newlines(); + self.drop(marker); } self.validate_dedent(); self.bump_token(TokenKind::Dedent(VALID_SPACES_LENGTH)); @@ -1581,6 +1585,7 @@ impl<'a> Parser<'a> { let mut elif_list = Vec::new(); let mut last_token = self.token; loop { + let marker = self.mark(); if !self.token.is_keyword(kw::Elif) { break; } @@ -1607,6 +1612,7 @@ impl<'a> Parser<'a> { self.sess.struct_token_loc(token, self.prev_token), ))); last_token = self.prev_token; + self.drop(marker); } if let TokenKind::Newline = self.token.kind { diff --git a/kclvm/parser/src/tests/error_recovery.rs b/kclvm/parser/src/tests/error_recovery.rs index 00bf54555..cff059570 100644 --- a/kclvm/parser/src/tests/error_recovery.rs +++ b/kclvm/parser/src/tests/error_recovery.rs @@ -52,6 +52,21 @@ parse_expr_snapshot! { list_recovery_9, "[*a, **b]" } parse_expr_snapshot! { list_recovery_10, "[**a, *b" } parse_expr_snapshot! { list_recovery_11, "[if True: a, b]" } parse_expr_snapshot! { list_recovery_12, "[if True: **a, b]" } +parse_expr_snapshot! { list_recovery_13, r#"[ + if True: + b = [] +] +"# } +parse_expr_snapshot! { list_recovery_14, r#"[ + if True: + b = +] +"# } +parse_expr_snapshot! { list_recovery_15, r#"[ + if True: + b - +] +"# } parse_expr_snapshot! { config_recovery_0, "{" } parse_expr_snapshot! { config_recovery_1, "{a = 1" } parse_expr_snapshot! { config_recovery_2, "{a = 1, b = 2" } @@ -71,6 +86,21 @@ parse_expr_snapshot! { config_recovery_12, "{if True: *a, b = 2}" } parse_expr_snapshot! { config_recovery_13, "{if True: key: {}}" } parse_expr_snapshot! { config_recovery_14, "{if True: key: []}" } parse_expr_snapshot! { config_recovery_15, "{你好" } +parse_expr_snapshot! { list_recovery_16, r#"{ + if True: + b = [] = [] +} +"# } +parse_expr_snapshot! { list_recovery_17, r#"{ + if True: + b = [] = +} +"# } +parse_expr_snapshot! { list_recovery_18, r#"{ + if True: + b = [] - +} +"# } parse_expr_snapshot! { comp_clause_recovery_0, "[i for i in [1,2,3]]" } parse_expr_snapshot! { comp_clause_recovery_1, "[i, j for i in [1,2,3]]" } parse_expr_snapshot! { comp_clause_recovery_2, "[for i in [1,2,3]]" } diff --git a/kclvm/parser/src/tests/snapshots/kclvm_parser__tests__error_recovery__list_recovery_13.snap b/kclvm/parser/src/tests/snapshots/kclvm_parser__tests__error_recovery__list_recovery_13.snap new file mode 100644 index 000000000..90b45fd76 --- /dev/null +++ b/kclvm/parser/src/tests/snapshots/kclvm_parser__tests__error_recovery__list_recovery_13.snap @@ -0,0 +1,90 @@ +--- +source: parser/src/tests/error_recovery.rs +expression: "crate::tests::parsing_expr_string(r#\"[\n if True:\n b = []\n]\n\"#)" +--- +Node { + node: List( + ListExpr { + elts: [ + Node { + node: ListIfItem( + ListIfItemExpr { + if_cond: Node { + node: NameConstantLit( + NameConstantLit { + value: True, + }, + ), + filename: "", + line: 2, + column: 7, + end_line: 2, + end_column: 11, + }, + exprs: [ + Node { + node: Identifier( + Identifier { + names: [ + Node { + node: "b", + filename: "", + line: 3, + column: 8, + end_line: 3, + end_column: 9, + }, + ], + pkgpath: "", + ctx: Load, + }, + ), + filename: "", + line: 3, + column: 8, + end_line: 3, + end_column: 9, + }, + Node { + node: Missing( + MissingExpr, + ), + filename: "", + line: 3, + column: 10, + end_line: 3, + end_column: 11, + }, + Node { + node: List( + ListExpr { + elts: [], + ctx: Load, + }, + ), + filename: "", + line: 3, + column: 12, + end_line: 3, + end_column: 14, + }, + ], + orelse: None, + }, + ), + filename: "", + line: 2, + column: 4, + end_line: 4, + end_column: 0, + }, + ], + ctx: Load, + }, + ), + filename: "", + line: 1, + column: 0, + end_line: 4, + end_column: 1, +} diff --git a/kclvm/parser/src/tests/snapshots/kclvm_parser__tests__error_recovery__list_recovery_14.snap b/kclvm/parser/src/tests/snapshots/kclvm_parser__tests__error_recovery__list_recovery_14.snap new file mode 100644 index 000000000..fe6b45e6d --- /dev/null +++ b/kclvm/parser/src/tests/snapshots/kclvm_parser__tests__error_recovery__list_recovery_14.snap @@ -0,0 +1,87 @@ +--- +source: parser/src/tests/error_recovery.rs +expression: "crate::tests::parsing_expr_string(r#\"[\n if True:\n b = \n]\n\"#)" +--- +Node { + node: List( + ListExpr { + elts: [ + Node { + node: ListIfItem( + ListIfItemExpr { + if_cond: Node { + node: NameConstantLit( + NameConstantLit { + value: True, + }, + ), + filename: "", + line: 2, + column: 7, + end_line: 2, + end_column: 11, + }, + exprs: [ + Node { + node: Identifier( + Identifier { + names: [ + Node { + node: "b", + filename: "", + line: 3, + column: 8, + end_line: 3, + end_column: 9, + }, + ], + pkgpath: "", + ctx: Load, + }, + ), + filename: "", + line: 3, + column: 8, + end_line: 3, + end_column: 9, + }, + Node { + node: Missing( + MissingExpr, + ), + filename: "", + line: 3, + column: 10, + end_line: 3, + end_column: 11, + }, + Node { + node: Missing( + MissingExpr, + ), + filename: "", + line: 3, + column: 12, + end_line: 4, + end_column: 0, + }, + ], + orelse: None, + }, + ), + filename: "", + line: 2, + column: 4, + end_line: 4, + end_column: 0, + }, + ], + ctx: Load, + }, + ), + filename: "", + line: 1, + column: 0, + end_line: 4, + end_column: 1, +} diff --git a/kclvm/parser/src/tests/snapshots/kclvm_parser__tests__error_recovery__list_recovery_15.snap b/kclvm/parser/src/tests/snapshots/kclvm_parser__tests__error_recovery__list_recovery_15.snap new file mode 100644 index 000000000..4d35ef38b --- /dev/null +++ b/kclvm/parser/src/tests/snapshots/kclvm_parser__tests__error_recovery__list_recovery_15.snap @@ -0,0 +1,89 @@ +--- +source: parser/src/tests/error_recovery.rs +expression: "crate::tests::parsing_expr_string(r#\"[\n if True:\n b -\n]\n\"#)" +--- +Node { + node: List( + ListExpr { + elts: [ + Node { + node: ListIfItem( + ListIfItemExpr { + if_cond: Node { + node: NameConstantLit( + NameConstantLit { + value: True, + }, + ), + filename: "", + line: 2, + column: 7, + end_line: 2, + end_column: 11, + }, + exprs: [ + Node { + node: Binary( + BinaryExpr { + left: Node { + node: Identifier( + Identifier { + names: [ + Node { + node: "b", + filename: "", + line: 3, + column: 8, + end_line: 3, + end_column: 9, + }, + ], + pkgpath: "", + ctx: Load, + }, + ), + filename: "", + line: 3, + column: 8, + end_line: 3, + end_column: 9, + }, + op: Sub, + right: Node { + node: Missing( + MissingExpr, + ), + filename: "", + line: 3, + column: 11, + end_line: 4, + end_column: 0, + }, + }, + ), + filename: "", + line: 3, + column: 8, + end_line: 3, + end_column: 11, + }, + ], + orelse: None, + }, + ), + filename: "", + line: 2, + column: 4, + end_line: 4, + end_column: 0, + }, + ], + ctx: Load, + }, + ), + filename: "", + line: 1, + column: 0, + end_line: 4, + end_column: 1, +} diff --git a/kclvm/parser/src/tests/snapshots/kclvm_parser__tests__error_recovery__list_recovery_16.snap b/kclvm/parser/src/tests/snapshots/kclvm_parser__tests__error_recovery__list_recovery_16.snap new file mode 100644 index 000000000..28dc6c75d --- /dev/null +++ b/kclvm/parser/src/tests/snapshots/kclvm_parser__tests__error_recovery__list_recovery_16.snap @@ -0,0 +1,140 @@ +--- +source: parser/src/tests/error_recovery.rs +expression: "crate::tests::parsing_expr_string(r#\"{\n if True:\n b = [] = []\n}\n\"#)" +--- +Node { + node: Config( + ConfigExpr { + items: [ + Node { + node: ConfigEntry { + key: None, + value: Node { + node: ConfigIfEntry( + ConfigIfEntryExpr { + if_cond: Node { + node: NameConstantLit( + NameConstantLit { + value: True, + }, + ), + filename: "", + line: 2, + column: 7, + end_line: 2, + end_column: 11, + }, + items: [ + Node { + node: ConfigEntry { + key: Some( + Node { + node: Identifier( + Identifier { + names: [ + Node { + node: "b", + filename: "", + line: 3, + column: 8, + end_line: 3, + end_column: 9, + }, + ], + pkgpath: "", + ctx: Load, + }, + ), + filename: "", + line: 3, + column: 8, + end_line: 3, + end_column: 9, + }, + ), + value: Node { + node: List( + ListExpr { + elts: [], + ctx: Load, + }, + ), + filename: "", + line: 3, + column: 12, + end_line: 3, + end_column: 14, + }, + operation: Override, + insert_index: -1, + }, + filename: "", + line: 3, + column: 8, + end_line: 3, + end_column: 14, + }, + Node { + node: ConfigEntry { + key: Some( + Node { + node: Missing( + MissingExpr, + ), + filename: "", + line: 3, + column: 15, + end_line: 3, + end_column: 16, + }, + ), + value: Node { + node: List( + ListExpr { + elts: [], + ctx: Load, + }, + ), + filename: "", + line: 3, + column: 17, + end_line: 3, + end_column: 19, + }, + operation: Override, + insert_index: -1, + }, + filename: "", + line: 3, + column: 15, + end_line: 3, + end_column: 19, + }, + ], + orelse: None, + }, + ), + filename: "", + line: 2, + column: 4, + end_line: 4, + end_column: 0, + }, + operation: Union, + insert_index: -1, + }, + filename: "", + line: 2, + column: 4, + end_line: 4, + end_column: 0, + }, + ], + }, + ), + filename: "", + line: 1, + column: 0, + end_line: 4, + end_column: 1, +} diff --git a/kclvm/parser/src/tests/snapshots/kclvm_parser__tests__error_recovery__list_recovery_17.snap b/kclvm/parser/src/tests/snapshots/kclvm_parser__tests__error_recovery__list_recovery_17.snap new file mode 100644 index 000000000..592f00612 --- /dev/null +++ b/kclvm/parser/src/tests/snapshots/kclvm_parser__tests__error_recovery__list_recovery_17.snap @@ -0,0 +1,137 @@ +--- +source: parser/src/tests/error_recovery.rs +expression: "crate::tests::parsing_expr_string(r#\"{\n if True:\n b = [] = \n}\n\"#)" +--- +Node { + node: Config( + ConfigExpr { + items: [ + Node { + node: ConfigEntry { + key: None, + value: Node { + node: ConfigIfEntry( + ConfigIfEntryExpr { + if_cond: Node { + node: NameConstantLit( + NameConstantLit { + value: True, + }, + ), + filename: "", + line: 2, + column: 7, + end_line: 2, + end_column: 11, + }, + items: [ + Node { + node: ConfigEntry { + key: Some( + Node { + node: Identifier( + Identifier { + names: [ + Node { + node: "b", + filename: "", + line: 3, + column: 8, + end_line: 3, + end_column: 9, + }, + ], + pkgpath: "", + ctx: Load, + }, + ), + filename: "", + line: 3, + column: 8, + end_line: 3, + end_column: 9, + }, + ), + value: Node { + node: List( + ListExpr { + elts: [], + ctx: Load, + }, + ), + filename: "", + line: 3, + column: 12, + end_line: 3, + end_column: 14, + }, + operation: Override, + insert_index: -1, + }, + filename: "", + line: 3, + column: 8, + end_line: 3, + end_column: 14, + }, + Node { + node: ConfigEntry { + key: Some( + Node { + node: Missing( + MissingExpr, + ), + filename: "", + line: 3, + column: 15, + end_line: 3, + end_column: 16, + }, + ), + value: Node { + node: Missing( + MissingExpr, + ), + filename: "", + line: 3, + column: 17, + end_line: 4, + end_column: 0, + }, + operation: Override, + insert_index: -1, + }, + filename: "", + line: 3, + column: 15, + end_line: 4, + end_column: 0, + }, + ], + orelse: None, + }, + ), + filename: "", + line: 2, + column: 4, + end_line: 4, + end_column: 0, + }, + operation: Union, + insert_index: -1, + }, + filename: "", + line: 2, + column: 4, + end_line: 4, + end_column: 0, + }, + ], + }, + ), + filename: "", + line: 1, + column: 0, + end_line: 4, + end_column: 1, +} diff --git a/kclvm/parser/src/tests/snapshots/kclvm_parser__tests__error_recovery__list_recovery_18.snap b/kclvm/parser/src/tests/snapshots/kclvm_parser__tests__error_recovery__list_recovery_18.snap new file mode 100644 index 000000000..514a63e75 --- /dev/null +++ b/kclvm/parser/src/tests/snapshots/kclvm_parser__tests__error_recovery__list_recovery_18.snap @@ -0,0 +1,126 @@ +--- +source: parser/src/tests/error_recovery.rs +expression: "crate::tests::parsing_expr_string(r#\"{\n if True:\n b = [] -\n}\n\"#)" +--- +Node { + node: Config( + ConfigExpr { + items: [ + Node { + node: ConfigEntry { + key: None, + value: Node { + node: ConfigIfEntry( + ConfigIfEntryExpr { + if_cond: Node { + node: NameConstantLit( + NameConstantLit { + value: True, + }, + ), + filename: "", + line: 2, + column: 7, + end_line: 2, + end_column: 11, + }, + items: [ + Node { + node: ConfigEntry { + key: Some( + Node { + node: Identifier( + Identifier { + names: [ + Node { + node: "b", + filename: "", + line: 3, + column: 8, + end_line: 3, + end_column: 9, + }, + ], + pkgpath: "", + ctx: Load, + }, + ), + filename: "", + line: 3, + column: 8, + end_line: 3, + end_column: 9, + }, + ), + value: Node { + node: Binary( + BinaryExpr { + left: Node { + node: List( + ListExpr { + elts: [], + ctx: Load, + }, + ), + filename: "", + line: 3, + column: 12, + end_line: 3, + end_column: 14, + }, + op: Sub, + right: Node { + node: Missing( + MissingExpr, + ), + filename: "", + line: 3, + column: 16, + end_line: 4, + end_column: 0, + }, + }, + ), + filename: "", + line: 3, + column: 12, + end_line: 3, + end_column: 16, + }, + operation: Override, + insert_index: -1, + }, + filename: "", + line: 3, + column: 8, + end_line: 3, + end_column: 16, + }, + ], + orelse: None, + }, + ), + filename: "", + line: 2, + column: 4, + end_line: 4, + end_column: 0, + }, + operation: Union, + insert_index: -1, + }, + filename: "", + line: 2, + column: 4, + end_line: 4, + end_column: 0, + }, + ], + }, + ), + filename: "", + line: 1, + column: 0, + end_line: 4, + end_column: 1, +} From c07925fcd68a1690110ba9053a9b71106c3e52d2 Mon Sep 17 00:00:00 2001 From: Wck-iipi <110763795+Wck-iipi@users.noreply.github.com> Date: Fri, 31 May 2024 15:54:25 +0530 Subject: [PATCH 2/2] [Refractor] Refractor lsp unit test (#1379) * Refractored lambda_local_var_test Signed-off-by: Wck-iipi <110763795+Wck-iipi@users.noreply.github.com> * Refractored goto_def_test with snapshot testing Signed-off-by: Wck-iipi <110763795+Wck-iipi@users.noreply.github.com> * Fixed goto_local_var_def_tests Signed-off-by: Wck-iipi <110763795+Wck-iipi@users.noreply.github.com> --------- Signed-off-by: Wck-iipi <110763795+Wck-iipi@users.noreply.github.com> --- kclvm/tools/src/LSP/src/goto_def.rs | 844 +++++------------- ...o_def__tests__complex_select_goto_def.snap | 5 + ...f__tests__config_desuger_def_goto_def.snap | 5 + ...oto_def__tests__goto_assign_type_test.snap | 5 + ...tests__goto_dict_to_schema_attr_test1.snap | 2 +- ...tests__goto_dict_to_schema_attr_test2.snap | 2 +- ...tests__goto_dict_to_schema_attr_test3.snap | 2 +- ...tests__goto_dict_to_schema_attr_test4.snap | 2 +- ...tests__goto_dict_to_schema_attr_test5.snap | 2 +- ..._def__tests__goto_identifier_def_test.snap | 5 + ...to_def__tests__goto_identifier_names1.snap | 5 + ...to_def__tests__goto_identifier_names2.snap | 5 + ...to_def__tests__goto_identifier_names3.snap | 5 + ...goto_def__tests__goto_import_pkg_test.snap | 5 + ...f__tests__goto_lambda_param_goto_def1.snap | 5 + ...f__tests__goto_lambda_param_goto_def2.snap | 5 + ..._def__tests__goto_local_var_def_test1.snap | 5 + ..._def__tests__goto_local_var_def_test2.snap | 5 + ..._def__tests__goto_local_var_def_test3.snap | 5 + ..._def__tests__goto_pkg_prefix_def_test.snap | 5 + ...ef__tests__goto_schema_attr_def_test1.snap | 5 + ...ef__tests__goto_schema_attr_def_test2.snap | 5 + ..._tests__goto_schema_attr_ty_def_test1.snap | 5 + ..._tests__goto_schema_attr_ty_def_test2.snap | 5 + ..._tests__goto_schema_attr_ty_def_test3.snap | 5 + ..._tests__goto_schema_attr_ty_def_test4.snap | 5 + ..._tests__goto_schema_attr_ty_def_test5.snap | 5 + ...goto_def__tests__goto_schema_def_test.snap | 5 + ...goto_def__tests__goto_system_pkg_test.snap | 2 +- ...var_def_in_config_and_config_if_test1.snap | 5 + ...var_def_in_config_and_config_if_test2.snap | 5 + ...var_def_in_config_and_config_if_test3.snap | 5 + ...var_def_in_config_and_config_if_test4.snap | 5 + ...ests__goto_var_def_in_dict_comp_test1.snap | 5 + ...ests__goto_var_def_in_dict_comp_test2.snap | 5 + ...oto_def__tests__lambda_local_var_test.snap | 5 + ...r__goto_def__tests__list_if_expr_test.snap | 5 + ..._tests__schema_attribute_def_goto_def.snap | 5 + ...r__hover__tests__dict_key_in_schema-2.snap | 5 - ...r__hover__tests__dict_key_in_schema-3.snap | 5 - ...ver__hover__tests__dict_key_in_schema.snap | 5 - .../complex_select_goto_def.k | 13 + .../config_desuger_def_goto_def.k | 8 + .../goto_assign_type_test.k | 5 + .../goto_identifier_def_test.k | 8 + .../goto_import_file_test.k | 1 + .../goto_import_pkg_test.k | 1 + .../goto_lambda_param_goto_def.k | 3 + .../goto_local_var_def_test.k | 12 + .../goto_pkg_prefix_def_test.k | 7 + .../goto_schema_attr_def_test.k | 18 + .../goto_schema_attr_ty_def_test.k | 8 + .../goto_schema_def_test.k | 7 + .../goto_system_pkg_test.k | 0 ...oto_var_def_in_config_and_config_if_test.k | 11 + .../goto_var_def_in_dict_comp_test.k | 8 + .../lambda_local_var_test.k | 3 + .../list_if_expr_test/list_if_expr_test.k | 6 + .../schema_attribute_def_goto_def.k | 3 + .../test_goto_identifier_names.k | 13 + 60 files changed, 543 insertions(+), 618 deletions(-) create mode 100644 kclvm/tools/src/LSP/src/snapshots/kcl_language_server__goto_def__tests__complex_select_goto_def.snap create mode 100644 kclvm/tools/src/LSP/src/snapshots/kcl_language_server__goto_def__tests__config_desuger_def_goto_def.snap create mode 100644 kclvm/tools/src/LSP/src/snapshots/kcl_language_server__goto_def__tests__goto_assign_type_test.snap create mode 100644 kclvm/tools/src/LSP/src/snapshots/kcl_language_server__goto_def__tests__goto_identifier_def_test.snap create mode 100644 kclvm/tools/src/LSP/src/snapshots/kcl_language_server__goto_def__tests__goto_identifier_names1.snap create mode 100644 kclvm/tools/src/LSP/src/snapshots/kcl_language_server__goto_def__tests__goto_identifier_names2.snap create mode 100644 kclvm/tools/src/LSP/src/snapshots/kcl_language_server__goto_def__tests__goto_identifier_names3.snap create mode 100644 kclvm/tools/src/LSP/src/snapshots/kcl_language_server__goto_def__tests__goto_import_pkg_test.snap create mode 100644 kclvm/tools/src/LSP/src/snapshots/kcl_language_server__goto_def__tests__goto_lambda_param_goto_def1.snap create mode 100644 kclvm/tools/src/LSP/src/snapshots/kcl_language_server__goto_def__tests__goto_lambda_param_goto_def2.snap create mode 100644 kclvm/tools/src/LSP/src/snapshots/kcl_language_server__goto_def__tests__goto_local_var_def_test1.snap create mode 100644 kclvm/tools/src/LSP/src/snapshots/kcl_language_server__goto_def__tests__goto_local_var_def_test2.snap create mode 100644 kclvm/tools/src/LSP/src/snapshots/kcl_language_server__goto_def__tests__goto_local_var_def_test3.snap create mode 100644 kclvm/tools/src/LSP/src/snapshots/kcl_language_server__goto_def__tests__goto_pkg_prefix_def_test.snap create mode 100644 kclvm/tools/src/LSP/src/snapshots/kcl_language_server__goto_def__tests__goto_schema_attr_def_test1.snap create mode 100644 kclvm/tools/src/LSP/src/snapshots/kcl_language_server__goto_def__tests__goto_schema_attr_def_test2.snap create mode 100644 kclvm/tools/src/LSP/src/snapshots/kcl_language_server__goto_def__tests__goto_schema_attr_ty_def_test1.snap create mode 100644 kclvm/tools/src/LSP/src/snapshots/kcl_language_server__goto_def__tests__goto_schema_attr_ty_def_test2.snap create mode 100644 kclvm/tools/src/LSP/src/snapshots/kcl_language_server__goto_def__tests__goto_schema_attr_ty_def_test3.snap create mode 100644 kclvm/tools/src/LSP/src/snapshots/kcl_language_server__goto_def__tests__goto_schema_attr_ty_def_test4.snap create mode 100644 kclvm/tools/src/LSP/src/snapshots/kcl_language_server__goto_def__tests__goto_schema_attr_ty_def_test5.snap create mode 100644 kclvm/tools/src/LSP/src/snapshots/kcl_language_server__goto_def__tests__goto_schema_def_test.snap create mode 100644 kclvm/tools/src/LSP/src/snapshots/kcl_language_server__goto_def__tests__goto_var_def_in_config_and_config_if_test1.snap create mode 100644 kclvm/tools/src/LSP/src/snapshots/kcl_language_server__goto_def__tests__goto_var_def_in_config_and_config_if_test2.snap create mode 100644 kclvm/tools/src/LSP/src/snapshots/kcl_language_server__goto_def__tests__goto_var_def_in_config_and_config_if_test3.snap create mode 100644 kclvm/tools/src/LSP/src/snapshots/kcl_language_server__goto_def__tests__goto_var_def_in_config_and_config_if_test4.snap create mode 100644 kclvm/tools/src/LSP/src/snapshots/kcl_language_server__goto_def__tests__goto_var_def_in_dict_comp_test1.snap create mode 100644 kclvm/tools/src/LSP/src/snapshots/kcl_language_server__goto_def__tests__goto_var_def_in_dict_comp_test2.snap create mode 100644 kclvm/tools/src/LSP/src/snapshots/kcl_language_server__goto_def__tests__lambda_local_var_test.snap create mode 100644 kclvm/tools/src/LSP/src/snapshots/kcl_language_server__goto_def__tests__list_if_expr_test.snap create mode 100644 kclvm/tools/src/LSP/src/snapshots/kcl_language_server__goto_def__tests__schema_attribute_def_goto_def.snap delete mode 100644 kclvm/tools/src/LSP/src/snapshots/kcl_language_server__hover__tests__dict_key_in_schema-2.snap delete mode 100644 kclvm/tools/src/LSP/src/snapshots/kcl_language_server__hover__tests__dict_key_in_schema-3.snap delete mode 100644 kclvm/tools/src/LSP/src/snapshots/kcl_language_server__hover__tests__dict_key_in_schema.snap create mode 100644 kclvm/tools/src/LSP/src/test_data/goto_def_test/complex_select_goto_def/complex_select_goto_def.k create mode 100644 kclvm/tools/src/LSP/src/test_data/goto_def_test/config_desuger_def_goto_def/config_desuger_def_goto_def.k create mode 100644 kclvm/tools/src/LSP/src/test_data/goto_def_test/goto_assign_type_test/goto_assign_type_test.k create mode 100644 kclvm/tools/src/LSP/src/test_data/goto_def_test/goto_identifier_def_test/goto_identifier_def_test.k create mode 100644 kclvm/tools/src/LSP/src/test_data/goto_def_test/goto_import_file_test/goto_import_file_test.k create mode 100644 kclvm/tools/src/LSP/src/test_data/goto_def_test/goto_import_pkg_test/goto_import_pkg_test.k create mode 100644 kclvm/tools/src/LSP/src/test_data/goto_def_test/goto_lambda_param_goto_def/goto_lambda_param_goto_def.k create mode 100644 kclvm/tools/src/LSP/src/test_data/goto_def_test/goto_local_var_def_test/goto_local_var_def_test.k create mode 100644 kclvm/tools/src/LSP/src/test_data/goto_def_test/goto_pkg_prefix_def_test/goto_pkg_prefix_def_test.k create mode 100644 kclvm/tools/src/LSP/src/test_data/goto_def_test/goto_schema_attr_def_test/goto_schema_attr_def_test.k create mode 100644 kclvm/tools/src/LSP/src/test_data/goto_def_test/goto_schema_attr_ty_def_test/goto_schema_attr_ty_def_test.k create mode 100644 kclvm/tools/src/LSP/src/test_data/goto_def_test/goto_schema_def_test/goto_schema_def_test.k create mode 100644 kclvm/tools/src/LSP/src/test_data/goto_def_test/goto_system_pkg_test/goto_system_pkg_test.k create mode 100644 kclvm/tools/src/LSP/src/test_data/goto_def_test/goto_var_def_in_config_and_config_if_test/goto_var_def_in_config_and_config_if_test.k create mode 100644 kclvm/tools/src/LSP/src/test_data/goto_def_test/goto_var_def_in_dict_comp_test/goto_var_def_in_dict_comp_test.k create mode 100644 kclvm/tools/src/LSP/src/test_data/goto_def_test/lambda_local_var_test/lambda_local_var_test.k create mode 100644 kclvm/tools/src/LSP/src/test_data/goto_def_test/list_if_expr_test/list_if_expr_test.k create mode 100644 kclvm/tools/src/LSP/src/test_data/goto_def_test/schema_attribute_def_goto_def/schema_attribute_def_goto_def.k create mode 100644 kclvm/tools/src/LSP/src/test_data/goto_def_test/test_goto_identifier_names/test_goto_identifier_names.k diff --git a/kclvm/tools/src/LSP/src/goto_def.rs b/kclvm/tools/src/LSP/src/goto_def.rs index bcb2dd7fe..11120ab5c 100644 --- a/kclvm/tools/src/LSP/src/goto_def.rs +++ b/kclvm/tools/src/LSP/src/goto_def.rs @@ -98,603 +98,10 @@ fn positions_to_goto_def_resp( #[cfg(test)] mod tests { use super::goto_def; - use crate::{ - from_lsp::file_path_from_url, - tests::{compare_goto_res, compile_test_file}, - }; - use indexmap::IndexSet; + use crate::{from_lsp::file_path_from_url, tests::compile_test_file}; use kclvm_error::Position as KCLPos; - use proc_macro_crate::bench_test; use std::path::{Path, PathBuf}; - #[test] - #[bench_test] - fn goto_import_pkg_test() { - let path = PathBuf::from(env!("CARGO_MANIFEST_DIR")); - let (file, _program, _, gs) = compile_test_file("src/test_data/goto_def_test/goto_def.k"); - let pos = KCLPos { - filename: file, - line: 1, - column: Some(10), - }; - - let res = goto_def(&pos, &gs); - - let mut expected_files = IndexSet::new(); - let path_str = path.to_str().unwrap(); - let test_files = [ - "src/test_data/goto_def_test/pkg/schema_def1.k", - "src/test_data/goto_def_test/pkg/schema_def.k", - ]; - expected_files.insert(format!("{}/{}", path_str, test_files[0])); - expected_files.insert(format!("{}/{}", path_str, test_files[1])); - - match res.unwrap() { - lsp_types::GotoDefinitionResponse::Array(arr) => { - assert_eq!(expected_files.len(), arr.len()); - for loc in arr { - let got_path = file_path_from_url(&loc.uri).unwrap(); - assert!(expected_files.contains(&got_path)); - } - } - _ => { - unreachable!("test error") - } - } - } - - #[test] - #[bench_test] - fn goto_import_file_test() { - let path = PathBuf::from(env!("CARGO_MANIFEST_DIR")); - - let (file, _program, _, gs) = compile_test_file("src/test_data/goto_def_test/goto_def.k"); - - let mut expected_path = path; - expected_path.push("src/test_data/goto_def_test/pkg/schema_def.k"); - - // test goto import file: import .pkg.schema_def - let pos = KCLPos { - filename: file, - line: 2, - column: Some(10), - }; - let res = goto_def(&pos, &gs); - match res.unwrap() { - lsp_types::GotoDefinitionResponse::Scalar(loc) => { - let got_path = file_path_from_url(&loc.uri).unwrap(); - assert_eq!(got_path, expected_path.to_str().unwrap()) - } - _ => { - unreachable!("test error") - } - } - } - - #[test] - #[bench_test] - fn goto_pkg_prefix_def_test() { - let path = PathBuf::from(env!("CARGO_MANIFEST_DIR")); - - let (file, _program, _, gs) = compile_test_file("src/test_data/goto_def_test/goto_def.k"); - - // test goto pkg prefix def: p = pkg.Person { <- pkg - let pos = KCLPos { - filename: file, - line: 4, - column: Some(7), - }; - let res = goto_def(&pos, &gs); - let mut expected_files = IndexSet::new(); - let path_str = path.to_str().unwrap(); - let test_files = [ - "src/test_data/goto_def_test/pkg/schema_def1.k", - "src/test_data/goto_def_test/pkg/schema_def.k", - ]; - expected_files.insert(format!("{}/{}", path_str, test_files[0])); - expected_files.insert(format!("{}/{}", path_str, test_files[1])); - - match res.unwrap() { - lsp_types::GotoDefinitionResponse::Array(arr) => { - assert_eq!(expected_files.len(), arr.len()); - for loc in arr { - let got_path = file_path_from_url(&loc.uri).unwrap(); - assert!(expected_files.contains(&got_path)); - } - } - _ => { - unreachable!("test error") - } - } - } - - #[test] - #[bench_test] - fn goto_schema_def_test() { - let path = PathBuf::from(env!("CARGO_MANIFEST_DIR")); - - let (file, _program, _, gs) = compile_test_file("src/test_data/goto_def_test/goto_def.k"); - - let mut expected_path = path; - expected_path.push("src/test_data/goto_def_test/pkg/schema_def.k"); - - // test goto schema definition: p = pkg.Person <- Person - let pos = KCLPos { - filename: file, - line: 4, - column: Some(11), - }; - - let res = goto_def(&pos, &gs); - compare_goto_res( - res, - (&expected_path.to_str().unwrap().to_string(), 0, 7, 0, 13), - ); - } - - #[test] - #[bench_test] - fn goto_var_def_in_config_and_config_if_test() { - let path = PathBuf::from(env!("CARGO_MANIFEST_DIR")); - - let (file, _program, _, gs) = compile_test_file("src/test_data/goto_def_test/goto_def.k"); - - let mut expected_path = path; - expected_path.push("src/test_data/goto_def_test/pkg/schema_def.k"); - - let pos = KCLPos { - filename: file.clone(), - line: 67, - column: Some(36), - }; - let res = goto_def(&pos, &gs); - compare_goto_res(res, (&file, 65, 11, 65, 14)); - - let pos = KCLPos { - filename: file.clone(), - line: 67, - column: Some(44), - }; - - let res = goto_def(&pos, &gs); - compare_goto_res(res, (&file, 65, 16, 65, 21)); - let pos = KCLPos { - filename: file.clone(), - line: 64, - column: Some(11), - }; - - let res = goto_def(&pos, &gs); - compare_goto_res(res, (&file, 69, 6, 69, 10)); - let pos = KCLPos { - filename: file.clone(), - line: 67, - column: Some(10), - }; - - let res = goto_def(&pos, &gs); - compare_goto_res(res, (&file, 69, 6, 69, 10)); - } - - #[test] - #[bench_test] - fn goto_var_def_in_dict_comp_test() { - let path = PathBuf::from(env!("CARGO_MANIFEST_DIR")); - - let (file, _program, _, gs) = compile_test_file("src/test_data/goto_def_test/goto_def.k"); - - let mut expected_path = path; - expected_path.push("src/test_data/goto_def_test/pkg/schema_def.k"); - - let pos = KCLPos { - filename: file.clone(), - line: 77, - column: Some(68), - }; - - let res = goto_def(&pos, &gs); - compare_goto_res(res, (&file, 76, 143, 76, 145)); - - let pos = KCLPos { - filename: file.clone(), - line: 77, - column: Some(61), - }; - - let res = goto_def(&pos, &gs); - compare_goto_res(res, (&file, 76, 143, 76, 145)); - } - - #[test] - #[bench_test] - fn goto_schema_attr_def_test() { - let path = PathBuf::from(env!("CARGO_MANIFEST_DIR")); - - let (file, _program, _, gs) = compile_test_file("src/test_data/goto_def_test/goto_def.k"); - - let mut expected_path = path; - expected_path.push("src/test_data/goto_def_test/pkg/schema_def.k"); - - // test goto schema attr definition: name: "alice" - let pos = KCLPos { - filename: file, - line: 5, - column: Some(7), - }; - - let res = goto_def(&pos, &gs); - compare_goto_res( - res, - (&expected_path.to_str().unwrap().to_string(), 4, 4, 4, 8), - ); - } - - #[test] - #[bench_test] - fn goto_schema_attr_def_test1() { - let path = PathBuf::from(env!("CARGO_MANIFEST_DIR")); - - let (file, _program, _, gs) = compile_test_file("src/test_data/goto_def_test/goto_def.k"); - - let mut expected_path = path; - expected_path.push("src/test_data/goto_def_test/goto_def.k"); - - // test goto schema attr definition, goto name in: s = p2.n.name - let pos = KCLPos { - filename: file, - line: 30, - column: Some(12), - }; - - let res = goto_def(&pos, &gs); - compare_goto_res( - res, - (&expected_path.to_str().unwrap().to_string(), 18, 4, 18, 8), - ); - } - - #[test] - #[bench_test] - fn test_goto_identifier_names() { - let path = PathBuf::from(env!("CARGO_MANIFEST_DIR")); - - let (file, _program, _, gs) = compile_test_file("src/test_data/goto_def_test/goto_def.k"); - - let mut expected_path = path; - expected_path.push("src/test_data/goto_def_test/goto_def.k"); - - // test goto p2 in: s = p2.n.name - let pos = KCLPos { - filename: file.clone(), - line: 30, - column: Some(5), - }; - - let res = goto_def(&pos, &gs); - compare_goto_res( - res, - (&expected_path.to_str().unwrap().to_string(), 23, 0, 23, 2), - ); - - // test goto n in: s = p2.n.name - let pos = KCLPos { - filename: file.clone(), - line: 30, - column: Some(8), - }; - - let res = goto_def(&pos, &gs); - compare_goto_res( - res, - (&expected_path.to_str().unwrap().to_string(), 21, 1, 21, 2), - ); - - // test goto name in: s = p2.n.name - let pos = KCLPos { - filename: file, - line: 30, - column: Some(12), - }; - - let res = goto_def(&pos, &gs); - compare_goto_res( - res, - (&expected_path.to_str().unwrap().to_string(), 18, 4, 18, 8), - ); - } - - #[test] - #[bench_test] - fn goto_identifier_def_test() { - let (file, _program, _, gs) = compile_test_file("src/test_data/goto_def_test/goto_def.k"); - - // test goto identifier definition: p1 = p - let pos = KCLPos { - filename: file.to_string(), - line: 9, - column: Some(6), - }; - - let res = goto_def(&pos, &gs); - compare_goto_res(res, (&file, 3, 0, 3, 1)); - } - - #[test] - #[bench_test] - fn goto_assign_type_test() { - let path = PathBuf::from(env!("CARGO_MANIFEST_DIR")); - - let (file, _program, _, gs) = compile_test_file("src/test_data/goto_def_test/goto_def.k"); - - let mut expected_path = path; - expected_path.push("src/test_data/goto_def_test/pkg/schema_def.k"); - - // test goto schema attr definition: name: "alice" - let pos = KCLPos { - filename: file.clone(), - line: 38, - column: Some(17), - }; - - let res = goto_def(&pos, &gs); - compare_goto_res(res, (&file, 33, 7, 33, 15)); - } - - #[test] - #[bench_test] - fn goto_schema_attr_ty_def_test() { - // test goto schema attr type definition: p1: pkg.Person - let path = PathBuf::from(env!("CARGO_MANIFEST_DIR")); - - let (file, _program, _, gs) = compile_test_file("src/test_data/goto_def_test/goto_def.k"); - - let mut expected_path = path; - expected_path.push("src/test_data/goto_def_test/pkg/schema_def.k"); - - let pos = KCLPos { - filename: file, - line: 12, - column: Some(15), - }; - - let res = goto_def(&pos, &gs); - compare_goto_res( - res, - (&expected_path.to_str().unwrap().to_string(), 0, 7, 0, 13), - ); - } - - #[test] - #[bench_test] - fn goto_schema_attr_ty_def_test1() { - // test goto schema attr type definition: p2: [pkg.Person] - let path = PathBuf::from(env!("CARGO_MANIFEST_DIR")); - - let (file, _program, _, gs) = compile_test_file("src/test_data/goto_def_test/goto_def.k"); - - let mut expected_path = path; - expected_path.push("src/test_data/goto_def_test/pkg/schema_def.k"); - - let pos = KCLPos { - filename: file, - line: 13, - column: Some(15), - }; - let res = goto_def(&pos, &gs); - compare_goto_res( - res, - (&expected_path.to_str().unwrap().to_string(), 0, 7, 0, 13), - ); - } - - #[test] - #[bench_test] - fn goto_schema_attr_ty_def_test3() { - // test goto schema attr type definition: p3: {str: pkg.Person} - let path = PathBuf::from(env!("CARGO_MANIFEST_DIR")); - - let (file, _program, _, gs) = compile_test_file("src/test_data/goto_def_test/goto_def.k"); - - let mut expected_path = path; - expected_path.push("src/test_data/goto_def_test/pkg/schema_def.k"); - - let pos = KCLPos { - filename: file, - line: 14, - column: Some(22), - }; - let res = goto_def(&pos, &gs); - compare_goto_res( - res, - (&expected_path.to_str().unwrap().to_string(), 0, 7, 0, 13), - ); - } - - #[test] - #[bench_test] - fn goto_schema_attr_ty_def_test4() { - // test goto schema attr type definition(Person): p4: pkg.Person | pkg.Person1 - let path = PathBuf::from(env!("CARGO_MANIFEST_DIR")); - - let (file, _program, _, gs) = compile_test_file("src/test_data/goto_def_test/goto_def.k"); - - let mut expected_path = path; - expected_path.push("src/test_data/goto_def_test/pkg/schema_def.k"); - - let pos = KCLPos { - filename: file, - line: 15, - column: Some(17), - }; - - let res = goto_def(&pos, &gs); - compare_goto_res( - res, - (&expected_path.to_str().unwrap().to_string(), 0, 7, 0, 13), - ); - } - - #[test] - #[bench_test] - fn goto_schema_attr_ty_def_test5() { - // test goto schema attr type definition(Person1): p4: pkg.Person | pkg.Person1 - let path = PathBuf::from(env!("CARGO_MANIFEST_DIR")); - - let (file, _program, _, gs) = compile_test_file("src/test_data/goto_def_test/goto_def.k"); - - let mut expected_path = path; - expected_path.push("src/test_data/goto_def_test/pkg/schema_def1.k"); - - let pos = KCLPos { - filename: file, - line: 15, - column: Some(28), - }; - let res = goto_def(&pos, &gs); - compare_goto_res( - res, - (&expected_path.to_str().unwrap().to_string(), 0, 7, 0, 14), - ); - } - - #[test] - #[bench_test] - fn goto_local_var_def_test() { - let path = PathBuf::from(env!("CARGO_MANIFEST_DIR")); - - let (file, _program, _, gs) = compile_test_file("src/test_data/goto_def_test/goto_def.k"); - - let mut expected_path = path; - expected_path.push("src/test_data/goto_def_test/pkg/schema_def.k"); - - // test goto local var def - let pos = KCLPos { - filename: file.clone(), - line: 47, - column: Some(11), - }; - - let res = goto_def(&pos, &gs); - compare_goto_res(res, (&file, 43, 4, 43, 9)); - - let pos = KCLPos { - filename: file.clone(), - line: 49, - column: Some(11), - }; - - let res = goto_def(&pos, &gs); - compare_goto_res(res, (&file, 43, 4, 43, 9)); - - let pos = KCLPos { - filename: file.clone(), - line: 51, - column: Some(11), - }; - - let res = goto_def(&pos, &gs); - compare_goto_res(res, (&file, 43, 4, 43, 9)); - } - - #[test] - #[bench_test] - fn complex_select_goto_def() { - let (file, _program, _, gs) = compile_test_file("src/test_data/goto_def_test/goto_def.k"); - - let pos = KCLPos { - filename: file.clone(), - line: 52, - column: Some(22), - }; - - let res = goto_def(&pos, &gs); - compare_goto_res(res, (&file, 43, 4, 43, 9)); - } - - #[test] - #[bench_test] - fn schema_attribute_def_goto_def() { - let (file, _program, _, gs) = compile_test_file("src/test_data/goto_def_test/goto_def.k"); - - let pos = KCLPos { - filename: file.clone(), - line: 19, - column: Some(5), - }; - - let res = goto_def(&pos, &gs); - compare_goto_res(res, (&file, 18, 4, 18, 8)); - } - - #[test] - #[bench_test] - fn config_desuger_def_goto_def() { - let (file, _program, _, gs) = compile_test_file("src/test_data/goto_def_test/goto_def.k"); - - let pos = KCLPos { - filename: file.clone(), - line: 82, - column: Some(9), - }; - - let res = goto_def(&pos, &gs); - compare_goto_res(res, (&file, 18, 4, 18, 8)); - } - - #[test] - #[bench_test] - fn lambda_param_goto_def() { - let (file, _program, _, gs) = compile_test_file("src/test_data/goto_def_test/goto_def.k"); - - let pos = KCLPos { - filename: file.clone(), - line: 86, - column: Some(4), - }; - - let res = goto_def(&pos, &gs); - compare_goto_res(res, (&file, 84, 14, 84, 15)); - - let pos = KCLPos { - filename: file.clone(), - line: 86, - column: Some(8), - }; - - let res = goto_def(&pos, &gs); - compare_goto_res(res, (&file, 84, 22, 84, 23)); - } - - #[test] - #[bench_test] - fn list_if_expr_test() { - let (file, _program, _, gs) = compile_test_file("src/test_data/goto_def_test/goto_def.k"); - - let pos = KCLPos { - filename: file.clone(), - line: 91, - column: Some(8), - }; - - let res = goto_def(&pos, &gs); - compare_goto_res(res, (&file, 88, 0, 88, 1)); - } - - #[test] - #[bench_test] - fn lambda_local_var_test() { - let (file, _program, _, gs) = compile_test_file("src/test_data/goto_def_test/goto_def.k"); - - let pos = KCLPos { - filename: file.clone(), - line: 96, - column: Some(9), - }; - - let res = goto_def(&pos, &gs); - compare_goto_res(res, (&file, 94, 11, 94, 12)); - } - #[macro_export] macro_rules! goto_def_test_snapshot { ($name:ident, $file:expr, $line:expr, $column: expr) => { @@ -725,19 +132,164 @@ mod tests { let relative_path = got_path.strip_prefix(root_path).unwrap(); format!("path: {:?}, range: {:?}", relative_path, loc.range) } - _ => todo!(), + lsp_types::GotoDefinitionResponse::Array(vec_location) => { + let mut res = String::new(); + for loc in vec_location { + let url = file_path_from_url(&loc.uri).unwrap(); + let got_path = Path::new(&url); + let relative_path = got_path.strip_prefix(root_path.clone()).unwrap(); + res.push_str(&format!( + "path: {:?}, range: {:?}\n", + relative_path, loc.range + )); + } + res + } + lsp_types::GotoDefinitionResponse::Link(vec_location_link) => { + let mut res = String::new(); + for loc in vec_location_link { + let url = file_path_from_url(&loc.target_uri).unwrap(); + let got_path = Path::new(&url); + let relative_path = got_path.strip_prefix(root_path.clone()).unwrap(); + res.push_str(&format!( + "path: {:?}, range: {:?}\n", + relative_path, loc.target_selection_range + )); + } + res + } }, None => "None".to_string(), } } goto_def_test_snapshot!( - goto_system_pkg_test, - "src/test_data/goto_def_test/goto_def.k", + goto_import_pkg_test, + "src/test_data/goto_def_test/goto_import_pkg_test/goto_import_pkg_test.k", + 1, + 11 + ); + + goto_def_test_snapshot!( + goto_pkg_prefix_def_test, + "src/test_data/goto_def_test/goto_pkg_prefix_def_test/goto_pkg_prefix_def_test.k", 3, + 7 + ); + + goto_def_test_snapshot!( + goto_var_def_in_config_and_config_if_test1, + "src/test_data/goto_def_test/goto_var_def_in_config_and_config_if_test/goto_var_def_in_config_and_config_if_test.k", + 7, + 36 + ); + + goto_def_test_snapshot!( + goto_var_def_in_config_and_config_if_test2, + "src/test_data/goto_def_test/goto_var_def_in_config_and_config_if_test/goto_var_def_in_config_and_config_if_test.k", + 7, + 44 + ); + + goto_def_test_snapshot!( + goto_var_def_in_config_and_config_if_test3, + "src/test_data/goto_def_test/goto_var_def_in_config_and_config_if_test/goto_var_def_in_config_and_config_if_test.k", + 4, + 11 + ); + + goto_def_test_snapshot!( + goto_var_def_in_config_and_config_if_test4, + "src/test_data/goto_def_test/goto_var_def_in_config_and_config_if_test/goto_var_def_in_config_and_config_if_test.k", + 7, + 10 + ); + + goto_def_test_snapshot!( + goto_var_def_in_dict_comp_test1, + "src/test_data/goto_def_test/goto_var_def_in_dict_comp_test/goto_var_def_in_dict_comp_test.k", + 5, + 68 + ); + + goto_def_test_snapshot!( + goto_var_def_in_dict_comp_test2, + "src/test_data/goto_def_test/goto_var_def_in_dict_comp_test/goto_var_def_in_dict_comp_test.k", + 5, + 61 + ); + + goto_def_test_snapshot!( + test_goto_identifier_names1, + "src/test_data/goto_def_test/test_goto_identifier_names/test_goto_identifier_names.k", + 13, + 5 + ); + + goto_def_test_snapshot!( + test_goto_identifier_names2, + "src/test_data/goto_def_test/test_goto_identifier_names/test_goto_identifier_names.k", + 13, + 8 + ); + + goto_def_test_snapshot!( + test_goto_identifier_names3, + "src/test_data/goto_def_test/test_goto_identifier_names/test_goto_identifier_names.k", + 13, + 12 + ); + + goto_def_test_snapshot!( + goto_local_var_def_test1, + "src/test_data/goto_def_test/goto_local_var_def_test/goto_local_var_def_test.k", + 7, + 11 + ); + + goto_def_test_snapshot!( + goto_local_var_def_test2, + "src/test_data/goto_def_test/goto_local_var_def_test/goto_local_var_def_test.k", + 9, + 11 + ); + + goto_def_test_snapshot!( + goto_local_var_def_test3, + "src/test_data/goto_def_test/goto_local_var_def_test/goto_local_var_def_test.k", + 11, + 11 + ); + + goto_def_test_snapshot!( + goto_lambda_param_goto_def1, + "src/test_data/goto_def_test/goto_lambda_param_goto_def/goto_lambda_param_goto_def.k", + 2, + 5 + ); + + goto_def_test_snapshot!( + goto_lambda_param_goto_def2, + "src/test_data/goto_def_test/goto_lambda_param_goto_def/goto_lambda_param_goto_def.k", + 2, + 9 + ); + + // To implement + goto_def_test_snapshot!( + goto_system_pkg_test, + "src/test_data/goto_def_test/goto_system_pkg_test/goto_system_pkg_test.k", + 1, 1 ); + goto_def_test_snapshot!( + lambda_local_var_test, + "src/test_data/goto_def_test/lambda_local_var_test/lambda_local_var_test.k", + 2, + 9 + ); + goto_def_test_snapshot!( goto_dict_to_schema_attr_test1, "src/test_data/goto_def_test/dict_to_schema/dict_to_schema.k", @@ -772,4 +324,102 @@ mod tests { 33, 11 ); + + goto_def_test_snapshot!( + list_if_expr_test, + "src/test_data/goto_def_test/list_if_expr_test/list_if_expr_test.k", + 3, + 8 + ); + + goto_def_test_snapshot!( + goto_identifier_def_test, + "src/test_data/goto_def_test/goto_identifier_def_test/goto_identifier_def_test.k", + 8, + 6 + ); + + goto_def_test_snapshot!( + complex_select_goto_def, + "src/test_data/goto_def_test/complex_select_goto_def/complex_select_goto_def.k", + 13, + 22 + ); + + goto_def_test_snapshot!( + schema_attribute_def_goto_def, + "src/test_data/goto_def_test/schema_attribute_def_goto_def/schema_attribute_def_goto_def.k", + 2, + 5 + ); + + goto_def_test_snapshot!( + config_desuger_def_goto_def, + "src/test_data/goto_def_test/config_desuger_def_goto_def/config_desuger_def_goto_def.k", + 7, + 9 + ); + + goto_def_test_snapshot!( + goto_schema_attr_ty_def_test5, + "src/test_data/goto_def_test/goto_schema_attr_ty_def_test/goto_schema_attr_ty_def_test.k", + 7, + 28 + ); + + goto_def_test_snapshot!( + goto_schema_attr_ty_def_test4, + "src/test_data/goto_def_test/goto_schema_attr_ty_def_test/goto_schema_attr_ty_def_test.k", + 7, + 17 + ); + + goto_def_test_snapshot!( + goto_schema_attr_ty_def_test3, + "src/test_data/goto_def_test/goto_schema_attr_ty_def_test/goto_schema_attr_ty_def_test.k", + 6, + 22 + ); + + goto_def_test_snapshot!( + goto_schema_attr_ty_def_test2, + "src/test_data/goto_def_test/goto_schema_attr_ty_def_test/goto_schema_attr_ty_def_test.k", + 5, + 15 + ); + + goto_def_test_snapshot!( + goto_schema_attr_ty_def_test1, + "src/test_data/goto_def_test/goto_schema_attr_ty_def_test/goto_schema_attr_ty_def_test.k", + 4, + 15 + ); + + goto_def_test_snapshot!( + goto_assign_type_test, + "src/test_data/goto_def_test/goto_assign_type_test/goto_assign_type_test.k", + 5, + 17 + ); + + goto_def_test_snapshot!( + goto_schema_def_test, + "src/test_data/goto_def_test/goto_schema_def_test/goto_schema_def_test.k", + 3, + 11 + ); + + goto_def_test_snapshot!( + goto_schema_attr_def_test1, + "src/test_data/goto_def_test/goto_schema_attr_def_test/goto_schema_attr_def_test.k", + 4, + 7 + ); + + goto_def_test_snapshot!( + goto_schema_attr_def_test2, + "src/test_data/goto_def_test/goto_schema_attr_def_test/goto_schema_attr_def_test.k", + 18, + 12 + ); } diff --git a/kclvm/tools/src/LSP/src/snapshots/kcl_language_server__goto_def__tests__complex_select_goto_def.snap b/kclvm/tools/src/LSP/src/snapshots/kcl_language_server__goto_def__tests__complex_select_goto_def.snap new file mode 100644 index 000000000..5ea864a56 --- /dev/null +++ b/kclvm/tools/src/LSP/src/snapshots/kcl_language_server__goto_def__tests__complex_select_goto_def.snap @@ -0,0 +1,5 @@ +--- +source: tools/src/LSP/src/goto_def.rs +expression: "format!(\"{:?}\",\n {\n let (file, _program, _, gs) =\n compile_test_file(\"src/test_data/goto_def_test/complex_select_goto_def/complex_select_goto_def.k\");\n let pos = KCLPos\n { filename : file.clone(), line : 13, column : Some(22), }; let res =\n goto_def(& pos, & gs); fmt_resp(& res)\n })" +--- +"path: \"src/test_data/goto_def_test/complex_select_goto_def/complex_select_goto_def.k\", range: Range { start: Position { line: 4, character: 4 }, end: Position { line: 4, character: 9 } }" diff --git a/kclvm/tools/src/LSP/src/snapshots/kcl_language_server__goto_def__tests__config_desuger_def_goto_def.snap b/kclvm/tools/src/LSP/src/snapshots/kcl_language_server__goto_def__tests__config_desuger_def_goto_def.snap new file mode 100644 index 000000000..37b9346a4 --- /dev/null +++ b/kclvm/tools/src/LSP/src/snapshots/kcl_language_server__goto_def__tests__config_desuger_def_goto_def.snap @@ -0,0 +1,5 @@ +--- +source: tools/src/LSP/src/goto_def.rs +expression: "format!(\"{:?}\",\n {\n let (file, _program, _, gs) =\n compile_test_file(\"src/test_data/goto_def_test/config_desuger_def_goto_def/config_desuger_def_goto_def.k\");\n let pos = KCLPos\n { filename : file.clone(), line : 7, column : Some(9), }; let res =\n goto_def(& pos, & gs); fmt_resp(& res)\n })" +--- +"path: \"src/test_data/goto_def_test/config_desuger_def_goto_def/config_desuger_def_goto_def.k\", range: Range { start: Position { line: 0, character: 7 }, end: Position { line: 0, character: 13 } }" diff --git a/kclvm/tools/src/LSP/src/snapshots/kcl_language_server__goto_def__tests__goto_assign_type_test.snap b/kclvm/tools/src/LSP/src/snapshots/kcl_language_server__goto_def__tests__goto_assign_type_test.snap new file mode 100644 index 000000000..e92020b19 --- /dev/null +++ b/kclvm/tools/src/LSP/src/snapshots/kcl_language_server__goto_def__tests__goto_assign_type_test.snap @@ -0,0 +1,5 @@ +--- +source: tools/src/LSP/src/goto_def.rs +expression: "format!(\"{:?}\",\n {\n let (file, _program, _, gs) =\n compile_test_file(\"src/test_data/goto_def_test/goto_assign_type_test/goto_assign_type_test.k\");\n let pos = KCLPos\n { filename : file.clone(), line : 5, column : Some(17), }; let res =\n goto_def(& pos, & gs); fmt_resp(& res)\n })" +--- +"path: \"src/test_data/goto_def_test/goto_assign_type_test/goto_assign_type_test.k\", range: Range { start: Position { line: 0, character: 7 }, end: Position { line: 0, character: 15 } }" diff --git a/kclvm/tools/src/LSP/src/snapshots/kcl_language_server__goto_def__tests__goto_dict_to_schema_attr_test1.snap b/kclvm/tools/src/LSP/src/snapshots/kcl_language_server__goto_def__tests__goto_dict_to_schema_attr_test1.snap index 24ace7572..e8407d4a1 100644 --- a/kclvm/tools/src/LSP/src/snapshots/kcl_language_server__goto_def__tests__goto_dict_to_schema_attr_test1.snap +++ b/kclvm/tools/src/LSP/src/snapshots/kcl_language_server__goto_def__tests__goto_dict_to_schema_attr_test1.snap @@ -1,5 +1,5 @@ --- source: tools/src/LSP/src/goto_def.rs -expression: "format!(\"{:?}\",\n {\n let(file, _program, _, gs) =\n compile_test_file(\"src/test_data/goto_def_test/dict_to_schema/dict_to_schema.k\")\n ; let pos = KCLPos\n { filename : file.clone(), line : 13, column : Some(15), } ; let res =\n goto_def(& pos, & gs) ; fmt_resp(& res)\n })" +expression: "format!(\"{:?}\",\n {\n let (file, _program, _, gs) =\n compile_test_file(\"src/test_data/goto_def_test/dict_to_schema/dict_to_schema.k\");\n let pos = KCLPos\n { filename : file.clone(), line : 13, column : Some(15), }; let res =\n goto_def(& pos, & gs); fmt_resp(& res)\n })" --- "path: \"src/test_data/goto_def_test/dict_to_schema/dict_to_schema.k\", range: Range { start: Position { line: 1, character: 4 }, end: Position { line: 1, character: 8 } }" diff --git a/kclvm/tools/src/LSP/src/snapshots/kcl_language_server__goto_def__tests__goto_dict_to_schema_attr_test2.snap b/kclvm/tools/src/LSP/src/snapshots/kcl_language_server__goto_def__tests__goto_dict_to_schema_attr_test2.snap index 31e11326f..23726a60c 100644 --- a/kclvm/tools/src/LSP/src/snapshots/kcl_language_server__goto_def__tests__goto_dict_to_schema_attr_test2.snap +++ b/kclvm/tools/src/LSP/src/snapshots/kcl_language_server__goto_def__tests__goto_dict_to_schema_attr_test2.snap @@ -1,5 +1,5 @@ --- source: tools/src/LSP/src/goto_def.rs -expression: "format!(\"{:?}\",\n {\n let(file, _program, _, gs) =\n compile_test_file(\"src/test_data/goto_def_test/dict_to_schema/dict_to_schema.k\")\n ; let pos = KCLPos\n { filename : file.clone(), line : 15, column : Some(7), } ; let res =\n goto_def(& pos, & gs) ; fmt_resp(& res)\n })" +expression: "format!(\"{:?}\",\n {\n let (file, _program, _, gs) =\n compile_test_file(\"src/test_data/goto_def_test/dict_to_schema/dict_to_schema.k\");\n let pos = KCLPos\n { filename : file.clone(), line : 15, column : Some(7), }; let res =\n goto_def(& pos, & gs); fmt_resp(& res)\n })" --- "path: \"src/test_data/goto_def_test/dict_to_schema/dict_to_schema.k\", range: Range { start: Position { line: 4, character: 4 }, end: Position { line: 4, character: 8 } }" diff --git a/kclvm/tools/src/LSP/src/snapshots/kcl_language_server__goto_def__tests__goto_dict_to_schema_attr_test3.snap b/kclvm/tools/src/LSP/src/snapshots/kcl_language_server__goto_def__tests__goto_dict_to_schema_attr_test3.snap index c16327319..ef93168c0 100644 --- a/kclvm/tools/src/LSP/src/snapshots/kcl_language_server__goto_def__tests__goto_dict_to_schema_attr_test3.snap +++ b/kclvm/tools/src/LSP/src/snapshots/kcl_language_server__goto_def__tests__goto_dict_to_schema_attr_test3.snap @@ -1,5 +1,5 @@ --- source: tools/src/LSP/src/goto_def.rs -expression: "format!(\"{:?}\",\n {\n let(file, _program, _, gs) =\n compile_test_file(\"src/test_data/goto_def_test/dict_to_schema/dict_to_schema.k\")\n ; let pos = KCLPos\n { filename : file.clone(), line : 19, column : Some(7), } ; let res =\n goto_def(& pos, & gs) ; fmt_resp(& res)\n })" +expression: "format!(\"{:?}\",\n {\n let (file, _program, _, gs) =\n compile_test_file(\"src/test_data/goto_def_test/dict_to_schema/dict_to_schema.k\");\n let pos = KCLPos\n { filename : file.clone(), line : 19, column : Some(7), }; let res =\n goto_def(& pos, & gs); fmt_resp(& res)\n })" --- "path: \"src/test_data/goto_def_test/dict_to_schema/dict_to_schema.k\", range: Range { start: Position { line: 9, character: 4 }, end: Position { line: 9, character: 8 } }" diff --git a/kclvm/tools/src/LSP/src/snapshots/kcl_language_server__goto_def__tests__goto_dict_to_schema_attr_test4.snap b/kclvm/tools/src/LSP/src/snapshots/kcl_language_server__goto_def__tests__goto_dict_to_schema_attr_test4.snap index 8ba371b50..52ed0ea4d 100644 --- a/kclvm/tools/src/LSP/src/snapshots/kcl_language_server__goto_def__tests__goto_dict_to_schema_attr_test4.snap +++ b/kclvm/tools/src/LSP/src/snapshots/kcl_language_server__goto_def__tests__goto_dict_to_schema_attr_test4.snap @@ -1,5 +1,5 @@ --- source: tools/src/LSP/src/goto_def.rs -expression: "format!(\"{:?}\",\n {\n let(file, _program, _, gs) =\n compile_test_file(\"src/test_data/goto_def_test/dict_to_schema/dict_to_schema.k\")\n ; let pos = KCLPos\n { filename : file.clone(), line : 26, column : Some(11), } ; let res =\n goto_def(& pos, & gs) ; fmt_resp(& res)\n })" +expression: "format!(\"{:?}\",\n {\n let (file, _program, _, gs) =\n compile_test_file(\"src/test_data/goto_def_test/dict_to_schema/dict_to_schema.k\");\n let pos = KCLPos\n { filename : file.clone(), line : 26, column : Some(11), }; let res =\n goto_def(& pos, & gs); fmt_resp(& res)\n })" --- "path: \"src/test_data/goto_def_test/dict_to_schema/dict_to_schema.k\", range: Range { start: Position { line: 4, character: 4 }, end: Position { line: 4, character: 8 } }" diff --git a/kclvm/tools/src/LSP/src/snapshots/kcl_language_server__goto_def__tests__goto_dict_to_schema_attr_test5.snap b/kclvm/tools/src/LSP/src/snapshots/kcl_language_server__goto_def__tests__goto_dict_to_schema_attr_test5.snap index 0c8a57a2f..a4736ebef 100644 --- a/kclvm/tools/src/LSP/src/snapshots/kcl_language_server__goto_def__tests__goto_dict_to_schema_attr_test5.snap +++ b/kclvm/tools/src/LSP/src/snapshots/kcl_language_server__goto_def__tests__goto_dict_to_schema_attr_test5.snap @@ -1,5 +1,5 @@ --- source: tools/src/LSP/src/goto_def.rs -expression: "format!(\"{:?}\",\n {\n let(file, _program, _, gs) =\n compile_test_file(\"src/test_data/goto_def_test/dict_to_schema/dict_to_schema.k\")\n ; let pos = KCLPos\n { filename : file.clone(), line : 33, column : Some(11), } ; let res =\n goto_def(& pos, & gs) ; fmt_resp(& res)\n })" +expression: "format!(\"{:?}\",\n {\n let (file, _program, _, gs) =\n compile_test_file(\"src/test_data/goto_def_test/dict_to_schema/dict_to_schema.k\");\n let pos = KCLPos\n { filename : file.clone(), line : 33, column : Some(11), }; let res =\n goto_def(& pos, & gs); fmt_resp(& res)\n })" --- "path: \"src/test_data/goto_def_test/dict_to_schema/dict_to_schema.k\", range: Range { start: Position { line: 9, character: 4 }, end: Position { line: 9, character: 8 } }" diff --git a/kclvm/tools/src/LSP/src/snapshots/kcl_language_server__goto_def__tests__goto_identifier_def_test.snap b/kclvm/tools/src/LSP/src/snapshots/kcl_language_server__goto_def__tests__goto_identifier_def_test.snap new file mode 100644 index 000000000..eef18153a --- /dev/null +++ b/kclvm/tools/src/LSP/src/snapshots/kcl_language_server__goto_def__tests__goto_identifier_def_test.snap @@ -0,0 +1,5 @@ +--- +source: tools/src/LSP/src/goto_def.rs +expression: "format!(\"{:?}\",\n {\n let (file, _program, _, gs) =\n compile_test_file(\"src/test_data/goto_def_test/goto_identifier_def_test/goto_identifier_def_test.k\");\n let pos = KCLPos\n { filename : file.clone(), line : 8, column : Some(6), }; let res =\n goto_def(& pos, & gs); fmt_resp(& res)\n })" +--- +"path: \"src/test_data/goto_def_test/goto_identifier_def_test/goto_identifier_def_test.k\", range: Range { start: Position { line: 2, character: 0 }, end: Position { line: 2, character: 1 } }" diff --git a/kclvm/tools/src/LSP/src/snapshots/kcl_language_server__goto_def__tests__goto_identifier_names1.snap b/kclvm/tools/src/LSP/src/snapshots/kcl_language_server__goto_def__tests__goto_identifier_names1.snap new file mode 100644 index 000000000..d8297444c --- /dev/null +++ b/kclvm/tools/src/LSP/src/snapshots/kcl_language_server__goto_def__tests__goto_identifier_names1.snap @@ -0,0 +1,5 @@ +--- +source: tools/src/LSP/src/goto_def.rs +expression: "format!(\"{:?}\",\n {\n let (file, _program, _, gs) =\n compile_test_file(\"src/test_data/goto_def_test/test_goto_identifier_names/test_goto_identifier_names.k\");\n let pos = KCLPos\n { filename : file.clone(), line : 13, column : Some(5), }; let res =\n goto_def(& pos, & gs); fmt_resp(& res)\n })" +--- +"path: \"src/test_data/goto_def_test/test_goto_identifier_names/test_goto_identifier_names.k\", range: Range { start: Position { line: 8, character: 0 }, end: Position { line: 8, character: 2 } }" diff --git a/kclvm/tools/src/LSP/src/snapshots/kcl_language_server__goto_def__tests__goto_identifier_names2.snap b/kclvm/tools/src/LSP/src/snapshots/kcl_language_server__goto_def__tests__goto_identifier_names2.snap new file mode 100644 index 000000000..eb955623b --- /dev/null +++ b/kclvm/tools/src/LSP/src/snapshots/kcl_language_server__goto_def__tests__goto_identifier_names2.snap @@ -0,0 +1,5 @@ +--- +source: tools/src/LSP/src/goto_def.rs +expression: "format!(\"{:?}\",\n {\n let (file, _program, _, gs) =\n compile_test_file(\"src/test_data/goto_def_test/test_goto_identifier_names/test_goto_identifier_names.k\");\n let pos = KCLPos\n { filename : file.clone(), line : 13, column : Some(8), }; let res =\n goto_def(& pos, & gs); fmt_resp(& res)\n })" +--- +"path: \"src/test_data/goto_def_test/test_goto_identifier_names/test_goto_identifier_names.k\", range: Range { start: Position { line: 6, character: 4 }, end: Position { line: 6, character: 5 } }" diff --git a/kclvm/tools/src/LSP/src/snapshots/kcl_language_server__goto_def__tests__goto_identifier_names3.snap b/kclvm/tools/src/LSP/src/snapshots/kcl_language_server__goto_def__tests__goto_identifier_names3.snap new file mode 100644 index 000000000..3cee1f4a6 --- /dev/null +++ b/kclvm/tools/src/LSP/src/snapshots/kcl_language_server__goto_def__tests__goto_identifier_names3.snap @@ -0,0 +1,5 @@ +--- +source: tools/src/LSP/src/goto_def.rs +expression: "format!(\"{:?}\",\n {\n let (file, _program, _, gs) =\n compile_test_file(\"src/test_data/goto_def_test/test_goto_identifier_names/test_goto_identifier_names.k\");\n let pos = KCLPos\n { filename : file.clone(), line : 13, column : Some(12), }; let res =\n goto_def(& pos, & gs); fmt_resp(& res)\n })" +--- +"path: \"src/test_data/goto_def_test/test_goto_identifier_names/test_goto_identifier_names.k\", range: Range { start: Position { line: 3, character: 4 }, end: Position { line: 3, character: 8 } }" diff --git a/kclvm/tools/src/LSP/src/snapshots/kcl_language_server__goto_def__tests__goto_import_pkg_test.snap b/kclvm/tools/src/LSP/src/snapshots/kcl_language_server__goto_def__tests__goto_import_pkg_test.snap new file mode 100644 index 000000000..cc4b3b84b --- /dev/null +++ b/kclvm/tools/src/LSP/src/snapshots/kcl_language_server__goto_def__tests__goto_import_pkg_test.snap @@ -0,0 +1,5 @@ +--- +source: tools/src/LSP/src/goto_def.rs +expression: "format!(\"{:?}\",\n {\n let (file, _program, _, gs) =\n compile_test_file(\"src/test_data/goto_def_test/goto_import_pkg_test/goto_import_pkg_test.k\");\n let pos = KCLPos\n { filename : file.clone(), line : 1, column : Some(11), }; let res =\n goto_def(& pos, & gs); fmt_resp(& res)\n })" +--- +"path: \"src/test_data/goto_def_test/pkg/schema_def.k\", range: Range { start: Position { line: 0, character: 0 }, end: Position { line: 0, character: 0 } }\npath: \"src/test_data/goto_def_test/pkg/schema_def1.k\", range: Range { start: Position { line: 0, character: 0 }, end: Position { line: 0, character: 0 } }\n" diff --git a/kclvm/tools/src/LSP/src/snapshots/kcl_language_server__goto_def__tests__goto_lambda_param_goto_def1.snap b/kclvm/tools/src/LSP/src/snapshots/kcl_language_server__goto_def__tests__goto_lambda_param_goto_def1.snap new file mode 100644 index 000000000..a5c3e9f36 --- /dev/null +++ b/kclvm/tools/src/LSP/src/snapshots/kcl_language_server__goto_def__tests__goto_lambda_param_goto_def1.snap @@ -0,0 +1,5 @@ +--- +source: tools/src/LSP/src/goto_def.rs +expression: "format!(\"{:?}\",\n {\n let (file, _program, _, gs) =\n compile_test_file(\"src/test_data/goto_def_test/goto_lambda_param_goto_def/goto_lambda_param_goto_def.k\");\n let pos = KCLPos\n { filename : file.clone(), line : 2, column : Some(5), }; let res =\n goto_def(& pos, & gs); fmt_resp(& res)\n })" +--- +"path: \"src/test_data/goto_def_test/goto_lambda_param_goto_def/goto_lambda_param_goto_def.k\", range: Range { start: Position { line: 0, character: 14 }, end: Position { line: 0, character: 15 } }" diff --git a/kclvm/tools/src/LSP/src/snapshots/kcl_language_server__goto_def__tests__goto_lambda_param_goto_def2.snap b/kclvm/tools/src/LSP/src/snapshots/kcl_language_server__goto_def__tests__goto_lambda_param_goto_def2.snap new file mode 100644 index 000000000..a00655f0a --- /dev/null +++ b/kclvm/tools/src/LSP/src/snapshots/kcl_language_server__goto_def__tests__goto_lambda_param_goto_def2.snap @@ -0,0 +1,5 @@ +--- +source: tools/src/LSP/src/goto_def.rs +expression: "format!(\"{:?}\",\n {\n let (file, _program, _, gs) =\n compile_test_file(\"src/test_data/goto_def_test/goto_lambda_param_goto_def/goto_lambda_param_goto_def.k\");\n let pos = KCLPos\n { filename : file.clone(), line : 2, column : Some(9), }; let res =\n goto_def(& pos, & gs); fmt_resp(& res)\n })" +--- +"path: \"src/test_data/goto_def_test/goto_lambda_param_goto_def/goto_lambda_param_goto_def.k\", range: Range { start: Position { line: 0, character: 22 }, end: Position { line: 0, character: 23 } }" diff --git a/kclvm/tools/src/LSP/src/snapshots/kcl_language_server__goto_def__tests__goto_local_var_def_test1.snap b/kclvm/tools/src/LSP/src/snapshots/kcl_language_server__goto_def__tests__goto_local_var_def_test1.snap new file mode 100644 index 000000000..0b5930b7e --- /dev/null +++ b/kclvm/tools/src/LSP/src/snapshots/kcl_language_server__goto_def__tests__goto_local_var_def_test1.snap @@ -0,0 +1,5 @@ +--- +source: tools/src/LSP/src/goto_def.rs +expression: "format!(\"{:?}\",\n {\n let (file, _program, _, gs) =\n compile_test_file(\"src/test_data/goto_def_test/goto_local_var_def_test/goto_local_var_def_test.k\");\n let pos = KCLPos\n { filename : file.clone(), line : 7, column : Some(11), }; let res =\n goto_def(& pos, & gs); fmt_resp(& res)\n })" +--- +"path: \"src/test_data/goto_def_test/goto_local_var_def_test/goto_local_var_def_test.k\", range: Range { start: Position { line: 4, character: 4 }, end: Position { line: 4, character: 9 } }" diff --git a/kclvm/tools/src/LSP/src/snapshots/kcl_language_server__goto_def__tests__goto_local_var_def_test2.snap b/kclvm/tools/src/LSP/src/snapshots/kcl_language_server__goto_def__tests__goto_local_var_def_test2.snap new file mode 100644 index 000000000..99fe6b949 --- /dev/null +++ b/kclvm/tools/src/LSP/src/snapshots/kcl_language_server__goto_def__tests__goto_local_var_def_test2.snap @@ -0,0 +1,5 @@ +--- +source: tools/src/LSP/src/goto_def.rs +expression: "format!(\"{:?}\",\n {\n let (file, _program, _, gs) =\n compile_test_file(\"src/test_data/goto_def_test/goto_local_var_def_test/goto_local_var_def_test.k\");\n let pos = KCLPos\n { filename : file.clone(), line : 9, column : Some(11), }; let res =\n goto_def(& pos, & gs); fmt_resp(& res)\n })" +--- +"path: \"src/test_data/goto_def_test/goto_local_var_def_test/goto_local_var_def_test.k\", range: Range { start: Position { line: 4, character: 4 }, end: Position { line: 4, character: 9 } }" diff --git a/kclvm/tools/src/LSP/src/snapshots/kcl_language_server__goto_def__tests__goto_local_var_def_test3.snap b/kclvm/tools/src/LSP/src/snapshots/kcl_language_server__goto_def__tests__goto_local_var_def_test3.snap new file mode 100644 index 000000000..752c4ef3e --- /dev/null +++ b/kclvm/tools/src/LSP/src/snapshots/kcl_language_server__goto_def__tests__goto_local_var_def_test3.snap @@ -0,0 +1,5 @@ +--- +source: tools/src/LSP/src/goto_def.rs +expression: "format!(\"{:?}\",\n {\n let (file, _program, _, gs) =\n compile_test_file(\"src/test_data/goto_def_test/goto_local_var_def_test/goto_local_var_def_test.k\");\n let pos = KCLPos\n { filename : file.clone(), line : 11, column : Some(11), }; let res =\n goto_def(& pos, & gs); fmt_resp(& res)\n })" +--- +"path: \"src/test_data/goto_def_test/goto_local_var_def_test/goto_local_var_def_test.k\", range: Range { start: Position { line: 4, character: 4 }, end: Position { line: 4, character: 9 } }" diff --git a/kclvm/tools/src/LSP/src/snapshots/kcl_language_server__goto_def__tests__goto_pkg_prefix_def_test.snap b/kclvm/tools/src/LSP/src/snapshots/kcl_language_server__goto_def__tests__goto_pkg_prefix_def_test.snap new file mode 100644 index 000000000..eb7d3146f --- /dev/null +++ b/kclvm/tools/src/LSP/src/snapshots/kcl_language_server__goto_def__tests__goto_pkg_prefix_def_test.snap @@ -0,0 +1,5 @@ +--- +source: tools/src/LSP/src/goto_def.rs +expression: "format!(\"{:?}\",\n {\n let (file, _program, _, gs) =\n compile_test_file(\"src/test_data/goto_def_test/goto_pkg_prefix_def_test/goto_pkg_prefix_def_test.k\");\n let pos = KCLPos\n { filename : file.clone(), line : 3, column : Some(7), }; let res =\n goto_def(& pos, & gs); fmt_resp(& res)\n })" +--- +"path: \"src/test_data/goto_def_test/pkg/schema_def.k\", range: Range { start: Position { line: 0, character: 0 }, end: Position { line: 0, character: 0 } }\npath: \"src/test_data/goto_def_test/pkg/schema_def1.k\", range: Range { start: Position { line: 0, character: 0 }, end: Position { line: 0, character: 0 } }\n" diff --git a/kclvm/tools/src/LSP/src/snapshots/kcl_language_server__goto_def__tests__goto_schema_attr_def_test1.snap b/kclvm/tools/src/LSP/src/snapshots/kcl_language_server__goto_def__tests__goto_schema_attr_def_test1.snap new file mode 100644 index 000000000..b9775a94e --- /dev/null +++ b/kclvm/tools/src/LSP/src/snapshots/kcl_language_server__goto_def__tests__goto_schema_attr_def_test1.snap @@ -0,0 +1,5 @@ +--- +source: tools/src/LSP/src/goto_def.rs +expression: "format!(\"{:?}\",\n {\n let (file, _program, _, gs) =\n compile_test_file(\"src/test_data/goto_def_test/goto_schema_attr_def_test/goto_schema_attr_def_test.k\");\n let pos = KCLPos\n { filename : file.clone(), line : 4, column : Some(7), }; let res =\n goto_def(& pos, & gs); fmt_resp(& res)\n })" +--- +"path: \"src/test_data/goto_def_test/pkg/schema_def.k\", range: Range { start: Position { line: 4, character: 4 }, end: Position { line: 4, character: 8 } }" diff --git a/kclvm/tools/src/LSP/src/snapshots/kcl_language_server__goto_def__tests__goto_schema_attr_def_test2.snap b/kclvm/tools/src/LSP/src/snapshots/kcl_language_server__goto_def__tests__goto_schema_attr_def_test2.snap new file mode 100644 index 000000000..113c0f3a4 --- /dev/null +++ b/kclvm/tools/src/LSP/src/snapshots/kcl_language_server__goto_def__tests__goto_schema_attr_def_test2.snap @@ -0,0 +1,5 @@ +--- +source: tools/src/LSP/src/goto_def.rs +expression: "format!(\"{:?}\",\n {\n let (file, _program, _, gs) =\n compile_test_file(\"src/test_data/goto_def_test/goto_schema_attr_def_test/goto_schema_attr_def_test.k\");\n let pos = KCLPos\n { filename : file.clone(), line : 18, column : Some(12), }; let res =\n goto_def(& pos, & gs); fmt_resp(& res)\n })" +--- +"path: \"src/test_data/goto_def_test/goto_schema_attr_def_test/goto_schema_attr_def_test.k\", range: Range { start: Position { line: 8, character: 4 }, end: Position { line: 8, character: 8 } }" diff --git a/kclvm/tools/src/LSP/src/snapshots/kcl_language_server__goto_def__tests__goto_schema_attr_ty_def_test1.snap b/kclvm/tools/src/LSP/src/snapshots/kcl_language_server__goto_def__tests__goto_schema_attr_ty_def_test1.snap new file mode 100644 index 000000000..ddc029b22 --- /dev/null +++ b/kclvm/tools/src/LSP/src/snapshots/kcl_language_server__goto_def__tests__goto_schema_attr_ty_def_test1.snap @@ -0,0 +1,5 @@ +--- +source: tools/src/LSP/src/goto_def.rs +expression: "format!(\"{:?}\",\n {\n let (file, _program, _, gs) =\n compile_test_file(\"src/test_data/goto_def_test/goto_schema_attr_ty_def_test/goto_schema_attr_ty_def_test.k\");\n let pos = KCLPos\n { filename : file.clone(), line : 4, column : Some(15), }; let res =\n goto_def(& pos, & gs); fmt_resp(& res)\n })" +--- +"path: \"src/test_data/goto_def_test/pkg/schema_def.k\", range: Range { start: Position { line: 0, character: 7 }, end: Position { line: 0, character: 13 } }" diff --git a/kclvm/tools/src/LSP/src/snapshots/kcl_language_server__goto_def__tests__goto_schema_attr_ty_def_test2.snap b/kclvm/tools/src/LSP/src/snapshots/kcl_language_server__goto_def__tests__goto_schema_attr_ty_def_test2.snap new file mode 100644 index 000000000..e3787f24f --- /dev/null +++ b/kclvm/tools/src/LSP/src/snapshots/kcl_language_server__goto_def__tests__goto_schema_attr_ty_def_test2.snap @@ -0,0 +1,5 @@ +--- +source: tools/src/LSP/src/goto_def.rs +expression: "format!(\"{:?}\",\n {\n let (file, _program, _, gs) =\n compile_test_file(\"src/test_data/goto_def_test/goto_schema_attr_ty_def_test/goto_schema_attr_ty_def_test.k\");\n let pos = KCLPos\n { filename : file.clone(), line : 5, column : Some(15), }; let res =\n goto_def(& pos, & gs); fmt_resp(& res)\n })" +--- +"path: \"src/test_data/goto_def_test/pkg/schema_def.k\", range: Range { start: Position { line: 0, character: 7 }, end: Position { line: 0, character: 13 } }" diff --git a/kclvm/tools/src/LSP/src/snapshots/kcl_language_server__goto_def__tests__goto_schema_attr_ty_def_test3.snap b/kclvm/tools/src/LSP/src/snapshots/kcl_language_server__goto_def__tests__goto_schema_attr_ty_def_test3.snap new file mode 100644 index 000000000..a4951e1bb --- /dev/null +++ b/kclvm/tools/src/LSP/src/snapshots/kcl_language_server__goto_def__tests__goto_schema_attr_ty_def_test3.snap @@ -0,0 +1,5 @@ +--- +source: tools/src/LSP/src/goto_def.rs +expression: "format!(\"{:?}\",\n {\n let (file, _program, _, gs) =\n compile_test_file(\"src/test_data/goto_def_test/goto_schema_attr_ty_def_test/goto_schema_attr_ty_def_test.k\");\n let pos = KCLPos\n { filename : file.clone(), line : 6, column : Some(22), }; let res =\n goto_def(& pos, & gs); fmt_resp(& res)\n })" +--- +"path: \"src/test_data/goto_def_test/pkg/schema_def.k\", range: Range { start: Position { line: 0, character: 7 }, end: Position { line: 0, character: 13 } }" diff --git a/kclvm/tools/src/LSP/src/snapshots/kcl_language_server__goto_def__tests__goto_schema_attr_ty_def_test4.snap b/kclvm/tools/src/LSP/src/snapshots/kcl_language_server__goto_def__tests__goto_schema_attr_ty_def_test4.snap new file mode 100644 index 000000000..0b1969f76 --- /dev/null +++ b/kclvm/tools/src/LSP/src/snapshots/kcl_language_server__goto_def__tests__goto_schema_attr_ty_def_test4.snap @@ -0,0 +1,5 @@ +--- +source: tools/src/LSP/src/goto_def.rs +expression: "format!(\"{:?}\",\n {\n let (file, _program, _, gs) =\n compile_test_file(\"src/test_data/goto_def_test/goto_schema_attr_ty_def_test/goto_schema_attr_ty_def_test.k\");\n let pos = KCLPos\n { filename : file.clone(), line : 7, column : Some(17), }; let res =\n goto_def(& pos, & gs); fmt_resp(& res)\n })" +--- +"path: \"src/test_data/goto_def_test/pkg/schema_def.k\", range: Range { start: Position { line: 0, character: 7 }, end: Position { line: 0, character: 13 } }" diff --git a/kclvm/tools/src/LSP/src/snapshots/kcl_language_server__goto_def__tests__goto_schema_attr_ty_def_test5.snap b/kclvm/tools/src/LSP/src/snapshots/kcl_language_server__goto_def__tests__goto_schema_attr_ty_def_test5.snap new file mode 100644 index 000000000..c40e21636 --- /dev/null +++ b/kclvm/tools/src/LSP/src/snapshots/kcl_language_server__goto_def__tests__goto_schema_attr_ty_def_test5.snap @@ -0,0 +1,5 @@ +--- +source: tools/src/LSP/src/goto_def.rs +expression: "format!(\"{:?}\",\n {\n let (file, _program, _, gs) =\n compile_test_file(\"src/test_data/goto_def_test/goto_schema_attr_ty_def_test/goto_schema_attr_ty_def_test.k\");\n let pos = KCLPos\n { filename : file.clone(), line : 7, column : Some(28), }; let res =\n goto_def(& pos, & gs); fmt_resp(& res)\n })" +--- +"path: \"src/test_data/goto_def_test/pkg/schema_def1.k\", range: Range { start: Position { line: 0, character: 7 }, end: Position { line: 0, character: 14 } }" diff --git a/kclvm/tools/src/LSP/src/snapshots/kcl_language_server__goto_def__tests__goto_schema_def_test.snap b/kclvm/tools/src/LSP/src/snapshots/kcl_language_server__goto_def__tests__goto_schema_def_test.snap new file mode 100644 index 000000000..08656bbf6 --- /dev/null +++ b/kclvm/tools/src/LSP/src/snapshots/kcl_language_server__goto_def__tests__goto_schema_def_test.snap @@ -0,0 +1,5 @@ +--- +source: tools/src/LSP/src/goto_def.rs +expression: "format!(\"{:?}\",\n {\n let (file, _program, _, gs) =\n compile_test_file(\"src/test_data/goto_def_test/goto_schema_def_test/goto_schema_def_test.k\");\n let pos = KCLPos\n { filename : file.clone(), line : 3, column : Some(11), }; let res =\n goto_def(& pos, & gs); fmt_resp(& res)\n })" +--- +"path: \"src/test_data/goto_def_test/pkg/schema_def.k\", range: Range { start: Position { line: 0, character: 7 }, end: Position { line: 0, character: 13 } }" diff --git a/kclvm/tools/src/LSP/src/snapshots/kcl_language_server__goto_def__tests__goto_system_pkg_test.snap b/kclvm/tools/src/LSP/src/snapshots/kcl_language_server__goto_def__tests__goto_system_pkg_test.snap index 1cd5643cd..11cd85e48 100644 --- a/kclvm/tools/src/LSP/src/snapshots/kcl_language_server__goto_def__tests__goto_system_pkg_test.snap +++ b/kclvm/tools/src/LSP/src/snapshots/kcl_language_server__goto_def__tests__goto_system_pkg_test.snap @@ -1,5 +1,5 @@ --- source: tools/src/LSP/src/goto_def.rs -expression: "format!(\"{:?}\",\n {\n let(file, _program, _, gs) =\n compile_test_file(\"src/test_data/goto_def_test/goto_def.k\") ; let pos\n = KCLPos { filename : file.clone(), line : 3, column : Some(1), } ;\n let res = goto_def(& pos, & gs) ; fmt_resp(& res)\n })" +expression: "format!(\"{:?}\",\n {\n let (file, _program, _, gs) =\n compile_test_file(\"src/test_data/goto_def_test/goto_system_pkg_test/goto_system_pkg_test.k\");\n let pos = KCLPos\n { filename : file.clone(), line : 1, column : Some(1), }; let res =\n goto_def(& pos, & gs); fmt_resp(& res)\n })" --- "None" diff --git a/kclvm/tools/src/LSP/src/snapshots/kcl_language_server__goto_def__tests__goto_var_def_in_config_and_config_if_test1.snap b/kclvm/tools/src/LSP/src/snapshots/kcl_language_server__goto_def__tests__goto_var_def_in_config_and_config_if_test1.snap new file mode 100644 index 000000000..b18dd490e --- /dev/null +++ b/kclvm/tools/src/LSP/src/snapshots/kcl_language_server__goto_def__tests__goto_var_def_in_config_and_config_if_test1.snap @@ -0,0 +1,5 @@ +--- +source: tools/src/LSP/src/goto_def.rs +expression: "format!(\"{:?}\",\n {\n let (file, _program, _, gs) =\n compile_test_file(\"src/test_data/goto_def_test/goto_var_def_in_config_and_config_if_test/goto_var_def_in_config_and_config_if_test.k\");\n let pos = KCLPos\n { filename : file.clone(), line : 7, column : Some(36), }; let res =\n goto_def(& pos, & gs); fmt_resp(& res)\n })" +--- +"path: \"src/test_data/goto_def_test/goto_var_def_in_config_and_config_if_test/goto_var_def_in_config_and_config_if_test.k\", range: Range { start: Position { line: 5, character: 11 }, end: Position { line: 5, character: 14 } }" diff --git a/kclvm/tools/src/LSP/src/snapshots/kcl_language_server__goto_def__tests__goto_var_def_in_config_and_config_if_test2.snap b/kclvm/tools/src/LSP/src/snapshots/kcl_language_server__goto_def__tests__goto_var_def_in_config_and_config_if_test2.snap new file mode 100644 index 000000000..1270eda3b --- /dev/null +++ b/kclvm/tools/src/LSP/src/snapshots/kcl_language_server__goto_def__tests__goto_var_def_in_config_and_config_if_test2.snap @@ -0,0 +1,5 @@ +--- +source: tools/src/LSP/src/goto_def.rs +expression: "format!(\"{:?}\",\n {\n let (file, _program, _, gs) =\n compile_test_file(\"src/test_data/goto_def_test/goto_var_def_in_config_and_config_if_test/goto_var_def_in_config_and_config_if_test.k\");\n let pos = KCLPos\n { filename : file.clone(), line : 7, column : Some(44), }; let res =\n goto_def(& pos, & gs); fmt_resp(& res)\n })" +--- +"path: \"src/test_data/goto_def_test/goto_var_def_in_config_and_config_if_test/goto_var_def_in_config_and_config_if_test.k\", range: Range { start: Position { line: 5, character: 16 }, end: Position { line: 5, character: 21 } }" diff --git a/kclvm/tools/src/LSP/src/snapshots/kcl_language_server__goto_def__tests__goto_var_def_in_config_and_config_if_test3.snap b/kclvm/tools/src/LSP/src/snapshots/kcl_language_server__goto_def__tests__goto_var_def_in_config_and_config_if_test3.snap new file mode 100644 index 000000000..0ab0496d3 --- /dev/null +++ b/kclvm/tools/src/LSP/src/snapshots/kcl_language_server__goto_def__tests__goto_var_def_in_config_and_config_if_test3.snap @@ -0,0 +1,5 @@ +--- +source: tools/src/LSP/src/goto_def.rs +expression: "format!(\"{:?}\",\n {\n let (file, _program, _, gs) =\n compile_test_file(\"src/test_data/goto_def_test/goto_var_def_in_config_and_config_if_test/goto_var_def_in_config_and_config_if_test.k\");\n let pos = KCLPos\n { filename : file.clone(), line : 4, column : Some(11), }; let res =\n goto_def(& pos, & gs); fmt_resp(& res)\n })" +--- +"path: \"src/test_data/goto_def_test/goto_var_def_in_config_and_config_if_test/goto_var_def_in_config_and_config_if_test.k\", range: Range { start: Position { line: 10, character: 6 }, end: Position { line: 10, character: 10 } }" diff --git a/kclvm/tools/src/LSP/src/snapshots/kcl_language_server__goto_def__tests__goto_var_def_in_config_and_config_if_test4.snap b/kclvm/tools/src/LSP/src/snapshots/kcl_language_server__goto_def__tests__goto_var_def_in_config_and_config_if_test4.snap new file mode 100644 index 000000000..a21dbcdb8 --- /dev/null +++ b/kclvm/tools/src/LSP/src/snapshots/kcl_language_server__goto_def__tests__goto_var_def_in_config_and_config_if_test4.snap @@ -0,0 +1,5 @@ +--- +source: tools/src/LSP/src/goto_def.rs +expression: "format!(\"{:?}\",\n {\n let (file, _program, _, gs) =\n compile_test_file(\"src/test_data/goto_def_test/goto_var_def_in_config_and_config_if_test/goto_var_def_in_config_and_config_if_test.k\");\n let pos = KCLPos\n { filename : file.clone(), line : 7, column : Some(10), }; let res =\n goto_def(& pos, & gs); fmt_resp(& res)\n })" +--- +"path: \"src/test_data/goto_def_test/goto_var_def_in_config_and_config_if_test/goto_var_def_in_config_and_config_if_test.k\", range: Range { start: Position { line: 10, character: 6 }, end: Position { line: 10, character: 10 } }" diff --git a/kclvm/tools/src/LSP/src/snapshots/kcl_language_server__goto_def__tests__goto_var_def_in_dict_comp_test1.snap b/kclvm/tools/src/LSP/src/snapshots/kcl_language_server__goto_def__tests__goto_var_def_in_dict_comp_test1.snap new file mode 100644 index 000000000..70df4e272 --- /dev/null +++ b/kclvm/tools/src/LSP/src/snapshots/kcl_language_server__goto_def__tests__goto_var_def_in_dict_comp_test1.snap @@ -0,0 +1,5 @@ +--- +source: tools/src/LSP/src/goto_def.rs +expression: "format!(\"{:?}\",\n {\n let (file, _program, _, gs) =\n compile_test_file(\"src/test_data/goto_def_test/goto_var_def_in_dict_comp_test/goto_var_def_in_dict_comp_test.k\");\n let pos = KCLPos\n { filename : file.clone(), line : 5, column : Some(68), }; let res =\n goto_def(& pos, & gs); fmt_resp(& res)\n })" +--- +"path: \"src/test_data/goto_def_test/goto_var_def_in_dict_comp_test/goto_var_def_in_dict_comp_test.k\", range: Range { start: Position { line: 4, character: 143 }, end: Position { line: 4, character: 145 } }" diff --git a/kclvm/tools/src/LSP/src/snapshots/kcl_language_server__goto_def__tests__goto_var_def_in_dict_comp_test2.snap b/kclvm/tools/src/LSP/src/snapshots/kcl_language_server__goto_def__tests__goto_var_def_in_dict_comp_test2.snap new file mode 100644 index 000000000..76986da90 --- /dev/null +++ b/kclvm/tools/src/LSP/src/snapshots/kcl_language_server__goto_def__tests__goto_var_def_in_dict_comp_test2.snap @@ -0,0 +1,5 @@ +--- +source: tools/src/LSP/src/goto_def.rs +expression: "format!(\"{:?}\",\n {\n let (file, _program, _, gs) =\n compile_test_file(\"src/test_data/goto_def_test/goto_var_def_in_dict_comp_test/goto_var_def_in_dict_comp_test.k\");\n let pos = KCLPos\n { filename : file.clone(), line : 5, column : Some(61), }; let res =\n goto_def(& pos, & gs); fmt_resp(& res)\n })" +--- +"path: \"src/test_data/goto_def_test/goto_var_def_in_dict_comp_test/goto_var_def_in_dict_comp_test.k\", range: Range { start: Position { line: 4, character: 143 }, end: Position { line: 4, character: 145 } }" diff --git a/kclvm/tools/src/LSP/src/snapshots/kcl_language_server__goto_def__tests__lambda_local_var_test.snap b/kclvm/tools/src/LSP/src/snapshots/kcl_language_server__goto_def__tests__lambda_local_var_test.snap new file mode 100644 index 000000000..297eac823 --- /dev/null +++ b/kclvm/tools/src/LSP/src/snapshots/kcl_language_server__goto_def__tests__lambda_local_var_test.snap @@ -0,0 +1,5 @@ +--- +source: tools/src/LSP/src/goto_def.rs +expression: "format!(\"{:?}\",\n {\n let (file, _program, _, gs) =\n compile_test_file(\"src/test_data/goto_def_test/lambda_local_var_test/lambda_local_var_test.k\");\n let pos = KCLPos\n { filename : file.clone(), line : 2, column : Some(9), }; let res =\n goto_def(& pos, & gs); fmt_resp(& res)\n })" +--- +"path: \"src/test_data/goto_def_test/lambda_local_var_test/lambda_local_var_test.k\", range: Range { start: Position { line: 0, character: 11 }, end: Position { line: 0, character: 12 } }" diff --git a/kclvm/tools/src/LSP/src/snapshots/kcl_language_server__goto_def__tests__list_if_expr_test.snap b/kclvm/tools/src/LSP/src/snapshots/kcl_language_server__goto_def__tests__list_if_expr_test.snap new file mode 100644 index 000000000..06c2bba9d --- /dev/null +++ b/kclvm/tools/src/LSP/src/snapshots/kcl_language_server__goto_def__tests__list_if_expr_test.snap @@ -0,0 +1,5 @@ +--- +source: tools/src/LSP/src/goto_def.rs +expression: "format!(\"{:?}\",\n {\n let (file, _program, _, gs) =\n compile_test_file(\"src/test_data/goto_def_test/list_if_expr_test/list_if_expr_test.k\");\n let pos = KCLPos\n { filename : file.clone(), line : 3, column : Some(8), }; let res =\n goto_def(& pos, & gs); fmt_resp(& res)\n })" +--- +"path: \"src/test_data/goto_def_test/list_if_expr_test/list_if_expr_test.k\", range: Range { start: Position { line: 0, character: 0 }, end: Position { line: 0, character: 1 } }" diff --git a/kclvm/tools/src/LSP/src/snapshots/kcl_language_server__goto_def__tests__schema_attribute_def_goto_def.snap b/kclvm/tools/src/LSP/src/snapshots/kcl_language_server__goto_def__tests__schema_attribute_def_goto_def.snap new file mode 100644 index 000000000..759784e72 --- /dev/null +++ b/kclvm/tools/src/LSP/src/snapshots/kcl_language_server__goto_def__tests__schema_attribute_def_goto_def.snap @@ -0,0 +1,5 @@ +--- +source: tools/src/LSP/src/goto_def.rs +expression: "format!(\"{:?}\",\n {\n let (file, _program, _, gs) =\n compile_test_file(\"src/test_data/goto_def_test/schema_attribute_def_goto_def/schema_attribute_def_goto_def.k\");\n let pos = KCLPos\n { filename : file.clone(), line : 2, column : Some(5), }; let res =\n goto_def(& pos, & gs); fmt_resp(& res)\n })" +--- +"path: \"src/test_data/goto_def_test/schema_attribute_def_goto_def/schema_attribute_def_goto_def.k\", range: Range { start: Position { line: 1, character: 4 }, end: Position { line: 1, character: 8 } }" diff --git a/kclvm/tools/src/LSP/src/snapshots/kcl_language_server__hover__tests__dict_key_in_schema-2.snap b/kclvm/tools/src/LSP/src/snapshots/kcl_language_server__hover__tests__dict_key_in_schema-2.snap deleted file mode 100644 index 1f95f47a9..000000000 --- a/kclvm/tools/src/LSP/src/snapshots/kcl_language_server__hover__tests__dict_key_in_schema-2.snap +++ /dev/null @@ -1,5 +0,0 @@ ---- -source: tools/src/LSP/src/hover.rs -expression: "format!(\"{:?}\", got)" ---- -Hover { contents: Scalar(LanguageString(LanguageString { language: "kcl", value: "name: int" })), range: None } diff --git a/kclvm/tools/src/LSP/src/snapshots/kcl_language_server__hover__tests__dict_key_in_schema-3.snap b/kclvm/tools/src/LSP/src/snapshots/kcl_language_server__hover__tests__dict_key_in_schema-3.snap deleted file mode 100644 index 1f95f47a9..000000000 --- a/kclvm/tools/src/LSP/src/snapshots/kcl_language_server__hover__tests__dict_key_in_schema-3.snap +++ /dev/null @@ -1,5 +0,0 @@ ---- -source: tools/src/LSP/src/hover.rs -expression: "format!(\"{:?}\", got)" ---- -Hover { contents: Scalar(LanguageString(LanguageString { language: "kcl", value: "name: int" })), range: None } diff --git a/kclvm/tools/src/LSP/src/snapshots/kcl_language_server__hover__tests__dict_key_in_schema.snap b/kclvm/tools/src/LSP/src/snapshots/kcl_language_server__hover__tests__dict_key_in_schema.snap deleted file mode 100644 index 1f95f47a9..000000000 --- a/kclvm/tools/src/LSP/src/snapshots/kcl_language_server__hover__tests__dict_key_in_schema.snap +++ /dev/null @@ -1,5 +0,0 @@ ---- -source: tools/src/LSP/src/hover.rs -expression: "format!(\"{:?}\", got)" ---- -Hover { contents: Scalar(LanguageString(LanguageString { language: "kcl", value: "name: int" })), range: None } diff --git a/kclvm/tools/src/LSP/src/test_data/goto_def_test/complex_select_goto_def/complex_select_goto_def.k b/kclvm/tools/src/LSP/src/test_data/goto_def_test/complex_select_goto_def/complex_select_goto_def.k new file mode 100644 index 000000000..a1abceb60 --- /dev/null +++ b/kclvm/tools/src/LSP/src/test_data/goto_def_test/complex_select_goto_def/complex_select_goto_def.k @@ -0,0 +1,13 @@ +schema Fib: + n1 = n - 1 + n2 = n1 - 1 + n: int + value: int + if n <= 1: + value = 1 + elif n == 2: + value = 1 + else: + value = Fib {n = n1}.value + Fib {n = n2}.value + +fib8 = Fib {n = 8}.value diff --git a/kclvm/tools/src/LSP/src/test_data/goto_def_test/config_desuger_def_goto_def/config_desuger_def_goto_def.k b/kclvm/tools/src/LSP/src/test_data/goto_def_test/config_desuger_def_goto_def/config_desuger_def_goto_def.k new file mode 100644 index 000000000..1c3175ad8 --- /dev/null +++ b/kclvm/tools/src/LSP/src/test_data/goto_def_test/config_desuger_def_goto_def/config_desuger_def_goto_def.k @@ -0,0 +1,8 @@ +schema Person: + n: Name + +schema Name: + name: str + +p4 = Person {n.name: "a"} + diff --git a/kclvm/tools/src/LSP/src/test_data/goto_def_test/goto_assign_type_test/goto_assign_type_test.k b/kclvm/tools/src/LSP/src/test_data/goto_def_test/goto_assign_type_test/goto_assign_type_test.k new file mode 100644 index 000000000..6b2d9f4f0 --- /dev/null +++ b/kclvm/tools/src/LSP/src/test_data/goto_def_test/goto_assign_type_test/goto_assign_type_test.k @@ -0,0 +1,5 @@ +schema Reviewer: + teams?: [int] + users?: [int] + +reviewers: [Reviewer] = [Reviewer {teams: [1]}] diff --git a/kclvm/tools/src/LSP/src/test_data/goto_def_test/goto_identifier_def_test/goto_identifier_def_test.k b/kclvm/tools/src/LSP/src/test_data/goto_def_test/goto_identifier_def_test/goto_identifier_def_test.k new file mode 100644 index 000000000..195f64d20 --- /dev/null +++ b/kclvm/tools/src/LSP/src/test_data/goto_def_test/goto_identifier_def_test/goto_identifier_def_test.k @@ -0,0 +1,8 @@ +import ..pkg + +p = pkg.Person { + name: "alice" + age: 1 +} + +p1 = p diff --git a/kclvm/tools/src/LSP/src/test_data/goto_def_test/goto_import_file_test/goto_import_file_test.k b/kclvm/tools/src/LSP/src/test_data/goto_def_test/goto_import_file_test/goto_import_file_test.k new file mode 100644 index 000000000..e63f728c7 --- /dev/null +++ b/kclvm/tools/src/LSP/src/test_data/goto_def_test/goto_import_file_test/goto_import_file_test.k @@ -0,0 +1 @@ +import ..pkg.schema_def diff --git a/kclvm/tools/src/LSP/src/test_data/goto_def_test/goto_import_pkg_test/goto_import_pkg_test.k b/kclvm/tools/src/LSP/src/test_data/goto_def_test/goto_import_pkg_test/goto_import_pkg_test.k new file mode 100644 index 000000000..f175c17db --- /dev/null +++ b/kclvm/tools/src/LSP/src/test_data/goto_def_test/goto_import_pkg_test/goto_import_pkg_test.k @@ -0,0 +1 @@ +import ..pkg diff --git a/kclvm/tools/src/LSP/src/test_data/goto_def_test/goto_lambda_param_goto_def/goto_lambda_param_goto_def.k b/kclvm/tools/src/LSP/src/test_data/goto_def_test/goto_lambda_param_goto_def/goto_lambda_param_goto_def.k new file mode 100644 index 000000000..2fa2a623a --- /dev/null +++ b/kclvm/tools/src/LSP/src/test_data/goto_def_test/goto_lambda_param_goto_def/goto_lambda_param_goto_def.k @@ -0,0 +1,3 @@ +func = lambda x: int, y: int -> int { + x + y +} diff --git a/kclvm/tools/src/LSP/src/test_data/goto_def_test/goto_local_var_def_test/goto_local_var_def_test.k b/kclvm/tools/src/LSP/src/test_data/goto_def_test/goto_local_var_def_test/goto_local_var_def_test.k new file mode 100644 index 000000000..8dd5c96e0 --- /dev/null +++ b/kclvm/tools/src/LSP/src/test_data/goto_def_test/goto_local_var_def_test/goto_local_var_def_test.k @@ -0,0 +1,12 @@ +schema Fib: + n1 = n - 1 + n2 = n1 - 1 + n: int + value: int + if n <= 1: + value = 1 + elif n == 2: + value = 1 + else: + value = Fib {n = n1}.value + Fib {n = n2}.value + diff --git a/kclvm/tools/src/LSP/src/test_data/goto_def_test/goto_pkg_prefix_def_test/goto_pkg_prefix_def_test.k b/kclvm/tools/src/LSP/src/test_data/goto_def_test/goto_pkg_prefix_def_test/goto_pkg_prefix_def_test.k new file mode 100644 index 000000000..7ca8eae50 --- /dev/null +++ b/kclvm/tools/src/LSP/src/test_data/goto_def_test/goto_pkg_prefix_def_test/goto_pkg_prefix_def_test.k @@ -0,0 +1,7 @@ +import ..pkg + +p = pkg.Person { + name: "alice" + age: 1 +} + diff --git a/kclvm/tools/src/LSP/src/test_data/goto_def_test/goto_schema_attr_def_test/goto_schema_attr_def_test.k b/kclvm/tools/src/LSP/src/test_data/goto_def_test/goto_schema_attr_def_test/goto_schema_attr_def_test.k new file mode 100644 index 000000000..f106cc0b8 --- /dev/null +++ b/kclvm/tools/src/LSP/src/test_data/goto_def_test/goto_schema_attr_def_test/goto_schema_attr_def_test.k @@ -0,0 +1,18 @@ +import ..pkg + +p = pkg.Person { + name: "alice" + age: 1 +} + +schema Name: + name: str + +schema Person: + n: Name + +p2 = Person { + n: Name {name: pkg.m.name} +} + +s = p2.n.name diff --git a/kclvm/tools/src/LSP/src/test_data/goto_def_test/goto_schema_attr_ty_def_test/goto_schema_attr_ty_def_test.k b/kclvm/tools/src/LSP/src/test_data/goto_def_test/goto_schema_attr_ty_def_test/goto_schema_attr_ty_def_test.k new file mode 100644 index 000000000..ed3910720 --- /dev/null +++ b/kclvm/tools/src/LSP/src/test_data/goto_def_test/goto_schema_attr_ty_def_test/goto_schema_attr_ty_def_test.k @@ -0,0 +1,8 @@ +import ..pkg + +schema Person3: + p1: pkg.Person + p2: [pkg.Person] + p3: {str:pkg.Person} + p4: pkg.Person | pkg.Person1 + diff --git a/kclvm/tools/src/LSP/src/test_data/goto_def_test/goto_schema_def_test/goto_schema_def_test.k b/kclvm/tools/src/LSP/src/test_data/goto_def_test/goto_schema_def_test/goto_schema_def_test.k new file mode 100644 index 000000000..7ca8eae50 --- /dev/null +++ b/kclvm/tools/src/LSP/src/test_data/goto_def_test/goto_schema_def_test/goto_schema_def_test.k @@ -0,0 +1,7 @@ +import ..pkg + +p = pkg.Person { + name: "alice" + age: 1 +} + diff --git a/kclvm/tools/src/LSP/src/test_data/goto_def_test/goto_system_pkg_test/goto_system_pkg_test.k b/kclvm/tools/src/LSP/src/test_data/goto_def_test/goto_system_pkg_test/goto_system_pkg_test.k new file mode 100644 index 000000000..e69de29bb diff --git a/kclvm/tools/src/LSP/src/test_data/goto_def_test/goto_var_def_in_config_and_config_if_test/goto_var_def_in_config_and_config_if_test.k b/kclvm/tools/src/LSP/src/test_data/goto_def_test/goto_var_def_in_config_and_config_if_test/goto_var_def_in_config_and_config_if_test.k new file mode 100644 index 000000000..9a0a70022 --- /dev/null +++ b/kclvm/tools/src/LSP/src/test_data/goto_def_test/goto_var_def_in_config_and_config_if_test/goto_var_def_in_config_and_config_if_test.k @@ -0,0 +1,11 @@ +params = option("params") +toMatch = params.toMatch +toAdd = params.toAdd +items = [item | { + # If all annotations are matched, patch more annotations + if all key, value in toMatch { + item.metadata.annotations[key] == value + }: + metadata.annotations: toAdd + +} for item in option("items")] diff --git a/kclvm/tools/src/LSP/src/test_data/goto_def_test/goto_var_def_in_dict_comp_test/goto_var_def_in_dict_comp_test.k b/kclvm/tools/src/LSP/src/test_data/goto_def_test/goto_var_def_in_dict_comp_test/goto_var_def_in_dict_comp_test.k new file mode 100644 index 000000000..16d866cb5 --- /dev/null +++ b/kclvm/tools/src/LSP/src/test_data/goto_def_test/goto_var_def_in_dict_comp_test/goto_var_def_in_dict_comp_test.k @@ -0,0 +1,8 @@ +capabilities = option("params").capabilities or ["SETUID", "SETFCAP"] +items1 = [item | { + if item.kind == "Pod": + spec.containers: [{ + "securityContext": {"capabilities": {"add" += [cc] if cc not in (container?.securityContext?.capabilities?.drop or []) else [] for cc in capabilities}} + } for container in item.spec.containers] + +} for item in option("items")] diff --git a/kclvm/tools/src/LSP/src/test_data/goto_def_test/lambda_local_var_test/lambda_local_var_test.k b/kclvm/tools/src/LSP/src/test_data/goto_def_test/lambda_local_var_test/lambda_local_var_test.k new file mode 100644 index 000000000..a2c975096 --- /dev/null +++ b/kclvm/tools/src/LSP/src/test_data/goto_def_test/lambda_local_var_test/lambda_local_var_test.k @@ -0,0 +1,3 @@ +f = lambda a: [str], b: [str], c: [str] -> [str] { + c + a + b +} diff --git a/kclvm/tools/src/LSP/src/test_data/goto_def_test/list_if_expr_test/list_if_expr_test.k b/kclvm/tools/src/LSP/src/test_data/goto_def_test/list_if_expr_test/list_if_expr_test.k new file mode 100644 index 000000000..c0896bc06 --- /dev/null +++ b/kclvm/tools/src/LSP/src/test_data/goto_def_test/list_if_expr_test/list_if_expr_test.k @@ -0,0 +1,6 @@ +b = True +command: [str] = [ + if b: + "a" + +] diff --git a/kclvm/tools/src/LSP/src/test_data/goto_def_test/schema_attribute_def_goto_def/schema_attribute_def_goto_def.k b/kclvm/tools/src/LSP/src/test_data/goto_def_test/schema_attribute_def_goto_def/schema_attribute_def_goto_def.k new file mode 100644 index 000000000..c0287b6c1 --- /dev/null +++ b/kclvm/tools/src/LSP/src/test_data/goto_def_test/schema_attribute_def_goto_def/schema_attribute_def_goto_def.k @@ -0,0 +1,3 @@ +schema Name: + name: str + diff --git a/kclvm/tools/src/LSP/src/test_data/goto_def_test/test_goto_identifier_names/test_goto_identifier_names.k b/kclvm/tools/src/LSP/src/test_data/goto_def_test/test_goto_identifier_names/test_goto_identifier_names.k new file mode 100644 index 000000000..a36869aea --- /dev/null +++ b/kclvm/tools/src/LSP/src/test_data/goto_def_test/test_goto_identifier_names/test_goto_identifier_names.k @@ -0,0 +1,13 @@ +import ..pkg + +schema Name: + name: str + +schema Person: + n: Name + +p2 = Person { + n: Name {name: pkg.m.name} +} + +s = p2.n.name