libgocryptfs/internal/cryptocore/cryptocore_test.go

33 lines
618 B
Go
Raw Normal View History

2016-05-04 19:51:58 +02:00
package cryptocore
import (
"testing"
)
2016-09-20 21:58:04 +02:00
// "New" should accept at least these param combinations
2016-05-04 19:51:58 +02:00
func TestCryptoCoreNew(t *testing.T) {
key := make([]byte, 32)
2016-09-20 21:58:04 +02:00
c := New(key, BackendOpenSSL, 128)
2016-05-04 19:51:58 +02:00
if c.IVLen != 16 {
t.Fail()
}
2016-09-20 21:58:04 +02:00
c = New(key, BackendGoGCM, 96)
2016-05-04 19:51:58 +02:00
if c.IVLen != 12 {
t.Fail()
}
// "New(key, BackendGoGCM, 128)" is tested for Go 1.4 and 1.5+ separately
2016-05-04 19:51:58 +02:00
}
// "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)
2016-09-20 21:58:04 +02:00
New(key, BackendOpenSSL, 128)
2016-05-04 19:51:58 +02:00
}