92 lines
2.2 KiB
Go
92 lines
2.2 KiB
Go
|
// Copyright 2013 The Go Authors. All rights reserved.
|
||
|
// Use of this source code is governed by a BSD-style
|
||
|
// license that can be found in the LICENSE file.
|
||
|
|
||
|
package cipher_test
|
||
|
|
||
|
import (
|
||
|
"bytes"
|
||
|
"crypto/cipher"
|
||
|
"crypto/des"
|
||
|
"testing"
|
||
|
|
||
|
"github.com/stacktic/cryptodev/aes"
|
||
|
)
|
||
|
|
||
|
func TestCryptBlocks(t *testing.T) {
|
||
|
buf := make([]byte, 16)
|
||
|
block, _ := aes.NewCipher(buf)
|
||
|
|
||
|
mode := cipher.NewCBCDecrypter(block, buf)
|
||
|
mustPanic(t, "crypto/cipher: input not full blocks", func() { mode.CryptBlocks(buf, buf[:3]) })
|
||
|
mustPanic(t, "crypto/cipher: output smaller than input", func() { mode.CryptBlocks(buf[:3], buf) })
|
||
|
|
||
|
mode = cipher.NewCBCEncrypter(block, buf)
|
||
|
mustPanic(t, "crypto/cipher: input not full blocks", func() { mode.CryptBlocks(buf, buf[:3]) })
|
||
|
mustPanic(t, "crypto/cipher: output smaller than input", func() { mode.CryptBlocks(buf[:3], buf) })
|
||
|
}
|
||
|
|
||
|
func mustPanic(t *testing.T, msg string, f func()) {
|
||
|
defer func() {
|
||
|
err := recover()
|
||
|
if err == nil {
|
||
|
t.Errorf("function did not panic, wanted %q", msg)
|
||
|
} else if err != msg {
|
||
|
t.Errorf("got panic %v, wanted %q", err, msg)
|
||
|
}
|
||
|
}()
|
||
|
f()
|
||
|
}
|
||
|
|
||
|
func TestEmptyPlaintext(t *testing.T) {
|
||
|
var key [16]byte
|
||
|
a, err := aes.NewCipher(key[:16])
|
||
|
if err != nil {
|
||
|
t.Fatal(err)
|
||
|
}
|
||
|
d, err := des.NewCipher(key[:8])
|
||
|
if err != nil {
|
||
|
t.Fatal(err)
|
||
|
}
|
||
|
|
||
|
s := 16
|
||
|
pt := make([]byte, s)
|
||
|
ct := make([]byte, s)
|
||
|
for i := 0; i < 16; i++ {
|
||
|
pt[i], ct[i] = byte(i), byte(i)
|
||
|
}
|
||
|
|
||
|
assertEqual := func(name string, got, want []byte) {
|
||
|
if !bytes.Equal(got, want) {
|
||
|
t.Fatalf("%s: got %v, want %v", name, got, want)
|
||
|
}
|
||
|
}
|
||
|
|
||
|
for _, b := range []cipher.Block{a, d} {
|
||
|
iv := make([]byte, b.BlockSize())
|
||
|
cbce := cipher.NewCBCEncrypter(b, iv)
|
||
|
cbce.CryptBlocks(ct, pt[:0])
|
||
|
assertEqual("CBC encrypt", ct, pt)
|
||
|
|
||
|
cbcd := cipher.NewCBCDecrypter(b, iv)
|
||
|
cbcd.CryptBlocks(ct, pt[:0])
|
||
|
assertEqual("CBC decrypt", ct, pt)
|
||
|
|
||
|
cfbe := cipher.NewCFBEncrypter(b, iv)
|
||
|
cfbe.XORKeyStream(ct, pt[:0])
|
||
|
assertEqual("CFB encrypt", ct, pt)
|
||
|
|
||
|
cfbd := cipher.NewCFBDecrypter(b, iv)
|
||
|
cfbd.XORKeyStream(ct, pt[:0])
|
||
|
assertEqual("CFB decrypt", ct, pt)
|
||
|
|
||
|
ctr := cipher.NewCTR(b, iv)
|
||
|
ctr.XORKeyStream(ct, pt[:0])
|
||
|
assertEqual("CTR", ct, pt)
|
||
|
|
||
|
ofb := cipher.NewOFB(b, iv)
|
||
|
ofb.XORKeyStream(ct, pt[:0])
|
||
|
assertEqual("OFB", ct, pt)
|
||
|
}
|
||
|
}
|