mirror of
https://github.com/golang/go
synced 2024-11-05 17:46:16 -07:00
6224300ba8
We should just use the protocol.SignatureInformation type, as it's essentially the same thing. Refactor tests a bit to make use of the shared type. Change-Id: I169949f6e23757ce0a6f54de36560c4c8e0479ad Reviewed-on: https://go-review.googlesource.com/c/tools/+/217731 Run-TryBot: Rebecca Stambler <rstambler@golang.org> TryBot-Result: Gobot Gobot <gobot@golang.org> Reviewed-by: Robert Findley <rfindley@google.com>
34 lines
933 B
Go
34 lines
933 B
Go
// Copyright 2019 The Go Authors. All rights reserved.
|
|
// Use of this source code is governed by a BSD-style
|
|
// license that can be found in the LICENSE file.
|
|
|
|
package cmdtest
|
|
|
|
import (
|
|
"fmt"
|
|
"testing"
|
|
|
|
"golang.org/x/tools/internal/lsp/protocol"
|
|
"golang.org/x/tools/internal/span"
|
|
)
|
|
|
|
func (r *runner) SignatureHelp(t *testing.T, spn span.Span, want *protocol.SignatureHelp) {
|
|
uri := spn.URI()
|
|
filename := uri.Filename()
|
|
target := filename + fmt.Sprintf(":%v:%v", spn.Start().Line(), spn.Start().Column())
|
|
got, _ := r.NormalizeGoplsCmd(t, "signature", target)
|
|
if want == nil {
|
|
if got != "" {
|
|
t.Fatalf("want nil, but got %s", got)
|
|
}
|
|
return
|
|
}
|
|
goldenTag := want.Signatures[0].Label + "-signature"
|
|
expect := string(r.data.Golden(goldenTag, filename, func() ([]byte, error) {
|
|
return []byte(got), nil
|
|
}))
|
|
if expect != got {
|
|
t.Errorf("signature failed for %s expected:\n%q\ngot:\n%q'", filename, expect, got)
|
|
}
|
|
}
|