mirror of
https://gitlab.com/pulsechaincom/prysm-pulse.git
synced 2025-01-19 00:04:12 +00:00
64f64f06bf
* removing flag requirement, can run web3signer without predefined public keys * placeholders for remote-keymanager-api * adding proto and accountschangedfeed * updating generated code * fix imports * fixing interface * adding work in progress apimiddleware code * started implementing functions for remote keymanager api * fixing generted code from proto * fixing protos * fixing import format * fixing proto generation again , didn't fix the first time * fixing imports again * continuing on implementing functions * implementing add function * implementing delete API function * handling errors for API * removing unusedcode and fixing format * fixing bazel * wip enable --web when running web3signer * fixing wallet check for web3signer * fixing apis * adding list remote keys unit test * import remote keys test * delete pubkeys tests * moving location of tests * adding unit tests * adding placeholder functions * adding more unit tests * fixing bazel * fixing build * fixing already slice issue with unit test * fixing linting * Update validator/client/validator.go Co-authored-by: Raul Jordan <raul@prysmaticlabs.com> * Update validator/keymanager/types.go Co-authored-by: Raul Jordan <raul@prysmaticlabs.com> * Update validator/node/node.go Co-authored-by: Raul Jordan <raul@prysmaticlabs.com> * Update validator/keymanager/types.go Co-authored-by: Raul Jordan <raul@prysmaticlabs.com> * Update validator/client/validator.go Co-authored-by: Raul Jordan <raul@prysmaticlabs.com> * adding comment on proto based on review * Update validator/keymanager/remote-web3signer/keymanager.go Co-authored-by: Radosław Kapka <rkapka@wp.pl> * Update validator/keymanager/remote-web3signer/keymanager.go Co-authored-by: Radosław Kapka <rkapka@wp.pl> * Update validator/rpc/standard_api.go Co-authored-by: Radosław Kapka <rkapka@wp.pl> * Update validator/rpc/standard_api.go Co-authored-by: Radosław Kapka <rkapka@wp.pl> * Update validator/rpc/standard_api.go Co-authored-by: Radosław Kapka <rkapka@wp.pl> * Update validator/rpc/standard_api.go Co-authored-by: Radosław Kapka <rkapka@wp.pl> * adding generated code based on review * updating based on feedback * fixing imports * fixing formatting * Update validator/rpc/standard_api.go Co-authored-by: Radosław Kapka <rkapka@wp.pl> * fixing event call * fixing dependency * updating bazel * Update validator/rpc/standard_api.go Co-authored-by: Radosław Kapka <rkapka@wp.pl> * Update validator/rpc/standard_api.go Co-authored-by: Radosław Kapka <rkapka@wp.pl> * Update validator/rpc/standard_api.go Co-authored-by: Radosław Kapka <rkapka@wp.pl> * Update validator/rpc/standard_api.go Co-authored-by: Radosław Kapka <rkapka@wp.pl> * addressing comment from review Co-authored-by: Raul Jordan <raul@prysmaticlabs.com> Co-authored-by: Radosław Kapka <rkapka@wp.pl>
272 lines
7.3 KiB
Go
272 lines
7.3 KiB
Go
package apimiddleware
|
|
|
|
import (
|
|
"encoding/json"
|
|
"fmt"
|
|
"testing"
|
|
|
|
fieldparams "github.com/prysmaticlabs/prysm/config/fieldparams"
|
|
"github.com/prysmaticlabs/prysm/proto/eth/service"
|
|
"github.com/prysmaticlabs/prysm/testing/require"
|
|
)
|
|
|
|
func TestListKeystores_JSONisEqual(t *testing.T) {
|
|
middlewareResponse := &listKeystoresResponseJson{
|
|
Keystores: []*keystoreJson{
|
|
&keystoreJson{
|
|
ValidatingPubkey: "0x0",
|
|
DerivationPath: "m/44'/60'/0'/0/0",
|
|
},
|
|
},
|
|
}
|
|
|
|
protoResponse := &service.ListKeystoresResponse{
|
|
Data: []*service.ListKeystoresResponse_Keystore{
|
|
&service.ListKeystoresResponse_Keystore{
|
|
ValidatingPubkey: make([]byte, fieldparams.BLSPubkeyLength),
|
|
DerivationPath: "m/44'/60'/0'/0/0",
|
|
},
|
|
},
|
|
}
|
|
|
|
listResp, err := areJsonPropertyNamesEqual(middlewareResponse, protoResponse)
|
|
require.NoError(t, err)
|
|
require.Equal(t, listResp, true)
|
|
|
|
resp, err := areJsonPropertyNamesEqual(middlewareResponse.Keystores[0], protoResponse.Data[0])
|
|
require.NoError(t, err)
|
|
require.Equal(t, resp, true)
|
|
}
|
|
|
|
func TestImportKeystores_JSONisEqual(t *testing.T) {
|
|
importKeystoresRequest := &importKeystoresRequestJson{}
|
|
|
|
protoImportRequest := &service.ImportKeystoresRequest{
|
|
Keystores: []string{""},
|
|
Passwords: []string{""},
|
|
SlashingProtection: "a",
|
|
}
|
|
|
|
requestResp, err := areJsonPropertyNamesEqual(importKeystoresRequest, protoImportRequest)
|
|
require.NoError(t, err)
|
|
require.Equal(t, requestResp, true)
|
|
|
|
importKeystoresResponse := &importKeystoresResponseJson{
|
|
Statuses: []*statusJson{
|
|
&statusJson{
|
|
Status: "Error",
|
|
Message: "a",
|
|
},
|
|
},
|
|
}
|
|
|
|
protoImportKeystoresResponse := &service.ImportKeystoresResponse{
|
|
Data: []*service.ImportedKeystoreStatus{
|
|
&service.ImportedKeystoreStatus{
|
|
Status: service.ImportedKeystoreStatus_ERROR,
|
|
Message: "a",
|
|
},
|
|
},
|
|
}
|
|
|
|
ImportResp, err := areJsonPropertyNamesEqual(importKeystoresResponse, protoImportKeystoresResponse)
|
|
require.NoError(t, err)
|
|
require.Equal(t, ImportResp, true)
|
|
|
|
resp, err := areJsonPropertyNamesEqual(importKeystoresResponse.Statuses[0], protoImportKeystoresResponse.Data[0])
|
|
require.NoError(t, err)
|
|
require.Equal(t, resp, true)
|
|
}
|
|
|
|
func TestDeleteKeystores_JSONisEqual(t *testing.T) {
|
|
deleteKeystoresRequest := &deleteKeystoresRequestJson{}
|
|
|
|
protoDeleteRequest := &service.DeleteKeystoresRequest{
|
|
Pubkeys: [][]byte{[]byte{}},
|
|
}
|
|
|
|
requestResp, err := areJsonPropertyNamesEqual(deleteKeystoresRequest, protoDeleteRequest)
|
|
require.NoError(t, err)
|
|
require.Equal(t, requestResp, true)
|
|
|
|
deleteKeystoresResponse := &deleteKeystoresResponseJson{
|
|
Statuses: []*statusJson{
|
|
&statusJson{
|
|
Status: "Error",
|
|
Message: "a",
|
|
},
|
|
},
|
|
SlashingProtection: "a",
|
|
}
|
|
protoDeleteResponse := &service.DeleteKeystoresResponse{
|
|
Data: []*service.DeletedKeystoreStatus{
|
|
&service.DeletedKeystoreStatus{
|
|
Status: service.DeletedKeystoreStatus_ERROR,
|
|
Message: "a",
|
|
},
|
|
},
|
|
SlashingProtection: "a",
|
|
}
|
|
|
|
deleteResp, err := areJsonPropertyNamesEqual(deleteKeystoresResponse, protoDeleteResponse)
|
|
require.NoError(t, err)
|
|
require.Equal(t, deleteResp, true)
|
|
|
|
resp, err := areJsonPropertyNamesEqual(deleteKeystoresResponse.Statuses[0], protoDeleteResponse.Data[0])
|
|
require.NoError(t, err)
|
|
require.Equal(t, resp, true)
|
|
|
|
}
|
|
|
|
func TestListRemoteKeys_JSONisEqual(t *testing.T) {
|
|
middlewareResponse := &listRemoteKeysResponseJson{
|
|
Keystores: []*remoteKeysListJson{
|
|
&remoteKeysListJson{
|
|
Pubkey: "0x0",
|
|
Url: "http://localhost:8080",
|
|
Readonly: true,
|
|
},
|
|
},
|
|
}
|
|
|
|
protoResponse := &service.ListRemoteKeysResponse{
|
|
Data: []*service.ListRemoteKeysResponse_Keystore{
|
|
&service.ListRemoteKeysResponse_Keystore{
|
|
Pubkey: make([]byte, fieldparams.BLSPubkeyLength),
|
|
Url: "http://localhost:8080",
|
|
Readonly: true,
|
|
},
|
|
},
|
|
}
|
|
|
|
listResp, err := areJsonPropertyNamesEqual(middlewareResponse, protoResponse)
|
|
require.NoError(t, err)
|
|
require.Equal(t, listResp, true)
|
|
|
|
resp, err := areJsonPropertyNamesEqual(middlewareResponse.Keystores[0], protoResponse.Data[0])
|
|
require.NoError(t, err)
|
|
require.Equal(t, resp, true)
|
|
}
|
|
|
|
func TestImportRemoteKeys_JSONisEqual(t *testing.T) {
|
|
importKeystoresRequest := &importRemoteKeysRequestJson{}
|
|
|
|
protoImportRequest := &service.ImportRemoteKeysRequest{
|
|
RemoteKeys: []*service.ImportRemoteKeysRequest_Keystore{
|
|
&service.ImportRemoteKeysRequest_Keystore{
|
|
Pubkey: make([]byte, fieldparams.BLSPubkeyLength),
|
|
Url: "http://localhost:8080",
|
|
},
|
|
},
|
|
}
|
|
|
|
requestResp, err := areJsonPropertyNamesEqual(importKeystoresRequest, protoImportRequest)
|
|
require.NoError(t, err)
|
|
require.Equal(t, requestResp, true)
|
|
|
|
importKeystoresResponse := &importRemoteKeysResponseJson{
|
|
Statuses: []*statusJson{
|
|
&statusJson{
|
|
Status: "Error",
|
|
Message: "a",
|
|
},
|
|
},
|
|
}
|
|
|
|
protoImportKeystoresResponse := &service.ImportRemoteKeysResponse{
|
|
Data: []*service.ImportedRemoteKeysStatus{
|
|
&service.ImportedRemoteKeysStatus{
|
|
Status: service.ImportedRemoteKeysStatus_ERROR,
|
|
Message: "a",
|
|
},
|
|
},
|
|
}
|
|
|
|
ImportResp, err := areJsonPropertyNamesEqual(importKeystoresResponse, protoImportKeystoresResponse)
|
|
require.NoError(t, err)
|
|
require.Equal(t, ImportResp, true)
|
|
|
|
resp, err := areJsonPropertyNamesEqual(importKeystoresResponse.Statuses[0], protoImportKeystoresResponse.Data[0])
|
|
require.NoError(t, err)
|
|
require.Equal(t, resp, true)
|
|
}
|
|
|
|
func TestDeleteRemoteKeys_JSONisEqual(t *testing.T) {
|
|
deleteKeystoresRequest := &deleteRemoteKeysRequestJson{}
|
|
|
|
protoDeleteRequest := &service.DeleteRemoteKeysRequest{
|
|
Pubkeys: [][]byte{[]byte{}},
|
|
}
|
|
|
|
requestResp, err := areJsonPropertyNamesEqual(deleteKeystoresRequest, protoDeleteRequest)
|
|
require.NoError(t, err)
|
|
require.Equal(t, requestResp, true)
|
|
|
|
deleteKeystoresResponse := &deleteRemoteKeysResponseJson{
|
|
Statuses: []*statusJson{
|
|
&statusJson{
|
|
Status: "Error",
|
|
Message: "a",
|
|
},
|
|
},
|
|
}
|
|
protoDeleteResponse := &service.DeleteRemoteKeysResponse{
|
|
Data: []*service.DeletedRemoteKeysStatus{
|
|
&service.DeletedRemoteKeysStatus{
|
|
Status: service.DeletedRemoteKeysStatus_ERROR,
|
|
Message: "a",
|
|
},
|
|
},
|
|
}
|
|
|
|
deleteResp, err := areJsonPropertyNamesEqual(deleteKeystoresResponse, protoDeleteResponse)
|
|
require.NoError(t, err)
|
|
require.Equal(t, deleteResp, true)
|
|
|
|
resp, err := areJsonPropertyNamesEqual(deleteKeystoresResponse.Statuses[0], protoDeleteResponse.Data[0])
|
|
require.NoError(t, err)
|
|
require.Equal(t, resp, true)
|
|
}
|
|
|
|
// note: this does not do a deep comparison of the structs
|
|
func areJsonPropertyNamesEqual(internal, proto interface{}) (bool, error) {
|
|
internalJSON, err := json.Marshal(internal)
|
|
if err != nil {
|
|
return false, err
|
|
}
|
|
protoJSON, err := json.Marshal(proto)
|
|
if err != nil {
|
|
return false, err
|
|
}
|
|
|
|
var internalRaw map[string]json.RawMessage
|
|
err = json.Unmarshal(internalJSON, &internalRaw)
|
|
if err != nil {
|
|
return false, err
|
|
}
|
|
|
|
var protoRaw map[string]json.RawMessage
|
|
err = json.Unmarshal(protoJSON, &protoRaw)
|
|
if err != nil {
|
|
return false, err
|
|
}
|
|
|
|
internalKeys := make([]string, 0, len(internalRaw))
|
|
protoKeys := make([]string, 0, len(protoRaw))
|
|
for key := range internalRaw {
|
|
internalKeys = append(internalKeys, key)
|
|
if _, ok := protoRaw[key]; !ok {
|
|
fmt.Printf("key: %s not found\n", key)
|
|
fmt.Printf("proto: %v\n", protoRaw)
|
|
return false, nil
|
|
} else {
|
|
protoKeys = append(protoKeys, key)
|
|
fmt.Printf("key: %s\n", key)
|
|
}
|
|
}
|
|
if len(internalKeys) != len(protoKeys) {
|
|
return false, nil
|
|
}
|
|
return true, nil
|
|
}
|