gcm_test.go 4.8 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160
  1. // Copyright 2013 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. package cipher_test
  5. import (
  6. "bytes"
  7. "crypto/aes"
  8. "crypto/cipher"
  9. "encoding/hex"
  10. "testing"
  11. )
  12. // AES-GCM test vectors taken from gcmEncryptExtIV128.rsp from
  13. // http://csrc.nist.gov/groups/STM/cavp/index.html.
  14. var aesGCMTests = []struct {
  15. key, nonce, plaintext, ad, result string
  16. }{
  17. {
  18. "11754cd72aec309bf52f7687212e8957",
  19. "3c819d9a9bed087615030b65",
  20. "",
  21. "",
  22. "250327c674aaf477aef2675748cf6971",
  23. },
  24. {
  25. "ca47248ac0b6f8372a97ac43508308ed",
  26. "ffd2b598feabc9019262d2be",
  27. "",
  28. "",
  29. "60d20404af527d248d893ae495707d1a",
  30. },
  31. {
  32. "77be63708971c4e240d1cb79e8d77feb",
  33. "e0e00f19fed7ba0136a797f3",
  34. "",
  35. "7a43ec1d9c0a5a78a0b16533a6213cab",
  36. "209fcc8d3675ed938e9c7166709dd946",
  37. },
  38. {
  39. "7680c5d3ca6154758e510f4d25b98820",
  40. "f8f105f9c3df4965780321f8",
  41. "",
  42. "c94c410194c765e3dcc7964379758ed3",
  43. "94dca8edfcf90bb74b153c8d48a17930",
  44. },
  45. {
  46. "7fddb57453c241d03efbed3ac44e371c",
  47. "ee283a3fc75575e33efd4887",
  48. "d5de42b461646c255c87bd2962d3b9a2",
  49. "",
  50. "2ccda4a5415cb91e135c2a0f78c9b2fdb36d1df9b9d5e596f83e8b7f52971cb3",
  51. },
  52. {
  53. "ab72c77b97cb5fe9a382d9fe81ffdbed",
  54. "54cc7dc2c37ec006bcc6d1da",
  55. "007c5e5b3e59df24a7c355584fc1518d",
  56. "",
  57. "0e1bde206a07a9c2c1b65300f8c649972b4401346697138c7a4891ee59867d0c",
  58. },
  59. {
  60. "fe47fcce5fc32665d2ae399e4eec72ba",
  61. "5adb9609dbaeb58cbd6e7275",
  62. "7c0e88c88899a779228465074797cd4c2e1498d259b54390b85e3eef1c02df60e743f1b840382c4bccaf3bafb4ca8429bea063",
  63. "88319d6e1d3ffa5f987199166c8a9b56c2aeba5a",
  64. "98f4826f05a265e6dd2be82db241c0fbbbf9ffb1c173aa83964b7cf5393043736365253ddbc5db8778371495da76d269e5db3e291ef1982e4defedaa2249f898556b47",
  65. },
  66. {
  67. "ec0c2ba17aa95cd6afffe949da9cc3a8",
  68. "296bce5b50b7d66096d627ef",
  69. "b85b3753535b825cbe5f632c0b843c741351f18aa484281aebec2f45bb9eea2d79d987b764b9611f6c0f8641843d5d58f3a242",
  70. "f8d00f05d22bf68599bcdeb131292ad6e2df5d14",
  71. "a7443d31c26bdf2a1c945e29ee4bd344a99cfaf3aa71f8b3f191f83c2adfc7a07162995506fde6309ffc19e716eddf1a828c5a890147971946b627c40016da1ecf3e77",
  72. },
  73. {
  74. "2c1f21cf0f6fb3661943155c3e3d8492",
  75. "23cb5ff362e22426984d1907",
  76. "42f758836986954db44bf37c6ef5e4ac0adaf38f27252a1b82d02ea949c8a1a2dbc0d68b5615ba7c1220ff6510e259f06655d8",
  77. "5d3624879d35e46849953e45a32a624d6a6c536ed9857c613b572b0333e701557a713e3f010ecdf9a6bd6c9e3e44b065208645aff4aabee611b391528514170084ccf587177f4488f33cfb5e979e42b6e1cfc0a60238982a7aec",
  78. "81824f0e0d523db30d3da369fdc0d60894c7a0a20646dd015073ad2732bd989b14a222b6ad57af43e1895df9dca2a5344a62cc57a3ee28136e94c74838997ae9823f3a",
  79. },
  80. {
  81. "d9f7d2411091f947b4d6f1e2d1f0fb2e",
  82. "e1934f5db57cc983e6b180e7",
  83. "73ed042327f70fe9c572a61545eda8b2a0c6e1d6c291ef19248e973aee6c312012f490c2c6f6166f4a59431e182663fcaea05a",
  84. "0a8a18a7150e940c3d87b38e73baee9a5c049ee21795663e264b694a949822b639092d0e67015e86363583fcf0ca645af9f43375f05fdb4ce84f411dcbca73c2220dea03a20115d2e51398344b16bee1ed7c499b353d6c597af8",
  85. "aaadbd5c92e9151ce3db7210b8714126b73e43436d242677afa50384f2149b831f1d573c7891c2a91fbc48db29967ec9542b2321b51ca862cb637cdd03b99a0f93b134",
  86. },
  87. {
  88. "fe9bb47deb3a61e423c2231841cfd1fb",
  89. "4d328eb776f500a2f7fb47aa",
  90. "f1cc3818e421876bb6b8bbd6c9",
  91. "",
  92. "b88c5c1977b35b517b0aeae96743fd4727fe5cdb4b5b42818dea7ef8c9",
  93. },
  94. {
  95. "6703df3701a7f54911ca72e24dca046a",
  96. "12823ab601c350ea4bc2488c",
  97. "793cd125b0b84a043e3ac67717",
  98. "",
  99. "b2051c80014f42f08735a7b0cd38e6bcd29962e5f2c13626b85a877101",
  100. },
  101. }
  102. func TestAESGCM(t *testing.T) {
  103. for i, test := range aesGCMTests {
  104. key, _ := hex.DecodeString(test.key)
  105. aes, err := aes.NewCipher(key)
  106. if err != nil {
  107. t.Fatal(err)
  108. }
  109. nonce, _ := hex.DecodeString(test.nonce)
  110. plaintext, _ := hex.DecodeString(test.plaintext)
  111. ad, _ := hex.DecodeString(test.ad)
  112. aesgcm, err := cipher.NewGCM(aes)
  113. if err != nil {
  114. t.Fatal(err)
  115. }
  116. ct := aesgcm.Seal(nil, nonce, plaintext, ad)
  117. if ctHex := hex.EncodeToString(ct); ctHex != test.result {
  118. t.Errorf("#%d: got %s, want %s", i, ctHex, test.result)
  119. continue
  120. }
  121. plaintext2, err := aesgcm.Open(nil, nonce, ct, ad)
  122. if err != nil {
  123. t.Errorf("#%d: Open failed", i)
  124. continue
  125. }
  126. if !bytes.Equal(plaintext, plaintext2) {
  127. t.Errorf("#%d: plaintext's don't match: got %x vs %x", i, plaintext2, plaintext)
  128. continue
  129. }
  130. if len(ad) > 0 {
  131. ad[0] ^= 0x80
  132. if _, err := aesgcm.Open(nil, nonce, ct, ad); err == nil {
  133. t.Errorf("#%d: Open was successful after altering additional data", i)
  134. }
  135. ad[0] ^= 0x80
  136. }
  137. nonce[0] ^= 0x80
  138. if _, err := aesgcm.Open(nil, nonce, ct, ad); err == nil {
  139. t.Errorf("#%d: Open was successful after altering nonce", i)
  140. }
  141. nonce[0] ^= 0x80
  142. ct[0] ^= 0x80
  143. if _, err := aesgcm.Open(nil, nonce, ct, ad); err == nil {
  144. t.Errorf("#%d: Open was successful after altering ciphertext", i)
  145. }
  146. ct[0] ^= 0x80
  147. }
  148. }