github.com/mattn/go@v0.0.0-20171011075504-07f7db3ea99f/src/crypto/cipher/ctr_test.go (about)

     1  // Copyright 2015 The Go Authors. All rights reserved.
     2  // Use of this source code is governed by a BSD-style
     3  // license that can be found in the LICENSE file.
     4  
     5  package cipher_test
     6  
     7  import (
     8  	"bytes"
     9  	"crypto/cipher"
    10  	"testing"
    11  )
    12  
    13  type noopBlock int
    14  
    15  func (b noopBlock) BlockSize() int        { return int(b) }
    16  func (noopBlock) Encrypt(dst, src []byte) { copy(dst, src) }
    17  func (noopBlock) Decrypt(dst, src []byte) { copy(dst, src) }
    18  
    19  func inc(b []byte) {
    20  	for i := len(b) - 1; i >= 0; i++ {
    21  		b[i]++
    22  		if b[i] != 0 {
    23  			break
    24  		}
    25  	}
    26  }
    27  
    28  func xor(a, b []byte) {
    29  	for i := range a {
    30  		a[i] ^= b[i]
    31  	}
    32  }
    33  
    34  func TestCTR(t *testing.T) {
    35  	for size := 64; size <= 1024; size *= 2 {
    36  		iv := make([]byte, size)
    37  		ctr := cipher.NewCTR(noopBlock(size), iv)
    38  		src := make([]byte, 1024)
    39  		for i := range src {
    40  			src[i] = 0xff
    41  		}
    42  		want := make([]byte, 1024)
    43  		copy(want, src)
    44  		counter := make([]byte, size)
    45  		for i := 1; i < len(want)/size; i++ {
    46  			inc(counter)
    47  			xor(want[i*size:(i+1)*size], counter)
    48  		}
    49  		dst := make([]byte, 1024)
    50  		ctr.XORKeyStream(dst, src)
    51  		if !bytes.Equal(dst, want) {
    52  			t.Errorf("for size %d\nhave %x\nwant %x", size, dst, want)
    53  		}
    54  	}
    55  }