rippled
Loading...
Searching...
No Matches
PaymentChannelClaimTests.cpp
1// Auto-generated unit tests for transaction PaymentChannelClaim
2
3
4#include <gtest/gtest.h>
5
6#include <protocol_autogen/TestHelpers.h>
7
8#include <xrpl/protocol/SecretKey.h>
9#include <xrpl/protocol/Seed.h>
10#include <xrpl/protocol/STTx.h>
11#include <xrpl/protocol_autogen/transactions/PaymentChannelClaim.h>
12#include <xrpl/protocol_autogen/transactions/AccountSet.h>
13
14#include <string>
15
16namespace xrpl::transactions {
17
18// 1 & 4) Set fields via builder setters, build, then read them back via
19// wrapper getters. After build(), validate() should succeed.
20TEST(TransactionsPaymentChannelClaimTests, BuilderSettersRoundTrip)
21{
22 // Generate a deterministic keypair for signing
23 auto const [publicKey, secretKey] =
24 generateKeyPair(KeyType::secp256k1, generateSeed("testPaymentChannelClaim"));
25
26 // Common transaction fields
27 auto const accountValue = calcAccountID(publicKey);
28 std::uint32_t const sequenceValue = 1;
29 auto const feeValue = canonical_AMOUNT();
30
31 // Transaction-specific field values
32 auto const channelValue = canonical_UINT256();
33 auto const amountValue = canonical_AMOUNT();
34 auto const balanceValue = canonical_AMOUNT();
35 auto const signatureValue = canonical_VL();
36 auto const publicKeyValue = canonical_VL();
37 auto const credentialIDsValue = canonical_VECTOR256();
38
40 accountValue,
41 channelValue,
42 sequenceValue,
43 feeValue
44 };
45
46 // Set optional fields
47 builder.setAmount(amountValue);
48 builder.setBalance(balanceValue);
49 builder.setSignature(signatureValue);
50 builder.setPublicKey(publicKeyValue);
51 builder.setCredentialIDs(credentialIDsValue);
52
53 auto tx = builder.build(publicKey, secretKey);
54
55 std::string reason;
56 EXPECT_TRUE(tx.validate(reason)) << reason;
57
58 // Verify signing was applied
59 EXPECT_FALSE(tx.getSigningPubKey().empty());
60 EXPECT_TRUE(tx.hasTxnSignature());
61
62 // Verify common fields
63 EXPECT_EQ(tx.getAccount(), accountValue);
64 EXPECT_EQ(tx.getSequence(), sequenceValue);
65 EXPECT_EQ(tx.getFee(), feeValue);
66
67 // Verify required fields
68 {
69 auto const& expected = channelValue;
70 auto const actual = tx.getChannel();
71 expectEqualField(expected, actual, "sfChannel");
72 }
73
74 // Verify optional fields
75 {
76 auto const& expected = amountValue;
77 auto const actualOpt = tx.getAmount();
78 ASSERT_TRUE(actualOpt.has_value()) << "Optional field sfAmount should be present";
79 expectEqualField(expected, *actualOpt, "sfAmount");
80 EXPECT_TRUE(tx.hasAmount());
81 }
82
83 {
84 auto const& expected = balanceValue;
85 auto const actualOpt = tx.getBalance();
86 ASSERT_TRUE(actualOpt.has_value()) << "Optional field sfBalance should be present";
87 expectEqualField(expected, *actualOpt, "sfBalance");
88 EXPECT_TRUE(tx.hasBalance());
89 }
90
91 {
92 auto const& expected = signatureValue;
93 auto const actualOpt = tx.getSignature();
94 ASSERT_TRUE(actualOpt.has_value()) << "Optional field sfSignature should be present";
95 expectEqualField(expected, *actualOpt, "sfSignature");
96 EXPECT_TRUE(tx.hasSignature());
97 }
98
99 {
100 auto const& expected = publicKeyValue;
101 auto const actualOpt = tx.getPublicKey();
102 ASSERT_TRUE(actualOpt.has_value()) << "Optional field sfPublicKey should be present";
103 expectEqualField(expected, *actualOpt, "sfPublicKey");
104 EXPECT_TRUE(tx.hasPublicKey());
105 }
106
107 {
108 auto const& expected = credentialIDsValue;
109 auto const actualOpt = tx.getCredentialIDs();
110 ASSERT_TRUE(actualOpt.has_value()) << "Optional field sfCredentialIDs should be present";
111 expectEqualField(expected, *actualOpt, "sfCredentialIDs");
112 EXPECT_TRUE(tx.hasCredentialIDs());
113 }
114
115}
116
117// 2 & 4) Start from an STTx, construct a builder from it, build a new wrapper,
118// and verify all fields match.
119TEST(TransactionsPaymentChannelClaimTests, BuilderFromStTxRoundTrip)
120{
121 // Generate a deterministic keypair for signing
122 auto const [publicKey, secretKey] =
123 generateKeyPair(KeyType::secp256k1, generateSeed("testPaymentChannelClaimFromTx"));
124
125 // Common transaction fields
126 auto const accountValue = calcAccountID(publicKey);
127 std::uint32_t const sequenceValue = 2;
128 auto const feeValue = canonical_AMOUNT();
129
130 // Transaction-specific field values
131 auto const channelValue = canonical_UINT256();
132 auto const amountValue = canonical_AMOUNT();
133 auto const balanceValue = canonical_AMOUNT();
134 auto const signatureValue = canonical_VL();
135 auto const publicKeyValue = canonical_VL();
136 auto const credentialIDsValue = canonical_VECTOR256();
137
138 // Build an initial transaction
139 PaymentChannelClaimBuilder initialBuilder{
140 accountValue,
141 channelValue,
142 sequenceValue,
143 feeValue
144 };
145
146 initialBuilder.setAmount(amountValue);
147 initialBuilder.setBalance(balanceValue);
148 initialBuilder.setSignature(signatureValue);
149 initialBuilder.setPublicKey(publicKeyValue);
150 initialBuilder.setCredentialIDs(credentialIDsValue);
151
152 auto initialTx = initialBuilder.build(publicKey, secretKey);
153
154 // Create builder from existing STTx
155 PaymentChannelClaimBuilder builderFromTx{initialTx.getSTTx()};
156
157 auto rebuiltTx = builderFromTx.build(publicKey, secretKey);
158
159 std::string reason;
160 EXPECT_TRUE(rebuiltTx.validate(reason)) << reason;
161
162 // Verify common fields
163 EXPECT_EQ(rebuiltTx.getAccount(), accountValue);
164 EXPECT_EQ(rebuiltTx.getSequence(), sequenceValue);
165 EXPECT_EQ(rebuiltTx.getFee(), feeValue);
166
167 // Verify required fields
168 {
169 auto const& expected = channelValue;
170 auto const actual = rebuiltTx.getChannel();
171 expectEqualField(expected, actual, "sfChannel");
172 }
173
174 // Verify optional fields
175 {
176 auto const& expected = amountValue;
177 auto const actualOpt = rebuiltTx.getAmount();
178 ASSERT_TRUE(actualOpt.has_value()) << "Optional field sfAmount should be present";
179 expectEqualField(expected, *actualOpt, "sfAmount");
180 }
181
182 {
183 auto const& expected = balanceValue;
184 auto const actualOpt = rebuiltTx.getBalance();
185 ASSERT_TRUE(actualOpt.has_value()) << "Optional field sfBalance should be present";
186 expectEqualField(expected, *actualOpt, "sfBalance");
187 }
188
189 {
190 auto const& expected = signatureValue;
191 auto const actualOpt = rebuiltTx.getSignature();
192 ASSERT_TRUE(actualOpt.has_value()) << "Optional field sfSignature should be present";
193 expectEqualField(expected, *actualOpt, "sfSignature");
194 }
195
196 {
197 auto const& expected = publicKeyValue;
198 auto const actualOpt = rebuiltTx.getPublicKey();
199 ASSERT_TRUE(actualOpt.has_value()) << "Optional field sfPublicKey should be present";
200 expectEqualField(expected, *actualOpt, "sfPublicKey");
201 }
202
203 {
204 auto const& expected = credentialIDsValue;
205 auto const actualOpt = rebuiltTx.getCredentialIDs();
206 ASSERT_TRUE(actualOpt.has_value()) << "Optional field sfCredentialIDs should be present";
207 expectEqualField(expected, *actualOpt, "sfCredentialIDs");
208 }
209
210}
211
212// 3) Verify wrapper throws when constructed from wrong transaction type.
213TEST(TransactionsPaymentChannelClaimTests, WrapperThrowsOnWrongTxType)
214{
215 // Build a valid transaction of a different type
216 auto const [pk, sk] =
218 auto const account = calcAccountID(pk);
219
220 AccountSetBuilder wrongBuilder{account, 1, canonical_AMOUNT()};
221 auto wrongTx = wrongBuilder.build(pk, sk);
222
223 EXPECT_THROW(PaymentChannelClaim{wrongTx.getSTTx()}, std::runtime_error);
224}
225
226// 4) Verify builder throws when constructed from wrong transaction type.
227TEST(TransactionsPaymentChannelClaimTests, BuilderThrowsOnWrongTxType)
228{
229 // Build a valid transaction of a different type
230 auto const [pk, sk] =
231 generateKeyPair(KeyType::secp256k1, generateSeed("testWrongTypeBuilder"));
232 auto const account = calcAccountID(pk);
233
234 AccountSetBuilder wrongBuilder{account, 1, canonical_AMOUNT()};
235 auto wrongTx = wrongBuilder.build(pk, sk);
236
237 EXPECT_THROW(PaymentChannelClaimBuilder{wrongTx.getSTTx()}, std::runtime_error);
238}
239
240// 5) Build with only required fields and verify optional fields return nullopt.
241TEST(TransactionsPaymentChannelClaimTests, OptionalFieldsReturnNullopt)
242{
243 // Generate a deterministic keypair for signing
244 auto const [publicKey, secretKey] =
245 generateKeyPair(KeyType::secp256k1, generateSeed("testPaymentChannelClaimNullopt"));
246
247 // Common transaction fields
248 auto const accountValue = calcAccountID(publicKey);
249 std::uint32_t const sequenceValue = 3;
250 auto const feeValue = canonical_AMOUNT();
251
252 // Transaction-specific required field values
253 auto const channelValue = canonical_UINT256();
254
256 accountValue,
257 channelValue,
258 sequenceValue,
259 feeValue
260 };
261
262 // Do NOT set optional fields
263
264 auto tx = builder.build(publicKey, secretKey);
265
266 // Verify optional fields are not present
267 EXPECT_FALSE(tx.hasAmount());
268 EXPECT_FALSE(tx.getAmount().has_value());
269 EXPECT_FALSE(tx.hasBalance());
270 EXPECT_FALSE(tx.getBalance().has_value());
271 EXPECT_FALSE(tx.hasSignature());
272 EXPECT_FALSE(tx.getSignature().has_value());
273 EXPECT_FALSE(tx.hasPublicKey());
274 EXPECT_FALSE(tx.getPublicKey().has_value());
275 EXPECT_FALSE(tx.hasCredentialIDs());
276 EXPECT_FALSE(tx.getCredentialIDs().has_value());
277}
278
279}
PaymentChannelClaim build(PublicKey const &publicKey, SecretKey const &secretKey)
Build and return the PaymentChannelClaim wrapper.
std::shared_ptr< STTx const > getSTTx() const
Get the underlying STTx object.
TEST(TransactionsAccountDeleteTests, BuilderSettersRoundTrip)
Vector256Value canonical_VECTOR256()
Seed generateSeed(std::string const &passPhrase)
Generate a seed deterministically.
Definition Seed.cpp:57
std::pair< PublicKey, SecretKey > generateKeyPair(KeyType type, Seed const &seed)
Generate a key pair deterministically.
AccountID calcAccountID(PublicKey const &pk)
void expectEqualField(T const &expected, T const &actual, char const *fieldName)