neoneo-go/pkg/consensus/block_test.go

48 lines
1.3 KiB
Go
Raw Normal View History

2019-11-15 10:32:40 +00:00
package consensus
import (
"testing"
"github.com/nspcc-dev/dbft"
"github.com/nspcc-dev/neo-go/pkg/core/transaction"
"github.com/nspcc-dev/neo-go/pkg/crypto/keys"
"github.com/nspcc-dev/neo-go/pkg/util"
2020-06-05 09:28:36 +00:00
"github.com/nspcc-dev/neo-go/pkg/vm/opcode"
2019-11-15 10:32:40 +00:00
"github.com/stretchr/testify/require"
)
func TestNeoBlock_Sign(t *testing.T) {
b := new(neoBlock)
priv, _ := keys.NewPrivateKey()
2019-11-15 10:32:40 +00:00
require.NoError(t, b.Sign(&privateKey{PrivateKey: priv}))
require.NoError(t, b.Verify(&publicKey{PublicKey: priv.PublicKey()}, b.Signature()))
2019-11-15 10:32:40 +00:00
}
func TestNeoBlock_Setters(t *testing.T) {
b := new(neoBlock)
b.Block.Version = 1
2019-11-15 10:32:40 +00:00
require.EqualValues(t, 1, b.Version())
b.Block.Index = 12
2019-11-15 10:32:40 +00:00
require.EqualValues(t, 12, b.Index())
b.Block.Timestamp = 777
// 777ms -> 777000000ns
require.EqualValues(t, 777000000, b.Timestamp())
b.Block.MerkleRoot = util.Uint256{1, 2, 3, 4}
2019-11-15 10:32:40 +00:00
require.Equal(t, util.Uint256{1, 2, 3, 4}, b.MerkleRoot())
b.Block.NextConsensus = util.Uint160{9, 2}
2019-11-15 10:32:40 +00:00
require.Equal(t, util.Uint160{9, 2}, b.NextConsensus())
b.Block.PrevHash = util.Uint256{9, 8, 7}
2019-11-15 10:32:40 +00:00
require.Equal(t, util.Uint256{9, 8, 7}, b.PrevHash())
txx := []dbft.Transaction[util.Uint256]{transaction.New([]byte{byte(opcode.PUSH1)}, 1)}
2019-11-15 10:32:40 +00:00
b.SetTransactions(txx)
require.Equal(t, txx, b.Transactions())
}