rpc: remove 'exported or builtin' restriction for parameters (#20332)
* rpc: remove 'exported or builtin' restriction for parameters There is no technial reason for this restriction because package reflect can create values of any type. Requiring parameters and return values to be exported causes a lot of noise in package exports. * rpc: fix staticcheck warnings
This commit is contained in:
committed by
Péter Szilágyi
parent
9c6cf960b4
commit
8008c5b1fa
@ -40,11 +40,11 @@ func TestClientRequest(t *testing.T) {
|
||||
client := DialInProc(server)
|
||||
defer client.Close()
|
||||
|
||||
var resp Result
|
||||
if err := client.Call(&resp, "test_echo", "hello", 10, &Args{"world"}); err != nil {
|
||||
var resp echoResult
|
||||
if err := client.Call(&resp, "test_echo", "hello", 10, &echoArgs{"world"}); err != nil {
|
||||
t.Fatal(err)
|
||||
}
|
||||
if !reflect.DeepEqual(resp, Result{"hello", 10, &Args{"world"}}) {
|
||||
if !reflect.DeepEqual(resp, echoResult{"hello", 10, &echoArgs{"world"}}) {
|
||||
t.Errorf("incorrect result %#v", resp)
|
||||
}
|
||||
}
|
||||
@ -58,13 +58,13 @@ func TestClientBatchRequest(t *testing.T) {
|
||||
batch := []BatchElem{
|
||||
{
|
||||
Method: "test_echo",
|
||||
Args: []interface{}{"hello", 10, &Args{"world"}},
|
||||
Result: new(Result),
|
||||
Args: []interface{}{"hello", 10, &echoArgs{"world"}},
|
||||
Result: new(echoResult),
|
||||
},
|
||||
{
|
||||
Method: "test_echo",
|
||||
Args: []interface{}{"hello2", 11, &Args{"world"}},
|
||||
Result: new(Result),
|
||||
Args: []interface{}{"hello2", 11, &echoArgs{"world"}},
|
||||
Result: new(echoResult),
|
||||
},
|
||||
{
|
||||
Method: "no_such_method",
|
||||
@ -78,13 +78,13 @@ func TestClientBatchRequest(t *testing.T) {
|
||||
wantResult := []BatchElem{
|
||||
{
|
||||
Method: "test_echo",
|
||||
Args: []interface{}{"hello", 10, &Args{"world"}},
|
||||
Result: &Result{"hello", 10, &Args{"world"}},
|
||||
Args: []interface{}{"hello", 10, &echoArgs{"world"}},
|
||||
Result: &echoResult{"hello", 10, &echoArgs{"world"}},
|
||||
},
|
||||
{
|
||||
Method: "test_echo",
|
||||
Args: []interface{}{"hello2", 11, &Args{"world"}},
|
||||
Result: &Result{"hello2", 11, &Args{"world"}},
|
||||
Args: []interface{}{"hello2", 11, &echoArgs{"world"}},
|
||||
Result: &echoResult{"hello2", 11, &echoArgs{"world"}},
|
||||
},
|
||||
{
|
||||
Method: "no_such_method",
|
||||
@ -104,7 +104,7 @@ func TestClientNotify(t *testing.T) {
|
||||
client := DialInProc(server)
|
||||
defer client.Close()
|
||||
|
||||
if err := client.Notify(context.Background(), "test_echo", "hello", 10, &Args{"world"}); err != nil {
|
||||
if err := client.Notify(context.Background(), "test_echo", "hello", 10, &echoArgs{"world"}); err != nil {
|
||||
t.Fatal(err)
|
||||
}
|
||||
}
|
||||
@ -393,9 +393,9 @@ func TestClientHTTP(t *testing.T) {
|
||||
|
||||
// Launch concurrent requests.
|
||||
var (
|
||||
results = make([]Result, 100)
|
||||
results = make([]echoResult, 100)
|
||||
errc = make(chan error)
|
||||
wantResult = Result{"a", 1, new(Args)}
|
||||
wantResult = echoResult{"a", 1, new(echoArgs)}
|
||||
)
|
||||
defer client.Close()
|
||||
for i := range results {
|
||||
@ -450,7 +450,7 @@ func TestClientReconnect(t *testing.T) {
|
||||
}
|
||||
|
||||
// Perform a call. This should work because the server is up.
|
||||
var resp Result
|
||||
var resp echoResult
|
||||
if err := client.CallContext(ctx, &resp, "test_echo", "", 1, nil); err != nil {
|
||||
t.Fatal(err)
|
||||
}
|
||||
@ -478,7 +478,7 @@ func TestClientReconnect(t *testing.T) {
|
||||
for i := 0; i < cap(errors); i++ {
|
||||
go func() {
|
||||
<-start
|
||||
var resp Result
|
||||
var resp echoResult
|
||||
errors <- client.CallContext(ctx, &resp, "test_echo", "", 3, nil)
|
||||
}()
|
||||
}
|
||||
|
Reference in New Issue
Block a user