20#include <xrpl/basics/random.h>
21#include <xrpl/ledger/BookDirs.h>
22#include <xrpl/ledger/Sandbox.h>
23#include <xrpl/protocol/Feature.h>
24#include <xrpl/protocol/Protocol.h>
25#include <xrpl/protocol/jss.h>
39 BEAST_EXPECT(i < 17577);
43 for (
int j = 0; j != 3; ++j)
64 p->setFieldU64(sfIndexNext, 0);
66 p->setFieldU64(sfIndexNext, i + 1);
69 p->setFieldU64(sfIndexPrevious, n - 1);
71 p->setFieldU64(sfIndexPrevious, i - 1);
87 testcase(
"Directory Ordering (with 'SortedDirectories' amendment)");
90 env.
fund(
XRP(10000000), alice, gw);
101 auto const view = env.
closed();
111 auto const& v = p->getFieldV256(sfIndexes);
120 for (
auto const& e : v)
124 BEAST_EXPECT(c->getFieldU32(sfSequence) >= minSeq);
125 BEAST_EXPECT(c->getFieldU32(sfSequence) < maxSeq);
128 page = p->getFieldU64(sfIndexNext);
138 for (
auto const&
offer : book)
141 BEAST_EXPECT(
offer->getFieldAmount(sfTakerPays) == USD(count));
142 BEAST_EXPECT(
offer->getFieldAmount(sfTakerGets) ==
XRP(count));
152 auto const alice =
Account(
"alice");
153 auto const bob =
Account(
"bob");
154 auto const charlie =
Account(
"charlie");
159 env.
fund(
XRP(1000000), alice, charlie, gw);
166 env(
signers(alice, 1, {{bob, 1}}));
188 auto cl = currencies;
190 for (
auto const& c : cl)
192 env(
trust(alice, c(50)));
200 for (
auto const& c : cl)
202 env(
trust(alice, c(0)));
212 auto cl = currencies;
216 for (
auto c : currencies)
218 env(
trust(charlie, c(50)));
220 env(
pay(gw, charlie, c(50)));
233 for (
auto const& c : cl)
235 env(
offer(charlie,
XRP(50), c(50)));
244 for (
auto const& c : cl)
246 env(
pay(alice, charlie, c(50)));
257 testcase(
"RIPD-1353 Empty Offer Directories");
262 auto const gw =
Account{
"gateway"};
263 auto const alice =
Account{
"alice"};
264 auto const USD = gw[
"USD"];
266 env.
fund(
XRP(10000), alice, gw);
268 env.
trust(USD(1000), alice);
269 env(
pay(gw, alice, USD(1000)));
271 auto const firstOfferSeq = env.
seq(alice);
274 for (
int i = 0; i < 3; ++i)
280 for (
auto page : {0, 2, 1})
305 env.
trust(USD(0), alice);
306 env(
pay(alice, gw, alice[
"USD"](1000)));
320 auto const gw =
Account{
"gateway"};
321 auto const alice =
Account{
"alice"};
322 auto const USD = gw[
"USD"];
328 "fb71c9aa3310141da4b01d6c744a98286af2d72ab5448d5adc0910ca0c910880");
331 "bad0f021aa3b2f6754a8fe82a5779730aa0bbbab82f17201ef24900efc2c7312");
345 p->setFieldV256(sfIndexes, v);
370 p1->setFieldV256(sfIndexes, v1);
378 p2->setFieldV256(sfIndexes, v2);
392 BEAST_EXPECT(p1->getFieldU64(sfIndexNext) == 0);
393 BEAST_EXPECT(p1->getFieldU64(sfIndexPrevious) == 0);
397 BEAST_EXPECT(p0->getFieldU64(sfIndexNext) == 1);
398 BEAST_EXPECT(p0->getFieldU64(sfIndexPrevious) == 1);
408 auto const gw =
Account{
"gateway"};
409 auto const alice =
Account{
"alice"};
410 auto const USD = gw[
"USD"];
412 auto ledger_data = [
this](
Env& env) {
414 params[jss::type] = jss::directory;
415 params[jss::ledger_index] =
"validated";
417 env.rpc(
"json",
"ledger_data",
to_string(params))[jss::result];
418 BEAST_EXPECT(!result.isMember(jss::marker));
424 env.
fund(
XRP(10000), alice, gw);
426 env.
trust(USD(1000), alice);
427 env(
pay(gw, alice, USD(1000)));
431 auto const jrr = ledger_data(env);
432 auto const& jstate = jrr[jss::state];
434 for (
auto const& directory : jstate)
437 directory[
"LedgerEntryType"] ==
441 BEAST_EXPECT(!directory.isMember(
"PreviousTxnID"));
442 BEAST_EXPECT(!directory.isMember(
"PreviousTxnLgrSeq"));
453 auto const txID =
to_string(env.
tx()->getTransactionID());
454 auto const ledgerSeq = env.
current()->info().seq;
461 auto const jrr = ledger_data(env);
462 auto const& jstate = jrr[jss::state];
464 for (
auto const& directory : jstate)
467 directory[
"LedgerEntryType"] ==
469 if (directory[jss::Owner] == gw.human())
473 BEAST_EXPECT(!directory.isMember(
"PreviousTxnID"));
474 BEAST_EXPECT(!directory.isMember(
"PreviousTxnLgrSeq"));
482 directory.isMember(
"PreviousTxnID") &&
483 directory[
"PreviousTxnID"].asString() == txID);
485 directory.isMember(
"PreviousTxnLgrSeq") &&
486 directory[
"PreviousTxnLgrSeq"].asUInt() == ledgerSeq);
testcase_t testcase
Memberspace for declaring test cases.
bool dirRemove(Keylet const &directory, std::uint64_t page, uint256 const &key, bool keepRoot)
Remove an entry from a directory.
void push_back(uint256 const &v)
Discardable, editable view to a ledger.
void update(std::shared_ptr< SLE > const &sle) override
Indicate changes to a peeked SLE.
void insert(std::shared_ptr< SLE > const &sle) override
Insert a new state SLE.
std::optional< key_type > succ(key_type const &key, std::optional< key_type > const &last=std::nullopt) const override
Return the key of the next state item.
std::shared_ptr< SLE > peek(Keylet const &k) override
Prepare to modify the SLE associated with key.
Immutable cryptographic account descriptor.
A transaction testing environment.
std::shared_ptr< ReadView const > closed()
Returns the last closed ledger.
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.
void trust(STAmount const &amount, Account const &account)
Establish trust lines.
void enableFeature(uint256 const feature)
void fund(bool setDefaultRipple, STAmount const &amount, Account const &account)
Keylet child(uint256 const &key) noexcept
Any item that can be in an owner dir.
Keylet page(uint256 const &root, std::uint64_t index=0) noexcept
A page in a directory.
Keylet unchecked(uint256 const &key) noexcept
Any ledger entry.
Keylet ownerDir(AccountID const &id) noexcept
The root page of an account's directory.
bool checkArraySize(Json::Value const &val, unsigned int size)
Json::Value signers(Account const &account, std::uint32_t quorum, std::vector< signer > const &v)
Json::Value trust(Account const &account, STAmount const &amount, std::uint32_t flags)
Modify a trust line.
Json::Value pay(AccountID const &account, AccountID const &to, AnyAmount amount)
Create a payment.
FeatureBitset testable_amendments()
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.
Json::Value offer_cancel(Account const &account, std::uint32_t offerSeq)
Cancel an offer.
Use hash_* containers for keys that do not need a cryptographically secure hashing algorithm.
Issue const & xrpIssue()
Returns an asset specifier that represents XRP.
bool dirIsEmpty(ReadView const &view, Keylet const &k)
Returns true if the directory is empty.
std::size_t constexpr dirNodeMaxEntries
The maximum number of entries per directory page.
uint256 getQualityNext(uint256 const &uBase)
std::string to_string(base_uint< Bits, Tag > const &a)
uint256 getBookBase(Book const &book)
beast::xor_shift_engine & default_prng()
Return the default random engine.
std::string currcode(std::size_t i)
void makePages(Sandbox &sb, uint256 const &base, std::uint64_t n)
void testDirectoryOrdering()
void run() override
Runs the suite.