forked from TrueCloudLab/neoneo-go
Merge pull request #2866 from nspcc-dev/findstates-ret-nothing
Fix findstates response difference
This commit is contained in:
commit
4e23695441
2 changed files with 20 additions and 7 deletions
|
@ -1538,8 +1538,8 @@ func (s *Server) findStates(ps params.Params) (interface{}, *neorpc.Error) {
|
||||||
}
|
}
|
||||||
pKey := makeStorageKey(cs.ID, prefix)
|
pKey := makeStorageKey(cs.ID, prefix)
|
||||||
kvs, err := s.chain.GetStateModule().FindStates(root, pKey, key, count+1) // +1 to define result truncation
|
kvs, err := s.chain.GetStateModule().FindStates(root, pKey, key, count+1) // +1 to define result truncation
|
||||||
if err != nil {
|
if err != nil && !errors.Is(err, mpt.ErrNotFound) {
|
||||||
return nil, neorpc.NewInternalServerError(fmt.Sprintf("failed to find historical items: %s", err))
|
return nil, neorpc.NewInternalServerError(fmt.Sprintf("failed to find state items: %s", err))
|
||||||
}
|
}
|
||||||
res := result.FindStates{}
|
res := result.FindStates{}
|
||||||
if len(kvs) == count+1 {
|
if len(kvs) == count+1 {
|
||||||
|
|
|
@ -472,22 +472,22 @@ var rpcTestCases = map[string][]rpcTestCase{
|
||||||
},
|
},
|
||||||
{
|
{
|
||||||
name: "invalid contract",
|
name: "invalid contract",
|
||||||
params: `["0000000000000000000000000000000000000000000000000000000000000000", "0xabcdef"]`,
|
params: `["` + block20StateRootLE + `", "0xabcdef"]`,
|
||||||
fail: true,
|
fail: true,
|
||||||
},
|
},
|
||||||
{
|
{
|
||||||
name: "invalid prefix",
|
name: "invalid prefix",
|
||||||
params: `["0000000000000000000000000000000000000000000000000000000000000000", "` + testContractHash + `", "notabase64%"]`,
|
params: `["` + block20StateRootLE + `", "` + testContractHash + `", "notabase64%"]`,
|
||||||
fail: true,
|
fail: true,
|
||||||
},
|
},
|
||||||
{
|
{
|
||||||
name: "invalid key",
|
name: "invalid key",
|
||||||
params: `["0000000000000000000000000000000000000000000000000000000000000000", "` + testContractHash + `", "QQ==", "notabase64%"]`,
|
params: `["` + block20StateRootLE + `", "` + testContractHash + `", "QQ==", "notabase64%"]`,
|
||||||
fail: true,
|
fail: true,
|
||||||
},
|
},
|
||||||
{
|
{
|
||||||
name: "unknown contract/large count",
|
name: "unknown contract/large count",
|
||||||
params: `["0000000000000000000000000000000000000000000000000000000000000000", "0000000000000000000000000000000000000000", "QQ==", "QQ==", 101]`,
|
params: `["` + block20StateRootLE + `", "0000000000000000000000000000000000000000", "QQ==", "QQ==", 101]`,
|
||||||
fail: true,
|
fail: true,
|
||||||
},
|
},
|
||||||
},
|
},
|
||||||
|
@ -2123,7 +2123,9 @@ func testRPCProtocol(t *testing.T, doRPCCall func(string, string, *testing.T) []
|
||||||
require.NoError(t, json.Unmarshal(rawRes, vp))
|
require.NoError(t, json.Unmarshal(rawRes, vp))
|
||||||
require.Equal(t, value, vp.Value)
|
require.Equal(t, value, vp.Value)
|
||||||
}
|
}
|
||||||
checkProof(t, actual.FirstProof, actual.Results[0].Value)
|
if len(actual.Results) > 0 {
|
||||||
|
checkProof(t, actual.FirstProof, actual.Results[0].Value)
|
||||||
|
}
|
||||||
if len(actual.Results) > 1 {
|
if len(actual.Results) > 1 {
|
||||||
checkProof(t, actual.LastProof, actual.Results[len(actual.Results)-1].Value)
|
checkProof(t, actual.LastProof, actual.Results[len(actual.Results)-1].Value)
|
||||||
}
|
}
|
||||||
|
@ -2157,6 +2159,17 @@ func testRPCProtocol(t *testing.T, doRPCCall func(string, string, *testing.T) []
|
||||||
Truncated: false,
|
Truncated: false,
|
||||||
})
|
})
|
||||||
})
|
})
|
||||||
|
t.Run("good: empty prefix, no limit, no data", func(t *testing.T) {
|
||||||
|
// empty prefix should be considered as no prefix specified.
|
||||||
|
root, err := e.chain.GetStateModule().GetStateRoot(20)
|
||||||
|
require.NoError(t, err)
|
||||||
|
stdHash, _ := e.chain.GetNativeContractScriptHash(nativenames.StdLib) // It has no data.
|
||||||
|
params := fmt.Sprintf(`"%s", "%s", ""`, root.Root.StringLE(), stdHash.StringLE())
|
||||||
|
testFindStates(t, params, root.Root, result.FindStates{
|
||||||
|
Results: []result.KeyValue{},
|
||||||
|
Truncated: false,
|
||||||
|
})
|
||||||
|
})
|
||||||
t.Run("good: with prefix, no limit", func(t *testing.T) {
|
t.Run("good: with prefix, no limit", func(t *testing.T) {
|
||||||
// pairs for this test where put to the contract storage at block #16
|
// pairs for this test where put to the contract storage at block #16
|
||||||
root, err := e.chain.GetStateModule().GetStateRoot(16)
|
root, err := e.chain.GetStateModule().GetStateRoot(16)
|
||||||
|
|
Loading…
Reference in a new issue