22#include <xrpld/app/tx/apply.h>
24#include <xrpl/protocol/AmountConversions.h>
25#include <xrpl/protocol/Feature.h>
26#include <xrpl/protocol/Quality.h>
27#include <xrpl/protocol/Rate.h>
28#include <xrpl/protocol/jss.h>
40 using namespace test::jtx;
42 Account
const alice(
"alice");
43 env.fund(XRP(10000), noripple(alice));
45 auto const jrr = env.le(alice);
46 BEAST_EXPECT(jrr && jrr->at(sfFlags) == 0u);
54 using namespace test::jtx;
55 Account
const alice(
"alice");
58 Env env(*
this, testable_amendments() - featureDepositAuth);
59 env.fund(XRP(10000), noripple(alice));
64 env(regkey(alice, alie));
67 auto testFlags = [
this, &alice, &alie, &env](
71 flag < std::numeric_limits<std::uint32_t>::digits;
111 if (
std::find(goodFlags.begin(), goodFlags.end(), flag) !=
115 env.require(nflags(alice, flag));
116 env(fset(alice, flag), sig(alice));
118 env.require(flags(alice, flag));
119 env(fclear(alice, flag), sig(alie));
121 env.require(nflags(alice, flag));
123 BEAST_EXPECT(now_flags == orig_flags);
128 BEAST_EXPECT((*env.le(alice))[sfFlags] == orig_flags);
129 env(fset(alice, flag), sig(alice));
131 BEAST_EXPECT((*env.le(alice))[sfFlags] == orig_flags);
132 env(fclear(alice, flag), sig(alie));
134 BEAST_EXPECT((*env.le(alice))[sfFlags] == orig_flags);
149 env.enableFeature(featureDepositAuth);
164 testcase(
"Set and reset AccountTxnID");
166 using namespace test::jtx;
168 Account
const alice(
"alice");
169 env.fund(XRP(10000), noripple(alice));
175 BEAST_EXPECT(!env.le(alice)->isFieldPresent(sfAccountTxnID));
177 BEAST_EXPECT(env.le(alice)->isFieldPresent(sfAccountTxnID));
179 BEAST_EXPECT(!env.le(alice)->isFieldPresent(sfAccountTxnID));
181 BEAST_EXPECT(now_flags == orig_flags);
189 using namespace test::jtx;
191 Account
const alice(
"alice");
192 env.fund(XRP(10000), noripple(alice));
194 env(regkey(alice,
"eric"));
210 using namespace test::jtx;
212 Account
const alice(
"alice");
213 env.fund(XRP(10000), alice);
214 auto jt =
noop(alice);
222 jt[sfDomain.fieldName] =
strHex(domain);
224 BEAST_EXPECT((*env.le(alice))[sfDomain] ==
makeSlice(domain));
226 jt[sfDomain.fieldName] =
"";
228 BEAST_EXPECT(!env.le(alice)->isFieldPresent(sfDomain));
234 for (
std::size_t len = maxLength - 1; len <= maxLength + 1; ++len)
239 BEAST_EXPECT(domain2.
length() == len);
241 jt[sfDomain.fieldName] =
strHex(domain2);
243 if (len <= maxLength)
246 BEAST_EXPECT((*env.le(alice))[sfDomain] ==
makeSlice(domain2));
260 using namespace test::jtx;
262 Account
const alice(
"alice");
263 env.fund(XRP(10000), alice);
264 auto jt =
noop(alice);
267 jt[sfMessageKey.fieldName] =
strHex(rkp.first.slice());
270 strHex((*env.le(alice))[sfMessageKey]) ==
271 strHex(rkp.first.slice()));
273 jt[sfMessageKey.fieldName] =
"";
275 BEAST_EXPECT(!env.le(alice)->isFieldPresent(sfMessageKey));
277 using namespace std::string_literals;
278 jt[sfMessageKey.fieldName] =
strHex(
"NOT_REALLY_A_PUBKEY"s);
287 using namespace test::jtx;
289 Account
const alice(
"alice");
290 env.fund(XRP(10000), alice);
291 auto jt =
noop(alice);
294 "9633EC8AF54F16B5286DB1D7B519EF49EEFC050C0C8AC4384F1D88ACD1BFDF05";
295 jt[sfWalletLocator.fieldName] = locator;
297 BEAST_EXPECT(
to_string((*env.le(alice))[sfWalletLocator]) == locator);
299 jt[sfWalletLocator.fieldName] =
"";
301 BEAST_EXPECT(!env.le(alice)->isFieldPresent(sfWalletLocator));
309 using namespace test::jtx;
311 Account
const alice(
"alice");
312 env.fund(XRP(10000), alice);
313 auto jt =
noop(alice);
315 std::string const mh(
"5F31A79367DC3137FADA860C05742EE6");
316 jt[sfEmailHash.fieldName] = mh;
318 BEAST_EXPECT(
to_string((*env.le(alice))[sfEmailHash]) == mh);
320 jt[sfEmailHash.fieldName] =
"";
322 BEAST_EXPECT(!env.le(alice)->isFieldPresent(sfEmailHash));
337 using namespace test::jtx;
338 auto doTests = [
this](
341 Env env(*
this, features);
343 Account
const alice(
"alice");
344 env.fund(XRP(10000), alice);
346 for (
auto const& r : testData)
348 env(rate(alice, r.set), ter(r.code));
352 if (!(*env.le(alice))[~sfTransferRate])
353 BEAST_EXPECT(r.get == 1.0);
356 *(*env.le(alice))[~sfTransferRate] ==
357 r.get * QUALITY_ONE);
362 testable_amendments(),
377 using namespace test::jtx;
379 Account
const alice(
"alice");
380 Account
const bob(
"bob");
381 Account
const gw(
"gateway");
382 auto const USD = gw[
"USD"];
389 env.fund(XRP(10000), gw, alice, bob);
391 env.trust(USD(10), alice, bob);
396 auto const amount = USD(1);
398 auto const amountWithRate =
401 env(pay(gw, alice, USD(10)));
403 env(pay(alice, bob, USD(1)), sendmax(USD(10)));
406 env.require(balance(alice, USD(10) - amountWithRate));
407 env.require(balance(bob, USD(1)));
421 env.fund(XRP(10000), gw, alice, bob);
423 env.trust(USD(10), alice, bob);
437 uint256 const nftId0{token::getNextID(env, gw, 0u)};
438 env(token::mint(gw, 0u));
441 env(token::burn(gw, nftId0));
448 env.app().openLedger().modify(
458 (*replacement)[sfTransferRate] =
464 auto const amount = USD(1);
468 env(pay(gw, alice, USD(10)));
469 env(pay(alice, bob, amount), sendmax(USD(10)));
471 env.require(balance(alice, USD(10) - amountWithRate));
472 env.require(balance(bob, amount));
481 using namespace test::jtx;
483 Account
const alice(
"alice");
484 env.fund(XRP(10000), alice);
524 using namespace test::jtx;
526 Account
const alice(
"alice");
527 Account
const bob(
"bob");
529 env.fund(XRP(10000), alice);
536 env(signers(alice, 1, {{bob, 1}}));
553 using namespace test::jtx;
555 Account
const alice(
"alice");
557 env.fund(XRP(10000), alice);
561 env(ticket::create(alice, 1));
563 env.require(owners(alice, 1), tickets(alice, 1));
568 env.require(owners(alice, 1), tickets(alice, 1));
573 env(
noop(alice), ticket::use(ticketSeq));
575 env.require(owners(alice, 0), tickets(alice, 0));
576 BEAST_EXPECT(aliceSeq == env.seq(alice));
586 using namespace test::jtx;
589 Account
const alice(
"alice");
591 env.fund(XRP(10000), alice);
595 if (!BEAST_EXPECT(jtx.stx))
604 BEAST_EXPECT(!result.applied);
605 return result.applied;
A generic endpoint for log messages.
testcase_t testcase
Memberspace for declaring test cases.
void testNullAccountSet()
void testSetAndResetAccountTxnID()
void testRequireAuthWithDir()
void run() override
Runs the suite.
Writable ledger view that accumulates state and tx changes.
std::shared_ptr< SLE const > read(Keylet const &k) const override
Return the state item associated with a key.
void rawReplace(std::shared_ptr< SLE > const &sle) override
Unconditionally replace a state item.
Keylet account(AccountID const &id) noexcept
AccountID root.
Keylet ownerDir(AccountID const &id) noexcept
The root page of an account's directory.
Use hash_* containers for keys that do not need a cryptographically secure hashing algorithm.
constexpr std::uint32_t tfAllowXRP
constexpr std::uint32_t asfGlobalFreeze
constexpr std::uint32_t asfDepositAuth
constexpr std::uint32_t asfDisallowIncomingNFTokenOffer
constexpr std::uint32_t asfAllowTrustLineLocking
constexpr std::uint32_t asfRequireDest
STAmount toAmount< STAmount >(STAmount const &amt)
constexpr std::uint32_t asfAuthorizedNFTokenMinter
constexpr std::uint32_t tfOptionalDestTag
constexpr std::uint32_t tfAccountSetMask
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,...
STAmount multiply(STAmount const &amount, Rate const &rate)
constexpr std::uint32_t asfNoFreeze
constexpr std::uint32_t asfDisableMaster
bool dirIsEmpty(ReadView const &view, Keylet const &k)
Returns true if the directory is empty.
constexpr std::uint32_t asfDisallowIncomingTrustline
std::string strHex(FwdIt begin, FwdIt end)
constexpr std::uint32_t asfAccountTxnID
constexpr std::uint32_t asfDefaultRipple
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 asfDisallowIncomingCheck
Rate transferRate(ReadView const &view, AccountID const &issuer)
Returns IOU issuer transfer fee as Rate.
constexpr std::uint32_t tfOptionalAuth
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)
constexpr std::uint32_t asfDisallowIncomingPayChan
T get(Section const §ion, std::string const &name, T const &defaultValue=T{})
Retrieve a key/value pair from a section.
std::pair< PublicKey, SecretKey > randomKeyPair(KeyType type)
Create a key pair using secure random numbers.
constexpr std::uint32_t asfAllowTrustLineClawback
constexpr std::uint32_t asfRequireAuth
constexpr std::uint32_t asfDisallowXRP
Represents a transfer rate.