auth_test.go 2.9 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130
  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. rawPayload := make([]byte, 8192*10)
  21. rand.Read(rawPayload)
  22. payload := buf.NewLocal(8192 * 10)
  23. payload.Append(rawPayload)
  24. cache := buf.NewLocal(160 * 1024)
  25. iv := make([]byte, 12)
  26. rand.Read(iv)
  27. writer := NewAuthenticationWriter(&AEADAuthenticator{
  28. AEAD: aead,
  29. NonceGenerator: &StaticBytesGenerator{
  30. Content: iv,
  31. },
  32. AdditionalDataGenerator: &NoOpBytesGenerator{},
  33. }, PlainChunkSizeParser{}, cache, ModeStream)
  34. assert.Error(writer.Write(buf.NewMultiBufferValue(payload))).IsNil()
  35. assert.Int(cache.Len()).Equals(83360)
  36. assert.Error(writer.Write(buf.NewMultiBuffer())).IsNil()
  37. assert.Error(err).IsNil()
  38. reader := NewAuthenticationReader(&AEADAuthenticator{
  39. AEAD: aead,
  40. NonceGenerator: &StaticBytesGenerator{
  41. Content: iv,
  42. },
  43. AdditionalDataGenerator: &NoOpBytesGenerator{},
  44. }, PlainChunkSizeParser{}, cache, ModeStream)
  45. mb := buf.NewMultiBuffer()
  46. for mb.Len() < len(rawPayload) {
  47. mb2, err := reader.Read()
  48. assert.Error(err).IsNil()
  49. mb.AppendMulti(mb2)
  50. }
  51. mbContent := make([]byte, 8192*10)
  52. mb.Read(mbContent)
  53. assert.Bytes(mbContent).Equals(rawPayload)
  54. _, err = reader.Read()
  55. assert.Error(err).Equals(io.EOF)
  56. }
  57. func TestAuthenticationReaderWriterPacket(t *testing.T) {
  58. assert := assert.On(t)
  59. key := make([]byte, 16)
  60. rand.Read(key)
  61. block, err := aes.NewCipher(key)
  62. assert.Error(err).IsNil()
  63. aead, err := cipher.NewGCM(block)
  64. assert.Error(err).IsNil()
  65. cache := buf.NewLocal(1024)
  66. iv := make([]byte, 12)
  67. rand.Read(iv)
  68. writer := NewAuthenticationWriter(&AEADAuthenticator{
  69. AEAD: aead,
  70. NonceGenerator: &StaticBytesGenerator{
  71. Content: iv,
  72. },
  73. AdditionalDataGenerator: &NoOpBytesGenerator{},
  74. }, PlainChunkSizeParser{}, cache, ModePacket)
  75. payload := buf.NewMultiBuffer()
  76. pb1 := buf.New()
  77. pb1.Append([]byte("abcd"))
  78. payload.Append(pb1)
  79. pb2 := buf.New()
  80. pb2.Append([]byte("efgh"))
  81. payload.Append(pb2)
  82. assert.Error(writer.Write(payload)).IsNil()
  83. assert.Int(cache.Len()).GreaterThan(0)
  84. assert.Error(writer.Write(buf.NewMultiBuffer())).IsNil()
  85. assert.Error(err).IsNil()
  86. reader := NewAuthenticationReader(&AEADAuthenticator{
  87. AEAD: aead,
  88. NonceGenerator: &StaticBytesGenerator{
  89. Content: iv,
  90. },
  91. AdditionalDataGenerator: &NoOpBytesGenerator{},
  92. }, PlainChunkSizeParser{}, cache, ModePacket)
  93. mb, err := reader.Read()
  94. assert.Error(err).IsNil()
  95. b1 := mb.SplitFirst()
  96. assert.String(b1.String()).Equals("abcd")
  97. b2 := mb.SplitFirst()
  98. assert.String(b2.String()).Equals("efgh")
  99. assert.Bool(mb.IsEmpty()).IsTrue()
  100. _, err = reader.Read()
  101. assert.Error(err).Equals(io.EOF)
  102. }