mirror of
https://github.com/XRPLF/rippled.git
synced 2025-11-20 11:05:54 +00:00
Merge branch 'develop' into pratik/Add-sanitizers-to-CI-builds
This commit is contained in:
@@ -66,7 +66,6 @@ XRPL_FEATURE(XRPFees, Supported::yes, VoteBehavior::DefaultNo
|
|||||||
XRPL_FEATURE(DisallowIncoming, Supported::yes, VoteBehavior::DefaultNo)
|
XRPL_FEATURE(DisallowIncoming, Supported::yes, VoteBehavior::DefaultNo)
|
||||||
XRPL_FIX (RemoveNFTokenAutoTrustLine, Supported::yes, VoteBehavior::DefaultYes)
|
XRPL_FIX (RemoveNFTokenAutoTrustLine, Supported::yes, VoteBehavior::DefaultYes)
|
||||||
XRPL_FEATURE(FlowSortStrands, Supported::yes, VoteBehavior::DefaultYes)
|
XRPL_FEATURE(FlowSortStrands, Supported::yes, VoteBehavior::DefaultYes)
|
||||||
XRPL_FEATURE(TicketBatch, Supported::yes, VoteBehavior::DefaultYes)
|
|
||||||
XRPL_FEATURE(NegativeUNL, Supported::yes, VoteBehavior::DefaultYes)
|
XRPL_FEATURE(NegativeUNL, Supported::yes, VoteBehavior::DefaultYes)
|
||||||
XRPL_FEATURE(RequireFullyCanonicalSig, Supported::yes, VoteBehavior::DefaultYes)
|
XRPL_FEATURE(RequireFullyCanonicalSig, Supported::yes, VoteBehavior::DefaultYes)
|
||||||
XRPL_FEATURE(DeletableAccounts, Supported::yes, VoteBehavior::DefaultYes)
|
XRPL_FEATURE(DeletableAccounts, Supported::yes, VoteBehavior::DefaultYes)
|
||||||
@@ -134,5 +133,6 @@ XRPL_RETIRE_FEATURE(MultiSignReserve)
|
|||||||
XRPL_RETIRE_FEATURE(NonFungibleTokensV1_1)
|
XRPL_RETIRE_FEATURE(NonFungibleTokensV1_1)
|
||||||
XRPL_RETIRE_FEATURE(PayChan)
|
XRPL_RETIRE_FEATURE(PayChan)
|
||||||
XRPL_RETIRE_FEATURE(SortedDirectories)
|
XRPL_RETIRE_FEATURE(SortedDirectories)
|
||||||
|
XRPL_RETIRE_FEATURE(TicketBatch)
|
||||||
XRPL_RETIRE_FEATURE(TickSize)
|
XRPL_RETIRE_FEATURE(TickSize)
|
||||||
XRPL_RETIRE_FEATURE(TrustSetAuth)
|
XRPL_RETIRE_FEATURE(TrustSetAuth)
|
||||||
|
|||||||
@@ -155,7 +155,7 @@ TRANSACTION(ttOFFER_CANCEL, 8, OfferCancel,
|
|||||||
#endif
|
#endif
|
||||||
TRANSACTION(ttTICKET_CREATE, 10, TicketCreate,
|
TRANSACTION(ttTICKET_CREATE, 10, TicketCreate,
|
||||||
Delegation::delegatable,
|
Delegation::delegatable,
|
||||||
featureTicketBatch,
|
uint256{},
|
||||||
noPriv,
|
noPriv,
|
||||||
({
|
({
|
||||||
{sfTicketCount, soeREQUIRED},
|
{sfTicketCount, soeREQUIRED},
|
||||||
|
|||||||
@@ -1703,7 +1703,6 @@ class Delegate_test : public beast::unit_test::suite
|
|||||||
// NFTokenMint, NFTokenBurn, NFTokenCreateOffer, NFTokenCancelOffer,
|
// NFTokenMint, NFTokenBurn, NFTokenCreateOffer, NFTokenCancelOffer,
|
||||||
// NFTokenAcceptOffer are not included, they are tested separately.
|
// NFTokenAcceptOffer are not included, they are tested separately.
|
||||||
std::unordered_map<std::string, uint256> txRequiredFeatures{
|
std::unordered_map<std::string, uint256> txRequiredFeatures{
|
||||||
{"TicketCreate", featureTicketBatch},
|
|
||||||
{"CheckCreate", featureChecks},
|
{"CheckCreate", featureChecks},
|
||||||
{"CheckCash", featureChecks},
|
{"CheckCash", featureChecks},
|
||||||
{"CheckCancel", featureChecks},
|
{"CheckCancel", featureChecks},
|
||||||
|
|||||||
@@ -360,52 +360,6 @@ class Ticket_test : public beast::unit_test::suite
|
|||||||
BEAST_EXPECT(ticketSeq < acctRootSeq);
|
BEAST_EXPECT(ticketSeq < acctRootSeq);
|
||||||
}
|
}
|
||||||
|
|
||||||
void
|
|
||||||
testTicketNotEnabled()
|
|
||||||
{
|
|
||||||
testcase("Feature Not Enabled");
|
|
||||||
|
|
||||||
using namespace test::jtx;
|
|
||||||
Env env{*this, testable_amendments() - featureTicketBatch};
|
|
||||||
|
|
||||||
env(ticket::create(env.master, 1), ter(temDISABLED));
|
|
||||||
env.close();
|
|
||||||
env.require(owners(env.master, 0), tickets(env.master, 0));
|
|
||||||
|
|
||||||
env(noop(env.master), ticket::use(1), ter(temMALFORMED));
|
|
||||||
env(noop(env.master),
|
|
||||||
ticket::use(1),
|
|
||||||
seq(env.seq(env.master)),
|
|
||||||
ter(temMALFORMED));
|
|
||||||
|
|
||||||
// Close enough ledgers that the previous transactions are no
|
|
||||||
// longer retried.
|
|
||||||
for (int i = 0; i < 8; ++i)
|
|
||||||
env.close();
|
|
||||||
|
|
||||||
env.enableFeature(featureTicketBatch);
|
|
||||||
env.close();
|
|
||||||
env.require(owners(env.master, 0), tickets(env.master, 0));
|
|
||||||
|
|
||||||
std::uint32_t ticketSeq{env.seq(env.master) + 1};
|
|
||||||
env(ticket::create(env.master, 2));
|
|
||||||
checkTicketCreateMeta(env);
|
|
||||||
env.close();
|
|
||||||
env.require(owners(env.master, 2), tickets(env.master, 2));
|
|
||||||
|
|
||||||
env(noop(env.master), ticket::use(ticketSeq++));
|
|
||||||
checkTicketConsumeMeta(env);
|
|
||||||
env.close();
|
|
||||||
env.require(owners(env.master, 1), tickets(env.master, 1));
|
|
||||||
|
|
||||||
env(fset(env.master, asfDisableMaster),
|
|
||||||
ticket::use(ticketSeq++),
|
|
||||||
ter(tecNO_ALTERNATIVE_KEY));
|
|
||||||
checkTicketConsumeMeta(env);
|
|
||||||
env.close();
|
|
||||||
env.require(owners(env.master, 0), tickets(env.master, 0));
|
|
||||||
}
|
|
||||||
|
|
||||||
void
|
void
|
||||||
testTicketCreatePreflightFail()
|
testTicketCreatePreflightFail()
|
||||||
{
|
{
|
||||||
@@ -907,37 +861,12 @@ class Ticket_test : public beast::unit_test::suite
|
|||||||
void
|
void
|
||||||
testFixBothSeqAndTicket()
|
testFixBothSeqAndTicket()
|
||||||
{
|
{
|
||||||
|
using namespace test::jtx;
|
||||||
|
|
||||||
// It is an error if a transaction contains a non-zero Sequence field
|
// It is an error if a transaction contains a non-zero Sequence field
|
||||||
// and a TicketSequence field. Verify that the error is detected.
|
// and a TicketSequence field. Verify that the error is detected.
|
||||||
testcase("Fix both Seq and Ticket");
|
testcase("Fix both Seq and Ticket");
|
||||||
|
|
||||||
// Try the test without featureTicketBatch enabled.
|
|
||||||
using namespace test::jtx;
|
|
||||||
{
|
|
||||||
Env env{*this, testable_amendments() - featureTicketBatch};
|
|
||||||
Account alice{"alice"};
|
|
||||||
|
|
||||||
env.fund(XRP(10000), alice);
|
|
||||||
env.close();
|
|
||||||
|
|
||||||
// Fail to create a ticket.
|
|
||||||
std::uint32_t const ticketSeq = env.seq(alice) + 1;
|
|
||||||
env(ticket::create(alice, 1), ter(temDISABLED));
|
|
||||||
env.close();
|
|
||||||
env.require(owners(alice, 0), tickets(alice, 0));
|
|
||||||
BEAST_EXPECT(ticketSeq == env.seq(alice) + 1);
|
|
||||||
|
|
||||||
// Create a transaction that includes both a ticket and a non-zero
|
|
||||||
// sequence number. Since a ticket is used and tickets are not yet
|
|
||||||
// enabled the transaction should be malformed.
|
|
||||||
env(noop(alice),
|
|
||||||
ticket::use(ticketSeq),
|
|
||||||
seq(env.seq(alice)),
|
|
||||||
ter(temMALFORMED));
|
|
||||||
env.close();
|
|
||||||
}
|
|
||||||
// Try the test with featureTicketBatch enabled.
|
|
||||||
{
|
|
||||||
Env env{*this, testable_amendments()};
|
Env env{*this, testable_amendments()};
|
||||||
Account alice{"alice"};
|
Account alice{"alice"};
|
||||||
|
|
||||||
@@ -964,13 +893,11 @@ class Ticket_test : public beast::unit_test::suite
|
|||||||
env.require(owners(alice, 1), tickets(alice, 1));
|
env.require(owners(alice, 1), tickets(alice, 1));
|
||||||
BEAST_EXPECT(ticketSeq + 1 == env.seq(alice));
|
BEAST_EXPECT(ticketSeq + 1 == env.seq(alice));
|
||||||
}
|
}
|
||||||
}
|
|
||||||
|
|
||||||
public:
|
public:
|
||||||
void
|
void
|
||||||
run() override
|
run() override
|
||||||
{
|
{
|
||||||
testTicketNotEnabled();
|
|
||||||
testTicketCreatePreflightFail();
|
testTicketCreatePreflightFail();
|
||||||
testTicketCreatePreclaimFail();
|
testTicketCreatePreclaimFail();
|
||||||
testTicketInsufficientReserve();
|
testTicketInsufficientReserve();
|
||||||
|
|||||||
@@ -143,14 +143,6 @@ preflightCheckSimulateKeys(
|
|||||||
NotTEC
|
NotTEC
|
||||||
Transactor::preflight1(PreflightContext const& ctx, std::uint32_t flagMask)
|
Transactor::preflight1(PreflightContext const& ctx, std::uint32_t flagMask)
|
||||||
{
|
{
|
||||||
// This is inappropriate in preflight0, because only Change transactions
|
|
||||||
// skip this function, and those do not allow an sfTicketSequence field.
|
|
||||||
if (ctx.tx.isFieldPresent(sfTicketSequence) &&
|
|
||||||
!ctx.rules.enabled(featureTicketBatch))
|
|
||||||
{
|
|
||||||
return temMALFORMED;
|
|
||||||
}
|
|
||||||
|
|
||||||
if (ctx.tx.isFieldPresent(sfDelegate))
|
if (ctx.tx.isFieldPresent(sfDelegate))
|
||||||
{
|
{
|
||||||
if (!ctx.rules.enabled(featurePermissionDelegationV1_1))
|
if (!ctx.rules.enabled(featurePermissionDelegationV1_1))
|
||||||
@@ -442,8 +434,7 @@ Transactor::checkSeqProxy(
|
|||||||
|
|
||||||
if (t_seqProx.isSeq())
|
if (t_seqProx.isSeq())
|
||||||
{
|
{
|
||||||
if (tx.isFieldPresent(sfTicketSequence) &&
|
if (tx.isFieldPresent(sfTicketSequence))
|
||||||
view.rules().enabled(featureTicketBatch))
|
|
||||||
{
|
{
|
||||||
JLOG(j.trace()) << "applyTransaction: has both a TicketSequence "
|
JLOG(j.trace()) << "applyTransaction: has both a TicketSequence "
|
||||||
"and a non-zero Sequence number";
|
"and a non-zero Sequence number";
|
||||||
|
|||||||
Reference in New Issue
Block a user