rippled
Loading...
Searching...
No Matches
LoanBrokerSetTests.cpp
1// Auto-generated unit tests for transaction LoanBrokerSet
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/LoanBrokerSet.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(TransactionsLoanBrokerSetTests, BuilderSettersRoundTrip)
21{
22 // Generate a deterministic keypair for signing
23 auto const [publicKey, secretKey] =
24 generateKeyPair(KeyType::secp256k1, generateSeed("testLoanBrokerSet"));
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 vaultIDValue = canonical_UINT256();
33 auto const loanBrokerIDValue = canonical_UINT256();
34 auto const dataValue = canonical_VL();
35 auto const managementFeeRateValue = canonical_UINT16();
36 auto const debtMaximumValue = canonical_NUMBER();
37 auto const coverRateMinimumValue = canonical_UINT32();
38 auto const coverRateLiquidationValue = canonical_UINT32();
39
41 accountValue,
42 vaultIDValue,
43 sequenceValue,
44 feeValue
45 };
46
47 // Set optional fields
48 builder.setLoanBrokerID(loanBrokerIDValue);
49 builder.setData(dataValue);
50 builder.setManagementFeeRate(managementFeeRateValue);
51 builder.setDebtMaximum(debtMaximumValue);
52 builder.setCoverRateMinimum(coverRateMinimumValue);
53 builder.setCoverRateLiquidation(coverRateLiquidationValue);
54
55 auto tx = builder.build(publicKey, secretKey);
56
57 std::string reason;
58 EXPECT_TRUE(tx.validate(reason)) << reason;
59
60 // Verify signing was applied
61 EXPECT_FALSE(tx.getSigningPubKey().empty());
62 EXPECT_TRUE(tx.hasTxnSignature());
63
64 // Verify common fields
65 EXPECT_EQ(tx.getAccount(), accountValue);
66 EXPECT_EQ(tx.getSequence(), sequenceValue);
67 EXPECT_EQ(tx.getFee(), feeValue);
68
69 // Verify required fields
70 {
71 auto const& expected = vaultIDValue;
72 auto const actual = tx.getVaultID();
73 expectEqualField(expected, actual, "sfVaultID");
74 }
75
76 // Verify optional fields
77 {
78 auto const& expected = loanBrokerIDValue;
79 auto const actualOpt = tx.getLoanBrokerID();
80 ASSERT_TRUE(actualOpt.has_value()) << "Optional field sfLoanBrokerID should be present";
81 expectEqualField(expected, *actualOpt, "sfLoanBrokerID");
82 EXPECT_TRUE(tx.hasLoanBrokerID());
83 }
84
85 {
86 auto const& expected = dataValue;
87 auto const actualOpt = tx.getData();
88 ASSERT_TRUE(actualOpt.has_value()) << "Optional field sfData should be present";
89 expectEqualField(expected, *actualOpt, "sfData");
90 EXPECT_TRUE(tx.hasData());
91 }
92
93 {
94 auto const& expected = managementFeeRateValue;
95 auto const actualOpt = tx.getManagementFeeRate();
96 ASSERT_TRUE(actualOpt.has_value()) << "Optional field sfManagementFeeRate should be present";
97 expectEqualField(expected, *actualOpt, "sfManagementFeeRate");
98 EXPECT_TRUE(tx.hasManagementFeeRate());
99 }
100
101 {
102 auto const& expected = debtMaximumValue;
103 auto const actualOpt = tx.getDebtMaximum();
104 ASSERT_TRUE(actualOpt.has_value()) << "Optional field sfDebtMaximum should be present";
105 expectEqualField(expected, *actualOpt, "sfDebtMaximum");
106 EXPECT_TRUE(tx.hasDebtMaximum());
107 }
108
109 {
110 auto const& expected = coverRateMinimumValue;
111 auto const actualOpt = tx.getCoverRateMinimum();
112 ASSERT_TRUE(actualOpt.has_value()) << "Optional field sfCoverRateMinimum should be present";
113 expectEqualField(expected, *actualOpt, "sfCoverRateMinimum");
114 EXPECT_TRUE(tx.hasCoverRateMinimum());
115 }
116
117 {
118 auto const& expected = coverRateLiquidationValue;
119 auto const actualOpt = tx.getCoverRateLiquidation();
120 ASSERT_TRUE(actualOpt.has_value()) << "Optional field sfCoverRateLiquidation should be present";
121 expectEqualField(expected, *actualOpt, "sfCoverRateLiquidation");
122 EXPECT_TRUE(tx.hasCoverRateLiquidation());
123 }
124
125}
126
127// 2 & 4) Start from an STTx, construct a builder from it, build a new wrapper,
128// and verify all fields match.
129TEST(TransactionsLoanBrokerSetTests, BuilderFromStTxRoundTrip)
130{
131 // Generate a deterministic keypair for signing
132 auto const [publicKey, secretKey] =
133 generateKeyPair(KeyType::secp256k1, generateSeed("testLoanBrokerSetFromTx"));
134
135 // Common transaction fields
136 auto const accountValue = calcAccountID(publicKey);
137 std::uint32_t const sequenceValue = 2;
138 auto const feeValue = canonical_AMOUNT();
139
140 // Transaction-specific field values
141 auto const vaultIDValue = canonical_UINT256();
142 auto const loanBrokerIDValue = canonical_UINT256();
143 auto const dataValue = canonical_VL();
144 auto const managementFeeRateValue = canonical_UINT16();
145 auto const debtMaximumValue = canonical_NUMBER();
146 auto const coverRateMinimumValue = canonical_UINT32();
147 auto const coverRateLiquidationValue = canonical_UINT32();
148
149 // Build an initial transaction
150 LoanBrokerSetBuilder initialBuilder{
151 accountValue,
152 vaultIDValue,
153 sequenceValue,
154 feeValue
155 };
156
157 initialBuilder.setLoanBrokerID(loanBrokerIDValue);
158 initialBuilder.setData(dataValue);
159 initialBuilder.setManagementFeeRate(managementFeeRateValue);
160 initialBuilder.setDebtMaximum(debtMaximumValue);
161 initialBuilder.setCoverRateMinimum(coverRateMinimumValue);
162 initialBuilder.setCoverRateLiquidation(coverRateLiquidationValue);
163
164 auto initialTx = initialBuilder.build(publicKey, secretKey);
165
166 // Create builder from existing STTx
167 LoanBrokerSetBuilder builderFromTx{initialTx.getSTTx()};
168
169 auto rebuiltTx = builderFromTx.build(publicKey, secretKey);
170
171 std::string reason;
172 EXPECT_TRUE(rebuiltTx.validate(reason)) << reason;
173
174 // Verify common fields
175 EXPECT_EQ(rebuiltTx.getAccount(), accountValue);
176 EXPECT_EQ(rebuiltTx.getSequence(), sequenceValue);
177 EXPECT_EQ(rebuiltTx.getFee(), feeValue);
178
179 // Verify required fields
180 {
181 auto const& expected = vaultIDValue;
182 auto const actual = rebuiltTx.getVaultID();
183 expectEqualField(expected, actual, "sfVaultID");
184 }
185
186 // Verify optional fields
187 {
188 auto const& expected = loanBrokerIDValue;
189 auto const actualOpt = rebuiltTx.getLoanBrokerID();
190 ASSERT_TRUE(actualOpt.has_value()) << "Optional field sfLoanBrokerID should be present";
191 expectEqualField(expected, *actualOpt, "sfLoanBrokerID");
192 }
193
194 {
195 auto const& expected = dataValue;
196 auto const actualOpt = rebuiltTx.getData();
197 ASSERT_TRUE(actualOpt.has_value()) << "Optional field sfData should be present";
198 expectEqualField(expected, *actualOpt, "sfData");
199 }
200
201 {
202 auto const& expected = managementFeeRateValue;
203 auto const actualOpt = rebuiltTx.getManagementFeeRate();
204 ASSERT_TRUE(actualOpt.has_value()) << "Optional field sfManagementFeeRate should be present";
205 expectEqualField(expected, *actualOpt, "sfManagementFeeRate");
206 }
207
208 {
209 auto const& expected = debtMaximumValue;
210 auto const actualOpt = rebuiltTx.getDebtMaximum();
211 ASSERT_TRUE(actualOpt.has_value()) << "Optional field sfDebtMaximum should be present";
212 expectEqualField(expected, *actualOpt, "sfDebtMaximum");
213 }
214
215 {
216 auto const& expected = coverRateMinimumValue;
217 auto const actualOpt = rebuiltTx.getCoverRateMinimum();
218 ASSERT_TRUE(actualOpt.has_value()) << "Optional field sfCoverRateMinimum should be present";
219 expectEqualField(expected, *actualOpt, "sfCoverRateMinimum");
220 }
221
222 {
223 auto const& expected = coverRateLiquidationValue;
224 auto const actualOpt = rebuiltTx.getCoverRateLiquidation();
225 ASSERT_TRUE(actualOpt.has_value()) << "Optional field sfCoverRateLiquidation should be present";
226 expectEqualField(expected, *actualOpt, "sfCoverRateLiquidation");
227 }
228
229}
230
231// 3) Verify wrapper throws when constructed from wrong transaction type.
232TEST(TransactionsLoanBrokerSetTests, WrapperThrowsOnWrongTxType)
233{
234 // Build a valid transaction of a different type
235 auto const [pk, sk] =
237 auto const account = calcAccountID(pk);
238
239 AccountSetBuilder wrongBuilder{account, 1, canonical_AMOUNT()};
240 auto wrongTx = wrongBuilder.build(pk, sk);
241
242 EXPECT_THROW(LoanBrokerSet{wrongTx.getSTTx()}, std::runtime_error);
243}
244
245// 4) Verify builder throws when constructed from wrong transaction type.
246TEST(TransactionsLoanBrokerSetTests, BuilderThrowsOnWrongTxType)
247{
248 // Build a valid transaction of a different type
249 auto const [pk, sk] =
250 generateKeyPair(KeyType::secp256k1, generateSeed("testWrongTypeBuilder"));
251 auto const account = calcAccountID(pk);
252
253 AccountSetBuilder wrongBuilder{account, 1, canonical_AMOUNT()};
254 auto wrongTx = wrongBuilder.build(pk, sk);
255
256 EXPECT_THROW(LoanBrokerSetBuilder{wrongTx.getSTTx()}, std::runtime_error);
257}
258
259// 5) Build with only required fields and verify optional fields return nullopt.
260TEST(TransactionsLoanBrokerSetTests, OptionalFieldsReturnNullopt)
261{
262 // Generate a deterministic keypair for signing
263 auto const [publicKey, secretKey] =
264 generateKeyPair(KeyType::secp256k1, generateSeed("testLoanBrokerSetNullopt"));
265
266 // Common transaction fields
267 auto const accountValue = calcAccountID(publicKey);
268 std::uint32_t const sequenceValue = 3;
269 auto const feeValue = canonical_AMOUNT();
270
271 // Transaction-specific required field values
272 auto const vaultIDValue = canonical_UINT256();
273
274 LoanBrokerSetBuilder builder{
275 accountValue,
276 vaultIDValue,
277 sequenceValue,
278 feeValue
279 };
280
281 // Do NOT set optional fields
282
283 auto tx = builder.build(publicKey, secretKey);
284
285 // Verify optional fields are not present
286 EXPECT_FALSE(tx.hasLoanBrokerID());
287 EXPECT_FALSE(tx.getLoanBrokerID().has_value());
288 EXPECT_FALSE(tx.hasData());
289 EXPECT_FALSE(tx.getData().has_value());
290 EXPECT_FALSE(tx.hasManagementFeeRate());
291 EXPECT_FALSE(tx.getManagementFeeRate().has_value());
292 EXPECT_FALSE(tx.hasDebtMaximum());
293 EXPECT_FALSE(tx.getDebtMaximum().has_value());
294 EXPECT_FALSE(tx.hasCoverRateMinimum());
295 EXPECT_FALSE(tx.getCoverRateMinimum().has_value());
296 EXPECT_FALSE(tx.hasCoverRateLiquidation());
297 EXPECT_FALSE(tx.getCoverRateLiquidation().has_value());
298}
299
300}
LoanBrokerSet build(PublicKey const &publicKey, SecretKey const &secretKey)
Build and return the LoanBrokerSet 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)