2#include <test/jtx/check.h>
3#include <test/jtx/envconfig.h>
5#include <xrpld/app/ledger/LedgerMaster.h>
6#include <xrpld/app/tx/apply.h>
8#include <xrpl/basics/CountedObject.h>
9#include <xrpl/basics/StringUtilities.h>
10#include <xrpl/json/json_reader.h>
11#include <xrpl/protocol/Indexes.h>
12#include <xrpl/protocol/jss.h>
26 auto const USD = gw[
"USD"];
27 env.
fund(
XRP(10000),
"alice", gw);
29 env(
offer(
"alice", USD(20),
XRP(10)),
31 { "OfferSequence" : 4 }
39 testcase(
"Account balance < fee destroys correct amount of XRP");
50 BEAST_EXPECT(closed->header().drops == expectedDrops);
52 auto const aliceXRP = 400;
53 auto const aliceAmount =
XRP(aliceXRP);
58 auto const jt = env.
jt(
pay(env.
master,
"alice", aliceAmount));
63 BEAST_EXPECT(result.applied);
67 expectedDrops -= next->fees().base;
68 BEAST_EXPECT(next->header().drops == expectedDrops);
72 auto balance = sle->getFieldAmount(sfBalance);
74 BEAST_EXPECT(
balance == aliceAmount);
80 auto const jt = env.
jt(
noop(
"alice"),
fee(expectedDrops),
seq(2));
86 BEAST_EXPECT(result.applied);
93 auto balance = sle->getFieldAmount(sfBalance);
98 BEAST_EXPECT(next->header().drops == expectedDrops);
104 testcase(
"Signing with a secp256r1 key should fail gracefully");
109 auto test256r1key = [&env](
Account const& acct) {
110 auto const baseFee = env.
current()->fees().base;
113 JTx jt = env.
jt(jsonNoop);
119 "045d02995ec24988d9a2ae06a3733aa35ba0741e87527"
120 "ed12909b60bd458052c944b24cbf5893c3e5be321774e"
121 "5082e11c034b765861d0effbde87423f8476bb2c";
124 jt.
jv[
"SigningPubKey"] = secp256r1PubKey;
128 auto pubKeyBlob =
strUnHex(secp256r1PubKey);
130 secp256r1Sig->setFieldVL(sfSigningPubKey, *pubKeyBlob);
131 jt.
stx.reset(secp256r1Sig.release());
133 env(jt,
rpc(
"invalidTransaction",
"fails local checks: Invalid signature."));
139 env.
fund(
XRP(10000), alice, becky);
148 testcase(
"Autofilled fee should use the escalated fee");
151 cfg->section(
"transaction_queue").
set(
"minimum_txn_in_ledger_standalone",
"3");
152 cfg->FEES.reference_fee = 10;
157 auto const alice =
Account(
"alice");
162 params[jss::fee_mult_max] = 5000;
167 for (
int i = 0; i < 5; ++i)
172 if (BEAST_EXPECT(tx))
174 BEAST_EXPECT(tx->getAccountID(sfAccount) == alice.id());
175 BEAST_EXPECT(tx->getTxnType() == ttACCOUNT_SET);
176 auto const fee = tx->getFieldAmount(sfFee);
177 BEAST_EXPECT(
fee ==
drops(expectedFees[i]));
185 testcase(
"Fee escalation shouldn't allocate extreme memory");
188 using namespace std::chrono_literals;
191 auto& s = cfg->section(
"transaction_queue");
192 s.set(
"minimum_txn_in_ledger_standalone",
"4294967295");
193 s.set(
"minimum_txn_in_ledger",
"4294967295");
194 s.set(
"target_txn_in_ledger",
"4294967295");
195 s.set(
"normal_consensus_increase_percent",
"4294967295");
203 auto const start = clock_type::now();
205 BEAST_EXPECT(clock_type::now() - start < 1s);
212 using boost::asio::buffer;
216 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";
224 BEAST_EXPECT(jrReader.parse(jvRequest, buffers) && jvRequest.isObject());
230 testcase(
"Invalid Transaction Object ID Type");
238 env.
fund(
XRP(10'000), alice, bob);
243 if (BEAST_EXPECT(alice_index.isNonZero()))
255 if (!state.peekItem(bob_index,
digest))
262 for (
auto const& e : list)
264 result[e.first] = e.second;
270 if (BEAST_EXPECT(bob_index.isNonZero()) && BEAST_EXPECT(
digest.has_value()))
280 using namespace std::string_literals;
281 BEAST_EXPECT(beforeCounts.at(
"CachedView::hit"s) == afterCounts.at(
"CachedView::hit"s));
283 beforeCounts.at(
"CachedView::hitExpired"s) + 1 == afterCounts.at(
"CachedView::hitExpired"s));
284 BEAST_EXPECT(beforeCounts.at(
"CachedView::miss"s) == afterCounts.at(
"CachedView::miss"s));
302BEAST_DEFINE_TESTSUITE(Regression, app,
xrpl);
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 Config & config()=0
virtual LedgerMaster & getLedgerMaster()=0
virtual Family & getNodeFamily()=0
virtual CachedSLEs & cachedSLEs()=0
virtual TimeKeeper & timeKeeper()=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.
uint256 const & as_uint256() const
bool del(key_type const &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.
bool close(NetClock::time_point closeTime, std::optional< std::chrono::milliseconds > consensusDelay=std::nullopt)
Close and advance the ledger.
void fund(bool setDefaultRipple, STAmount const &amount, Account const &account)
std::uint32_t seq(Account const &account) const
Returns the next sequence number on account.
JTx jt(JsonValue &&jv, FN const &... fN)
Create a JTx from parameters.
Json::Value json(JsonValue &&jv, FN const &... fN)
Create JSON from parameters.
std::shared_ptr< STTx const > tx() const
Return the tx data for the last JTx.
void memoize(Account const &account)
Associate AccountID with account.
beast::Journal const journal
std::shared_ptr< OpenView const > current() const
Returns the current ledger.
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.
XRP_t const XRP
Converts to XRP Issue or STAmount.
Json::Value pay(AccountID const &account, AccountID const &to, AnyAmount amount)
Create a payment.
constexpr XRPAmount dropsPerXRP
std::unique_ptr< Config > envconfig()
creates and initializes a default configuration for jtx::Env
PrettyAmount drops(Integer i)
Returns an XRP PrettyAmount, which is trivially convertible to STAmount.
Json::Value offer(Account const &account, STAmount const &takerPays, STAmount const &takerGets, std::uint32_t flags)
Create an offer.
Use hash_* containers for keys that do not need a cryptographically secure hashing algorithm.
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,...
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
std::optional< Blob > strUnHex(std::size_t strSize, Iterator begin, Iterator end)
constexpr XRPAmount INITIAL_XRP
Configure the native currency.
void run() override
Runs the suite.
void testFeeEscalationAutofill()
void testInvalidTxObjectIDType()
void testLowBalanceDestroy()
void testFeeEscalationExtremeConfig()
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.