// 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/aes" "crypto/cipher" "crypto/des" "testing" ) 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) } }