Merge pull request #383 from nspcc-dev/fix_blockchain_test

unitTests: fix for failing test
This commit is contained in:
Roman Khimov 2019-09-10 23:53:50 +03:00 committed by GitHub
commit 9193ec45de
No known key found for this signature in database
GPG key ID: 4AEE18F83AFDEB23
2 changed files with 10 additions and 46 deletions

View file

@ -20,10 +20,10 @@ ProtocolConfiguration:
ApplicationConfiguration: ApplicationConfiguration:
DBConfiguration: DBConfiguration:
Type: "leveldb" #other options: 'inmemory','redis'. Type: "inmemory" #other options: 'inmemory','redis'.
# DB type options. Uncomment those you need in case you want to switch DB type. # DB type options. Uncomment those you need in case you want to switch DB type.
LevelDBOptions: # LevelDBOptions:
DataDirectoryPath: "./chains/unit_testnet" # DataDirectoryPath: "./chains/unit_testnet"
# RedisDBOptions: # RedisDBOptions:
# Addr: "localhost:6379" # Addr: "localhost:6379"
# Password: "" # Password: ""

View file

@ -6,7 +6,6 @@ import (
"github.com/CityOfZion/neo-go/config" "github.com/CityOfZion/neo-go/config"
"github.com/CityOfZion/neo-go/pkg/core/storage" "github.com/CityOfZion/neo-go/pkg/core/storage"
"github.com/CityOfZion/neo-go/pkg/core/transaction"
"github.com/CityOfZion/neo-go/pkg/util" "github.com/CityOfZion/neo-go/pkg/util"
"github.com/stretchr/testify/assert" "github.com/stretchr/testify/assert"
"github.com/stretchr/testify/require" "github.com/stretchr/testify/require"
@ -130,7 +129,7 @@ func TestHasBlock(t *testing.T) {
} }
func TestGetTransaction(t *testing.T) { func TestGetTransaction(t *testing.T) {
block := getDecodedBlock(t, 1) block := getDecodedBlock(t, 2)
bc := newTestChain(t) bc := newTestChain(t)
assert.Nil(t, bc.AddBlock(block)) assert.Nil(t, bc.AddBlock(block))
@ -142,10 +141,15 @@ func TestGetTransaction(t *testing.T) {
} }
assert.Equal(t, block.Index, height) assert.Equal(t, block.Index, height)
assert.Equal(t, block.Transactions[0], tx) assert.Equal(t, block.Transactions[0], tx)
assert.Equal(t, 10, tx.Size())
assert.Equal(t, 1, util.GetVarSize(tx.Attributes))
assert.Equal(t, 1, util.GetVarSize(tx.Inputs))
assert.Equal(t, 1, util.GetVarSize(tx.Outputs))
assert.Equal(t, 1, util.GetVarSize(tx.Scripts))
} }
func newTestChain(t *testing.T) *Blockchain { func newTestChain(t *testing.T) *Blockchain {
cfg, err := config.Load("../../config", config.ModePrivNet) cfg, err := config.Load("../../config", config.ModeUnitTestNet)
if err != nil { if err != nil {
t.Fatal(err) t.Fatal(err)
} }
@ -155,43 +159,3 @@ func newTestChain(t *testing.T) *Blockchain {
} }
return chain return chain
} }
func TestSize(t *testing.T) {
txID := "f999c36145a41306c846ea80290416143e8e856559818065be3f4e143c60e43a"
tx := getTestTransaction(txID, t)
assert.Equal(t, 283, tx.Size())
assert.Equal(t, 22, util.GetVarSize(tx.Attributes))
assert.Equal(t, 35, util.GetVarSize(tx.Inputs))
assert.Equal(t, 121, util.GetVarSize(tx.Outputs))
assert.Equal(t, 103, util.GetVarSize(tx.Scripts))
}
func getTestBlockchain(t *testing.T) *Blockchain {
net := config.ModeUnitTestNet
configPath := "../../config"
cfg, err := config.Load(configPath, net)
require.NoError(t, err, "could not create levelDB chain")
// adjust datadirectory to point to the correct folder
cfg.ApplicationConfiguration.DBConfiguration.LevelDBOptions.DataDirectoryPath = "../rpc/chains/unit_testnet"
store, err := storage.NewLevelDBStore(context.Background(),
cfg.ApplicationConfiguration.DBConfiguration.LevelDBOptions)
assert.Nil(t, err)
chain, err := NewBlockchain(context.Background(), store, cfg.ProtocolConfiguration)
require.NoErrorf(t, err, "could not create levelDB chain")
return chain
}
func getTestTransaction(txID string, t *testing.T) *transaction.Transaction {
chain := getTestBlockchain(t)
txHash, err := util.Uint256DecodeReverseString(txID)
require.NoErrorf(t, err, "could not decode string %s to Uint256", txID)
tx, _, err := chain.GetTransaction(txHash)
require.NoErrorf(t, err, "could not get transaction with hash=%s", txHash)
return tx
}