|  | // Copyright 2010 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 cast5 | 
|  |  | 
|  | import ( | 
|  | "bytes" | 
|  | "encoding/hex" | 
|  | "testing" | 
|  | ) | 
|  |  | 
|  | // This test vector is taken from RFC 2144, App B.1. | 
|  | // Since the other two test vectors are for reduced-round variants, we can't | 
|  | // use them. | 
|  | var basicTests = []struct { | 
|  | key, plainText, cipherText string | 
|  | }{ | 
|  | { | 
|  | "0123456712345678234567893456789a", | 
|  | "0123456789abcdef", | 
|  | "238b4fe5847e44b2", | 
|  | }, | 
|  | } | 
|  |  | 
|  | func TestBasic(t *testing.T) { | 
|  | for i, test := range basicTests { | 
|  | key, _ := hex.DecodeString(test.key) | 
|  | plainText, _ := hex.DecodeString(test.plainText) | 
|  | expected, _ := hex.DecodeString(test.cipherText) | 
|  |  | 
|  | c, err := NewCipher(key) | 
|  | if err != nil { | 
|  | t.Errorf("#%d: failed to create Cipher: %s", i, err) | 
|  | continue | 
|  | } | 
|  | var cipherText [BlockSize]byte | 
|  | c.Encrypt(cipherText[:], plainText) | 
|  | if !bytes.Equal(cipherText[:], expected) { | 
|  | t.Errorf("#%d: got:%x want:%x", i, cipherText, expected) | 
|  | } | 
|  |  | 
|  | var plainTextAgain [BlockSize]byte | 
|  | c.Decrypt(plainTextAgain[:], cipherText[:]) | 
|  | if !bytes.Equal(plainTextAgain[:], plainText) { | 
|  | t.Errorf("#%d: got:%x want:%x", i, plainTextAgain, plainText) | 
|  | } | 
|  | } | 
|  | } | 
|  |  | 
|  | // TestFull performs the test specified in RFC 2144, App B.2. | 
|  | // However, due to the length of time taken, it's disabled here and a more | 
|  | // limited version is included, below. | 
|  | func TestFull(t *testing.T) { | 
|  | if testing.Short() { | 
|  | // This is too slow for normal testing | 
|  | return | 
|  | } | 
|  |  | 
|  | a, b := iterate(1000000) | 
|  |  | 
|  | const expectedA = "eea9d0a249fd3ba6b3436fb89d6dca92" | 
|  | const expectedB = "b2c95eb00c31ad7180ac05b8e83d696e" | 
|  |  | 
|  | if hex.EncodeToString(a) != expectedA { | 
|  | t.Errorf("a: got:%x want:%s", a, expectedA) | 
|  | } | 
|  | if hex.EncodeToString(b) != expectedB { | 
|  | t.Errorf("b: got:%x want:%s", b, expectedB) | 
|  | } | 
|  | } | 
|  |  | 
|  | func iterate(iterations int) ([]byte, []byte) { | 
|  | const initValueHex = "0123456712345678234567893456789a" | 
|  |  | 
|  | initValue, _ := hex.DecodeString(initValueHex) | 
|  |  | 
|  | var a, b [16]byte | 
|  | copy(a[:], initValue) | 
|  | copy(b[:], initValue) | 
|  |  | 
|  | for i := 0; i < iterations; i++ { | 
|  | c, _ := NewCipher(b[:]) | 
|  | c.Encrypt(a[:8], a[:8]) | 
|  | c.Encrypt(a[8:], a[8:]) | 
|  | c, _ = NewCipher(a[:]) | 
|  | c.Encrypt(b[:8], b[:8]) | 
|  | c.Encrypt(b[8:], b[8:]) | 
|  | } | 
|  |  | 
|  | return a[:], b[:] | 
|  | } | 
|  |  | 
|  | func TestLimited(t *testing.T) { | 
|  | a, b := iterate(1000) | 
|  |  | 
|  | const expectedA = "23f73b14b02a2ad7dfb9f2c35644798d" | 
|  | const expectedB = "e5bf37eff14c456a40b21ce369370a9f" | 
|  |  | 
|  | if hex.EncodeToString(a) != expectedA { | 
|  | t.Errorf("a: got:%x want:%s", a, expectedA) | 
|  | } | 
|  | if hex.EncodeToString(b) != expectedB { | 
|  | t.Errorf("b: got:%x want:%s", b, expectedB) | 
|  | } | 
|  | } |