github.com/lbryio/lbcd@v0.22.119/blockchain/difficulty_test.go (about)

     1  // Copyright (c) 2014-2017 The btcsuite developers
     2  // Use of this source code is governed by an ISC
     3  // license that can be found in the LICENSE file.
     4  
     5  package blockchain
     6  
     7  import (
     8  	"math/big"
     9  	"testing"
    10  )
    11  
    12  // TestBigToCompact ensures BigToCompact converts big integers to the expected
    13  // compact representation.
    14  func TestBigToCompact(t *testing.T) {
    15  	tests := []struct {
    16  		in  int64
    17  		out uint32
    18  	}{
    19  		{0, 0},
    20  		{-1, 25231360},
    21  	}
    22  
    23  	for x, test := range tests {
    24  		n := big.NewInt(test.in)
    25  		r := BigToCompact(n)
    26  		if r != test.out {
    27  			t.Errorf("TestBigToCompact test #%d failed: got %d want %d\n",
    28  				x, r, test.out)
    29  			return
    30  		}
    31  	}
    32  }
    33  
    34  // TestCompactToBig ensures CompactToBig converts numbers using the compact
    35  // representation to the expected big intergers.
    36  func TestCompactToBig(t *testing.T) {
    37  	tests := []struct {
    38  		in  uint32
    39  		out int64
    40  	}{
    41  		{10000000, 0},
    42  	}
    43  
    44  	for x, test := range tests {
    45  		n := CompactToBig(test.in)
    46  		want := big.NewInt(test.out)
    47  		if n.Cmp(want) != 0 {
    48  			t.Errorf("TestCompactToBig test #%d failed: got %d want %d\n",
    49  				x, n.Int64(), want.Int64())
    50  			return
    51  		}
    52  	}
    53  }
    54  
    55  // TestCalcWork ensures CalcWork calculates the expected work value from values
    56  // in compact representation.
    57  func TestCalcWork(t *testing.T) {
    58  	tests := []struct {
    59  		in  uint32
    60  		out int64
    61  	}{
    62  		{10000000, 0},
    63  	}
    64  
    65  	for x, test := range tests {
    66  		bits := test.in
    67  
    68  		r := CalcWork(bits)
    69  		if r.Int64() != test.out {
    70  			t.Errorf("TestCalcWork test #%d failed: got %v want %d\n",
    71  				x, r.Int64(), test.out)
    72  			return
    73  		}
    74  	}
    75  }