passforios-gopenpgp/crypto/base_test.go

73 lines
1.6 KiB
Go
Raw Normal View History

2019-05-13 14:06:54 +00:00
package crypto
import (
"crypto/rsa"
2019-05-13 14:06:54 +00:00
"io/ioutil"
"math/big"
2019-05-14 16:08:25 +00:00
"strings"
"testing"
"github.com/ProtonMail/go-crypto/openpgp/ecdh"
2022-08-12 11:48:09 +02:00
"github.com/ProtonMail/go-crypto/openpgp/eddsa"
"github.com/stretchr/testify/assert"
2019-05-13 14:06:54 +00:00
)
const testTime = 1557754627 // 2019-05-13T13:37:07+00:00
2019-05-13 14:06:54 +00:00
2019-05-14 16:08:25 +00:00
func readTestFile(name string, trimNewlines bool) string {
data, err := ioutil.ReadFile("testdata/" + name) //nolint
2019-05-13 14:06:54 +00:00
if err != nil {
panic(err)
}
2019-05-14 16:08:25 +00:00
if trimNewlines {
return strings.TrimRight(string(data), "\n")
}
2019-05-13 14:06:54 +00:00
return string(data)
}
func init() {
UpdateTime(testTime) // 2019-05-13T13:37:07+00:00
initGenerateKeys()
initArmoredKeys()
initKeyRings()
}
func assertBigIntCleared(t *testing.T, x *big.Int) {
w := x.Bits()
for k := range w {
assert.Exactly(t, big.Word(0x00), w[k])
}
}
func assertMemCleared(t *testing.T, b []byte) {
for k := range b {
assert.Exactly(t, uint8(0x00), b[k])
}
}
func assertRSACleared(t *testing.T, rsaPriv *rsa.PrivateKey) {
assertBigIntCleared(t, rsaPriv.D)
for idx := range rsaPriv.Primes {
assertBigIntCleared(t, rsaPriv.Primes[idx])
}
assertBigIntCleared(t, rsaPriv.Precomputed.Qinv)
assertBigIntCleared(t, rsaPriv.Precomputed.Dp)
assertBigIntCleared(t, rsaPriv.Precomputed.Dq)
for idx := range rsaPriv.Precomputed.CRTValues {
assertBigIntCleared(t, rsaPriv.Precomputed.CRTValues[idx].Exp)
assertBigIntCleared(t, rsaPriv.Precomputed.CRTValues[idx].Coeff)
assertBigIntCleared(t, rsaPriv.Precomputed.CRTValues[idx].R)
}
}
2022-08-12 11:48:09 +02:00
func assertEdDSACleared(t *testing.T, priv *eddsa.PrivateKey) {
assertMemCleared(t, priv.D)
}
func assertECDHCleared(t *testing.T, priv *ecdh.PrivateKey) {
assertMemCleared(t, priv.D)
}