File: assert.go

package info (click to toggle)
addchain 0.4.0-2
  • links: PTS, VCS
  • area: main
  • in suites: forky, sid
  • size: 1,396 kB
  • sloc: sh: 428; makefile: 8
file content (52 lines) | stat: -rw-r--r-- 1,222 bytes parent folder | download
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
package algtest

import (
	"math/big"
	"reflect"
	"testing"

	"github.com/mmcloughlin/addchain"
	"github.com/mmcloughlin/addchain/alg"
)

// AssertChainAlgorithmGenerates asserts that the algorithm generates the expected chain for n.
func AssertChainAlgorithmGenerates(t *testing.T, a alg.ChainAlgorithm, n *big.Int, expect addchain.Chain) {
	c, err := a.FindChain(n)
	if err != nil {
		t.Fatal(err)
	}
	if err := c.Validate(); err != nil {
		t.Error(err)
	}
	if !reflect.DeepEqual(expect, c) {
		t.Fatalf("got %v; expect %v", c, expect)
	}
}

// AssertChainAlgorithmProduces verifies that a returns a valid chain for n.
func AssertChainAlgorithmProduces(t *testing.T, a alg.ChainAlgorithm, n *big.Int) addchain.Chain {
	c, err := a.FindChain(n)
	if err != nil {
		t.Fatal(err)
	}
	err = c.Produces(n)
	if err != nil {
		t.Log(c)
		t.Fatal(err)
	}
	return c
}

// AssertSequenceAlgorithmProduces verifies that a returns a valid chain containing targets.
func AssertSequenceAlgorithmProduces(t *testing.T, a alg.SequenceAlgorithm, targets []*big.Int) addchain.Chain {
	c, err := a.FindSequence(targets)
	if err != nil {
		t.Fatal(err)
	}
	err = c.Superset(targets)
	if err != nil {
		t.Log(c)
		t.Fatal(err)
	}
	return c
}