forked from TrueCloudLab/neoneo-go
Merge pull request #660 from nspcc-dev/update-getblock-response-wrapper
[rpc] Fix wrong answer for getblock method
This commit is contained in:
commit
cac233383f
3 changed files with 99 additions and 40 deletions
|
@ -88,32 +88,9 @@ type StringResultResponse struct {
|
||||||
|
|
||||||
// GetBlockResponse struct for testing.
|
// GetBlockResponse struct for testing.
|
||||||
type GetBlockResponse struct {
|
type GetBlockResponse struct {
|
||||||
Jsonrpc string `json:"jsonrpc"`
|
Jsonrpc string `json:"jsonrpc"`
|
||||||
Result struct {
|
Result wrappers.Block `json:"result"`
|
||||||
Version int `json:"version"`
|
ID int `json:"id"`
|
||||||
Previousblockhash string `json:"previousblockhash"`
|
|
||||||
Merkleroot string `json:"merkleroot"`
|
|
||||||
Time int `json:"time"`
|
|
||||||
Height int `json:"height"`
|
|
||||||
Nonce int `json:"nonce"`
|
|
||||||
NextConsensus string `json:"next_consensus"`
|
|
||||||
Script struct {
|
|
||||||
Invocation string `json:"invocation"`
|
|
||||||
Verification string `json:"verification"`
|
|
||||||
} `json:"script"`
|
|
||||||
Tx []struct {
|
|
||||||
Type string `json:"type"`
|
|
||||||
Version int `json:"version"`
|
|
||||||
Attributes interface{} `json:"attributes"`
|
|
||||||
Vin interface{} `json:"vin"`
|
|
||||||
Vout interface{} `json:"vout"`
|
|
||||||
Scripts interface{} `json:"scripts"`
|
|
||||||
} `json:"tx"`
|
|
||||||
Confirmations int `json:"confirmations"`
|
|
||||||
Nextblockhash string `json:"nextblockhash"`
|
|
||||||
Hash string `json:"hash"`
|
|
||||||
} `json:"result"`
|
|
||||||
ID int `json:"id"`
|
|
||||||
}
|
}
|
||||||
|
|
||||||
// GetAssetResponse struct for testing.
|
// GetAssetResponse struct for testing.
|
||||||
|
|
|
@ -12,6 +12,7 @@ import (
|
||||||
"testing"
|
"testing"
|
||||||
|
|
||||||
"github.com/CityOfZion/neo-go/pkg/core"
|
"github.com/CityOfZion/neo-go/pkg/core"
|
||||||
|
"github.com/CityOfZion/neo-go/pkg/core/transaction"
|
||||||
"github.com/CityOfZion/neo-go/pkg/rpc/wrappers"
|
"github.com/CityOfZion/neo-go/pkg/rpc/wrappers"
|
||||||
"github.com/CityOfZion/neo-go/pkg/util"
|
"github.com/CityOfZion/neo-go/pkg/util"
|
||||||
"github.com/stretchr/testify/assert"
|
"github.com/stretchr/testify/assert"
|
||||||
|
@ -123,8 +124,16 @@ var rpcTestCases = map[string][]rpcTestCase{
|
||||||
block, err := e.chain.GetBlock(e.chain.GetHeaderHash(1))
|
block, err := e.chain.GetBlock(e.chain.GetHeaderHash(1))
|
||||||
require.NoErrorf(t, err, "could not get block")
|
require.NoErrorf(t, err, "could not get block")
|
||||||
|
|
||||||
expectedHash := "0x" + block.Hash().StringLE()
|
assert.Equal(t, block.Hash(), res.Result.Hash)
|
||||||
assert.Equal(t, expectedHash, res.Result.Hash)
|
for i := range res.Result.Tx {
|
||||||
|
tx := res.Result.Tx[i]
|
||||||
|
require.Equal(t, transaction.MinerType, tx.Type)
|
||||||
|
|
||||||
|
miner, ok := block.Transactions[i].Data.(*transaction.MinerTX)
|
||||||
|
require.True(t, ok)
|
||||||
|
require.Equal(t, miner.Nonce, tx.Nonce)
|
||||||
|
require.Equal(t, block.Transactions[i].Hash(), tx.TxID)
|
||||||
|
}
|
||||||
},
|
},
|
||||||
},
|
},
|
||||||
{
|
{
|
||||||
|
|
|
@ -1,34 +1,107 @@
|
||||||
package wrappers
|
package wrappers
|
||||||
|
|
||||||
import (
|
import (
|
||||||
|
"strconv"
|
||||||
|
|
||||||
"github.com/CityOfZion/neo-go/pkg/core"
|
"github.com/CityOfZion/neo-go/pkg/core"
|
||||||
"github.com/CityOfZion/neo-go/pkg/core/block"
|
"github.com/CityOfZion/neo-go/pkg/core/block"
|
||||||
|
"github.com/CityOfZion/neo-go/pkg/core/transaction"
|
||||||
|
"github.com/CityOfZion/neo-go/pkg/io"
|
||||||
"github.com/CityOfZion/neo-go/pkg/util"
|
"github.com/CityOfZion/neo-go/pkg/util"
|
||||||
)
|
)
|
||||||
|
|
||||||
type (
|
type (
|
||||||
|
// Tx wrapper used for the representation of
|
||||||
|
// transaction on the RPC Server.
|
||||||
|
Tx struct {
|
||||||
|
TxID util.Uint256 `json:"txid"`
|
||||||
|
Size int `json:"size"`
|
||||||
|
Type transaction.TXType `json:"type"`
|
||||||
|
Version uint8 `json:"version"`
|
||||||
|
Attributes []transaction.Attribute `json:"attributes"`
|
||||||
|
VIn []transaction.Input `json:"vin"`
|
||||||
|
VOut []transaction.Output `json:"vout"`
|
||||||
|
Scripts []transaction.Witness `json:"scripts"`
|
||||||
|
|
||||||
|
SysFee util.Fixed8 `json:"sys_fee"`
|
||||||
|
NetFee util.Fixed8 `json:"net_fee"`
|
||||||
|
|
||||||
|
Nonce uint32 `json:"nonce,omitempty"`
|
||||||
|
}
|
||||||
|
|
||||||
// Block wrapper used for the representation of
|
// Block wrapper used for the representation of
|
||||||
// block.Block / block.Base on the RPC Server.
|
// block.Block / block.Base on the RPC Server.
|
||||||
Block struct {
|
Block struct {
|
||||||
*block.Block
|
Hash util.Uint256 `json:"hash"`
|
||||||
Confirmations uint32 `json:"confirmations"`
|
Size int `json:"size"`
|
||||||
NextBlockHash util.Uint256 `json:"nextblockhash,omitempty"`
|
Version uint32 `json:"version"`
|
||||||
Hash util.Uint256 `json:"hash"`
|
NextBlockHash *util.Uint256 `json:"nextblockhash,omitempty"`
|
||||||
|
PreviousBlockHash util.Uint256 `json:"previousblockhash"`
|
||||||
|
MerkleRoot util.Uint256 `json:"merkleroot"`
|
||||||
|
Time uint32 `json:"time"`
|
||||||
|
Index uint32 `json:"index"`
|
||||||
|
Nonce string `json:"nonce"`
|
||||||
|
NextConsensus util.Uint160 `json:"nextconsensus"`
|
||||||
|
|
||||||
|
Confirmations uint32 `json:"confirmations"`
|
||||||
|
|
||||||
|
Script transaction.Witness `json:"script"`
|
||||||
|
|
||||||
|
Tx []Tx `json:"tx"`
|
||||||
}
|
}
|
||||||
)
|
)
|
||||||
|
|
||||||
// NewBlock creates a new Block wrapper.
|
// NewBlock creates a new Block wrapper.
|
||||||
func NewBlock(block *block.Block, chain core.Blockchainer) Block {
|
func NewBlock(b *block.Block, chain core.Blockchainer) Block {
|
||||||
blockWrapper := Block{
|
res := Block{
|
||||||
Block: block,
|
Version: b.Version,
|
||||||
Hash: block.Hash(),
|
Hash: b.Hash(),
|
||||||
|
Size: io.GetVarSize(b),
|
||||||
|
PreviousBlockHash: b.PrevHash,
|
||||||
|
MerkleRoot: b.MerkleRoot,
|
||||||
|
Time: b.Timestamp,
|
||||||
|
Index: b.Index,
|
||||||
|
Nonce: strconv.FormatUint(b.ConsensusData, 16),
|
||||||
|
NextConsensus: b.NextConsensus,
|
||||||
|
Confirmations: chain.BlockHeight() - b.Index - 1,
|
||||||
|
|
||||||
|
Script: b.Script,
|
||||||
|
|
||||||
|
Tx: make([]Tx, 0, len(b.Transactions)),
|
||||||
}
|
}
|
||||||
|
|
||||||
hash := chain.GetHeaderHash(int(block.Index) + 1)
|
hash := chain.GetHeaderHash(int(b.Index) + 1)
|
||||||
if !hash.Equals(util.Uint256{}) {
|
if !hash.Equals(util.Uint256{}) {
|
||||||
blockWrapper.NextBlockHash = hash
|
res.NextBlockHash = &hash
|
||||||
}
|
}
|
||||||
|
|
||||||
blockWrapper.Confirmations = chain.BlockHeight() - block.Index - 1
|
for i := range b.Transactions {
|
||||||
return blockWrapper
|
tx := Tx{
|
||||||
|
TxID: b.Transactions[i].Hash(),
|
||||||
|
Size: io.GetVarSize(b.Transactions[i]),
|
||||||
|
Type: b.Transactions[i].Type,
|
||||||
|
Version: b.Transactions[i].Version,
|
||||||
|
Attributes: make([]transaction.Attribute, 0, len(b.Transactions[i].Attributes)),
|
||||||
|
VIn: make([]transaction.Input, 0, len(b.Transactions[i].Inputs)),
|
||||||
|
VOut: make([]transaction.Output, 0, len(b.Transactions[i].Outputs)),
|
||||||
|
Scripts: make([]transaction.Witness, 0, len(b.Transactions[i].Scripts)),
|
||||||
|
}
|
||||||
|
|
||||||
|
copy(tx.Attributes, b.Transactions[i].Attributes)
|
||||||
|
copy(tx.VIn, b.Transactions[i].Inputs)
|
||||||
|
copy(tx.VOut, b.Transactions[i].Outputs)
|
||||||
|
copy(tx.Scripts, b.Transactions[i].Scripts)
|
||||||
|
|
||||||
|
tx.SysFee = chain.SystemFee(b.Transactions[i])
|
||||||
|
tx.NetFee = chain.NetworkFee(b.Transactions[i])
|
||||||
|
|
||||||
|
// set nonce only for MinerTransaction
|
||||||
|
if miner, ok := b.Transactions[i].Data.(*transaction.MinerTX); ok {
|
||||||
|
tx.Nonce = miner.Nonce
|
||||||
|
}
|
||||||
|
|
||||||
|
res.Tx = append(res.Tx, tx)
|
||||||
|
}
|
||||||
|
|
||||||
|
return res
|
||||||
}
|
}
|
||||||
|
|
Loading…
Reference in a new issue