File: block_test.go

package info (click to toggle)
golang-github-miscreant-miscreant.go 0.0~git20200214.26d3763-3
  • links: PTS, VCS
  • area: main
  • in suites: bookworm, bullseye, bullseye-backports, forky, sid, trixie
  • size: 216 kB
  • sloc: makefile: 3
file content (72 lines) | stat: -rw-r--r-- 1,495 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
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
package block

import (
	"bytes"
	"encoding/hex"
	"encoding/json"
	"io/ioutil"
	"testing"
)

type dblExample struct {
	input  []byte
	output []byte
}

// Load dbl test vectors from dbl.tjson
// TODO: switch to a native Go TJSON parser when available
func loadDblExamples() []dblExample {
	var examplesJSON map[string]interface{}

	exampleData, err := ioutil.ReadFile("../vectors/dbl.tjson")
	if err != nil {
		panic(err)
	}

	if err = json.Unmarshal(exampleData, &examplesJSON); err != nil {
		panic(err)
	}

	examplesArray := examplesJSON["examples:A<O>"].([]interface{})

	if examplesArray == nil {
		panic("no toplevel 'examples:A<O>' key in dbl.tjson")
	}

	result := make([]dblExample, len(examplesArray))

	for i, exampleJSON := range examplesArray {
		example := exampleJSON.(map[string]interface{})

		inputHex := example["input:d16"].(string)
		input := make([]byte, hex.DecodedLen(len(inputHex)))

		if _, err := hex.Decode(input, []byte(inputHex)); err != nil {
			panic(err)
		}

		outputHex := example["output:d16"].(string)
		output := make([]byte, hex.DecodedLen(len(outputHex)))

		if _, err := hex.Decode(output, []byte(outputHex)); err != nil {
			panic(err)
		}

		result[i] = dblExample{input, output}
	}

	return result
}

func TestDbl(t *testing.T) {
	for i, tt := range loadDblExamples() {
		var b Block
		copy(b[:], tt.input)
		b.Dbl()

		if !bytes.Equal(b[:], tt.output) {
			t.Errorf("test %d: dbl mismatch\n\twant %x\n\thave %x", i, tt.output, b)
			continue
		}
	}
}