20 #include <ripple/beast/unit_test.h>
21 #include <ripple/protocol/PublicKey.h>
22 #include <ripple/protocol/SecretKey.h>
32 template <
class FwdIter,
class Container>
42 for (
int i = 0; i < 10; ++i)
44 for (
int i = 0; i < 6; ++i)
46 val[
'A' + i] = 10 + i;
47 val[
'a' + i] = 10 + i;
61 auto const hi(lut[(*first++)]);
62 auto const lo(lut[(*first++)]);
63 out.push_back((hi * 16) + lo);
84 testcase(
"Canonical");
90 "022100FF478110D1D4294471EC76E0157540C2181F47DEBD25D7F9E7DDCCCD47EE"
92 "0220078F07CDAE6C240855D084AD91D1479609533C147C93B0AEF19BC9724D003F"
97 "0221009218248292F1762D8A51BE80F8A7F2CD288D810CE781D5955700DA1684DF"
99 "022041A1EE1746BFD72C9760CC93A7AAA8047D52C8833A03A20EAAE92EA19717B4"
104 "02206A9E43775F73B6D1EC420E4DDD222A80D4C6DF5D1BEECC431A91B63C928B75"
106 "022023E9CC2D61DDA6F73EAA6BCB12688BEB0F434769276B3127E4044ED895C9D9"
111 "022056E720007221F3CD4EFBB6352741D8E5A0968D48D8D032C2FBC4F6304AD1D0"
113 "02201F39EB392C20D7801C3E8D81D487E742FA84A1665E923225BD6323847C7187"
118 "022100FDFD5AD05518CEA0017A2DCB5C4DF61E7C73B6D3A38E7AE93210A1564E8C"
120 "0220214FF061CCC123C81D0BB9D0EDEA04CD40D96BF1425D311DA62A7096BB18EA"
127 "022100F477B3FA6F31C7CB3A0D1AD94A231FDD24B8D78862EE334CEA7CD08F6CBC"
129 "022100928E6BCF1ED2684679730C5414AEC48FD62282B090041C41453C1D064AF5"
134 "022063E7C7CA93CB2400E413A342C027D00665F8BAB9C22EF0A7B8AE3AAF092230"
136 "0221008F2E8BB7D09521ABBC277717B14B93170AE6465C5A1B36561099319C4BEB"
141 "02210099DCA1188663DDEA506A06A7B20C2B7D8C26AFF41DECE69D6C5F7C967D32"
143 "022100897658A6B1F9EEE5D140D7A332DA0BD73BB98974EA53F6201B01C1B594F2"
148 "02200855DE366E4E323AA2CE2A25674401A7D11F72EC432770D07F7B57DF7387AE"
150 "022100DA4C6ADDEA14888858DE2AC5B91ED9050D6972BB388DEF582628CEE32869"
162 "02203932c892e2e550f3af8ee4ce9c215a87f9bb831dcac87b2838e2c2eaa891df"
164 "022030b61dd36543125d56b9f9f3a1f53189e5af33cdda8d77a5209aec03978fa0"
169 "0220076045be6f9eca28ff1ec606b833d0b87e70b2a630f5e3a496b110967a40f9"
171 "0221008fffd599910eefe00bc803c688eca1d2ba7f6b180620eaa03488e6585db6"
176 "022100876045be6f9eca28ff1ec606b833d0b87e70b2a630f5e3a496b110967a40"
178 "0221008fffd599910eefe00bc803c688c2eca1d2ba7f6b180620eaa03488e6585d"
224 "0221005990e0584b2b238e1dfaad8d6ed69ecc1a4a13ac85fc0b31d0df395eb1ba"
226 "022200002d5876262c288beb511d061691bf26777344b702b00f8fe28621fe4e56"
231 "02205990e0584b2b238e1dfaad8d6ed69ecc1a4a13ac85fc0b31d0df395eb1ba61"
233 "02202d5876262c288beb511d061691bf26777344b702b00f8fe28621fe4e566695"
238 "02205990e0584b2b238e1dfaad8d6ed69ecc1a4a13ac85fc0b31d0df395eb1ba61"
240 "02202d5876262c288beb511d061691bf26777344b702b00f8fe28621fe4e566695"
245 "01205990e0584b2b238e1dfaad8d6ed69ecc1a4a13ac85fc0b31d0df395eb1"));
249 "02205990e0584b2b238e1dfaad8d6ed69ecc1a4a13ac85fc0b31d0df395eb1ba61"
251 "02202d5876262c288beb511d061691bf26777344b702b00f8fe28621fe4e566695"
256 "01205990e0584b2b238e1dfaad8d6ed69ecc1a4a13ac85fc0b31d0df395eb1ba61"
258 "02202d5876262c288beb511d061691bf26777344b702b00f8fe28621fe4e566695"
264 "02202d5876262c288beb511d061691bf26777344b702b00f8fe28621fe4e566695"
269 "02208990e0584b2b238e1dfaad8d6ed69ecc1a4a13ac85fc0b31d0df395eb1ba61"
271 "02202d5876262c288beb511d061691bf26777344b702b00f8fe28621fe4e566695"
276 "0221005990e0584b2b238e1dfaad8d6ed69ecc1a4a13ac85fc0b31d0df395eb1ba"
278 "02202d5876262c288beb511d061691bf26777344b702b00f8fe28621fe4e566695"
283 "02205990e0584b2b238e1dfaad8d6ed69ecc1a4a13ac85fc0b31d0df395eb1ba61"
285 "02d5876262c288beb511d061691bf26777344b702b00f8fe28621fe4e566695e"
290 "02205990e0584b2b238e1dfaad8d6ed69ecc1a4a13ac85fc0b31d0df395eb1ba61"
296 "02205990e0584b2b238e1dfaad8d6ed69ecc1a4a13ac85fc0b31d0df395eb1ba61"
298 "0220fd5876262c288beb511d061691bf26777344b702b00f8fe28621fe4e566695"
303 "02205990e0584b2b238e1dfaad8d6ed69ecc1a4a13ac85fc0b31d0df395eb1ba61"
305 "0221002d5876262c288beb511d061691bf26777344b702b00f8fe28621fe4e5666"
330 s.erase(r(s) % s.size(), 1);
339 s.resize(s.size() + i, s[i % s.size()]);
374 BEAST_EXPECT(!si.empty());
377 BEAST_EXPECT(ski && (keys[i] == *ski));
381 BEAST_EXPECT((keys[i] == keys[j]) == (i == j));
385 BEAST_EXPECT((si == sj) == (i == j));
389 BEAST_EXPECT(skj && (keys[j] == *skj));
391 BEAST_EXPECT((*ski == *skj) == (i == j));
399 testcase(
"Base58: secp256k1");
407 auto const pk2 = parseBase58<PublicKey>(
409 "n94a1u4jAz288pZLtw6yFWVbi89YamiC6JBXPVUj5zmExe5fTVg9");
412 BEAST_EXPECT(pk1 == *pk2);
417 testcase(
"Base58: ed25519");
425 auto const pk2 = parseBase58<PublicKey>(
427 "nHUeeJCSY2dM71oxM8Cgjouf5ekTuev2mwDpc374aLMxzDLXNmjf");
430 BEAST_EXPECT(pk1 == *pk2);
439 testcase(
"Miscellaneous operations");
447 BEAST_EXPECT(pk1 == pk2);
448 BEAST_EXPECT(pk2 == pk1);
452 BEAST_EXPECT(pk3 == pk2);
453 BEAST_EXPECT(pk1 == pk3);