rippled
Loading...
Searching...
No Matches
LoanBrokerCoverWithdrawTests.cpp
1// Auto-generated unit tests for transaction LoanBrokerCoverWithdraw
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/LoanBrokerCoverWithdraw.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(TransactionsLoanBrokerCoverWithdrawTests, BuilderSettersRoundTrip)
21{
22 // Generate a deterministic keypair for signing
23 auto const [publicKey, secretKey] =
24 generateKeyPair(KeyType::secp256k1, generateSeed("testLoanBrokerCoverWithdraw"));
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 loanBrokerIDValue = canonical_UINT256();
33 auto const amountValue = canonical_AMOUNT();
34 auto const destinationValue = canonical_ACCOUNT();
35 auto const destinationTagValue = canonical_UINT32();
36
38 accountValue,
39 loanBrokerIDValue,
40 amountValue,
41 sequenceValue,
42 feeValue
43 };
44
45 // Set optional fields
46 builder.setDestination(destinationValue);
47 builder.setDestinationTag(destinationTagValue);
48
49 auto tx = builder.build(publicKey, secretKey);
50
51 std::string reason;
52 EXPECT_TRUE(tx.validate(reason)) << reason;
53
54 // Verify signing was applied
55 EXPECT_FALSE(tx.getSigningPubKey().empty());
56 EXPECT_TRUE(tx.hasTxnSignature());
57
58 // Verify common fields
59 EXPECT_EQ(tx.getAccount(), accountValue);
60 EXPECT_EQ(tx.getSequence(), sequenceValue);
61 EXPECT_EQ(tx.getFee(), feeValue);
62
63 // Verify required fields
64 {
65 auto const& expected = loanBrokerIDValue;
66 auto const actual = tx.getLoanBrokerID();
67 expectEqualField(expected, actual, "sfLoanBrokerID");
68 }
69
70 {
71 auto const& expected = amountValue;
72 auto const actual = tx.getAmount();
73 expectEqualField(expected, actual, "sfAmount");
74 }
75
76 // Verify optional fields
77 {
78 auto const& expected = destinationValue;
79 auto const actualOpt = tx.getDestination();
80 ASSERT_TRUE(actualOpt.has_value()) << "Optional field sfDestination should be present";
81 expectEqualField(expected, *actualOpt, "sfDestination");
82 EXPECT_TRUE(tx.hasDestination());
83 }
84
85 {
86 auto const& expected = destinationTagValue;
87 auto const actualOpt = tx.getDestinationTag();
88 ASSERT_TRUE(actualOpt.has_value()) << "Optional field sfDestinationTag should be present";
89 expectEqualField(expected, *actualOpt, "sfDestinationTag");
90 EXPECT_TRUE(tx.hasDestinationTag());
91 }
92
93}
94
95// 2 & 4) Start from an STTx, construct a builder from it, build a new wrapper,
96// and verify all fields match.
97TEST(TransactionsLoanBrokerCoverWithdrawTests, BuilderFromStTxRoundTrip)
98{
99 // Generate a deterministic keypair for signing
100 auto const [publicKey, secretKey] =
101 generateKeyPair(KeyType::secp256k1, generateSeed("testLoanBrokerCoverWithdrawFromTx"));
102
103 // Common transaction fields
104 auto const accountValue = calcAccountID(publicKey);
105 std::uint32_t const sequenceValue = 2;
106 auto const feeValue = canonical_AMOUNT();
107
108 // Transaction-specific field values
109 auto const loanBrokerIDValue = canonical_UINT256();
110 auto const amountValue = canonical_AMOUNT();
111 auto const destinationValue = canonical_ACCOUNT();
112 auto const destinationTagValue = canonical_UINT32();
113
114 // Build an initial transaction
115 LoanBrokerCoverWithdrawBuilder initialBuilder{
116 accountValue,
117 loanBrokerIDValue,
118 amountValue,
119 sequenceValue,
120 feeValue
121 };
122
123 initialBuilder.setDestination(destinationValue);
124 initialBuilder.setDestinationTag(destinationTagValue);
125
126 auto initialTx = initialBuilder.build(publicKey, secretKey);
127
128 // Create builder from existing STTx
129 LoanBrokerCoverWithdrawBuilder builderFromTx{initialTx.getSTTx()};
130
131 auto rebuiltTx = builderFromTx.build(publicKey, secretKey);
132
133 std::string reason;
134 EXPECT_TRUE(rebuiltTx.validate(reason)) << reason;
135
136 // Verify common fields
137 EXPECT_EQ(rebuiltTx.getAccount(), accountValue);
138 EXPECT_EQ(rebuiltTx.getSequence(), sequenceValue);
139 EXPECT_EQ(rebuiltTx.getFee(), feeValue);
140
141 // Verify required fields
142 {
143 auto const& expected = loanBrokerIDValue;
144 auto const actual = rebuiltTx.getLoanBrokerID();
145 expectEqualField(expected, actual, "sfLoanBrokerID");
146 }
147
148 {
149 auto const& expected = amountValue;
150 auto const actual = rebuiltTx.getAmount();
151 expectEqualField(expected, actual, "sfAmount");
152 }
153
154 // Verify optional fields
155 {
156 auto const& expected = destinationValue;
157 auto const actualOpt = rebuiltTx.getDestination();
158 ASSERT_TRUE(actualOpt.has_value()) << "Optional field sfDestination should be present";
159 expectEqualField(expected, *actualOpt, "sfDestination");
160 }
161
162 {
163 auto const& expected = destinationTagValue;
164 auto const actualOpt = rebuiltTx.getDestinationTag();
165 ASSERT_TRUE(actualOpt.has_value()) << "Optional field sfDestinationTag should be present";
166 expectEqualField(expected, *actualOpt, "sfDestinationTag");
167 }
168
169}
170
171// 3) Verify wrapper throws when constructed from wrong transaction type.
172TEST(TransactionsLoanBrokerCoverWithdrawTests, WrapperThrowsOnWrongTxType)
173{
174 // Build a valid transaction of a different type
175 auto const [pk, sk] =
177 auto const account = calcAccountID(pk);
178
179 AccountSetBuilder wrongBuilder{account, 1, canonical_AMOUNT()};
180 auto wrongTx = wrongBuilder.build(pk, sk);
181
182 EXPECT_THROW(LoanBrokerCoverWithdraw{wrongTx.getSTTx()}, std::runtime_error);
183}
184
185// 4) Verify builder throws when constructed from wrong transaction type.
186TEST(TransactionsLoanBrokerCoverWithdrawTests, BuilderThrowsOnWrongTxType)
187{
188 // Build a valid transaction of a different type
189 auto const [pk, sk] =
190 generateKeyPair(KeyType::secp256k1, generateSeed("testWrongTypeBuilder"));
191 auto const account = calcAccountID(pk);
192
193 AccountSetBuilder wrongBuilder{account, 1, canonical_AMOUNT()};
194 auto wrongTx = wrongBuilder.build(pk, sk);
195
196 EXPECT_THROW(LoanBrokerCoverWithdrawBuilder{wrongTx.getSTTx()}, std::runtime_error);
197}
198
199// 5) Build with only required fields and verify optional fields return nullopt.
200TEST(TransactionsLoanBrokerCoverWithdrawTests, OptionalFieldsReturnNullopt)
201{
202 // Generate a deterministic keypair for signing
203 auto const [publicKey, secretKey] =
204 generateKeyPair(KeyType::secp256k1, generateSeed("testLoanBrokerCoverWithdrawNullopt"));
205
206 // Common transaction fields
207 auto const accountValue = calcAccountID(publicKey);
208 std::uint32_t const sequenceValue = 3;
209 auto const feeValue = canonical_AMOUNT();
210
211 // Transaction-specific required field values
212 auto const loanBrokerIDValue = canonical_UINT256();
213 auto const amountValue = canonical_AMOUNT();
214
216 accountValue,
217 loanBrokerIDValue,
218 amountValue,
219 sequenceValue,
220 feeValue
221 };
222
223 // Do NOT set optional fields
224
225 auto tx = builder.build(publicKey, secretKey);
226
227 // Verify optional fields are not present
228 EXPECT_FALSE(tx.hasDestination());
229 EXPECT_FALSE(tx.getDestination().has_value());
230 EXPECT_FALSE(tx.hasDestinationTag());
231 EXPECT_FALSE(tx.getDestinationTag().has_value());
232}
233
234}
LoanBrokerCoverWithdraw build(PublicKey const &publicKey, SecretKey const &secretKey)
Build and return the LoanBrokerCoverWithdraw wrapper.
std::shared_ptr< STTx const > getSTTx() const
Get the underlying STTx object.
TEST(TransactionsAccountDeleteTests, BuilderSettersRoundTrip)
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)