-
Notifications
You must be signed in to change notification settings - Fork 1
/
Copy pathsemanticTokens_test.go
93 lines (84 loc) · 3.3 KB
/
semanticTokens_test.go
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
package server_test
import (
"bytes"
"context"
"os"
"testing"
"github.com/docker/docker-language-server/internal/bake/hcl"
"github.com/docker/docker-language-server/internal/tliron/glsp/protocol"
"github.com/sourcegraph/jsonrpc2"
"github.com/stretchr/testify/require"
)
func TestSemanticTokensFull(t *testing.T) {
s := startServer()
client := bytes.NewBuffer(make([]byte, 0, 1024))
server := bytes.NewBuffer(make([]byte, 0, 1024))
serverStream := &TestStream{incoming: server, outgoing: client, closed: false}
defer serverStream.Close()
go s.ServeStream(serverStream)
clientStream := jsonrpc2.NewBufferedStream(&TestStream{incoming: client, outgoing: server, closed: false}, jsonrpc2.VSCodeObjectCodec{})
defer clientStream.Close()
conn := jsonrpc2.NewConn(context.Background(), clientStream, &ConfigurationHandler{t: t})
initialize(t, conn, protocol.InitializeParams{})
homedir, err := os.UserHomeDir()
require.NoError(t, err)
testCases := []struct {
name string
content string
result []uint32
}{
{
name: "target {}",
content: "target {}",
result: []uint32{0, 0, 6, hcl.SemanticTokenTypeIndex(hcl.TokenType_Type), 0},
},
{
name: "single line comment after content with no newlines after it",
content: "variable \"port\" {default = true} # hello",
result: []uint32{
0, 0, 8, hcl.SemanticTokenTypeIndex(hcl.TokenType_Type), 0,
0, 9, 6, hcl.SemanticTokenTypeIndex(hcl.TokenType_Class), 0,
0, 8, 7, hcl.SemanticTokenTypeIndex(hcl.TokenType_Property), 0,
0, 10, 4, hcl.SemanticTokenTypeIndex(hcl.TokenType_Keyword), 0,
0, 6, 7, hcl.SemanticTokenTypeIndex(hcl.TokenType_Comment), 0,
},
},
{
name: "single line comment after content followed by LF",
content: "variable \"port\" {default = true} # hello\n",
result: []uint32{
0, 0, 8, hcl.SemanticTokenTypeIndex(hcl.TokenType_Type), 0,
0, 9, 6, hcl.SemanticTokenTypeIndex(hcl.TokenType_Class), 0,
0, 8, 7, hcl.SemanticTokenTypeIndex(hcl.TokenType_Property), 0,
0, 10, 4, hcl.SemanticTokenTypeIndex(hcl.TokenType_Keyword), 0,
0, 6, 7, hcl.SemanticTokenTypeIndex(hcl.TokenType_Comment), 0,
},
},
{
name: "single line comment after content followed by CRLF",
content: "variable \"port\" {default = true} # hello\r\n",
result: []uint32{
0, 0, 8, hcl.SemanticTokenTypeIndex(hcl.TokenType_Type), 0,
0, 9, 6, hcl.SemanticTokenTypeIndex(hcl.TokenType_Class), 0,
0, 8, 7, hcl.SemanticTokenTypeIndex(hcl.TokenType_Property), 0,
0, 10, 4, hcl.SemanticTokenTypeIndex(hcl.TokenType_Keyword), 0,
0, 6, 7, hcl.SemanticTokenTypeIndex(hcl.TokenType_Comment), 0,
},
},
}
for _, tc := range testCases {
t.Run(tc.name, func(t *testing.T) {
didOpen := createDidOpenTextDocumentParams(homedir, t.Name()+".hcl", tc.content, "dockerbake")
err := conn.Notify(context.Background(), protocol.MethodTextDocumentDidOpen, didOpen)
require.NoError(t, err)
var result protocol.SemanticTokens
var unset protocol.SemanticTokens
err = conn.Call(context.Background(), protocol.MethodTextDocumentSemanticTokensFull, protocol.SemanticTokensParams{
TextDocument: protocol.TextDocumentIdentifier{URI: didOpen.TextDocument.URI},
}, &result)
require.NoError(t, err)
require.Equal(t, unset.ResultID, result.ResultID)
require.Equal(t, tc.result, result.Data)
})
}
}