auth_test.go 3.0 KB

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