19#include <test/jtx/check.h>
20#include <test/jtx/envconfig.h>
21#include <xrpld/app/ledger/LedgerMaster.h>
22#include <xrpld/app/tx/apply.h>
23#include <xrpl/basics/CountedObject.h>
24#include <xrpl/basics/StringUtilities.h>
25#include <xrpl/json/json_reader.h>
26#include <xrpl/protocol/Indexes.h>
27#include <xrpl/protocol/jss.h>
41 auto const USD = gw[
"USD"];
42 env.
fund(
XRP(10000),
"alice", gw);
44 env(
offer(
"alice", USD(20),
XRP(10)),
46 { "OfferSequence" : 4 }
54 testcase(
"Account balance < fee destroys correct amount of XRP");
62 auto closed = std::make_shared<Ledger>(
68 BEAST_EXPECT(closed->info().drops == expectedDrops);
70 auto const aliceXRP = 400;
71 auto const aliceAmount =
XRP(aliceXRP);
73 auto next = std::make_shared<Ledger>(
77 auto const jt = env.
jt(
pay(env.
master,
"alice", aliceAmount));
83 BEAST_EXPECT(result.applied);
87 expectedDrops -= next->fees().base;
88 BEAST_EXPECT(next->info().drops == expectedDrops);
92 auto balance = sle->getFieldAmount(sfBalance);
94 BEAST_EXPECT(
balance == aliceAmount);
100 auto const jt = env.
jt(
noop(
"alice"),
fee(expectedDrops),
seq(2));
107 BEAST_EXPECT(result.applied);
114 auto balance = sle->getFieldAmount(sfBalance);
119 BEAST_EXPECT(next->info().drops == expectedDrops);
125 testcase(
"Signing with a secp256r1 key should fail gracefully");
130 auto test256r1key = [&env](
Account const& acct) {
131 auto const baseFee = env.
current()->fees().base;
135 JTx jt = env.
jt(jsonNoop);
141 "045d02995ec24988d9a2ae06a3733aa35ba0741e87527"
142 "ed12909b60bd458052c944b24cbf5893c3e5be321774e"
143 "5082e11c034b765861d0effbde87423f8476bb2c";
146 jt.
jv[
"SigningPubKey"] = secp256r1PubKey;
149 auto secp256r1Sig = std::make_unique<STTx>(*(jt.
stx));
150 auto pubKeyBlob =
strUnHex(secp256r1PubKey);
152 secp256r1Sig->setFieldVL(sfSigningPubKey, *pubKeyBlob);
153 jt.
stx.reset(secp256r1Sig.release());
156 rpc(
"invalidTransaction",
157 "fails local checks: Invalid signature."));
163 env.
fund(
XRP(10000), alice, becky);
172 testcase(
"Autofilled fee should use the escalated fee");
175 cfg->section(
"transaction_queue")
176 .
set(
"minimum_txn_in_ledger_standalone",
"3");
181 auto const alice =
Account(
"alice");
186 params[jss::fee_mult_max] = 5000;
191 for (
int i = 0; i < 5; ++i)
196 if (BEAST_EXPECT(tx))
198 BEAST_EXPECT(tx->getAccountID(sfAccount) == alice.id());
199 BEAST_EXPECT(tx->getTxnType() == ttACCOUNT_SET);
200 auto const fee = tx->getFieldAmount(sfFee);
201 BEAST_EXPECT(
fee ==
drops(expectedFees[i]));
209 testcase(
"Fee escalation shouldn't allocate extreme memory");
212 using namespace std::chrono_literals;
215 auto& s = cfg->section(
"transaction_queue");
216 s.set(
"minimum_txn_in_ledger_standalone",
"4294967295");
217 s.set(
"minimum_txn_in_ledger",
"4294967295");
218 s.set(
"target_txn_in_ledger",
"4294967295");
219 s.set(
"normal_consensus_increase_percent",
"4294967295");
227 auto const start = clock_type::now();
229 BEAST_EXPECT(clock_type::now() - start < 1s);
236 using boost::asio::buffer;
240 R
"json({"command":"path_find","id":19,"subcommand":"create","source_account":"rHb9CJAWyB4rj91VRWn96DkukG4bwdtyTh","destination_account":"rHb9CJAWyB4rj91VRWn96DkukG4bwdtyTh","destination_amount":"1000000","source_currencies":[{"currency":"0000000000000000000000000000000000000000"},{"currency":"0000000000000000000000005553440000000000"},{"currency":"0000000000000000000000004254430000000000"},{"issuer":"rHb9CJAWyB4rj91VRWn96DkukG4bwdtyTh","currency":"0000000000000000000000004254430000000000"},{"issuer":"rHb9CJAWyB4rj91VRWn96DkukG4bwdtyTh","currency":"0000000000000000000000004254430000000000"},{"issuer":"rHb9CJAWyB4rj91VRWn96DkukG4bwdtyTh","currency":"0000000000000000000000004555520000000000"},{"currency":"0000000000000000000000004554480000000000"},{"currency":"0000000000000000000000004A50590000000000"},{"issuer":"rHb9CJAWyB4rj91VRWn96DkukG4bwdtyTh","currency":"000000000000000000000000434E590000000000"},{"currency":"0000000000000000000000004742490000000000"},{"issuer":"rHb9CJAWyB4rj91VRWn96DkukG4bwdtyTh","currency":"0000000000000000000000004341440000000000"}]})json";
248 buffer(request.data() + 1024, request.length() - 1024));
256 testcase(
"Invalid Transaction Object ID Type");
264 env.
fund(
XRP(10'000), alice, bob);
269 if (BEAST_EXPECT(alice_index.isNonZero()))
284 if (!state.peekItem(bob_index,
digest))
286 return digest.as_uint256();
291 for (
auto const& e : list)
293 result[e.first] = e.second;
299 if (BEAST_EXPECT(bob_index.isNonZero()) &&
300 BEAST_EXPECT(
digest.has_value()))
304 auto const beforeCounts =
310 auto const afterCounts =
313 using namespace std::string_literals;
315 beforeCounts.at(
"CachedView::hit"s) ==
316 afterCounts.at(
"CachedView::hit"s));
318 beforeCounts.at(
"CachedView::hitExpired"s) + 1 ==
319 afterCounts.at(
"CachedView::hitExpired"s));
321 beforeCounts.at(
"CachedView::miss"s) ==
322 afterCounts.at(
"CachedView::miss"s));
340BEAST_DEFINE_TESTSUITE(Regression, app,
ripple);
Unserialize a JSON document into a Value.
bool parse(std::string const &document, Value &root)
Read a Value from a JSON document.
testcase_t testcase
Memberspace for declaring test cases.
virtual CachedSLEs & cachedSLEs()=0
virtual Config & config()=0
virtual TimeKeeper & timeKeeper()=0
virtual Family & getNodeFamily()=0
virtual LedgerMaster & getLedgerMaster()=0
static CountedObjects & getInstance() noexcept
std::shared_ptr< Ledger const > getClosedLedger()
Writable ledger view that accumulates state and tx changes.
void apply(TxsRawView &to) const
Apply changes.
bool del(const key_type &key, bool valid)
time_point closeTime() const
Returns the predicted close time, in network time.
Immutable cryptographic account descriptor.
A transaction testing environment wrapper.
A transaction testing environment.
Json::Value json(JsonValue &&jv, FN const &... fN)
Create JSON from parameters.
std::uint32_t seq(Account const &account) const
Returns the next sequence number on account.
std::shared_ptr< STTx const > tx() const
Return the tx data for the last JTx.
std::shared_ptr< OpenView const > current() const
Returns the current ledger.
bool close(NetClock::time_point closeTime, std::optional< std::chrono::milliseconds > consensusDelay=std::nullopt)
Close and advance the ledger.
JTx jt(JsonValue &&jv, FN const &... fN)
Create a JTx from parameters.
beast::Journal const journal
void fund(bool setDefaultRipple, STAmount const &amount, Account const &account)
void memoize(Account const &account)
Associate AccountID with account.
Match the number of items in the account's owner directory.
Check a set of conditions.
Set the expected result code for a JTx The test will fail if the code doesn't match.
Set the regular signature on a JTx.
Set the expected result code for a JTx The test will fail if the code doesn't match.
T emplace_back(T... args)
@ objectValue
object value (collection of name/value pairs).
Keylet account(AccountID const &id) noexcept
AccountID root.
Json::Value cash(jtx::Account const &dest, uint256 const &checkId, STAmount const &amount)
Cash a check requiring that a specific amount be delivered.
PrettyAmount drops(Integer i)
Returns an XRP PrettyAmount, which is trivially convertible to STAmount.
constexpr XRPAmount dropsPerXRP
Json::Value pay(AccountID const &account, AccountID const &to, AnyAmount amount)
Create a payment.
std::unique_ptr< Config > envconfig()
creates and initializes a default configuration for jtx::Env
Json::Value noop(Account const &account)
The null transaction.
Json::Value offer(Account const &account, STAmount const &takerPays, STAmount const &takerGets, std::uint32_t flags)
Create an offer.
XRP_t const XRP
Converts to XRP Issue or STAmount.
Use hash_* containers for keys that do not need a cryptographically secure hashing algorithm.
std::optional< Blob > strUnHex(std::size_t strSize, Iterator begin, Iterator end)
bool set(T &target, std::string const &name, Section const §ion)
Set a value from a configuration Section If the named value is not found or doesn't parse as a T,...
constexpr XRPAmount INITIAL_XRP
Configure the native currency.
static Hasher::result_type digest(void const *data, std::size_t size) noexcept
ApplyResult apply(Application &app, OpenView &view, STTx const &tx, ApplyFlags flags, beast::Journal journal)
Apply a transaction to an OpenView.
create_genesis_t const create_genesis
void testInvalidTxObjectIDType()
void run() override
Runs the suite.
void testFeeEscalationExtremeConfig()
void testLowBalanceDestroy()
void testFeeEscalationAutofill()
Execution context for applying a JSON transaction.
std::shared_ptr< STTx const > stx
Type used to specify DeliverMin for cashing a check.
Set the sequence number on a JTx.