diff options
author | Jakob Unterwurzacher | 2017-07-01 09:55:14 +0200 |
---|---|---|
committer | Jakob Unterwurzacher | 2017-07-01 09:56:05 +0200 |
commit | 9f4bd765762237e1d0e95c5194fe9768f1281c8c (patch) | |
tree | 66beef9ac1d33f0943bffd1d5f1ad768b3a5fdca /internal | |
parent | 12c0101a232928e8969f23235ca45506e743d547 (diff) |
stupidgcm: add test for in-place Open
Adds a test for the optimization introduced in:
stupidgcm: Open: if "dst" is big enough, use it as the output buffer
Diffstat (limited to 'internal')
-rw-r--r-- | internal/stupidgcm/stupidgcm_test.go | 33 |
1 files changed, 32 insertions, 1 deletions
diff --git a/internal/stupidgcm/stupidgcm_test.go b/internal/stupidgcm/stupidgcm_test.go index e5c99da..f652c45 100644 --- a/internal/stupidgcm/stupidgcm_test.go +++ b/internal/stupidgcm/stupidgcm_test.go @@ -116,7 +116,38 @@ func TestInplaceSeal(t *testing.T) { // Check that this works correctly by testing different "dst" capacities from // 5000 to 16 and "in" lengths from 1 to 5000. func TestInplaceOpen(t *testing.T) { - t.Skipf("TODO: IMPLEMENT TEST") + key := randBytes(32) + sGCM := New(key, false) + authData := randBytes(24) + iv := randBytes(16) + + gAES, err := aes.NewCipher(key) + if err != nil { + t.Fatal(err) + } + gGCM, err := cipher.NewGCMWithNonceSize(gAES, 16) + if err != nil { + t.Fatal(err) + } + max := 5016 + // Check all block sizes from 1 to 5000 + for i := 1; i < max-16; i++ { + in := make([]byte, i) + + gCiphertext := gGCM.Seal(iv, iv, in, authData) + + dst := make([]byte, max-i) + // sPlaintext ... stupidgcm plaintext + sPlaintext, err := sGCM.Open(dst[:0], iv, gCiphertext[16:], authData) + if err != nil { + t.Fatal(err) + } + + // Plaintext must be identical to Go GCM + if !bytes.Equal(in, sPlaintext) { + t.Fatalf("Compare failed, i=%d", i) + } + } } // TestCorruption verifies that changes in the ciphertext result in a decryption |