mirror of
https://github.com/nspcc-dev/neo-go.git
synced 2025-01-18 03:57:34 +00:00
Merge pull request #3696 from nspcc-dev/basic-chain-tests
basicchain: use UnitTestNet default config for generation
This commit is contained in:
commit
6d1eea307b
8 changed files with 36 additions and 14 deletions
|
@ -30,3 +30,8 @@ var MainNetNeoFS []byte
|
|||
//
|
||||
//go:embed protocol.testnet.neofs.yml
|
||||
var TestNetNeoFS []byte
|
||||
|
||||
// UnitTestNet is the unit test network configuration.
|
||||
//
|
||||
//go:embed protocol.unit_testnet.yml
|
||||
var UnitTestNet []byte
|
||||
|
|
|
@ -18,7 +18,10 @@ ProtocolConfiguration:
|
|||
VerifyTransactions: true
|
||||
P2PSigExtensions: true
|
||||
Hardforks:
|
||||
Aspidochelone: 25
|
||||
Aspidochelone: 3
|
||||
Basilisk: 6
|
||||
Cockatrice: 9
|
||||
Domovoi: 12
|
||||
|
||||
ApplicationConfiguration:
|
||||
SkipBlockVerification: false
|
||||
|
|
|
@ -137,6 +137,8 @@ func getEmbeddedConfig(configPath string) ([]byte, error) {
|
|||
return config.MainNetNeoFS, nil
|
||||
case fmt.Sprintf("%s/protocol.%s.yml", DefaultConfigPath, netmode.TestNetNeoFS):
|
||||
return config.TestNetNeoFS, nil
|
||||
case fmt.Sprintf("%s/protocol.%s.yml", DefaultConfigPath, netmode.UnitTestNet):
|
||||
return config.UnitTestNet, nil
|
||||
default:
|
||||
return nil, fmt.Errorf("config '%s' doesn't exist and no matching embedded config was found", configPath)
|
||||
}
|
||||
|
|
|
@ -139,6 +139,9 @@ func TestNativeContract_InvokeInternal(t *testing.T) {
|
|||
mdDeploy := manState.Manifest.ABI.GetMethod("deploy", 2)
|
||||
require.NotNil(t, mdDeploy)
|
||||
t.Run("fail, bad call flag", func(t *testing.T) {
|
||||
bc, _, _ := chain.NewMultiWithCustomConfig(t, func(c *config.Blockchain) {
|
||||
c.Hardforks = nil
|
||||
})
|
||||
ic, err := bc.GetTestVM(trigger.Application, nil, nil)
|
||||
require.NoError(t, err)
|
||||
v := ic.SpawnVM()
|
||||
|
|
|
@ -401,6 +401,17 @@ func TestNEO_RecursiveGASMint(t *testing.T) {
|
|||
func TestNEO_GetCommitteeAddress(t *testing.T) {
|
||||
neoValidatorInvoker := newNeoValidatorsClient(t)
|
||||
e := neoValidatorInvoker.Executor
|
||||
cfg := neoValidatorInvoker.Chain.GetConfig()
|
||||
|
||||
maxHardforkHeight := uint32(0)
|
||||
for _, height := range cfg.Hardforks {
|
||||
if height > maxHardforkHeight {
|
||||
maxHardforkHeight = height
|
||||
}
|
||||
}
|
||||
for range maxHardforkHeight {
|
||||
neoValidatorInvoker.AddNewBlock(t)
|
||||
}
|
||||
standByCommitteePublicKeys, err := keys.NewPublicKeysFromStrings(e.Chain.GetConfig().StandbyCommittee)
|
||||
require.NoError(t, err)
|
||||
slices.SortFunc(standByCommitteePublicKeys, (*keys.PublicKey).Cmp)
|
||||
|
|
|
@ -258,18 +258,13 @@ func NewMultiWithOptionsNoCheck(t testing.TB, options *Options) (*core.Blockchai
|
|||
options = &Options{}
|
||||
}
|
||||
|
||||
cfg := config.Blockchain{
|
||||
ProtocolConfiguration: config.ProtocolConfiguration{
|
||||
Magic: netmode.UnitTestNet,
|
||||
MaxTraceableBlocks: MaxTraceableBlocks,
|
||||
TimePerBlock: TimePerBlock,
|
||||
StandbyCommittee: standByCommittee,
|
||||
ValidatorsCount: 4,
|
||||
VerifyTransactions: true,
|
||||
},
|
||||
cfg, err := config.Load(config.DefaultConfigPath, netmode.UnitTestNet)
|
||||
if err != nil {
|
||||
return nil, nil, nil, err
|
||||
}
|
||||
bcfg := cfg.Blockchain()
|
||||
if options.BlockchainConfigHook != nil {
|
||||
options.BlockchainConfigHook(&cfg)
|
||||
options.BlockchainConfigHook(&bcfg)
|
||||
}
|
||||
|
||||
store := options.Store
|
||||
|
@ -282,7 +277,7 @@ func NewMultiWithOptionsNoCheck(t testing.TB, options *Options) (*core.Blockchai
|
|||
logger = zaptest.NewLogger(t)
|
||||
}
|
||||
|
||||
bc, err := core.NewBlockchain(store, cfg, logger)
|
||||
bc, err := core.NewBlockchain(store, bcfg, logger)
|
||||
if err == nil && !options.SkipRun {
|
||||
go bc.Run()
|
||||
t.Cleanup(bc.Close)
|
||||
|
|
|
@ -2457,7 +2457,10 @@ func TestClient_GetVersion_Hardforks(t *testing.T) {
|
|||
v, err := c.GetVersion()
|
||||
require.NoError(t, err)
|
||||
expected := map[config.Hardfork]uint32{
|
||||
config.HFAspidochelone: 25,
|
||||
config.HFAspidochelone: 3,
|
||||
config.HFBasilisk: 6,
|
||||
config.HFCockatrice: 9,
|
||||
config.HFDomovoi: 12,
|
||||
}
|
||||
require.InDeltaMapValues(t, expected, v.Protocol.Hardforks, 0)
|
||||
}
|
||||
|
|
|
@ -121,7 +121,7 @@ const (
|
|||
// not yet deployed to the testing basic chain.
|
||||
invokescriptContractAVM = "VwIADBQBDAMOBQYMDQIODw0DDgcJAAAAAErZMCQE2zBwaEH4J+yMqiYEEUAMFA0PAwIJAAIBAwcDBAUCAQAOBgwJStkwJATbMHFpQfgn7IyqJgQSQBNA"
|
||||
// block20StateRootLE is an LE stateroot of block #20 of basic testing chain.
|
||||
block20StateRootLE = "394e20adf99a6ba160df7351770dfb193ee8af174b7b3ed45f4e2ae8c43694e8"
|
||||
block20StateRootLE = "570ba0814003f6e6a2a2e41d1b727f8af756e9c26d2453c8316868607b66da0a"
|
||||
)
|
||||
|
||||
var (
|
||||
|
|
Loading…
Reference in a new issue