Skip to content

Commit

Permalink
Add tests for SLH-DSA (FIPS 205)
Browse files Browse the repository at this point in the history
SLH-DSA test vectors generated from
https://github.com/mjosaarinen/py-acvp-pqc/tree/main.

Co-Authored-By: Amos Treiber <[email protected]>
  • Loading branch information
2 people authored and reneme committed Oct 14, 2024
1 parent 74b0e5e commit 028efec
Show file tree
Hide file tree
Showing 14 changed files with 361 additions and 126 deletions.
35 changes: 35 additions & 0 deletions src/cli/perf_pk_sig.cpp
Original file line number Diff line number Diff line change
Expand Up @@ -347,6 +347,41 @@ BOTAN_REGISTER_PERF_TEST("SPHINCS+", PerfTest_SPHINCSp);

#endif

#if defined(BOTAN_HAS_SLH_DSA_WITH_SHA2) || defined(BOTAN_HAS_SLH_DSA_WITH_SHAKE)

class PerfTest_SLH_DSA final : public PerfTest_PKSig {
public:
std::string algo() const override { return "SLH-DSA"; }

std::string hash() const override { return ""; }

std::string format_name(const std::string& alg, const std::string& param) const override {
BOTAN_UNUSED(alg);
return param; // Param already has algo in the string
}

std::vector<std::string> keygen_params(const PerfConfig& config) const override {
BOTAN_UNUSED(config);

return {"SLH-DSA-SHA2-128s",
"SLH-DSA-SHA2-128f",
"SLH-DSA-SHA2-192s",
"SLH-DSA-SHA2-192f",
"SLH-DSA-SHA2-256s",
"SLH-DSA-SHA2-256f",
"SLH-DSA-SHAKE-128s",
"SLH-DSA-SHAKE-128f",
"SLH-DSA-SHAKE-192s",
"SLH-DSA-SHAKE-192f",
"SLH-DSA-SHAKE-256s",
"SLH-DSA-SHAKE-256f"};
}
};

BOTAN_REGISTER_PERF_TEST("SLH-DSA", PerfTest_SLH_DSA);

#endif

#if defined(BOTAN_HAS_DILITHIUM) || defined(BOTAN_HAS_DILITHIUM_AES)

class PerfTest_Dilithium final : public PerfTest_PKSig {
Expand Down
1 change: 1 addition & 0 deletions src/cli/speed.cpp
Original file line number Diff line number Diff line change
Expand Up @@ -309,6 +309,7 @@ class Speed final : public Command {
"X25519",
"X448",
"Kyber",
"SLH-DSA",
"SPHINCS+",
"FrodoKEM",
"HSS-LMS",
Expand Down
2 changes: 1 addition & 1 deletion src/scripts/dev_tools/gen_sphincsplus_kat.py
Original file line number Diff line number Diff line change
Expand Up @@ -83,7 +83,7 @@ def main(args = None):

reader = KatReader(open(katfile, encoding="utf-8"))

hash_fn = sha256 if "sha2" in param else sha3_256
hash_fn = sha256 if "sha2" in param.lower() else sha3_256

l = 0
for kat in reader.read_kats():
Expand Down
2 changes: 1 addition & 1 deletion src/scripts/test_cli.py
Original file line number Diff line number Diff line change
Expand Up @@ -1623,7 +1623,7 @@ def cli_speed_pk_tests(_tmp_dir):

pk_algos = ["ECDSA", "ECDH", "SM2", "ECKCDSA", "ECGDSA", "GOST-34.10",
"DH", "DSA", "ElGamal", "Ed25519", "Ed448", "X25519", "X448",
"RSA", "RSA_keygen", "XMSS", "Kyber", "Dilithium", "SPHINCS+"]
"RSA", "RSA_keygen", "XMSS", "Kyber", "Dilithium", "SLH-DSA"]

output = test_cli("speed", ["--msec=%d" % (msec)] + pk_algos, None).split('\n')

Expand Down
4 changes: 2 additions & 2 deletions src/tests/data/pubkey/api_sign.vec
Original file line number Diff line number Diff line change
Expand Up @@ -54,9 +54,9 @@ SigParams = [email protected],SM3
AlgoParams = secp256r1
SigParams = [email protected],Raw

[SPHINCS+]
[SLH-DSA]

AlgoParams = SphincsPlus-shake-128s-r3.1
AlgoParams = SLH-DSA-SHA2-128f
SigParams =

[XMSS]
Expand Down
101 changes: 101 additions & 0 deletions src/tests/data/pubkey/slh_dsa.vec
Original file line number Diff line number Diff line change
@@ -0,0 +1,101 @@
# This test data is generated from the SLH_DSA implementation of https://github.com/mjosaarinen/py-acvp-pqc/tree/main
# See src/scripts/dev_tools/gen_pqc_dsa_kats.py
# To save space the signature is hashed with the hash function used in SPHINCS+
# (i.e. either SHA-3 or SHA-256).

SphincsParameterSet = SLH-DSA-SHA2-128s
seed = 23F1C88BD0E65F2C891CE865BD3275A7FFDBE4F9036E75B96AAD0412650E9CD2EA4591D4AB7131EA971B34C23A4ED245
msg = D81C4D8D734FCBFBEADE3D3F8A039FAA2A2C9957E835AD55B22E75BF57BB556AC8
pk = 5EF56915BB461280CD7A1428BF89ECFBACE44265B801314A0D20A6006C9FF1E6
sk = F696484048EC21F96CF50A56D0759C448F3779752F0383D37449690694CF7A685EF56915BB461280CD7A1428BF89ECFBACE44265B801314A0D20A6006C9FF1E6
HashSigDet = 34F54432D5AF7ACC187BB6221ED7EA6863A6EEDDDA016849C1CA8B7506251003
HashSigRand = 1C1DDB4F6EBF48CB706C765FB598CDC22C7F8543BC183FC58F230160773F7AAA

SphincsParameterSet = SLH-DSA-SHAKE-128s
seed = 6FB79C668EB6E0F65A09135CDD243CE205D7065A0924F86024ADCD111F654A6DFE2E398A12369064C2A217229113E570
msg = D81C4D8D734FCBFBEADE3D3F8A039FAA2A2C9957E835AD55B22E75BF57BB556AC8
pk = F08E01A57A272B738FA8EA2F465D59400B96B2F9934DAA0DA7C9873550013599
sk = 6DE62E3465A55C9C78A07D265BE8540B3E58B0801A124D07FF12B438D5202EA0F08E01A57A272B738FA8EA2F465D59400B96B2F9934DAA0DA7C9873550013599
HashSigDet = 3F74A7A28E32DA3BE820E7FFA9344814A3227BDFBFDEBEC60DC883B0A9F141B6
HashSigRand = F9180D932F295F34FD4C421D5BBE9199D003D6B080BFA63BAFEDA8127BE029F4

SphincsParameterSet = SLH-DSA-SHA2-128f
seed = AD4D2D306639620AFCB3753A137F89331836A5ADCE1C40BEBE77B82D43A40D3249000C7AA3786406D5D5FA65462D1A57
msg = D81C4D8D734FCBFBEADE3D3F8A039FAA2A2C9957E835AD55B22E75BF57BB556AC8
pk = 67B4319D2F67BAE52055DCD010A25A16220B1DDABBED69F503B5F07CBBA7F134
sk = 1EAAE6BB91B27CD748C402C4111140D5A942CF3C95FF7977F88D2EF515BB26D067B4319D2F67BAE52055DCD010A25A16220B1DDABBED69F503B5F07CBBA7F134
HashSigDet = A19E2A5AE585EC140DC8C6910847C1E67EA2A96E6707E96F3F5646C23393ED1E
HashSigRand = 210C514552736ED214130EE31982DF2BE25FBBE25FA3465EDC9096AA6D6D0037

SphincsParameterSet = SLH-DSA-SHAKE-128f
seed = 950684CB360FF0C011FD02A09A273C9F023D0A34AE0AA338C6F5283634AE9BEF5D100BCD48F6577E5910BEAAFE6C52C3
msg = D81C4D8D734FCBFBEADE3D3F8A039FAA2A2C9957E835AD55B22E75BF57BB556AC8
pk = A27E9866875FD15DFB375E035774304B8C608A901A6194334B70B7C8D4E2BF82
sk = B585D4EB01085111A172A87688D0032E3381A9E9A35FDD6EF2F8AEB3B40EB5CEA27E9866875FD15DFB375E035774304B8C608A901A6194334B70B7C8D4E2BF82
HashSigDet = 0C63B2FE04DA937129A6649B87AB6E3BCDCB3C587D1B25567B13624D75BB4449
HashSigRand = 56A9105B8772FA6719BE5331506F200872AB61FDDD54C3C698FC53613EFEDCFC

SphincsParameterSet = SLH-DSA-SHA2-192s
seed = 0633CCD19471803E0CEFFC7A11B2E7B70C3329DFDDE5BE18160DF0D4C609900D67154893921376CC4B4B8C586E3EFE79
msg = D81C4D8D734FCBFBEADE3D3F8A039FAA2A2C9957E835AD55B22E75BF57BB556AC8
pk = C9C02F34DAF335681F00668A6B4209CAAD8F0A98AFD3CB6A10AC13A54B552951257A36F005A60E3F1D4FC605C6C69CA8
sk = A9F93C7B791356B66AFCCEB745A548C7F6B185E4F45EC1FF1A22ACDD96E7A6D8D290F4ECB0E97B42C65CE45583DA8AD8C9C02F34DAF335681F00668A6B4209CAAD8F0A98AFD3CB6A10AC13A54B552951257A36F005A60E3F1D4FC605C6C69CA8
HashSigDet = 36A7CE4B9FAAB952245E1218098B0A8C5FC93FC672146CA49DB0C84444C3664F
HashSigRand = 902880A875BE16D2957838CC4AA45951F2B68B07F4A52034F1CF15D88ECF2266

SphincsParameterSet = SLH-DSA-SHAKE-192s
seed = 2605426643CAB04B2801416B3239CD046DFE7BA59874A3A05C5B32A4505F21D8B7217B5ECC8646FC6A845211AE4BC708
msg = D81C4D8D734FCBFBEADE3D3F8A039FAA2A2C9957E835AD55B22E75BF57BB556AC8
pk = 311E8EADB8A321C1BF80F61581DF0DA196F0F694B5C335BCDF767CDAD5DAB7542ECB362183467BD0FC5B334A7D615F61
sk = 85DA83B47129711A63C2C2F6A5BCB701237B2B0B66814EEC9FCC1C560992A5962A826338E5C2F03BDEA549E2BCCD8463311E8EADB8A321C1BF80F61581DF0DA196F0F694B5C335BCDF767CDAD5DAB7542ECB362183467BD0FC5B334A7D615F61
HashSigDet = 2BC141EE0A76E1AD588FCA079A036A0B5B629D651020AEF36EA16AFDF55C2F2D
HashSigRand = E01FE5D4ACA562FA07EEA7995F150B933ED5ED5446DD6D70E67F6755DC64E0A8

SphincsParameterSet = SLH-DSA-SHA2-192f
seed = D3880D1B7802B4A3277687863C5A248BEFC95D3E4748403F3BB61F83ABCDDEAE42AE6C8624812FD38F463122D99D59A9
msg = D81C4D8D734FCBFBEADE3D3F8A039FAA2A2C9957E835AD55B22E75BF57BB556AC8
pk = F04CA9D2E28AFCA52EA1C8178445CAD8C8F4EFC9D99F4753B1170FF7DF5359A4277F8EF072A833EE58C420A436928774
sk = F7ECFC9143EE45E44F5E98FD9CA1455340EC5DB4FB098534365EBBFBCC57D34DDE0999AA0C3992D155B9D6BE993CB9D7F04CA9D2E28AFCA52EA1C8178445CAD8C8F4EFC9D99F4753B1170FF7DF5359A4277F8EF072A833EE58C420A436928774
HashSigDet = 1B8CB853E473AE803E5CB46B4A1002DA48BD35EA7CEB40A3E81F5887F5934941
HashSigRand = EC603A2DEF5A114F8836BDF29B175CD1379AF303FABC4F76E9249FA0A89DABE8

SphincsParameterSet = SLH-DSA-SHAKE-192f
seed = 343B81870E2721DD75EE0AD7FDB269EB5AAE0AE83A6316AD8ECE3C76D3DD3CC391F1B12B22E988C1257B5F56D905A06C
msg = D81C4D8D734FCBFBEADE3D3F8A039FAA2A2C9957E835AD55B22E75BF57BB556AC8
pk = 5DAB087C2E696072C3A207A25C42FBC1AA96FB8EC2A5AF71CAF5215B739F48EE14FBBE4B0CE50DBF8104998CA133E19C
sk = DAA360ECBB51BCB33F5D36F92FFFE77C2DE7ED43D281DCB5FD68CFA0CE19DF2EB36398FFAEF28A6AC96AE6CEC608B0545DAB087C2E696072C3A207A25C42FBC1AA96FB8EC2A5AF71CAF5215B739F48EE14FBBE4B0CE50DBF8104998CA133E19C
HashSigDet = BF373807C8981EC8BD76C0758BA7DB9F8FB77BC7E1D23D5FD00699CF3912D9BC
HashSigRand = 7A341802EEAA6EF566C928094409BEB4824B53958E5C7F943127F2DDFEFC5B18

SphincsParameterSet = SLH-DSA-SHA2-256s
seed = 406D9C95F9813CA6A9E6071D3A7A63093F9E00CD15EE968C3AB28CB7368699491E5662F6B63721FE059D50295C3A7516
msg = D81C4D8D734FCBFBEADE3D3F8A039FAA2A2C9957E835AD55B22E75BF57BB556AC8
pk = B2EA4B9157C191935629E8914AB581799F366ECC13A153BA88961EBD2D25E7B8126760D273E037DC76CFF5EDDECABEAD489F8A725BE650544C1E3145042D0C2A
sk = AD10AD3409A90C4B24AB0DA526F289209ABCB1F05C86C7E4437A144C91E1C8674BB0634876C4471D23C2F3A041A9830DAD41945642DA3487CE5D2E9E2BE9A1D4B2EA4B9157C191935629E8914AB581799F366ECC13A153BA88961EBD2D25E7B8126760D273E037DC76CFF5EDDECABEAD489F8A725BE650544C1E3145042D0C2A
HashSigDet = F2E3FB0542D8164853BC0E1BE95125F346B75508D92272E41E009B3AC55AFC0C
HashSigRand = E7FA299EEBFB885BE6B7327B20FF4414A74952DB7A4FF12B34242A5E60376F1B


SphincsParameterSet = SLH-DSA-SHAKE-256s
seed = B3C83C13DD15DFFE58FDB6026D32E33E5EF24B094BE16741DD5B587EA841AD19B6F026A127678849EC1B459A365FD645
msg = D81C4D8D734FCBFBEADE3D3F8A039FAA2A2C9957E835AD55B22E75BF57BB556AC8
pk = E23D931A7E2679EB15C2D3727552A5A5686B13F319C17C48FCAE2CA136D9FE223B5F3C9B72D1318EC5C18191238914691955FBD06947CE3E7010809FD3D31832
sk = 793871AFCCB50F4035B9788C7292B717939AA28F5094D99EE262047B15E42DEB92568F82621D1EE33A233B858296887279FF85CFDA7F5C415B714E9451CB20A6E23D931A7E2679EB15C2D3727552A5A5686B13F319C17C48FCAE2CA136D9FE223B5F3C9B72D1318EC5C18191238914691955FBD06947CE3E7010809FD3D31832
HashSigDet = FE25C9658E9AFE5D1A67480C5202DEBC2C05C4D3FB2BFBD875723DEA9AB8D195
HashSigRand = 66BA90FC5E104EE0D8F53835C4748B251D546DC3C40A8E18016EAD928D26F748

SphincsParameterSet = SLH-DSA-SHA2-256f
seed = 937BD532FF7C92404ACA9C2389E314F72D780234E1FD930F967A724937204C59877AF25D38245638FDA72B0EE74F8492
msg = D81C4D8D734FCBFBEADE3D3F8A039FAA2A2C9957E835AD55B22E75BF57BB556AC8
pk = 36B35AEFAEEF610994159BA32295631C237F59D285E62248442D5CCCA196973D3DFE70C01BD69E90313BA13437891E8AEBBFB4D42FCCCDFDF98655B272757553
sk = EDB1483BD9DB934A5C0970C76E96ADAC58C2786F5525CCE741206154222B1BADA4B54A813A208AD3472C64BEF72AA37AD944484A7525B3BFAB58B72D5878ADCC36B35AEFAEEF610994159BA32295631C237F59D285E62248442D5CCCA196973D3DFE70C01BD69E90313BA13437891E8AEBBFB4D42FCCCDFDF98655B272757553
HashSigDet = 3883D4E0A47250B66D44E80CD19E4F55195A89C2C1E020CFC534347DF7D00302
HashSigRand = A5D79BF02F5EDDAA10B9A18BC19E7F90593D67B33867D318F7A12C0BD3138C71

SphincsParameterSet = SLH-DSA-SHAKE-256f
seed = 075D939507DDEAB7C64FB847EDB74CF693866BEA32C93BC5C129CBD7141C0B79901B26992481236A56CB404D464DA0E1
msg = D81C4D8D734FCBFBEADE3D3F8A039FAA2A2C9957E835AD55B22E75BF57BB556AC8
pk = 95E8F648FB380F083398E4A3400C07724162FA30E25E8D3784A2E90FDF27CDBB4456B4892B3A49FD6DE7CDAE86D7432BF8F651E09B2920AD7D0618CCF70135E8
sk = EC5FD75F942B76A278C3F4DF4C25B0DD5DB712A253CC8B9C22287BEFAFBEB6257E53018E4F2B21F571E02C8B128F401ED16391B74336DDD719A0306DB181135395E8F648FB380F083398E4A3400C07724162FA30E25E8D3784A2E90FDF27CDBB4456B4892B3A49FD6DE7CDAE86D7432BF8F651E09B2920AD7D0618CCF70135E8
HashSigDet = F3A817C8FC206F5F65B3FFE1225588E74A698C58D478214CCAA80EE684D5A0EE
HashSigRand = 3B5C559EBC8AB40DACAC2214830B64EF2237F3EBFEA296021F86588759354AC8
13 changes: 13 additions & 0 deletions src/tests/data/pubkey/slh_dsa_generic.vec

Large diffs are not rendered by default.

24 changes: 12 additions & 12 deletions src/tests/data/pubkey/sphincsplus.vec
Original file line number Diff line number Diff line change
Expand Up @@ -12,81 +12,81 @@ seed = 061550234D158C5EC95595FE04EF7A25767F2E24CC2BC479D09D86DC9ABCFDE7056A8C266
msg = D81C4D8D734FCBFBEADE3D3F8A039FAA2A2C9957E835AD55B22E75BF57BB556AC8
pk = B505D7CFAD1B497499323C8686325E47AFBC007BA1E2B4A138F03AA9A6195AC8
sk = 7C9935A0B07694AA0C6D10E4DB6B1ADD2FD81A25CCB148032DCD739936737F2DB505D7CFAD1B497499323C8686325E47AFBC007BA1E2B4A138F03AA9A6195AC8
HashSig = 7FAF31F05279B409B15FB258C07B666F4917C2F361ECBF996E6D4CFB8F36BCC6
HashSigRand = 7FAF31F05279B409B15FB258C07B666F4917C2F361ECBF996E6D4CFB8F36BCC6

SphincsParameterSet = SphincsPlus-shake-128s-r3.1
seed = 061550234D158C5EC95595FE04EF7A25767F2E24CC2BC479D09D86DC9ABCFDE7056A8C266F9EF97ED08541DBD2E1FFA1
msg = D81C4D8D734FCBFBEADE3D3F8A039FAA2A2C9957E835AD55B22E75BF57BB556AC8
pk = B505D7CFAD1B497499323C8686325E47AC524902FC81F5032BC27B17D9261EBD
sk = 7C9935A0B07694AA0C6D10E4DB6B1ADD2FD81A25CCB148032DCD739936737F2DB505D7CFAD1B497499323C8686325E47AC524902FC81F5032BC27B17D9261EBD
HashSig = 6A8EB621C4E5D927275C86CD3DE84FAB1898BCB433FE218EE71D30482BA30F54
HashSigRand = 6A8EB621C4E5D927275C86CD3DE84FAB1898BCB433FE218EE71D30482BA30F54

SphincsParameterSet = SphincsPlus-shake-192f-r3.1
seed = 061550234D158C5EC95595FE04EF7A25767F2E24CC2BC479D09D86DC9ABCFDE7056A8C266F9EF97ED08541DBD2E1FFA1
msg = D81C4D8D734FCBFBEADE3D3F8A039FAA2A2C9957E835AD55B22E75BF57BB556AC8
pk = 92F267AAFA3F87CA60D01CB54F29202A3E784CCB7EBCDCFD9B836B00B9F458C1A193F062A9A3CDAFE7869F47546CB346
sk = 7C9935A0B07694AA0C6D10E4DB6B1ADD2FD81A25CCB148032DCD739936737F2DB505D7CFAD1B497499323C8686325E4792F267AAFA3F87CA60D01CB54F29202A3E784CCB7EBCDCFD9B836B00B9F458C1A193F062A9A3CDAFE7869F47546CB346
HashSig = 37BFD608EF6890087D3CD8DEAA61D884CFA4C2B0D46D0E9661C58B3A592056E2
HashSigRand = 37BFD608EF6890087D3CD8DEAA61D884CFA4C2B0D46D0E9661C58B3A592056E2

SphincsParameterSet = SphincsPlus-shake-192s-r3.1
seed = 061550234D158C5EC95595FE04EF7A25767F2E24CC2BC479D09D86DC9ABCFDE7056A8C266F9EF97ED08541DBD2E1FFA1
msg = D81C4D8D734FCBFBEADE3D3F8A039FAA2A2C9957E835AD55B22E75BF57BB556AC8
pk = 92F267AAFA3F87CA60D01CB54F29202A3E784CCB7EBCDCFD0BDE2780ED4CCDAF544D88F22D41610D4EF994825CFB4D45
sk = 7C9935A0B07694AA0C6D10E4DB6B1ADD2FD81A25CCB148032DCD739936737F2DB505D7CFAD1B497499323C8686325E4792F267AAFA3F87CA60D01CB54F29202A3E784CCB7EBCDCFD0BDE2780ED4CCDAF544D88F22D41610D4EF994825CFB4D45
HashSig = 28765D857CCE9D98D9A56745B3AD2280B08A6188B08EB23ECE4974B02CE55D90
HashSigRand = 28765D857CCE9D98D9A56745B3AD2280B08A6188B08EB23ECE4974B02CE55D90

SphincsParameterSet = SphincsPlus-shake-256f-r3.1
seed = 061550234D158C5EC95595FE04EF7A25767F2E24CC2BC479D09D86DC9ABCFDE7056A8C266F9EF97ED08541DBD2E1FFA1
msg = D81C4D8D734FCBFBEADE3D3F8A039FAA2A2C9957E835AD55B22E75BF57BB556AC8
pk = 3E784CCB7EBCDCFD45542B7F6AF778742E0F4479175084AA488B3B74340678AA514264D1B7EF27574AE6933E374225CF87683DE3BFEE657200F3667C8D800722
sk = 7C9935A0B07694AA0C6D10E4DB6B1ADD2FD81A25CCB148032DCD739936737F2DB505D7CFAD1B497499323C8686325E4792F267AAFA3F87CA60D01CB54F29202A3E784CCB7EBCDCFD45542B7F6AF778742E0F4479175084AA488B3B74340678AA514264D1B7EF27574AE6933E374225CF87683DE3BFEE657200F3667C8D800722
HashSig = 9332A86A6A9C73728B70D2911C81D37D44D2612E62D925824563DCE3064036E7
HashSigRand = 9332A86A6A9C73728B70D2911C81D37D44D2612E62D925824563DCE3064036E7

SphincsParameterSet = SphincsPlus-shake-256s-r3.1
seed = 061550234D158C5EC95595FE04EF7A25767F2E24CC2BC479D09D86DC9ABCFDE7056A8C266F9EF97ED08541DBD2E1FFA1
msg = D81C4D8D734FCBFBEADE3D3F8A039FAA2A2C9957E835AD55B22E75BF57BB556AC8
pk = 3E784CCB7EBCDCFD45542B7F6AF778742E0F4479175084AA488B3B74340678AA3623940D5D834494148A661F9AC6A96BDC54AD4D0B8B0913484A9233C56212A4
sk = 7C9935A0B07694AA0C6D10E4DB6B1ADD2FD81A25CCB148032DCD739936737F2DB505D7CFAD1B497499323C8686325E4792F267AAFA3F87CA60D01CB54F29202A3E784CCB7EBCDCFD45542B7F6AF778742E0F4479175084AA488B3B74340678AA3623940D5D834494148A661F9AC6A96BDC54AD4D0B8B0913484A9233C56212A4
HashSig = D0E3EEC05FA643A3952CD718948811578C36D7086C4EEE26FD401AFC867AFCF4
HashSigRand = D0E3EEC05FA643A3952CD718948811578C36D7086C4EEE26FD401AFC867AFCF4

SphincsParameterSet = SphincsPlus-sha2-128f-r3.1
seed = 061550234D158C5EC95595FE04EF7A25767F2E24CC2BC479D09D86DC9ABCFDE7056A8C266F9EF97ED08541DBD2E1FFA1
msg = D81C4D8D734FCBFBEADE3D3F8A039FAA2A2C9957E835AD55B22E75BF57BB556AC8
pk = B505D7CFAD1B497499323C8686325E47FDF7400AB7A5D8C7ABA7350AC4092ADD
sk = 7C9935A0B07694AA0C6D10E4DB6B1ADD2FD81A25CCB148032DCD739936737F2DB505D7CFAD1B497499323C8686325E47FDF7400AB7A5D8C7ABA7350AC4092ADD
HashSig = 75467372C5E79953BC8D69C2A05982813F9934ADC7D0864AB0F63A65B19CDF93
HashSigRand = 75467372C5E79953BC8D69C2A05982813F9934ADC7D0864AB0F63A65B19CDF93

SphincsParameterSet = SphincsPlus-sha2-128s-r3.1
seed = 061550234D158C5EC95595FE04EF7A25767F2E24CC2BC479D09D86DC9ABCFDE7056A8C266F9EF97ED08541DBD2E1FFA1
msg = D81C4D8D734FCBFBEADE3D3F8A039FAA2A2C9957E835AD55B22E75BF57BB556AC8
pk = B505D7CFAD1B497499323C8686325E476D2E5993D919B7F288CC823133046CF9
sk = 7C9935A0B07694AA0C6D10E4DB6B1ADD2FD81A25CCB148032DCD739936737F2DB505D7CFAD1B497499323C8686325E476D2E5993D919B7F288CC823133046CF9
HashSig = 79F3F09AB540EBB40F9C7691A019D0355EC540410CB7AC7A32146256D3F20E09
HashSigRand = 79F3F09AB540EBB40F9C7691A019D0355EC540410CB7AC7A32146256D3F20E09

SphincsParameterSet = SphincsPlus-sha2-192f-r3.1
seed = 061550234D158C5EC95595FE04EF7A25767F2E24CC2BC479D09D86DC9ABCFDE7056A8C266F9EF97ED08541DBD2E1FFA1
msg = D81C4D8D734FCBFBEADE3D3F8A039FAA2A2C9957E835AD55B22E75BF57BB556AC8
pk = 92F267AAFA3F87CA60D01CB54F29202A3E784CCB7EBCDCFDAD7EF867981E22877AA4C2A8829F657E931C55409B897D2E
sk = 7C9935A0B07694AA0C6D10E4DB6B1ADD2FD81A25CCB148032DCD739936737F2DB505D7CFAD1B497499323C8686325E4792F267AAFA3F87CA60D01CB54F29202A3E784CCB7EBCDCFDAD7EF867981E22877AA4C2A8829F657E931C55409B897D2E
HashSig = 535FD6592D279F7A1AA16ABD49D5FA257272C026629794DA3F6FC92B41E59146
HashSigRand = 535FD6592D279F7A1AA16ABD49D5FA257272C026629794DA3F6FC92B41E59146

SphincsParameterSet = SphincsPlus-sha2-192s-r3.1
seed = 061550234D158C5EC95595FE04EF7A25767F2E24CC2BC479D09D86DC9ABCFDE7056A8C266F9EF97ED08541DBD2E1FFA1
msg = D81C4D8D734FCBFBEADE3D3F8A039FAA2A2C9957E835AD55B22E75BF57BB556AC8
pk = 92F267AAFA3F87CA60D01CB54F29202A3E784CCB7EBCDCFDEE27692EF30BAD87B55C4E2A25E7F47875C1F53723CE31C6
sk = 7C9935A0B07694AA0C6D10E4DB6B1ADD2FD81A25CCB148032DCD739936737F2DB505D7CFAD1B497499323C8686325E4792F267AAFA3F87CA60D01CB54F29202A3E784CCB7EBCDCFDEE27692EF30BAD87B55C4E2A25E7F47875C1F53723CE31C6
HashSig = FBC7B620E045AD67D132D2D8CDB0EA1D1CF231B85671CDB396DF5D4D608E974E
HashSigRand = FBC7B620E045AD67D132D2D8CDB0EA1D1CF231B85671CDB396DF5D4D608E974E

SphincsParameterSet = SphincsPlus-sha2-256f-r3.1
seed = 061550234D158C5EC95595FE04EF7A25767F2E24CC2BC479D09D86DC9ABCFDE7056A8C266F9EF97ED08541DBD2E1FFA1
msg = D81C4D8D734FCBFBEADE3D3F8A039FAA2A2C9957E835AD55B22E75BF57BB556AC8
pk = 3E784CCB7EBCDCFD45542B7F6AF778742E0F4479175084AA488B3B74340678AAD9D73F07F69A7D12C49B9A367DE0668544E8471660678A4EF7CEE8BE9638CA53
sk = 7C9935A0B07694AA0C6D10E4DB6B1ADD2FD81A25CCB148032DCD739936737F2DB505D7CFAD1B497499323C8686325E4792F267AAFA3F87CA60D01CB54F29202A3E784CCB7EBCDCFD45542B7F6AF778742E0F4479175084AA488B3B74340678AAD9D73F07F69A7D12C49B9A367DE0668544E8471660678A4EF7CEE8BE9638CA53
HashSig = 4FFFA9B69ABFEEFDC31A1D59EB503A362BFCF6FF5320CE3E8D9E0BB75BAB961D
HashSigRand = 4FFFA9B69ABFEEFDC31A1D59EB503A362BFCF6FF5320CE3E8D9E0BB75BAB961D

SphincsParameterSet = SphincsPlus-sha2-256s-r3.1
seed = 061550234D158C5EC95595FE04EF7A25767F2E24CC2BC479D09D86DC9ABCFDE7056A8C266F9EF97ED08541DBD2E1FFA1
msg = D81C4D8D734FCBFBEADE3D3F8A039FAA2A2C9957E835AD55B22E75BF57BB556AC8
pk = 3E784CCB7EBCDCFD45542B7F6AF778742E0F4479175084AA488B3B74340678AA026F566CDCD2987EB7AB1EC71E86B617F97B98EF63902E283FB5249119C6CEB0
sk = 7C9935A0B07694AA0C6D10E4DB6B1ADD2FD81A25CCB148032DCD739936737F2DB505D7CFAD1B497499323C8686325E4792F267AAFA3F87CA60D01CB54F29202A3E784CCB7EBCDCFD45542B7F6AF778742E0F4479175084AA488B3B74340678AA026F566CDCD2987EB7AB1EC71E86B617F97B98EF63902E283FB5249119C6CEB0
HashSig = 27A5A600A541485A34E263EFA546829F573FE215DB5DB66C1BDB1F49D9CB0A98
HashSigRand = 27A5A600A541485A34E263EFA546829F573FE215DB5DB66C1BDB1F49D9CB0A98
2 changes: 1 addition & 1 deletion src/tests/test_pubkey.cpp
Original file line number Diff line number Diff line change
Expand Up @@ -611,7 +611,7 @@ std::vector<Test::Result> PK_Key_Generation_Test::run() {
oid.value().to_string(),
key.object_identifier().to_string());
} else {
const bool exception = name == "Kyber" || name == "FrodoKEM" || name == "SPHINCS+";
const bool exception = name == "Kyber" || name == "FrodoKEM" || name == "SLH-DSA" || name == "SPHINCS+";

if(!exception) {
result.test_failure("Keys name " + name + " does not map to an OID");
Expand Down
Loading

0 comments on commit 028efec

Please sign in to comment.