forked from TrueCloudLab/neoneo-go
transaction: move and adapt test from dev
Slightly increases coverage for transaction package.
This commit is contained in:
parent
d6686350ee
commit
aa94ae70b6
1 changed files with 12 additions and 20 deletions
|
@ -5,8 +5,6 @@ import (
|
|||
"encoding/hex"
|
||||
"testing"
|
||||
|
||||
"github.com/CityOfZion/neo-go/pkg/wire/payload/transaction/types"
|
||||
|
||||
"github.com/stretchr/testify/assert"
|
||||
)
|
||||
|
||||
|
@ -14,32 +12,26 @@ func TestEncodeDecodeContract(t *testing.T) {
|
|||
|
||||
// mainnet transaction: bdf6cc3b9af12a7565bda80933a75ee8cef1bc771d0d58effc08e4c8b436da79
|
||||
rawtx := "80000001888da99f8f497fd65c4325786a09511159c279af4e7eb532e9edd628c87cc1ee0000019b7cffdaa674beae0f930ebe6085af9093e5fe56b34a5c220ccdcf6efc336fc50082167010000000a8666b4830229d6a1a9b80f6088059191c122d2b0141409e79e132290c82916a88f1a3db5cf9f3248b780cfece938ab0f0812d0e188f3a489c7d1a23def86bd69d863ae67de753b2c2392e9497eadc8eb9fc43aa52c645232103e2f6a334e05002624cf616f01a62cff2844c34a3b08ca16048c259097e315078ac"
|
||||
rawtxBytes, _ := hex.DecodeString(rawtx)
|
||||
c := NewContract(30)
|
||||
tx := decodeTransaction(rawtx, t)
|
||||
|
||||
r := bytes.NewReader(rawtxBytes)
|
||||
err := c.Decode(r)
|
||||
assert.Equal(t, nil, err)
|
||||
assert.Equal(t, ContractType, tx.Type)
|
||||
assert.IsType(t, tx.Data, &ContractTX{})
|
||||
assert.Equal(t, 0, int(tx.Version))
|
||||
assert.Equal(t, 1, int(len(tx.Inputs)))
|
||||
|
||||
assert.Equal(t, types.Contract, c.Type)
|
||||
assert.Equal(t, 0, int(c.Version))
|
||||
assert.Equal(t, 1, int(len(c.Inputs)))
|
||||
|
||||
input := c.Inputs[0]
|
||||
input := tx.Inputs[0]
|
||||
|
||||
assert.Equal(t, "eec17cc828d6ede932b57e4eaf79c2591151096a7825435cd67f498f9fa98d88", input.PrevHash.ReverseString())
|
||||
assert.Equal(t, 0, int(input.PrevIndex))
|
||||
assert.Equal(t, int64(70600000000), c.Outputs[0].Amount)
|
||||
assert.Equal(t, "c56f33fc6ecfcd0c225c4ab356fee59390af8560be0e930faebe74a6daff7c9b", c.Outputs[0].AssetID.ReverseString())
|
||||
assert.Equal(t, "a8666b4830229d6a1a9b80f6088059191c122d2b", c.Outputs[0].ScriptHash.String())
|
||||
assert.Equal(t, "bdf6cc3b9af12a7565bda80933a75ee8cef1bc771d0d58effc08e4c8b436da79", c.Hash.ReverseString())
|
||||
assert.Equal(t, int64(706), tx.Outputs[0].Amount.Int64Value())
|
||||
assert.Equal(t, "c56f33fc6ecfcd0c225c4ab356fee59390af8560be0e930faebe74a6daff7c9b", tx.Outputs[0].AssetID.ReverseString())
|
||||
assert.Equal(t, "a8666b4830229d6a1a9b80f6088059191c122d2b", tx.Outputs[0].ScriptHash.String())
|
||||
assert.Equal(t, "bdf6cc3b9af12a7565bda80933a75ee8cef1bc771d0d58effc08e4c8b436da79", tx.Hash().ReverseString())
|
||||
|
||||
// Encode
|
||||
buf := new(bytes.Buffer)
|
||||
|
||||
err = c.Encode(buf)
|
||||
err := tx.EncodeBinary(buf)
|
||||
assert.Equal(t, nil, err)
|
||||
|
||||
assert.Equal(t, rawtxBytes, buf.Bytes())
|
||||
|
||||
assert.Equal(t, rawtx, hex.EncodeToString(buf.Bytes()))
|
||||
}
|
Loading…
Reference in a new issue