rippled
Loading...
Searching...
No Matches
PreimageSha256_test.cpp
1#include <xrpl/basics/Buffer.h>
2#include <xrpl/basics/Slice.h>
3#include <xrpl/basics/StringUtilities.h>
4#include <xrpl/basics/strHex.h>
5#include <xrpl/beast/unit_test.h>
6#include <xrpl/conditions/Condition.h>
7#include <xrpl/conditions/Fulfillment.h>
8#include <xrpl/conditions/detail/PreimageSha256.h>
9
10#include <algorithm>
11#include <string>
12#include <utility>
13#include <vector>
14
15namespace xrpl {
16namespace cryptoconditions {
17
19{
20 inline Buffer
22 {
23 auto blob = strUnHex(s);
24 BEAST_EXPECT(blob);
25 return {blob->data(), blob->size()};
26 }
27
28 void
30 {
31 testcase("Known Vectors");
32
34 {"A0028000",
35 "A0258020E3B0C44298FC1C149AFBF4C8996FB92427AE41E4649B934CA495991B7"
36 "852B855810100"},
37 {"A0058003616161",
38 "A02580209834876DCFB05CB167A5C24953EBA58C4AC89B1ADF57F28F2F9D09AF1"
39 "07EE8F0810103"},
40 };
41
43
44 auto f1 = Fulfillment::deserialize(hexblob(known[0].first), ec);
45 BEAST_EXPECT(f1);
46 BEAST_EXPECT(!ec);
47
48 auto c1 = Condition::deserialize(hexblob(known[0].second), ec);
49 BEAST_EXPECT(c1);
50 BEAST_EXPECT(!ec);
51
52 auto f2 = Fulfillment::deserialize(hexblob(known[1].first), ec);
53 BEAST_EXPECT(f2);
54 BEAST_EXPECT(!ec);
55
56 auto c2 = Condition::deserialize(hexblob(known[1].second), ec);
57 BEAST_EXPECT(c2);
58 BEAST_EXPECT(!ec);
59
60 // Check equality and inequality
61 BEAST_EXPECT(f1->condition() == *c1);
62 BEAST_EXPECT(f1->condition() != *c2);
63 BEAST_EXPECT(f2->condition() == *c2);
64 BEAST_EXPECT(f2->condition() != *c1);
65 BEAST_EXPECT(*c1 != *c2);
66 BEAST_EXPECT(*c1 == *c1);
67 BEAST_EXPECT(f1->condition() == f1->condition());
68
69 // Should validate with the empty string
70 BEAST_EXPECT(validate(*f1, *c1));
71 BEAST_EXPECT(validate(*f2, *c2));
72
73 // And with any string - the message doesn't matter for PrefixSha256
74 BEAST_EXPECT(validate(*f1, *c1, makeSlice(known[0].first)));
75 BEAST_EXPECT(validate(*f1, *c1, makeSlice(known[0].second)));
76 BEAST_EXPECT(validate(*f2, *c2, makeSlice(known[0].first)));
77 BEAST_EXPECT(validate(*f2, *c2, makeSlice(known[0].second)));
78
79 // Shouldn't validate if the fulfillment & condition don't match
80 // regardless of the message.
81 BEAST_EXPECT(!validate(*f2, *c1));
82 BEAST_EXPECT(!validate(*f2, *c1, makeSlice(known[0].first)));
83 BEAST_EXPECT(!validate(*f2, *c1, makeSlice(known[0].second)));
84 BEAST_EXPECT(!validate(*f1, *c2));
85 BEAST_EXPECT(!validate(*f1, *c2, makeSlice(known[0].first)));
86 BEAST_EXPECT(!validate(*f1, *c2, makeSlice(known[0].second)));
87 }
88
89 void
91 {
92 testcase("Other Types");
93
95 // PREFIX + PREIMAGE:
96 {"A10B8000810100A204A0028000",
97
98 "A12A8020BB1AC5260C0141B7E54B26EC2330637C5597BF811951AC09E744AD20F"
99 "F77E287810204"
100 "0082020780"},
101
102 // THRESHOLD:
103 {"A208A004A0028000A100",
104
105 "A22A8020B4B84136DF48A71D73F4985C04C6767A778ECB65BA7023B4506823BEE"
106 "E7631B9810204"
107 "0082020780"},
108
109 // RSA:
110 {"A382020880820100E1EF8B24D6F76B09C81ED7752AA262F044F04A874D43809D3"
111 "1CEA612F99B0C97"
112 "A8B4374153E3EEF3D66616843E0E41C293264B71B6173DB1CF0D6CD558C586577"
113 "06FCF097F704C48"
114 "3E59CBFDFD5B3EE7BC80D740C5E0F047F3E85FC0D75815776A6F3F23C5DC5E797"
115 "139A6882E38336A"
116 "4A5FB36137620FF3663DBAE328472801862F72F2F87B202B9C89ADD7CD5B0A076"
117 "F7C53E35039F67E"
118 "D17EC815E5B4305CC63197068D5E6E579BA6DE5F4E3E57DF5E4E072FF2CE4C66E"
119 "B45233973875275"
120 "9639F0257BF57DBD5C443FB5158CCE0A3D36ADC7BA01F33A0BB6DBB2BF989D607"
121 "112F2344D993E77"
122 "E563C1D361DEDF57DA96EF2CFC685F002B638246A5B309B981820100BD42D6569"
123 "F6599AED455F96B"
124 "C0ED08ED1480BF36CD9E1467F9C6F74461C9E3A749334B2F6404AA5F9F6BAFE76"
125 "C347D069250B35D"
126 "1C970C793059EE733A8193F30FA78FEC7CAE459E3DDFD7633805D476940D0CB53"
127 "D7FB389DCDAEAF6"
128 "E8CF48C4B5635430E4F2BCDFE505C2C0FC17B40D93C7EDB7C261EBF43895A705E"
129 "024AA0549A660F7"
130 "0A32150647522DBE6B63520497CFF8F8D5D74768A27C5B86E580BE3FCDC96F197"
131 "6293CBA0D58DFC6"
132 "0B518B632A6DC1E950C43E231FE1A379AA6DDCC52C70EDF851C6C0123A964261C"
133 "FDB3857CD6CD5AD"
134 "C37D8DA2CC924EDAE1D84CF6124587F274C1FA3697DA2901F0269F03B243C03B6"
135 "14E0385E1961FAC"
136 "5000F9BB",
137
138 "A3258020484950515253545548495051525354554849505152535455484950515"
139 "2535455810101"},
140
141 // ED25519:
142 {"A4648020D75A980182B10AB7D54BFED3C964073A0EE172F3DAA62325AF021A68F"
143 "707511A8140E556"
144 "4300C360AC729086E2CC806E828A84877F1EB8E5D974D873E065224901555FB88"
145 "21590A33BACC61E"
146 "39701CF9B46BD25BF5F0595BBE24655141438E7A100B",
147
148 "A4278020799239ABA8FC4FF7EABFBC4C44E69E8BDFED993324E12ED64792ABE28"
149 "9CF1D5F810302"
150 "0000"}};
151
152 for (auto x : others)
153 {
155
156 BEAST_EXPECT(!Fulfillment::deserialize(hexblob(x.first), ec));
157 BEAST_EXPECT(!Condition::deserialize(hexblob(x.second), ec));
158 }
159 }
160
161 void
162 run() override
163 {
166 }
167};
168
169BEAST_DEFINE_TESTSUITE(PreimageSha256, conditions, xrpl);
170
171} // namespace cryptoconditions
172
173} // namespace xrpl
A testsuite class.
Definition suite.h:51
testcase_t testcase
Memberspace for declaring test cases.
Definition suite.h:147
Like std::vector<char> but better.
Definition Buffer.h:16
static std::unique_ptr< Condition > deserialize(Slice s, std::error_code &ec)
Load a condition from its binary form.
bool validate(Fulfillment const &f, Condition const &c, Slice m)
Verify if the given message satisfies the fulfillment.
Use hash_* containers for keys that do not need a cryptographically secure hashing algorithm.
Definition algorithm.h:5
std::optional< Blob > strUnHex(std::size_t strSize, Iterator begin, Iterator end)
std::enable_if_t< std::is_same< T, char >::value||std::is_same< T, unsigned char >::value, Slice > makeSlice(std::array< T, N > const &a)
Definition Slice.h:213
static std::unique_ptr< Fulfillment > deserialize(Slice s, std::error_code &ec)
Load a fulfillment from its binary form.