#![allow(clippy::needless_update)] use df_ls_core::Reference; use df_ls_debug_structure::*; use df_ls_diagnostics::lsp_types::*; use df_ls_lexical_analysis::test_utils::LexerTestBuilder; use df_ls_syntax_analysis::test_utils::SyntaxTestBuilder; #[test] fn error_in_token_ref() { SyntaxTestBuilder::from_lexer_test_builder( LexerTestBuilder::test_source( "h [MAIN:TYPE1] [TYPE1:DOG] [ITE[M:T1]", ) .add_test_lexer_diagnostics_codes(vec!["missing_end_bracket"]) .add_test_lexer_diagnostics_ranges(vec![Range { start: Position { line: 4, character: 20, }, end: Position { line: 4, character: 20, }, }]), ) .add_test_structure(DebugRaw { header: "h".to_owned(), token_structure: vec![MainToken { type_1: vec![Type1Token { reference: Some(Reference("DOG".to_owned())), ..Default::default() }], ..Default::default() }], }) .add_test_syntax_diagnostics_codes(vec!["unknown_token", "unchecked_code"]) .add_test_syntax_diagnostics_ranges(vec![ Range { start: Position { line: 4, character: 16, }, end: Position { line: 4, character: 20, }, }, Range { start: Position { line: 4, character: 20, }, end: Position { line: 4, character: 26, }, }, ]) .run_test(); }