auth_test.go 2.8 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120
  1. package crypto_test
  2. import (
  3. "crypto/aes"
  4. "crypto/cipher"
  5. "crypto/rand"
  6. "io"
  7. "testing"
  8. "v2ray.com/core/common/buf"
  9. . "v2ray.com/core/common/crypto"
  10. "v2ray.com/core/testing/assert"
  11. )
  12. func TestAuthenticationReaderWriter(t *testing.T) {
  13. assert := assert.On(t)
  14. key := make([]byte, 16)
  15. rand.Read(key)
  16. block, err := aes.NewCipher(key)
  17. assert.Error(err).IsNil()
  18. aead, err := cipher.NewGCM(block)
  19. assert.Error(err).IsNil()
  20. payload := make([]byte, 8*1024)
  21. rand.Read(payload)
  22. cache := buf.NewLocal(16 * 1024)
  23. iv := make([]byte, 12)
  24. rand.Read(iv)
  25. writer := NewAuthenticationWriter(&AEADAuthenticator{
  26. AEAD: aead,
  27. NonceGenerator: &StaticBytesGenerator{
  28. Content: iv,
  29. },
  30. AdditionalDataGenerator: &NoOpBytesGenerator{},
  31. }, cache)
  32. nBytes, err := writer.Write(payload)
  33. assert.Error(err).IsNil()
  34. assert.Int(nBytes).Equals(len(payload))
  35. assert.Int(cache.Len()).GreaterThan(0)
  36. _, err = writer.Write([]byte{})
  37. assert.Error(err).IsNil()
  38. reader := NewAuthenticationReader(&AEADAuthenticator{
  39. AEAD: aead,
  40. NonceGenerator: &StaticBytesGenerator{
  41. Content: iv,
  42. },
  43. AdditionalDataGenerator: &NoOpBytesGenerator{},
  44. }, cache)
  45. actualPayload := make([]byte, 16*1024)
  46. nBytes, err = reader.Read(actualPayload)
  47. assert.Error(err).IsNil()
  48. assert.Int(nBytes).Equals(len(payload))
  49. assert.Bytes(actualPayload[:nBytes]).Equals(payload)
  50. _, err = reader.Read(actualPayload)
  51. assert.Error(err).Equals(io.EOF)
  52. }
  53. func TestAuthenticationReaderWriterPartial(t *testing.T) {
  54. assert := assert.On(t)
  55. key := make([]byte, 16)
  56. rand.Read(key)
  57. block, err := aes.NewCipher(key)
  58. assert.Error(err).IsNil()
  59. aead, err := cipher.NewGCM(block)
  60. assert.Error(err).IsNil()
  61. payload := make([]byte, 8*1024)
  62. rand.Read(payload)
  63. cache := buf.NewLocal(16 * 1024)
  64. iv := make([]byte, 12)
  65. rand.Read(iv)
  66. writer := NewAuthenticationWriter(&AEADAuthenticator{
  67. AEAD: aead,
  68. NonceGenerator: &StaticBytesGenerator{
  69. Content: iv,
  70. },
  71. AdditionalDataGenerator: &NoOpBytesGenerator{},
  72. }, cache)
  73. nBytes, err := writer.Write(payload)
  74. assert.Error(err).IsNil()
  75. assert.Int(nBytes).Equals(len(payload))
  76. assert.Int(cache.Len()).GreaterThan(0)
  77. _, err = writer.Write([]byte{})
  78. assert.Error(err).IsNil()
  79. reader := NewAuthenticationReader(&AEADAuthenticator{
  80. AEAD: aead,
  81. NonceGenerator: &StaticBytesGenerator{
  82. Content: iv,
  83. },
  84. AdditionalDataGenerator: &NoOpBytesGenerator{},
  85. }, cache)
  86. actualPayload := make([]byte, 7*1024)
  87. nBytes, err = reader.Read(actualPayload)
  88. assert.Error(err).IsNil()
  89. assert.Int(nBytes).Equals(len(actualPayload))
  90. assert.Bytes(actualPayload[:nBytes]).Equals(payload[:nBytes])
  91. nBytes, err = reader.Read(actualPayload)
  92. assert.Error(err).IsNil()
  93. assert.Int(nBytes).Equals(len(payload) - len(actualPayload))
  94. assert.Bytes(actualPayload[:nBytes]).Equals(payload[7*1024:])
  95. _, err = reader.Read(actualPayload)
  96. assert.Error(err).Equals(io.EOF)
  97. }