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));
47 auto testFlags = [
this, &alice, &alie, &env](
51 flag < std::numeric_limits<std::uint32_t>::digits;
91 if (
std::find(goodFlags.begin(), goodFlags.end(), flag) !=
95 env.require(nflags(alice, flag));
96 env(fset(alice, flag), sig(alice));
98 env.require(flags(alice, flag));
99 env(fclear(alice, flag), sig(alie));
101 env.require(nflags(alice, flag));
103 BEAST_EXPECT(now_flags == orig_flags);
108 BEAST_EXPECT((*env.le(alice))[sfFlags] == orig_flags);
109 env(fset(alice, flag), sig(alice));
111 BEAST_EXPECT((*env.le(alice))[sfFlags] == orig_flags);
112 env(fclear(alice, flag), sig(alie));
114 BEAST_EXPECT((*env.le(alice))[sfFlags] == orig_flags);
131 testcase(
"Set and reset AccountTxnID");
133 using namespace test::jtx;
135 Account
const alice(
"alice");
136 env.fund(XRP(10000), noripple(alice));
142 BEAST_EXPECT(!env.le(alice)->isFieldPresent(sfAccountTxnID));
144 BEAST_EXPECT(env.le(alice)->isFieldPresent(sfAccountTxnID));
146 BEAST_EXPECT(!env.le(alice)->isFieldPresent(sfAccountTxnID));
148 BEAST_EXPECT(now_flags == orig_flags);
156 using namespace test::jtx;
158 Account
const alice(
"alice");
159 env.fund(XRP(10000), noripple(alice));
161 env(regkey(alice,
"eric"));
177 using namespace test::jtx;
179 Account
const alice(
"alice");
180 env.fund(XRP(10000), alice);
181 auto jt =
noop(alice);
189 jt[sfDomain.fieldName] =
strHex(domain);
191 BEAST_EXPECT((*env.le(alice))[sfDomain] ==
makeSlice(domain));
193 jt[sfDomain.fieldName] =
"";
195 BEAST_EXPECT(!env.le(alice)->isFieldPresent(sfDomain));
201 for (
std::size_t len = maxLength - 1; len <= maxLength + 1; ++len)
206 BEAST_EXPECT(domain2.
length() == len);
208 jt[sfDomain.fieldName] =
strHex(domain2);
210 if (len <= maxLength)
213 BEAST_EXPECT((*env.le(alice))[sfDomain] ==
makeSlice(domain2));
227 using namespace test::jtx;
229 Account
const alice(
"alice");
230 env.fund(XRP(10000), alice);
231 auto jt =
noop(alice);
234 jt[sfMessageKey.fieldName] =
strHex(rkp.first.slice());
237 strHex((*env.le(alice))[sfMessageKey]) ==
238 strHex(rkp.first.slice()));
240 jt[sfMessageKey.fieldName] =
"";
242 BEAST_EXPECT(!env.le(alice)->isFieldPresent(sfMessageKey));
244 using namespace std::string_literals;
245 jt[sfMessageKey.fieldName] =
strHex(
"NOT_REALLY_A_PUBKEY"s);
254 using namespace test::jtx;
256 Account
const alice(
"alice");
257 env.fund(XRP(10000), alice);
258 auto jt =
noop(alice);
261 "9633EC8AF54F16B5286DB1D7B519EF49EEFC050C0C8AC4384F1D88ACD1BFDF05";
262 jt[sfWalletLocator.fieldName] = locator;
264 BEAST_EXPECT(
to_string((*env.le(alice))[sfWalletLocator]) == locator);
266 jt[sfWalletLocator.fieldName] =
"";
268 BEAST_EXPECT(!env.le(alice)->isFieldPresent(sfWalletLocator));
276 using namespace test::jtx;
278 Account
const alice(
"alice");
279 env.fund(XRP(10000), alice);
280 auto jt =
noop(alice);
282 std::string const mh(
"5F31A79367DC3137FADA860C05742EE6");
283 jt[sfEmailHash.fieldName] = mh;
285 BEAST_EXPECT(
to_string((*env.le(alice))[sfEmailHash]) == mh);
287 jt[sfEmailHash.fieldName] =
"";
289 BEAST_EXPECT(!env.le(alice)->isFieldPresent(sfEmailHash));
304 using namespace test::jtx;
305 auto doTests = [
this](
308 Env env(*
this, features);
310 Account
const alice(
"alice");
311 env.fund(XRP(10000), alice);
313 for (
auto const& r : testData)
315 env(rate(alice, r.set), ter(r.code));
319 if (!(*env.le(alice))[~sfTransferRate])
320 BEAST_EXPECT(r.get == 1.0);
323 *(*env.le(alice))[~sfTransferRate] ==
324 r.get * QUALITY_ONE);
329 testable_amendments(),
344 using namespace test::jtx;
346 Account
const alice(
"alice");
347 Account
const bob(
"bob");
348 Account
const gw(
"gateway");
349 auto const USD = gw[
"USD"];
356 env.fund(XRP(10000), gw, alice, bob);
358 env.trust(USD(10), alice, bob);
363 auto const amount = USD(1);
365 auto const amountWithRate =
368 env(pay(gw, alice, USD(10)));
370 env(pay(alice, bob, USD(1)), sendmax(USD(10)));
373 env.require(balance(alice, USD(10) - amountWithRate));
374 env.require(balance(bob, USD(1)));
388 env.fund(XRP(10000), gw, alice, bob);
390 env.trust(USD(10), alice, bob);
404 uint256 const nftId0{token::getNextID(env, gw, 0u)};
405 env(token::mint(gw, 0u));
408 env(token::burn(gw, nftId0));
415 env.app().openLedger().modify(
425 (*replacement)[sfTransferRate] =
431 auto const amount = USD(1);
435 env(pay(gw, alice, USD(10)));
436 env(pay(alice, bob, amount), sendmax(USD(10)));
438 env.require(balance(alice, USD(10) - amountWithRate));
439 env.require(balance(bob, amount));
448 using namespace test::jtx;
450 Account
const alice(
"alice");
451 env.fund(XRP(10000), alice);
491 using namespace test::jtx;
493 Account
const alice(
"alice");
494 Account
const bob(
"bob");
496 env.fund(XRP(10000), alice);
503 env(signers(alice, 1, {{bob, 1}}));
520 using namespace test::jtx;
522 Account
const alice(
"alice");
524 env.fund(XRP(10000), alice);
528 env(ticket::create(alice, 1));
530 env.require(owners(alice, 1), tickets(alice, 1));
535 env.require(owners(alice, 1), tickets(alice, 1));
540 env(
noop(alice), ticket::use(ticketSeq));
542 env.require(owners(alice, 0), tickets(alice, 0));
543 BEAST_EXPECT(aliceSeq == env.seq(alice));
553 using namespace test::jtx;
556 Account
const alice(
"alice");
558 env.fund(XRP(10000), alice);
562 if (!BEAST_EXPECT(jtx.stx))
571 BEAST_EXPECT(!result.applied);
572 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.