Hunter0x7c7
2022-08-11 b8230139fb40edea387617b6accd8371e37eda58
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
package crypto_test
 
import (
    "crypto/cipher"
    "testing"
 
    . "github.com/v2fly/v2ray-core/v5/common/crypto"
)
 
const benchSize = 1024 * 1024
 
func benchmarkStream(b *testing.B, c cipher.Stream) {
    b.SetBytes(benchSize)
    input := make([]byte, benchSize)
    output := make([]byte, benchSize)
    b.ResetTimer()
    for i := 0; i < b.N; i++ {
        c.XORKeyStream(output, input)
    }
}
 
func BenchmarkChaCha20(b *testing.B) {
    key := make([]byte, 32)
    nonce := make([]byte, 8)
    c := NewChaCha20Stream(key, nonce)
    benchmarkStream(b, c)
}
 
func BenchmarkChaCha20IETF(b *testing.B) {
    key := make([]byte, 32)
    nonce := make([]byte, 12)
    c := NewChaCha20Stream(key, nonce)
    benchmarkStream(b, c)
}
 
func BenchmarkAESEncryption(b *testing.B) {
    key := make([]byte, 32)
    iv := make([]byte, 16)
    c := NewAesEncryptionStream(key, iv)
 
    benchmarkStream(b, c)
}
 
func BenchmarkAESDecryption(b *testing.B) {
    key := make([]byte, 32)
    iv := make([]byte, 16)
    c := NewAesDecryptionStream(key, iv)
 
    benchmarkStream(b, c)
}