diff --git a/openpgp/read_test.go b/openpgp/read_test.go index 318d927ef..a9846cbc2 100644 --- a/openpgp/read_test.go +++ b/openpgp/read_test.go @@ -11,6 +11,7 @@ import ( "encoding/hex" "io" "io/ioutil" + "math/bits" "os" "strings" "testing" @@ -634,10 +635,13 @@ func TestReadV6Messages(t *testing.T) { t.Errorf("inline message is wrong: %s", contents) } } - func TestSymmetricDecryptionArgon2(t *testing.T) { + if bits.UintSize == 32 { + // 32-bit platforms cannot allocate 2GiB of RAM + // required by the test vector. + t.Skip() + } // Appendix IETF OpenPGP crypto refresh draft v08 A.8.1 - passphrase := []byte("password") file, err := os.Open("test_data/argon2-sym-message.asc") if err != nil { t.Fatal(err) @@ -646,6 +650,22 @@ func TestSymmetricDecryptionArgon2(t *testing.T) { if err != nil { t.Fatal(err) } + testSymmetricDecryptionArgon2Run(t, armoredEncryptedMessage) +} + +func TestSymmetricDecryptionArgon2LessMemory(t *testing.T) { + armoredEncryptedMessage := []byte(`-----BEGIN PGP MESSAGE----- + +w0gGJgcCFATa3KMW/4/9RsPME+un+MBqAwQQljCpv3dPfmVTFJAcqn+YRcIFrbY4 +iiVOkxM5uAKScyYn/T2su2j2fu+uPl/HpgLSWQIHAgx/1caHYWvwl7tyjJ/tSYwK +m8OMKQHidSWi7UM88mN17ltnLCV/Wa3bLDIyAgJr9XKubHXeUK6/FqmtPxepd4y/ +SXkqZq0XEafMIbynK2gH6JHjctFX +-----END PGP MESSAGE-----`) + testSymmetricDecryptionArgon2Run(t, armoredEncryptedMessage) +} + +func testSymmetricDecryptionArgon2Run(t *testing.T, armoredEncryptedMessage []byte) { + passphrase := []byte("password") // Unarmor string raw, err := armor.Decode(strings.NewReader(string(armoredEncryptedMessage))) if err != nil { diff --git a/openpgp/v2/read_test.go b/openpgp/v2/read_test.go index 2feaf392f..25926d810 100644 --- a/openpgp/v2/read_test.go +++ b/openpgp/v2/read_test.go @@ -11,6 +11,7 @@ import ( "encoding/hex" "io" "io/ioutil" + "math/bits" "os" "strings" "testing" @@ -667,8 +668,12 @@ func TestReadV6Messages(t *testing.T) { } func TestSymmetricDecryptionArgon2(t *testing.T) { + if bits.UintSize == 32 { + // 32-bit platforms cannot allocate 2GiB of RAM + // required by the test vector. + t.Skip() + } // Appendix IETF OpenPGP crypto refresh draft v08 A.8.1 - passphrase := []byte("password") file, err := os.Open("../test_data/argon2-sym-message.asc") if err != nil { t.Fatal(err) @@ -677,6 +682,22 @@ func TestSymmetricDecryptionArgon2(t *testing.T) { if err != nil { t.Fatal(err) } + testSymmetricDecryptionArgon2Run(t, armoredEncryptedMessage) +} + +func TestSymmetricDecryptionArgon2LessMemory(t *testing.T) { + armoredEncryptedMessage := []byte(`-----BEGIN PGP MESSAGE----- + +w0gGJgcCFATa3KMW/4/9RsPME+un+MBqAwQQljCpv3dPfmVTFJAcqn+YRcIFrbY4 +iiVOkxM5uAKScyYn/T2su2j2fu+uPl/HpgLSWQIHAgx/1caHYWvwl7tyjJ/tSYwK +m8OMKQHidSWi7UM88mN17ltnLCV/Wa3bLDIyAgJr9XKubHXeUK6/FqmtPxepd4y/ +SXkqZq0XEafMIbynK2gH6JHjctFX +-----END PGP MESSAGE-----`) + testSymmetricDecryptionArgon2Run(t, armoredEncryptedMessage) +} + +func testSymmetricDecryptionArgon2Run(t *testing.T, armoredEncryptedMessage []byte) { + passphrase := []byte("password") // Unarmor string raw, err := armor.Decode(strings.NewReader(string(armoredEncryptedMessage))) if err != nil {