2023-09-27 21:59:09 +00:00
package nip44_test
import (
"encoding/hex"
"testing"
"git.ekzyis.com/ekzyis/nip44"
2023-09-30 17:40:06 +00:00
"github.com/decred/dcrd/dcrec/secp256k1/v4"
2023-09-27 21:59:09 +00:00
"github.com/stretchr/testify/assert"
)
2023-12-22 05:50:48 +00:00
func assertCryptPriv ( t * testing . T , sk1 string , sk2 string , conversationKey string , salt string , plaintext string , expected string ) {
2023-09-27 21:59:09 +00:00
var (
2023-09-30 17:40:06 +00:00
k1 [ ] byte
2023-09-30 12:40:52 +00:00
s [ ] byte
actual string
decrypted string
2023-09-30 17:40:06 +00:00
ok bool
2023-09-30 12:40:52 +00:00
err error
2023-09-30 17:40:06 +00:00
)
k1 , err = hex . DecodeString ( conversationKey )
if ok = assert . NoErrorf ( t , err , "hex decode failed for conversation key: %v" , err ) ; ! ok {
return
}
if ok = assertConversationKeyGenerationSec ( t , sk1 , sk2 , conversationKey ) ; ! ok {
return
}
s , err = hex . DecodeString ( salt )
if ok = assert . NoErrorf ( t , err , "hex decode failed for salt: %v" , err ) ; ! ok {
return
}
actual , err = nip44 . Encrypt ( k1 , plaintext , & nip44 . EncryptOptions { Salt : s } )
if ok = assert . NoError ( t , err , "encryption failed: %v" , err ) ; ! ok {
return
}
if ok = assert . Equalf ( t , expected , actual , "wrong encryption" ) ; ! ok {
return
}
decrypted , err = nip44 . Decrypt ( k1 , expected )
if ok = assert . NoErrorf ( t , err , "decryption failed: %v" , err ) ; ! ok {
return
}
assert . Equal ( t , decrypted , plaintext , "wrong decryption" )
}
func assertCryptPub ( t * testing . T , sk1 string , pub2 string , conversationKey string , salt string , plaintext string , expected string ) {
var (
k1 [ ] byte
s [ ] byte
actual string
decrypted string
2023-09-30 17:24:00 +00:00
ok bool
2023-09-30 17:40:06 +00:00
err error
2023-09-27 21:59:09 +00:00
)
2023-09-30 17:40:06 +00:00
k1 , err = hex . DecodeString ( conversationKey )
if ok = assert . NoErrorf ( t , err , "hex decode failed for conversation key: %v" , err ) ; ! ok {
return
}
if ok = assertConversationKeyGenerationPub ( t , sk1 , pub2 , conversationKey ) ; ! ok {
2023-09-30 17:24:00 +00:00
return
2023-09-27 21:59:09 +00:00
}
2023-09-30 17:24:00 +00:00
s , err = hex . DecodeString ( salt )
if ok = assert . NoErrorf ( t , err , "hex decode failed for salt: %v" , err ) ; ! ok {
return
2023-09-27 21:59:09 +00:00
}
2023-09-30 17:40:06 +00:00
actual , err = nip44 . Encrypt ( k1 , plaintext , & nip44 . EncryptOptions { Salt : s } )
2023-09-30 17:24:00 +00:00
if ok = assert . NoError ( t , err , "encryption failed: %v" , err ) ; ! ok {
return
2023-09-27 21:59:09 +00:00
}
2023-09-30 17:24:00 +00:00
if ok = assert . Equalf ( t , expected , actual , "wrong encryption" ) ; ! ok {
return
}
2023-09-30 17:40:06 +00:00
decrypted , err = nip44 . Decrypt ( k1 , expected )
2023-09-30 17:24:00 +00:00
if ok = assert . NoErrorf ( t , err , "decryption failed: %v" , err ) ; ! ok {
return
}
assert . Equal ( t , decrypted , plaintext , "wrong decryption" )
2023-09-27 21:59:09 +00:00
}
2023-09-30 17:40:06 +00:00
func assertDecryptFail ( t * testing . T , sk1 string , pub2 string , conversationKey string , ciphertext string , msg string ) {
2023-09-30 13:18:27 +00:00
var (
2023-09-30 17:40:06 +00:00
k1 [ ] byte
2023-09-30 17:24:00 +00:00
ok bool
2023-09-30 17:40:06 +00:00
err error
2023-09-30 13:18:27 +00:00
)
2023-09-30 17:40:06 +00:00
k1 , err = hex . DecodeString ( conversationKey )
if ok = assert . NoErrorf ( t , err , "hex decode failed for conversation key: %v" , err ) ; ! ok {
return
}
if ok = assertConversationKeyGenerationPub ( t , sk1 , pub2 , conversationKey ) ; ! ok {
2023-09-30 17:24:00 +00:00
return
2023-09-30 13:18:27 +00:00
}
2023-09-30 17:40:06 +00:00
_ , err = nip44 . Decrypt ( k1 , ciphertext )
2023-09-30 13:18:27 +00:00
assert . ErrorContains ( t , err , msg )
}
2023-09-30 17:40:06 +00:00
func assertConversationKeyGeneration ( t * testing . T , sendPrivkey * secp256k1 . PrivateKey , recvPubkey * secp256k1 . PublicKey , conversationKey string ) bool {
var (
actualConversationKey [ ] byte
expectedConversationKey [ ] byte
ok bool
err error
)
expectedConversationKey , err = hex . DecodeString ( conversationKey )
if ok = assert . NoErrorf ( t , err , "hex decode failed for conversation key: %v" , err ) ; ! ok {
return false
}
actualConversationKey = nip44 . GenerateConversationKey ( sendPrivkey , recvPubkey )
if ok = assert . Equalf ( t , expectedConversationKey , actualConversationKey , "wrong conversation key" ) ; ! ok {
return false
}
return true
}
func assertConversationKeyGenerationSec ( t * testing . T , sk1 string , sk2 string , conversationKey string ) bool {
var (
sendPrivkey * secp256k1 . PrivateKey
recvPubkey * secp256k1 . PublicKey
ok bool
err error
)
if decoded , err := hex . DecodeString ( sk1 ) ; err == nil {
sendPrivkey = secp256k1 . PrivKeyFromBytes ( decoded )
}
if ok = assert . NoErrorf ( t , err , "hex decode failed for sk1: %v" , err ) ; ! ok {
return false
}
if decoded , err := hex . DecodeString ( sk2 ) ; err == nil {
recvPubkey = secp256k1 . PrivKeyFromBytes ( decoded ) . PubKey ( )
}
if ok = assert . NoErrorf ( t , err , "hex decode failed for sk2: %v" , err ) ; ! ok {
return false
}
return assertConversationKeyGeneration ( t , sendPrivkey , recvPubkey , conversationKey )
}
func assertConversationKeyGenerationPub ( t * testing . T , sk1 string , pub2 string , conversationKey string ) bool {
var (
sendPrivkey * secp256k1 . PrivateKey
recvPubkey * secp256k1 . PublicKey
ok bool
err error
)
if decoded , err := hex . DecodeString ( sk1 ) ; err == nil {
sendPrivkey = secp256k1 . PrivKeyFromBytes ( decoded )
}
if ok = assert . NoErrorf ( t , err , "hex decode failed for sk1: %v" , err ) ; ! ok {
return false
}
if decoded , err := hex . DecodeString ( "02" + pub2 ) ; err == nil {
recvPubkey , err = secp256k1 . ParsePubKey ( decoded )
if ok = assert . NoErrorf ( t , err , "parse pubkey failed: %v" , err ) ; ! ok {
return false
}
}
if ok = assert . NoErrorf ( t , err , "hex decode failed for pub2: %v" , err ) ; ! ok {
return false
}
return assertConversationKeyGeneration ( t , sendPrivkey , recvPubkey , conversationKey )
}
2023-12-22 05:50:48 +00:00
func TestCryptPriv001 ( t * testing . T ) {
assertCryptPriv ( t ,
2023-09-30 17:40:06 +00:00
"0000000000000000000000000000000000000000000000000000000000000001" ,
"0000000000000000000000000000000000000000000000000000000000000002" ,
2023-09-27 21:59:09 +00:00
"c6047f9441ed7d6d3045406e95c07cd85c778e4b8cef3ca7abac09b95c709ee5" ,
"0000000000000000000000000000000000000000000000000000000000000001" ,
"a" ,
2023-09-30 12:00:53 +00:00
"AgAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAABYNpT9ESckRbRUY7bUF5P+1rObpA4BNoksAUQ8myMDd9/37W/J2YHvBpRjvy9uC0+ovbpLc0WLaMFieqAMdIYqR14" ,
2023-09-27 21:59:09 +00:00
)
}
2023-12-22 05:50:48 +00:00
func TestCryptPriv002 ( t * testing . T ) {
assertCryptPriv ( t ,
2023-09-30 17:40:06 +00:00
"0000000000000000000000000000000000000000000000000000000000000002" ,
"0000000000000000000000000000000000000000000000000000000000000001" ,
2023-09-27 21:59:09 +00:00
"c6047f9441ed7d6d3045406e95c07cd85c778e4b8cef3ca7abac09b95c709ee5" ,
"f00000000000000000000000000000f00000000000000000000000000000000f" ,
2023-09-30 12:00:53 +00:00
"🍕🫃" ,
"AvAAAAAAAAAAAAAAAAAAAPAAAAAAAAAAAAAAAAAAAAAPKY68BwdF7PIT205jBoaZHSs7OMpKsULW5F5ClOJWiy6XjZy7s2v85KugYmbBKgEC2LytbXbxkr7Jpgfk529K3/pP" ,
2023-09-27 21:59:09 +00:00
)
}
2023-12-22 05:50:48 +00:00
func TestCryptPriv003 ( t * testing . T ) {
assertCryptPriv ( t ,
2023-09-30 17:40:06 +00:00
"5c0c523f52a5b6fad39ed2403092df8cebc36318b39383bca6c00808626fab3a" ,
"4b22aa260e4acb7021e32f38a6cdf4b673c6a277755bfce287e370c924dc936d" ,
2023-09-27 21:59:09 +00:00
"94da47d851b9c1ed33b3b72f35434f56aa608d60e573e9c295f568011f4f50a4" ,
"b635236c42db20f021bb8d1cdff5ca75dd1a0cc72ea742ad750f33010b24f73b" ,
2023-09-30 12:00:53 +00:00
"表ポあA鷗ŒéB 逍Üߪąñ丂㐀𠀀" ,
"ArY1I2xC2yDwIbuNHN/1ynXdGgzHLqdCrXUPMwELJPc7yuU7XwJ8wCYUrq4aXX86HLnkMx7fPFvNeMk0uek9ma01magfEBIf+vJvZdWKiv48eUu9Cv31plAJsH6kSIsGc5TVYBYipkrQUNRxxJA15QT+uCURF96v3XuSS0k2Pf108AI=" ,
2023-09-27 21:59:09 +00:00
)
}
2023-12-22 05:50:48 +00:00
func TestCryptPriv004 ( t * testing . T ) {
assertCryptPriv ( t ,
2023-09-30 17:40:06 +00:00
"8f40e50a84a7462e2b8d24c28898ef1f23359fff50d8c509e6fb7ce06e142f9c" ,
"b9b0a1e9cc20100c5faa3bbe2777303d25950616c4c6a3fa2e3e046f936ec2ba" ,
2023-09-27 21:59:09 +00:00
"ab99c122d4586cdd5c813058aa543d0e7233545dbf6874fc34a3d8d9a18fbbc3" ,
"b20989adc3ddc41cd2c435952c0d59a91315d8c5218d5040573fc3749543acaf" ,
2023-09-30 12:00:53 +00:00
"ability🤝的 ȺȾ" ,
"ArIJia3D3cQc0sQ1lSwNWakTFdjFIY1QQFc/w3SVQ6yvPSc+7YCIFTmGk5OLuh1nhl6TvID7sGKLFUCWRW1eRfV/0a7sT46N3nTQzD7IE67zLWrYqGnE+0DDNz6sJ4hAaFrT" ,
2023-09-27 21:59:09 +00:00
)
}
2023-12-22 05:50:48 +00:00
func TestCryptPriv005 ( t * testing . T ) {
assertCryptPriv ( t ,
2023-09-30 17:40:06 +00:00
"875adb475056aec0b4809bd2db9aa00cff53a649e7b59d8edcbf4e6330b0995c" ,
"9c05781112d5b0a2a7148a222e50e0bd891d6b60c5483f03456e982185944aae" ,
2023-09-27 21:59:09 +00:00
"a449f2a85c6d3db0f44c64554a05d11a3c0988d645e4b4b2592072f63662f422" ,
"8d4442713eb9d4791175cb040d98d6fc5be8864d6ec2f89cf0895a2b2b72d1b1" ,
"pepper👀їжа к" ,
2023-09-30 12:00:53 +00:00
"Ao1EQnE+udR5EXXLBA2Y1vxb6IZNbsL4nPCJWisrctGx1TkkMfiHJxEeSdQ/4Rlaghn0okDCNYLihBsHrDzBsNRC27APmH9mmZcpcg66Mb0exH9V5/lLBWdQW+fcY9GpvXv0" ,
2023-09-27 21:59:09 +00:00
)
}
2023-12-22 05:50:48 +00:00
func TestCryptPriv006 ( t * testing . T ) {
assertCryptPriv ( t ,
2023-09-30 17:40:06 +00:00
"eba1687cab6a3101bfc68fd70f214aa4cc059e9ec1b79fdb9ad0a0a4e259829f" ,
"dff20d262bef9dfd94666548f556393085e6ea421c8af86e9d333fa8747e94b3" ,
2023-09-27 21:59:09 +00:00
"decde9938ffcb14fa7ff300105eb1bf239469af9baf376e69755b9070ae48c47" ,
"2180b52ae645fcf9f5080d81b1f0b5d6f2cd77ff3c986882bb549158462f3407" ,
2023-09-30 12:00:53 +00:00
"( ͡° ͜ʖ ͡°)" ,
"AiGAtSrmRfz59QgNgbHwtdbyzXf/PJhogrtUkVhGLzQHiR8Hljs6Nl/XsNDAmCz6U1Z3NUGhbCtczc3wXXxDzFkjjMimxsf/74OEzu7LphUadM9iSWvVKPrNXY7lTD0B2muz" ,
2023-09-27 21:59:09 +00:00
)
}
2023-12-22 05:50:48 +00:00
func TestCryptPriv007 ( t * testing . T ) {
assertCryptPriv ( t ,
2023-09-30 17:40:06 +00:00
"d5633530f5bcfebceb5584cfbbf718a30df0751b729dd9a789b9f30c0587d74e" ,
"b74e6a341fb134127272b795a08b59250e5fa45a82a2eb4095e4ce9ed5f5e214" ,
2023-09-27 21:59:09 +00:00
"c6f2fde7aa00208c388f506455c31c3fa07caf8b516d43bf7514ee19edcda994" ,
"e4cd5f7ce4eea024bc71b17ad456a986a74ac426c2c62b0a15eb5c5c8f888b68" ,
2023-09-30 12:00:53 +00:00
"مُنَاقَشَةُ سُبُلِ اِسْتِخْدَامِ اللُّغَةِ فِي النُّظُمِ الْقَائِمَةِ وَفِيم يَخُصَّ التَّطْبِيقَاتُ الْحاسُوبِيَّةُ،" ,
"AuTNX3zk7qAkvHGxetRWqYanSsQmwsYrChXrXFyPiItohfde4vHVRHUupr+Glh9JW4f9EY+w795hvRZbixs0EQgDZ7zwLlymVQI3NNvMqvemQzHUA1I5+9gSu8XSMwX9gDCUAjUJtntCkRt9+tjdy2Wa2ZrDYqCvgirvzbJTIC69Ve3YbKuiTQCKtVi0PA5ZLqVmnkHPIqfPqDOGj/a3dvJVzGSgeijcIpjuEgFF54uirrWvIWmTBDeTA+tlQzJHpB2wQnUndd2gLDb8+eKFUZPBifshD3WmgWxv8wRv6k3DeWuWEZQ70Z+YDpgpeOzuzHj0MDBwMAlY8Qq86Rx6pxY76PLDDfHh3rE2CHJEKl2MhDj7pGXao2o633vSRd9ueG8W" ,
2023-09-27 21:59:09 +00:00
)
}
2023-12-22 05:50:48 +00:00
func TestCryptPriv008 ( t * testing . T ) {
assertCryptPriv ( t ,
2023-09-30 17:40:06 +00:00
"d5633530f5bcfebceb5584cfbbf718a30df0751b729dd9a789b9f30c0587d74e" ,
"b74e6a341fb134127272b795a08b59250e5fa45a82a2eb4095e4ce9ed5f5e214" ,
2023-09-27 21:59:09 +00:00
"c6f2fde7aa00208c388f506455c31c3fa07caf8b516d43bf7514ee19edcda994" ,
"38d1ca0abef9e5f564e89761a86cee04574b6825d3ef2063b10ad75899e4b023" ,
2023-09-30 12:00:53 +00:00
"الكل في المجمو عة (5)" ,
"AjjRygq++eX1ZOiXYahs7gRXS2gl0+8gY7EK11iZ5LAjTHmhdBC3meTY4A7Lv8s8B86MnmlUBJ8ebzwxFQzDyVCcdSbWFaKe0gigEBdXew7TjrjH8BCpAbtYjoa4YHa8GNjj7zH314ApVnwoByHdLHLB9Vr6VdzkxcJgA6oL4MAsRLg=" ,
2023-09-27 21:59:09 +00:00
)
}
2023-12-22 05:50:48 +00:00
func TestCryptPriv009 ( t * testing . T ) {
assertCryptPriv ( t ,
2023-09-30 17:40:06 +00:00
"d5633530f5bcfebceb5584cfbbf718a30df0751b729dd9a789b9f30c0587d74e" ,
"b74e6a341fb134127272b795a08b59250e5fa45a82a2eb4095e4ce9ed5f5e214" ,
2023-09-27 21:59:09 +00:00
"c6f2fde7aa00208c388f506455c31c3fa07caf8b516d43bf7514ee19edcda994" ,
"4f1a31909f3483a9e69c8549a55bbc9af25fa5bbecf7bd32d9896f83ef2e12e0" ,
2023-09-30 12:00:53 +00:00
"𝖑 𝖆 𝖟 𝖞 社會科學院語學研究所" ,
"Ak8aMZCfNIOp5pyFSaVbvJryX6W77Pe9MtmJb4PvLhLg/25Q5uBC88jl5ghtEREXX6o4QijPzM0uwmkeQ54/6aIqUyzGNVdryWKZ0mee2lmVVWhU+26X6XGFQ5DGRn+1v0POsFUCZ/REh35+beBNHnyvjxD/rbrMfhP2Blc8X5m8Xvk=" ,
2023-09-27 21:59:09 +00:00
)
}
2023-12-22 05:50:48 +00:00
func TestCryptPriv010 ( t * testing . T ) {
assertCryptPriv ( t ,
2023-09-30 17:40:06 +00:00
"d5633530f5bcfebceb5584cfbbf718a30df0751b729dd9a789b9f30c0587d74e" ,
"b74e6a341fb134127272b795a08b59250e5fa45a82a2eb4095e4ce9ed5f5e214" ,
2023-09-27 21:59:09 +00:00
"c6f2fde7aa00208c388f506455c31c3fa07caf8b516d43bf7514ee19edcda994" ,
"a3e219242d85465e70adcd640b564b3feff57d2ef8745d5e7a0663b2dccceb54" ,
2023-09-30 12:00:53 +00:00
"🙈 🙉 🙊 0️ ⃣ 1️ ⃣ 2️ ⃣ 3️ ⃣ 4️ ⃣ 5️ ⃣ 6️ ⃣ 7️ ⃣ 8️ ⃣ 9️ ⃣ 🔟 Powerلُلُصّبُلُلصّبُررً ॣ ॣh ॣ ॣ冗" ,
"AqPiGSQthUZecK3NZAtWSz/v9X0u+HRdXnoGY7LczOtU9bUC2ji2A2udRI2VCEQZ7IAmYRRgxodBtd5Yi/5htCUczf1jLHxIt9AhVAZLKuRgbWOuEMq5RBybkxPsSeAkxzXVOlWHZ1Febq5ogkjqY/6Xj8CwwmaZxfbx+d1BKKO3Wa+IFuXwuVAZa1Xo+fan+skyf+2R5QSj10QGAnGO7odAu/iZ9A28eMoSNeXsdxqy1+PRt5Zk4i019xmf7C4PDGSzgFZSvQ2EzusJN5WcsnRFmF1L5rXpX1AYo8HusOpWcGf9PjmFbO+8spUkX1W/T21GRm4o7dro1Y6ycgGOA9BsiQ==" ,
2023-09-27 21:59:09 +00:00
)
}
2023-09-30 17:40:06 +00:00
func TestCryptPub001 ( t * testing . T ) {
assertCryptPub ( t ,
"fffffffffffffffffffffffffffffffebaaedce6af48a03bbfd25e8cd0364139" ,
"0000000000000000000000000000000000000000000000000000000000000002" ,
2023-09-30 12:00:53 +00:00
"7a1ccf5ce5a08e380f590de0c02776623b85a61ae67cfb6a017317e505b7cb51" ,
2023-09-27 21:59:09 +00:00
"a000000000000000000000000000000000000000000000000000000000000001" ,
2023-09-30 12:00:53 +00:00
"⁰⁴⁵₀₁₂" ,
"AqAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAB2+xmGnjIMPMqqJGmjdYAYZUDUyEEUO3/evHUaO40LePeR91VlMVZ7I+nKJPkaUiKZ3cQiQnA86Uwti2IxepmzOFN" ,
2023-09-27 21:59:09 +00:00
)
}
2023-09-30 12:42:22 +00:00
2023-09-30 17:40:06 +00:00
func TestCryptPub002 ( t * testing . T ) {
assertCryptPub ( t ,
"0000000000000000000000000000000000000000000000000000000000000002" ,
"1234567890abcdef1234567890abcdef1234567890abcdef1234567890abcdeb" ,
2023-09-27 21:59:09 +00:00
"aa971537d741089885a0b48f2730a125e15b36033d089d4537a4e1204e76b39e" ,
"b000000000000000000000000000000000000000000000000000000000000002" ,
"A Peer-to-Peer Electronic Cash System" ,
2023-09-30 12:00:53 +00:00
"ArAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAACyuqG6RycuPyDPtwxzTcuMQu+is3N5XuWTlvCjligVaVBRydexaylXbsX592MEd3/Jt13BNL/GlpYpGDvLS4Tt/+2s9FX/16e/RDc+czdwXglc4DdSHiq+O06BvvXYfEQOPw=" ,
2023-09-27 21:59:09 +00:00
)
}
2023-09-30 12:42:22 +00:00
2023-09-30 17:40:06 +00:00
func TestCryptPub003 ( t * testing . T ) {
assertCryptPub ( t ,
"0000000000000000000000000000000000000000000000000000000000000001" ,
"79be667ef9dcbbac55a06295ce870b07029bfcdb2dce28d959f2815b16f81798" ,
2023-09-27 21:59:09 +00:00
"79be667ef9dcbbac55a06295ce870b07029bfcdb2dce28d959f2815b16f81798" ,
"79be667ef9dcbbac55a06295ce870b07029bfcdb2dce28d959f2815b16f81798" ,
"A purely peer-to-peer version of electronic cash would allow online payments to be sent directly from one party to another without going through a financial institution. Digital signatures provide part of the solution, but the main benefits are lost if a trusted third party is still required to prevent double-spending." ,
2023-09-30 12:00:53 +00:00
"Anm+Zn753LusVaBilc6HCwcCm/zbLc4o2VnygVsW+BeYb9wHyKevpe7ohJ6OkpceFcb0pySY8TLGwT7Q3zWNDKxc9blXanxKborEXkQH8xNaB2ViJfgxpkutbwbYd0Grix34xzaZBASufdsNm7R768t51tI6sdS0nms6kWLVJpEGu6Ke4Bldv4StJtWBLaTcgsgN+4WxDbBhC/nhwjEQiBBbbmUrPWjaVZXjl8dzzPrYtkSoeBNJs/UNvDwym4+qrmhv4ASTvVflpZgLlSe4seqeu6dWoRqn8uRHZQnPs+XhqwbdCHpeKGB3AfGBykZY0RIr0tjarWdXNasGbIhGM3GiLasioJeabAZw0plCevDkKpZYDaNfMJdzqFVJ8UXRIpvDpQad0SOm8lLum/aBzUpLqTjr3RvSlhYdbuODpd9pR5K60k4L2N8nrPtBv08wlilQg2ymwQgKVE6ipxIzzKMetn8+f0nQ9bHjWFJqxetSuMzzArTUQl9c4q/DwZmCBhI2" ,
2023-09-27 21:59:09 +00:00
)
}
2023-09-30 13:18:27 +00:00
func TestCryptFail001 ( t * testing . T ) {
assertDecryptFail ( t ,
2023-09-30 17:40:06 +00:00
"2573d1e9b9ac5de5d570f652cbb9e8d4f235e3d3d334181448e87c417f374e83" ,
"8348c2d35549098706e5bab7966d9a9c72fbf6554e918f41c2b6cb275f79ec13" ,
2023-09-30 13:18:27 +00:00
"8673ec68393a997bfad7eab8661461daf8b3931b7e885d78312a3fb7fe17f41a" ,
"##Atqupco0WyaOW2IGDKcshwxI9xO8HgD/P8Ddt46CbxDbOsrsqIEybscEwg5rnI/Cx03mDSmeweOLKD7dw5BDZQDxXSlCwX1LIcTJEZaJPTz98Ftu0zSE0d93ED7OtdlvNeZx" ,
"unknown version" ,
)
}
func TestCryptFail002 ( t * testing . T ) {
assertDecryptFail ( t ,
2023-09-30 17:40:06 +00:00
"11063318c5cb3cd9cafcced42b4db5ea02ec976ed995962d2bc1fa1e9b52e29f" ,
"5c49873b6eac3dd363325250cc55d5dd4c7ce9a885134580405736d83506bb74" ,
2023-09-30 13:18:27 +00:00
"e2aad10de00913088e5cb0f73fa526a6a17e95763cc5b2a127022f5ea5a73445" ,
2023-09-30 17:28:13 +00:00
"AK1AjUvoYW3IS7C/BGRUoqEC7ayTfDUgnEPNeWTF/reBA4fZmoHrtrz5I5pCHuwWZ22qqL/Xt1VidEZGMLds0yaJ5VwUbeEifEJlPICOFt1ssZJxCUf43HvRwCVTFskbhSMh" ,
"unknown version" ,
2023-09-30 13:18:27 +00:00
)
}
func TestCryptFail003 ( t * testing . T ) {
assertDecryptFail ( t ,
2023-09-30 17:40:06 +00:00
"2573d1e9b9ac5de5d570f652cbb9e8d4f235e3d3d334181448e87c417f374e83" ,
"8348c2d35549098706e5bab7966d9a9c72fbf6554e918f41c2b6cb275f79ec13" ,
2023-09-30 13:18:27 +00:00
"8673ec68393a997bfad7eab8661461daf8b3931b7e885d78312a3fb7fe17f41a" ,
"Atqupco0WyaOW2IGDKcshwxI9xO8HgD/P8Ddt46CbxDbOsrsqIEybscEwg5rnI/Cx03mDSmeweOLKD,7dw5BDZQDxXSlCwX1LIcTJEZaJPTz98Ftu0zSE0d93ED7OtdlvNeZx" ,
"invalid base64" ,
)
}
func TestCryptFail004 ( t * testing . T ) {
assertDecryptFail ( t ,
2023-09-30 17:40:06 +00:00
"5a2f39347fed3883c9fe05868a8f6156a292c45f606bc610495fcc020ed158f7" ,
"775bbfeba58d07f9d1fbb862e306ac780f39e5418043dadb547c7b5900245e71" ,
2023-09-30 13:18:27 +00:00
"2e70c0a1cde884b88392458ca86148d859b273a5695ede5bbe41f731d7d88ffd" ,
2023-09-30 17:28:13 +00:00
"Agn/l3ULCEAS4V7LhGFM6IGA17jsDUaFCKhrbXDANholdUejFZPARM22IvOqp1U/UmFSkeSyTBYbbwy5ykmi+mKiEcWL+nVmTOf28MMiC+rTpZys/8p1hqQFpn+XWZRPrVay" ,
2023-09-30 13:18:27 +00:00
"invalid hmac" ,
)
}
func TestCryptFail005 ( t * testing . T ) {
assertDecryptFail ( t ,
2023-09-30 17:40:06 +00:00
"067eda13c4a36090ad28a7a183e9df611186ca01f63cb30fcdfa615ebfd6fb6d" ,
"32c1ece2c5dd2160ad03b243f50eff12db605b86ac92da47eacc78144bf0cdd3" ,
2023-09-30 13:18:27 +00:00
"a808915e31afc5b853d654d2519632dac7298ee2ecddc11695b8eba925935c2a" ,
2023-09-30 17:28:13 +00:00
"AmWxSwuUmqp9UsQX63U7OQ6K1thLI69L7G2b+j4DoIr0U0P/M1/oKm95z8qz6Kg0zQawLzwk3DskvWA2drXP4zK+tzHpKvWq0KOdx5MdypboSQsP4NXfhh2KoUffjkyIOiMA" ,
2023-09-30 13:18:27 +00:00
"invalid hmac" ,
)
}
func TestCryptFail006 ( t * testing . T ) {
assertDecryptFail ( t ,
2023-09-30 17:40:06 +00:00
"3e7be560fb9f8c965c48953dbd00411d48577e200cf00d7cc427e49d0e8d9c01" ,
"e539e5fee58a337307e2a937ee9a7561b45876fb5df405c5e7be3ee564b239cc" ,
2023-09-30 13:18:27 +00:00
"6ee3efc4255e3b8270e5dd3f7dc7f6b60878cda6218c8df34a3261cd48744931" ,
"Anq2XbuLvCuONcr7V0UxTh8FAyWoZNEdBHXvdbNmDZHBu7F9m36yBd58mVUBB5ktBTOJREDaQT1KAyPmZidP+IRea1lNw5YAEK7+pbnpfCw8CD0i2n8Pf2IDWlKDhLiVvatw" ,
"invalid padding" ,
)
}
func TestCryptFail007 ( t * testing . T ) {
assertDecryptFail ( t ,
2023-09-30 17:40:06 +00:00
"c22e1d4de967aa39dc143354d8f596cec1d7c912c3140831fff2976ce3e387c1" ,
"4e405be192677a2da95ffc733950777213bf880cf7c3b084eeb6f3fe5bd43705" ,
2023-09-30 13:18:27 +00:00
"1675a773dbf6fbcbef6a293004a4504b6c856978be738b10584b0269d437c8d1" ,
"An1Cg+O1TIhdav7ogfSOYvCj9dep4ctxzKtZSniCw5MwhT0hvSnF9Xjp9Lml792qtNbmAVvR6laukTe9eYEjeWPpZFxtkVpYTbbL9wDKFeplDMKsUKVa+roSeSvv0ela9seDVl2Sfso=" ,
"invalid padding" ,
)
}
func TestCryptFail008 ( t * testing . T ) {
assertDecryptFail ( t ,
2023-09-30 17:40:06 +00:00
"be1edab14c5912e5c59084f197f0945242e969c363096cccb59af8898815096f" ,
"9eaf0775d971e4941c97189232542e1daefcdb7dddafc39bcea2520217710ba2" ,
2023-09-30 13:18:27 +00:00
"1741a44c052d5ae363c7845441f73d2b6c28d9bfb3006190012bba12eb4c774b" ,
"Am+f1yZnwnOs0jymZTcRpwhDRHTdnrFcPtsBzpqVdD6bL9HUMo3Mjkz4bjQo/FJF2LWHmaCr9Byc3hU9D7we+EkNBWenBHasT1G52fZk9r3NKeOC1hLezNwBLr7XXiULh+NbMBDtJh9/aQh1uZ9EpAfeISOzbZXwYwf0P5M85g9XER8hZ2fgJDLb4qMOuQRG6CrPezhr357nS3UHwPC2qHo3uKACxhE+2td+965yDcvMTx4KYTQg1zNhd7PA5v/WPnWeq2B623yLxlevUuo/OvXplFho3QVy7s5QZVop6qV2g2/l/SIsvD0HIcv3V35sywOCBR0K4VHgduFqkx/LEF3NGgAbjONXQHX8ZKushsEeR4TxlFoRSovAyYjhWolz+Ok3KJL2Ertds3H+M/Bdl2WnZGT0IbjZjn3DS+b1Ke0R0X4Onww2ZG3+7o6ncIwTc+lh1O7YQn00V0HJ+EIp03heKV2zWdVSC615By/+Yt9KAiV56n5+02GAuNqA" ,
"invalid padding" ,
)
}