aboutsummaryrefslogtreecommitdiff
path: root/internal/cryptocore/cryptocore_test.go
blob: d37e9413c8d8658aefc5f3b4ddd5970ce240a339 (plain)
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
package cryptocore

import (
	"testing"

	"github.com/rfjakob/gocryptfs/v2/internal/stupidgcm"
)

// "New" should accept at least these param combinations
func TestCryptoCoreNew(t *testing.T) {
	key := make([]byte, 32)
	for _, useHKDF := range []bool{true, false} {
		c := New(key, BackendGoGCM, 96, useHKDF)
		if c.IVLen != 12 {
			t.Fail()
		}
		c = New(key, BackendGoGCM, 128, useHKDF)
		if c.IVLen != 16 {
			t.Fail()
		}
		if stupidgcm.BuiltWithoutOpenssl {
			continue
		}
		c = New(key, BackendOpenSSL, 128, useHKDF)
		if c.IVLen != 16 {
			t.Fail()
		}
	}
}

// "New" should panic on any key not 32 bytes long
func TestNewPanic(t *testing.T) {
	defer func() {
		if r := recover(); r == nil {
			t.Errorf("The code did not panic")
		}
	}()

	key := make([]byte, 16)
	New(key, BackendOpenSSL, 128, true)
}