dcrd/dcrjson/parse_test.go
Dave Collins e2232a5c3d
dcrjson: Remove unused vote bit concat codec funcs.
These functions and associated tests are being removed because nothing
depends on them and they end up creating a dependency on
blockchain/stake package, which is not desirable.
2018-08-05 16:24:56 -05:00

82 lines
2.6 KiB
Go

// Copyright (c) 2016 The Decred developers
// Use of this source code is governed by an ISC
// license that can be found in the LICENSE file.
package dcrjson
import (
"encoding/hex"
"strings"
"testing"
"github.com/decred/dcrd/chaincfg/chainhash"
)
func decodeHash(reversedHash string) chainhash.Hash {
h, err := chainhash.NewHashFromStr(reversedHash)
if err != nil {
panic(err)
}
return *h
}
func TestEncodeConcatenatedHashes(t *testing.T) {
// Input Hash slice. Data taken from Decred's first three mainnet blocks.
hashSlice := []chainhash.Hash{
decodeHash("298e5cc3d985bfe7f81dc135f360abe089edd4396b86d2de66b0cef42b21d980"),
decodeHash("000000000000437482b6d47f82f374cde539440ddb108b0a76886f0d87d126b9"),
decodeHash("000000000000c41019872ff7db8fd2e9bfa05f42d3f8fee8e895e8c1e5b8dcba"),
}
hashLen := hex.EncodedLen(len(hashSlice[0]))
// Expected output. The string representations of the underlying byte arrays
// in the input []chainhash.Hash
blockHashes := []string{
"80d9212bf4ceb066ded2866b39d4ed89e0ab60f335c11df8e7bf85d9c35c8e29",
"b926d1870d6f88760a8b10db0d4439e5cd74f3827fd4b6827443000000000000",
"badcb8e5c1e895e8e8fef8d3425fa0bfe9d28fdbf72f871910c4000000000000",
}
concatenatedHashes := strings.Join(blockHashes, "")
// Test from 0 to N of the hashes
for j := 0; j < len(hashSlice)+1; j++ {
// Expected output string
concatRef := concatenatedHashes[:j*hashLen]
// Encode to string
concatenated := EncodeConcatenatedHashes(hashSlice[:j])
// Verify output
if concatenated != concatRef {
t.Fatalf("EncodeConcatenatedHashes failed (%v!=%v)",
concatenated, concatRef)
}
}
}
func TestDecodeConcatenatedHashes(t *testing.T) {
// Test data taken from Decred's first three mainnet blocks
testHashes := []chainhash.Hash{
decodeHash("298e5cc3d985bfe7f81dc135f360abe089edd4396b86d2de66b0cef42b21d980"),
decodeHash("000000000000437482b6d47f82f374cde539440ddb108b0a76886f0d87d126b9"),
decodeHash("000000000000c41019872ff7db8fd2e9bfa05f42d3f8fee8e895e8c1e5b8dcba"),
}
var concatenatedHashBytes []byte
for _, h := range testHashes {
concatenatedHashBytes = append(concatenatedHashBytes, h[:]...)
}
concatenatedHashes := hex.EncodeToString(concatenatedHashBytes)
decodedHashes, err := DecodeConcatenatedHashes(concatenatedHashes)
if err != nil {
t.Fatalf("Decode failed: %v", err)
}
if len(testHashes) != len(decodedHashes) {
t.Fatalf("Got wrong number of decoded hashes (%v)", len(decodedHashes))
}
for i, expected := range testHashes {
if expected != decodedHashes[i] {
t.Fatalf("Decoded hash %d `%v` does not match expected `%v`",
i, decodedHashes[i], expected)
}
}
}