auth_test.go 3.5 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141
  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, NewShakeUint16Generator([]byte{'a'}))
  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, NewShakeUint16Generator([]byte{'a'}))
  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, NewShakeUint16Generator([]byte{'a', 'b'}))
  74. writer.Write([]byte{'a', 'b', 'c', 'd'})
  75. nBytes, err := writer.Write(payload)
  76. assert.Error(err).IsNil()
  77. assert.Int(nBytes).Equals(len(payload))
  78. assert.Int(cache.Len()).GreaterThan(0)
  79. _, err = writer.Write([]byte{})
  80. assert.Error(err).IsNil()
  81. pr, pw := io.Pipe()
  82. go func() {
  83. pw.Write(cache.BytesTo(1024))
  84. time.Sleep(time.Second * 2)
  85. pw.Write(cache.BytesRange(1024, 2048))
  86. time.Sleep(time.Second * 2)
  87. pw.Write(cache.BytesRange(2048, 3072))
  88. time.Sleep(time.Second * 2)
  89. pw.Write(cache.BytesFrom(3072))
  90. time.Sleep(time.Second * 2)
  91. pw.Close()
  92. }()
  93. reader := NewAuthenticationReader(&AEADAuthenticator{
  94. AEAD: aead,
  95. NonceGenerator: &StaticBytesGenerator{
  96. Content: iv,
  97. },
  98. AdditionalDataGenerator: &NoOpBytesGenerator{},
  99. }, pr, NewShakeUint16Generator([]byte{'a', 'b'}))
  100. actualPayload := make([]byte, 7*1024)
  101. nBytes, err = reader.Read(actualPayload)
  102. assert.Error(err).IsNil()
  103. assert.Int(nBytes).Equals(4)
  104. assert.Bytes(actualPayload[:nBytes]).Equals([]byte{'a', 'b', 'c', 'd'})
  105. nBytes, err = reader.Read(actualPayload)
  106. assert.Error(err).IsNil()
  107. assert.Int(nBytes).Equals(len(actualPayload))
  108. assert.Bytes(actualPayload[:nBytes]).Equals(payload[:nBytes])
  109. nBytes, err = reader.Read(actualPayload)
  110. assert.Error(err).IsNil()
  111. assert.Int(nBytes).Equals(len(payload) - len(actualPayload))
  112. assert.Bytes(actualPayload[:nBytes]).Equals(payload[7*1024:])
  113. _, err = reader.Read(actualPayload)
  114. assert.Error(err).Equals(io.EOF)
  115. }