forked from TrueCloudLab/frostfs-contract
[#135] frostfsid: Add migration tests
Signed-off-by: Alexander Chuprov <a.chuprov@yadro.com>
This commit is contained in:
parent
c102a44c56
commit
8b32e7c2e7
7 changed files with 107 additions and 0 deletions
2
.gitignore
vendored
2
.gitignore
vendored
|
@ -2,6 +2,8 @@
|
||||||
*.nef
|
*.nef
|
||||||
*.manifest.json
|
*.manifest.json
|
||||||
config.json
|
config.json
|
||||||
|
!tests/testdata/**/*.nef
|
||||||
|
!tests/testdata/**/config.json
|
||||||
/vendor/
|
/vendor/
|
||||||
.idea
|
.idea
|
||||||
/bin/
|
/bin/
|
||||||
|
|
|
@ -2,6 +2,7 @@ package tests
|
||||||
|
|
||||||
import (
|
import (
|
||||||
"errors"
|
"errors"
|
||||||
|
"fmt"
|
||||||
"path"
|
"path"
|
||||||
"testing"
|
"testing"
|
||||||
|
|
||||||
|
@ -649,6 +650,52 @@ func TestAdditionalKeyFromPrimarySubject(t *testing.T) {
|
||||||
invoker.Invoke(t, stackitem.Null{}, addSubjectKeyMethod, subjAKeyAddr, subjDPrimaryKey.PublicKey().Bytes())
|
invoker.Invoke(t, stackitem.Null{}, addSubjectKeyMethod, subjAKeyAddr, subjDPrimaryKey.PublicKey().Bytes())
|
||||||
}
|
}
|
||||||
|
|
||||||
|
const frostfsidContractName = "frostfsid"
|
||||||
|
|
||||||
|
func TestFrostfsid_Migration(t *testing.T) {
|
||||||
|
e := newExecutor(t)
|
||||||
|
|
||||||
|
acc, err := wallet.NewAccount()
|
||||||
|
require.NoError(t, err)
|
||||||
|
|
||||||
|
args := make([]any, 5)
|
||||||
|
args[0] = acc.ScriptHash()
|
||||||
|
|
||||||
|
c := loadCompiledContract(t, e.CommitteeHash, fmt.Sprintf(contractPathFormat, v0_19_2, frostfsidContractName, frostfsidContractName),
|
||||||
|
fmt.Sprintf(manifestPathFormat, v0_19_2, frostfsidContractName))
|
||||||
|
e.DeployContract(t, c, args)
|
||||||
|
updateContract(t, c, e, c.Hash, args)
|
||||||
|
|
||||||
|
inv := testFrostFSIDInvoker{
|
||||||
|
e: e,
|
||||||
|
contractHash: c.Hash,
|
||||||
|
owner: acc,
|
||||||
|
}
|
||||||
|
newSigner(t, e.CommitteeInvoker(c.Hash), acc)
|
||||||
|
require.NoError(t, err)
|
||||||
|
invoker := inv.OwnerInvoker()
|
||||||
|
|
||||||
|
subjAPrimaryKey, err := keys.NewPrivateKey()
|
||||||
|
require.NoError(t, err)
|
||||||
|
|
||||||
|
subjBPrimaryKey, err := keys.NewPrivateKey()
|
||||||
|
require.NoError(t, err)
|
||||||
|
subjBKeyAddr := subjBPrimaryKey.PublicKey().GetScriptHash()
|
||||||
|
|
||||||
|
invoker.Invoke(t, stackitem.Null{}, createSubjectMethod, defaultNamespace, subjAPrimaryKey.PublicKey().Bytes())
|
||||||
|
|
||||||
|
invoker.Invoke(t, stackitem.Null{}, createSubjectMethod, defaultNamespace, subjBPrimaryKey.PublicKey().Bytes())
|
||||||
|
|
||||||
|
invoker.Invoke(t, stackitem.Null{}, addSubjectKeyMethod, subjBKeyAddr, subjAPrimaryKey.PublicKey().Bytes())
|
||||||
|
|
||||||
|
c1 := loadCompiledContract(t, e.CommitteeHash, fmt.Sprintf(contractPathFormat, v0_21_1, frostfsidContractName, frostfsidContractName),
|
||||||
|
fmt.Sprintf(manifestPathFormat, v0_21_1, frostfsidContractName))
|
||||||
|
updateContractFail(t, c1, e, c.Hash, args, "frostfsid contract contains duplicate keys")
|
||||||
|
invoker.Invoke(t, stackitem.Null{}, deleteSubjectMethod, subjBKeyAddr)
|
||||||
|
updateContract(t, c1, e, c.Hash, args)
|
||||||
|
updateContract(t, c1, e, c.Hash, args)
|
||||||
|
}
|
||||||
|
|
||||||
func checkPublicKeyResult(t *testing.T, s *vm.Stack, err error, key *keys.PrivateKey) {
|
func checkPublicKeyResult(t *testing.T, s *vm.Stack, err error, key *keys.PrivateKey) {
|
||||||
if key == nil {
|
if key == nil {
|
||||||
require.ErrorContains(t, err, "not found")
|
require.ErrorContains(t, err, "not found")
|
||||||
|
|
1
tests/testdata/migration/0.19.2/frostfsid/config.json
vendored
Executable file
1
tests/testdata/migration/0.19.2/frostfsid/config.json
vendored
Executable file
File diff suppressed because one or more lines are too long
BIN
tests/testdata/migration/0.19.2/frostfsid/frostfsid_contract.nef
vendored
Executable file
BIN
tests/testdata/migration/0.19.2/frostfsid/frostfsid_contract.nef
vendored
Executable file
Binary file not shown.
1
tests/testdata/migration/0.21.1/frostfsid/config.json
vendored
Executable file
1
tests/testdata/migration/0.21.1/frostfsid/config.json
vendored
Executable file
File diff suppressed because one or more lines are too long
BIN
tests/testdata/migration/0.21.1/frostfsid/frostfsid_contract.nef
vendored
Executable file
BIN
tests/testdata/migration/0.21.1/frostfsid/frostfsid_contract.nef
vendored
Executable file
Binary file not shown.
|
@ -7,6 +7,7 @@ import (
|
||||||
"testing"
|
"testing"
|
||||||
"time"
|
"time"
|
||||||
|
|
||||||
|
json "github.com/nspcc-dev/go-ordered-json"
|
||||||
"github.com/nspcc-dev/neo-go/pkg/config"
|
"github.com/nspcc-dev/neo-go/pkg/config"
|
||||||
"github.com/nspcc-dev/neo-go/pkg/consensus"
|
"github.com/nspcc-dev/neo-go/pkg/consensus"
|
||||||
"github.com/nspcc-dev/neo-go/pkg/core"
|
"github.com/nspcc-dev/neo-go/pkg/core"
|
||||||
|
@ -20,6 +21,8 @@ import (
|
||||||
"github.com/nspcc-dev/neo-go/pkg/rpcclient"
|
"github.com/nspcc-dev/neo-go/pkg/rpcclient"
|
||||||
"github.com/nspcc-dev/neo-go/pkg/services/rpcsrv"
|
"github.com/nspcc-dev/neo-go/pkg/services/rpcsrv"
|
||||||
"github.com/nspcc-dev/neo-go/pkg/services/stateroot"
|
"github.com/nspcc-dev/neo-go/pkg/services/stateroot"
|
||||||
|
"github.com/nspcc-dev/neo-go/pkg/smartcontract/manifest"
|
||||||
|
"github.com/nspcc-dev/neo-go/pkg/smartcontract/nef"
|
||||||
"github.com/nspcc-dev/neo-go/pkg/smartcontract/trigger"
|
"github.com/nspcc-dev/neo-go/pkg/smartcontract/trigger"
|
||||||
"github.com/nspcc-dev/neo-go/pkg/util"
|
"github.com/nspcc-dev/neo-go/pkg/util"
|
||||||
"github.com/nspcc-dev/neo-go/pkg/vm/stackitem"
|
"github.com/nspcc-dev/neo-go/pkg/vm/stackitem"
|
||||||
|
@ -226,3 +229,56 @@ func runRPC(ctx context.Context, t *testing.T, chain *core.Blockchain, walletPat
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
func loadCompiledContract(t testing.TB, sender util.Uint160, nefPath, manifestPath string) *neotest.Contract {
|
||||||
|
nefBytes, err := os.ReadFile(nefPath)
|
||||||
|
require.NoError(t, err)
|
||||||
|
|
||||||
|
f, err := nef.FileFromBytes(nefBytes)
|
||||||
|
require.NoError(t, err)
|
||||||
|
|
||||||
|
manifestBytes, err := os.ReadFile(manifestPath)
|
||||||
|
require.NoError(t, err)
|
||||||
|
|
||||||
|
m := new(manifest.Manifest)
|
||||||
|
err = json.Unmarshal(manifestBytes, m)
|
||||||
|
require.NoError(t, err)
|
||||||
|
|
||||||
|
hash := state.CreateContractHash(sender, f.Checksum, m.Name)
|
||||||
|
|
||||||
|
return &neotest.Contract{
|
||||||
|
Hash: hash,
|
||||||
|
NEF: &f,
|
||||||
|
Manifest: m,
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
const contractPathFormat = "testdata/migration/%s/%s/%s_contract.nef"
|
||||||
|
const manifestPathFormat = "testdata/migration/%s/%s/config.json"
|
||||||
|
|
||||||
|
const v0_19_2 = "0.19.2"
|
||||||
|
const v0_21_1 = "0.21.1"
|
||||||
|
|
||||||
|
func updateContract(t testing.TB, c *neotest.Contract, e *neotest.Executor, contractHash util.Uint160, data any) {
|
||||||
|
neb, err := c.NEF.Bytes()
|
||||||
|
require.NoError(t, err)
|
||||||
|
|
||||||
|
rawManifest, err := json.Marshal(c.Manifest)
|
||||||
|
require.NoError(t, err)
|
||||||
|
|
||||||
|
inv := e.NewInvoker(contractHash, e.Committee)
|
||||||
|
|
||||||
|
inv.Invoke(t, nil, "update", neb, rawManifest, data)
|
||||||
|
}
|
||||||
|
|
||||||
|
func updateContractFail(t testing.TB, c *neotest.Contract, e *neotest.Executor, contractHash util.Uint160, data any, faultException string) {
|
||||||
|
neb, err := c.NEF.Bytes()
|
||||||
|
require.NoError(t, err)
|
||||||
|
|
||||||
|
rawManifest, err := json.Marshal(c.Manifest)
|
||||||
|
require.NoError(t, err)
|
||||||
|
|
||||||
|
inv := e.NewInvoker(contractHash, e.Committee)
|
||||||
|
|
||||||
|
inv.InvokeFail(t, faultException, "update", neb, rawManifest, data)
|
||||||
|
}
|
||||||
|
|
Loading…
Reference in a new issue