-
Notifications
You must be signed in to change notification settings - Fork 1
/
Copy pathcompletion_test.go
119 lines (110 loc) · 4.1 KB
/
completion_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
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
package server_test
import (
"bytes"
"context"
"os"
"testing"
"github.com/docker/docker-language-server/internal/tliron/glsp/protocol"
"github.com/docker/docker-language-server/internal/types"
"github.com/sourcegraph/jsonrpc2"
"github.com/stretchr/testify/require"
)
func TestCompletion(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
line uint32
character uint32
items []protocol.CompletionItem
}{
{
name: "empty file",
content: "",
line: 0,
character: 0,
items: []protocol.CompletionItem{
{
Detail: types.CreateStringPointer("Block"),
Kind: types.CreateCompletionItemKindPointer(protocol.CompletionItemKindClass),
Label: "function",
InsertTextFormat: types.CreateInsertTextFormatPointer(protocol.InsertTextFormatSnippet),
TextEdit: protocol.TextEdit{
Range: protocol.Range{
Start: protocol.Position{Line: 0, Character: 0},
End: protocol.Position{Line: 0, Character: 0},
},
NewText: "function \"${1:functionName}\" {\n ${2}\n}",
},
},
{
Detail: types.CreateStringPointer("Block"),
Kind: types.CreateCompletionItemKindPointer(protocol.CompletionItemKindClass),
Label: "group",
InsertTextFormat: types.CreateInsertTextFormatPointer(protocol.InsertTextFormatSnippet),
TextEdit: protocol.TextEdit{
Range: protocol.Range{
Start: protocol.Position{Line: 0, Character: 0},
End: protocol.Position{Line: 0, Character: 0},
},
NewText: "group \"${1:groupName}\" {\n ${2}\n}",
},
},
{
Detail: types.CreateStringPointer("Block"),
Kind: types.CreateCompletionItemKindPointer(protocol.CompletionItemKindClass),
Label: "target",
InsertTextFormat: types.CreateInsertTextFormatPointer(protocol.InsertTextFormatSnippet),
TextEdit: protocol.TextEdit{
Range: protocol.Range{
Start: protocol.Position{Line: 0, Character: 0},
End: protocol.Position{Line: 0, Character: 0},
},
NewText: "target \"${1:targetName}\" {\n ${2}\n}",
},
},
{
Detail: types.CreateStringPointer("Block"),
Kind: types.CreateCompletionItemKindPointer(protocol.CompletionItemKindClass),
Label: "variable",
InsertTextFormat: types.CreateInsertTextFormatPointer(protocol.InsertTextFormatSnippet),
TextEdit: protocol.TextEdit{
Range: protocol.Range{
Start: protocol.Position{Line: 0, Character: 0},
End: protocol.Position{Line: 0, Character: 0},
},
NewText: "variable \"${1:variableName}\" {\n ${2}\n}",
},
},
},
},
}
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.CompletionList
err = conn.Call(context.Background(), protocol.MethodTextDocumentCompletion, protocol.CompletionParams{
TextDocumentPositionParams: protocol.TextDocumentPositionParams{
TextDocument: protocol.TextDocumentIdentifier{URI: didOpen.TextDocument.URI},
Position: protocol.Position{Line: 0, Character: 0},
},
}, &result)
require.NoError(t, err)
require.False(t, result.IsIncomplete)
require.Equal(t, tc.items, result.Items)
})
}
}