3#include <xrpld/app/tx/apply.h>
5#include <xrpl/protocol/AmountConversions.h>
6#include <xrpl/protocol/Feature.h>
7#include <xrpl/protocol/Quality.h>
8#include <xrpl/protocol/Rate.h>
9#include <xrpl/protocol/jss.h>
21 using namespace test::jtx;
23 Account
const alice(
"alice");
24 env.fund(XRP(10000), noripple(alice));
26 auto const jrr = env.le(alice);
27 BEAST_EXPECT(jrr && jrr->at(sfFlags) == 0u);
35 using namespace test::jtx;
36 Account
const alice(
"alice");
38 Env env(*
this, testable_amendments());
39 env.fund(XRP(10000), noripple(alice));
44 env(regkey(alice, alie));
49 for (
std::uint32_t flag{1u}; flag < std::numeric_limits<std::uint32_t>::digits; ++flag)
86 if (
std::find(goodFlags.begin(), goodFlags.end(), flag) != goodFlags.end())
89 env.require(nflags(alice, flag));
90 env(fset(alice, flag), sig(alice));
92 env.require(flags(alice, flag));
93 env(fclear(alice, flag), sig(alie));
95 env.require(nflags(alice, flag));
97 BEAST_EXPECT(now_flags == orig_flags);
102 BEAST_EXPECT((*env.le(alice))[sfFlags] == orig_flags);
103 env(fset(alice, flag), sig(alice));
105 BEAST_EXPECT((*env.le(alice))[sfFlags] == orig_flags);
106 env(fclear(alice, flag), sig(alie));
108 BEAST_EXPECT((*env.le(alice))[sfFlags] == orig_flags);
125 testcase(
"Set and reset AccountTxnID");
127 using namespace test::jtx;
129 Account
const alice(
"alice");
130 env.fund(XRP(10000), noripple(alice));
136 BEAST_EXPECT(!env.le(alice)->isFieldPresent(sfAccountTxnID));
138 BEAST_EXPECT(env.le(alice)->isFieldPresent(sfAccountTxnID));
140 BEAST_EXPECT(!env.le(alice)->isFieldPresent(sfAccountTxnID));
142 BEAST_EXPECT(now_flags == orig_flags);
150 using namespace test::jtx;
152 Account
const alice(
"alice");
153 env.fund(XRP(10000), noripple(alice));
155 env(regkey(alice,
"eric"));
171 using namespace test::jtx;
173 Account
const alice(
"alice");
174 env.fund(XRP(10000), alice);
175 auto jt =
noop(alice);
183 jt[sfDomain.fieldName] =
strHex(domain);
185 BEAST_EXPECT((*env.le(alice))[sfDomain] ==
makeSlice(domain));
187 jt[sfDomain.fieldName] =
"";
189 BEAST_EXPECT(!env.le(alice)->isFieldPresent(sfDomain));
195 for (
std::size_t len = maxLength - 1; len <= maxLength + 1; ++len)
199 BEAST_EXPECT(domain2.
length() == len);
201 jt[sfDomain.fieldName] =
strHex(domain2);
203 if (len <= maxLength)
206 BEAST_EXPECT((*env.le(alice))[sfDomain] ==
makeSlice(domain2));
220 using namespace test::jtx;
222 Account
const alice(
"alice");
223 env.fund(XRP(10000), alice);
224 auto jt =
noop(alice);
227 jt[sfMessageKey.fieldName] =
strHex(rkp.first.slice());
229 BEAST_EXPECT(
strHex((*env.le(alice))[sfMessageKey]) ==
strHex(rkp.first.slice()));
231 jt[sfMessageKey.fieldName] =
"";
233 BEAST_EXPECT(!env.le(alice)->isFieldPresent(sfMessageKey));
235 using namespace std::string_literals;
236 jt[sfMessageKey.fieldName] =
strHex(
"NOT_REALLY_A_PUBKEY"s);
245 using namespace test::jtx;
247 Account
const alice(
"alice");
248 env.fund(XRP(10000), alice);
249 auto jt =
noop(alice);
251 std::string const locator =
"9633EC8AF54F16B5286DB1D7B519EF49EEFC050C0C8AC4384F1D88ACD1BFDF05";
252 jt[sfWalletLocator.fieldName] = locator;
254 BEAST_EXPECT(
to_string((*env.le(alice))[sfWalletLocator]) == locator);
256 jt[sfWalletLocator.fieldName] =
"";
258 BEAST_EXPECT(!env.le(alice)->isFieldPresent(sfWalletLocator));
266 using namespace test::jtx;
268 Account
const alice(
"alice");
269 env.fund(XRP(10000), alice);
270 auto jt =
noop(alice);
272 std::string const mh(
"5F31A79367DC3137FADA860C05742EE6");
273 jt[sfEmailHash.fieldName] = mh;
275 BEAST_EXPECT(
to_string((*env.le(alice))[sfEmailHash]) == mh);
277 jt[sfEmailHash.fieldName] =
"";
279 BEAST_EXPECT(!env.le(alice)->isFieldPresent(sfEmailHash));
294 using namespace test::jtx;
296 Env env(*
this, features);
298 Account
const alice(
"alice");
299 env.fund(XRP(10000), alice);
301 for (
auto const& r : testData)
303 env(rate(alice, r.set), ter(r.code));
307 if (!(*env.le(alice))[~sfTransferRate])
308 BEAST_EXPECT(r.get == 1.0);
310 BEAST_EXPECT(*(*env.le(alice))[~sfTransferRate] == r.get * QUALITY_ONE);
315 testable_amendments(),
330 using namespace test::jtx;
332 Account
const alice(
"alice");
333 Account
const bob(
"bob");
334 Account
const gw(
"gateway");
335 auto const USD = gw[
"USD"];
341 env.fund(XRP(10000), gw, alice, bob);
343 env.trust(USD(10), alice, bob);
348 auto const amount = USD(1);
352 env(pay(gw, alice, USD(10)));
354 env(pay(alice, bob, USD(1)), sendmax(USD(10)));
357 env.require(balance(alice, USD(10) - amountWithRate));
358 env.require(balance(bob, USD(1)));
372 env.fund(XRP(10000), gw, alice, bob);
374 env.trust(USD(10), alice, bob);
388 uint256 const nftId0{token::getNextID(env, gw, 0u)};
389 env(token::mint(gw, 0u));
392 env(token::burn(gw, nftId0));
413 auto const amount = USD(1);
416 env(pay(gw, alice, USD(10)));
417 env(pay(alice, bob, amount), sendmax(USD(10)));
419 env.require(balance(alice, USD(10) - amountWithRate));
420 env.require(balance(bob, amount));
429 using namespace test::jtx;
431 Account
const alice(
"alice");
432 env.fund(XRP(10000), alice);
470 using namespace test::jtx;
472 Account
const alice(
"alice");
473 Account
const bob(
"bob");
475 env.fund(XRP(10000), alice);
482 env(signers(alice, 1, {{bob, 1}}));
499 using namespace test::jtx;
501 Account
const alice(
"alice");
503 env.fund(XRP(10000), alice);
507 env(ticket::create(alice, 1));
509 env.require(owners(alice, 1), tickets(alice, 1));
514 env.require(owners(alice, 1), tickets(alice, 1));
519 env(
noop(alice), ticket::use(ticketSeq));
521 env.require(owners(alice, 0), tickets(alice, 0));
522 BEAST_EXPECT(aliceSeq == env.seq(alice));
532 using namespace test::jtx;
535 Account
const alice(
"alice");
537 env.fund(XRP(10000), alice);
541 if (!BEAST_EXPECT(jtx.stx))
549 BEAST_EXPECT(!result.applied);
550 return result.applied;
A generic endpoint for log messages.
testcase_t testcase
Memberspace for declaring test cases.
void testRequireAuthWithDir()
void testNullAccountSet()
void testSetAndResetAccountTxnID()
void run() override
Runs the suite.
Writable ledger view that accumulates state and tx changes.
void rawReplace(std::shared_ptr< SLE > const &sle) override
Unconditionally replace a state item.
std::shared_ptr< SLE const > read(Keylet const &k) const override
Return the state item associated with a key.
Keylet ownerDir(AccountID const &id) noexcept
The root page of an account's directory.
Keylet account(AccountID const &id) noexcept
AccountID root.
Use hash_* containers for keys that do not need a cryptographically secure hashing algorithm.
constexpr std::uint32_t asfAllowTrustLineClawback
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 std::uint32_t asfGlobalFreeze
constexpr std::uint32_t asfRequireDest
std::pair< PublicKey, SecretKey > randomKeyPair(KeyType type)
Create a key pair using secure random numbers.
constexpr std::uint32_t asfDisableMaster
bool dirIsEmpty(ReadView const &view, Keylet const &k)
Returns true if the directory is empty.
ApplyResult apply(Application &app, OpenView &view, STTx const &tx, ApplyFlags flags, beast::Journal journal)
Apply a transaction to an OpenView.
std::string to_string(base_uint< Bits, Tag > const &a)
T get(Section const §ion, std::string const &name, T const &defaultValue=T{})
Retrieve a key/value pair from a section.
std::string strHex(FwdIt begin, FwdIt end)
constexpr std::uint32_t asfAccountTxnID
constexpr std::uint32_t asfDisallowIncomingPayChan
constexpr std::uint32_t tfOptionalAuth
constexpr std::uint32_t asfDepositAuth
STAmount multiply(STAmount const &amount, Rate const &rate)
constexpr std::uint32_t tfAccountSetMask
constexpr std::uint32_t asfDefaultRipple
constexpr std::uint32_t asfDisallowIncomingTrustline
constexpr std::uint32_t tfAllowXRP
constexpr std::uint32_t asfAuthorizedNFTokenMinter
Rate transferRate(ReadView const &view, AccountID const &issuer)
Returns IOU issuer transfer fee as Rate.
constexpr std::uint32_t tfOptionalDestTag
constexpr std::uint32_t asfDisallowIncomingCheck
constexpr std::uint32_t asfRequireAuth
constexpr std::uint32_t asfNoFreeze
constexpr std::uint32_t asfDisallowXRP
std::enable_if_t< std::is_same< T, char >::value||std::is_same< T, unsigned char >::value, Slice > makeSlice(std::array< T, N > const &a)
constexpr std::uint32_t asfDisallowIncomingNFTokenOffer
constexpr std::uint32_t asfAllowTrustLineLocking
STAmount toAmount< STAmount >(STAmount const &amt)
Represents a transfer rate.