auth_test.go 1.5 KB

12345678910111213141516171819202122232425262728293031323334353637383940414243444546474849505152535455565758596061626364656667
  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)
  21. rand.Read(rawPayload)
  22. payload := buf.NewLocal(8192)
  23. payload.Append(rawPayload)
  24. cache := buf.NewLocal(16 * 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)
  34. assert.Error(writer.Write(buf.NewMultiBufferValue(payload))).IsNil()
  35. assert.Int(cache.Len()).Equals(8210)
  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)
  45. mb, err := reader.Read()
  46. assert.Error(err).IsNil()
  47. assert.Int(mb.Len()).Equals(len(rawPayload))
  48. mbContent := make([]byte, 8192)
  49. mb.Read(mbContent)
  50. assert.Bytes(mbContent).Equals(rawPayload)
  51. _, err = reader.Read()
  52. assert.Error(err).Equals(io.EOF)
  53. }