mirror of
https://github.com/Xahau/xahaud.git
synced 2025-12-06 17:27:52 +00:00
Augment LedgerRequestRPC tests (RIPD-1270):
Add basic ledger_request validation tests to replace the existing ledger.js tests. Provide tests that trigger some error conditions in RPC handling code.
This commit is contained in:
committed by
Nik Bougalis
parent
8f41817cb9
commit
fd061bba8a
@@ -22,6 +22,7 @@
|
|||||||
#include <ripple/protocol/JsonFields.h>
|
#include <ripple/protocol/JsonFields.h>
|
||||||
#include <ripple/test/jtx.h>
|
#include <ripple/test/jtx.h>
|
||||||
#include <ripple/beast/unit_test.h>
|
#include <ripple/beast/unit_test.h>
|
||||||
|
#include <ripple/app/ledger/LedgerMaster.h>
|
||||||
|
|
||||||
namespace ripple {
|
namespace ripple {
|
||||||
|
|
||||||
@@ -30,6 +31,18 @@ namespace RPC {
|
|||||||
class LedgerRequestRPC_test : public beast::unit_test::suite
|
class LedgerRequestRPC_test : public beast::unit_test::suite
|
||||||
{
|
{
|
||||||
public:
|
public:
|
||||||
|
|
||||||
|
static
|
||||||
|
std::unique_ptr<Config>
|
||||||
|
makeNonAdminConfig()
|
||||||
|
{
|
||||||
|
auto p = std::make_unique<Config>();
|
||||||
|
test::setupConfigForUnitTests(*p);
|
||||||
|
(*p)["port_rpc"].set("admin","");
|
||||||
|
(*p)["port_ws"].set("admin","");
|
||||||
|
return p;
|
||||||
|
}
|
||||||
|
|
||||||
void testLedgerRequest()
|
void testLedgerRequest()
|
||||||
{
|
{
|
||||||
using namespace test::jtx;
|
using namespace test::jtx;
|
||||||
@@ -145,9 +158,155 @@ public:
|
|||||||
|
|
||||||
}
|
}
|
||||||
|
|
||||||
|
void testEvolution()
|
||||||
|
{
|
||||||
|
using namespace test::jtx;
|
||||||
|
Env env { *this };
|
||||||
|
Account const gw { "gateway" };
|
||||||
|
auto const USD = gw["USD"];
|
||||||
|
env.fund(XRP(100000), gw);
|
||||||
|
env.close();
|
||||||
|
|
||||||
|
env.memoize("bob");
|
||||||
|
env.fund(XRP(1000), "bob");
|
||||||
|
env.close();
|
||||||
|
|
||||||
|
env.memoize("alice");
|
||||||
|
env.fund(XRP(1000), "alice");
|
||||||
|
env.close();
|
||||||
|
|
||||||
|
env.memoize("carol");
|
||||||
|
env.fund(XRP(1000), "carol");
|
||||||
|
env.close();
|
||||||
|
|
||||||
|
auto result = env.rpc ( "ledger_request", "1" ) [jss::result];
|
||||||
|
BEAST_EXPECT(result[jss::ledger][jss::ledger_index] == "1");
|
||||||
|
BEAST_EXPECT(result[jss::ledger][jss::total_coins] == "100000000000000000");
|
||||||
|
BEAST_EXPECT(result[jss::ledger][jss::closed] == true);
|
||||||
|
BEAST_EXPECT(result[jss::ledger][jss::ledger_hash] == "AB868A6CFEEC779C2FF845C0AF00A642259986AF40C01976A7F842B6918936C7");
|
||||||
|
BEAST_EXPECT(result[jss::ledger][jss::parent_hash] == "0000000000000000000000000000000000000000000000000000000000000000");
|
||||||
|
BEAST_EXPECT(result[jss::ledger][jss::account_hash] == "A21ED30C04C88046FC61DB9DC19375EEDBD365FD8C17286F27127DF804E9CAA6");
|
||||||
|
BEAST_EXPECT(result[jss::ledger][jss::transaction_hash] == "0000000000000000000000000000000000000000000000000000000000000000");
|
||||||
|
|
||||||
|
result = env.rpc ( "ledger_request", "2" ) [jss::result];
|
||||||
|
BEAST_EXPECT(result[jss::ledger][jss::ledger_index] == "2");
|
||||||
|
BEAST_EXPECT(result[jss::ledger][jss::total_coins] == "100000000000000000");
|
||||||
|
BEAST_EXPECT(result[jss::ledger][jss::closed] == true);
|
||||||
|
BEAST_EXPECT(result[jss::ledger][jss::ledger_hash] == "8AEDBB96643962F1D40F01E25632ABB3C56C9F04B0231EE4B18248B90173D189");
|
||||||
|
BEAST_EXPECT(result[jss::ledger][jss::parent_hash] == "AB868A6CFEEC779C2FF845C0AF00A642259986AF40C01976A7F842B6918936C7");
|
||||||
|
BEAST_EXPECT(result[jss::ledger][jss::account_hash] == "183D5235C7C1FB5AE67AD2F6CC3B28F5FB86E8C4F89DB50DD85641A96470534E");
|
||||||
|
BEAST_EXPECT(result[jss::ledger][jss::transaction_hash] == "0000000000000000000000000000000000000000000000000000000000000000");
|
||||||
|
|
||||||
|
result = env.rpc ( "ledger_request", "3" ) [jss::result];
|
||||||
|
BEAST_EXPECT(result[jss::ledger][jss::ledger_index] == "3");
|
||||||
|
BEAST_EXPECT(result[jss::ledger][jss::total_coins] == "99999999999999980");
|
||||||
|
BEAST_EXPECT(result[jss::ledger][jss::closed] == true);
|
||||||
|
BEAST_EXPECT(result[jss::ledger][jss::ledger_hash] == "D2EE1E2A7288AAD43D6FA8AD8007FD1A95646F365EF3A1AD608A03258F11CF18");
|
||||||
|
BEAST_EXPECT(result[jss::ledger][jss::parent_hash] == "8AEDBB96643962F1D40F01E25632ABB3C56C9F04B0231EE4B18248B90173D189");
|
||||||
|
BEAST_EXPECT(result[jss::ledger][jss::account_hash] == "22565DC00D1A30F2C15871714E512976EF476281E5E87FF63D3E129C9069F4F4");
|
||||||
|
BEAST_EXPECT(result[jss::ledger][jss::transaction_hash] == "0213EC486C058B3942FBE3DAC6839949A5C5B02B8B4244C8998EFDF04DBD8222");
|
||||||
|
|
||||||
|
result = env.rpc ( "ledger_request", "4" ) [jss::result];
|
||||||
|
BEAST_EXPECT(result[jss::ledger][jss::ledger_index] == "4");
|
||||||
|
BEAST_EXPECT(result[jss::ledger][jss::total_coins] == "99999999999999960");
|
||||||
|
BEAST_EXPECT(result[jss::ledger][jss::closed] == true);
|
||||||
|
BEAST_EXPECT(result[jss::ledger][jss::ledger_hash] == "8F9032390CDD4C9D7A5B216AFDA3B525A3B39D7589C69D90D4C6BCA4619DD33C");
|
||||||
|
BEAST_EXPECT(result[jss::ledger][jss::parent_hash] == "D2EE1E2A7288AAD43D6FA8AD8007FD1A95646F365EF3A1AD608A03258F11CF18");
|
||||||
|
BEAST_EXPECT(result[jss::ledger][jss::account_hash] == "C3335CA14E712CB28F2A7C09BEB9A24BF30BBFA5528F156C19F6665D7A588FEA");
|
||||||
|
BEAST_EXPECT(result[jss::ledger][jss::transaction_hash] == "3CBDB8F42E04333E1642166BFB93AC9A7E1C6C067092CD5D881D6F3AB3D67E76");
|
||||||
|
|
||||||
|
result = env.rpc ( "ledger_request", "5" ) [jss::result];
|
||||||
|
BEAST_EXPECT(result[jss::ledger][jss::ledger_index] == "5");
|
||||||
|
BEAST_EXPECT(result[jss::ledger][jss::total_coins] == "99999999999999940");
|
||||||
|
BEAST_EXPECT(result[jss::ledger][jss::closed] == true);
|
||||||
|
BEAST_EXPECT(result[jss::ledger][jss::ledger_hash] == "3EDEB201735867A8EEECBC79A75902C05A7E3F192E4C12E02E67BFDDE5566CCE");
|
||||||
|
BEAST_EXPECT(result[jss::ledger][jss::parent_hash] == "8F9032390CDD4C9D7A5B216AFDA3B525A3B39D7589C69D90D4C6BCA4619DD33C");
|
||||||
|
BEAST_EXPECT(result[jss::ledger][jss::account_hash] == "7C77B1E9EB86410D84EE0CD50716AAA21192F19CF533194AD705798895248212");
|
||||||
|
BEAST_EXPECT(result[jss::ledger][jss::transaction_hash] == "C3D086CD6BDB9E97AD1D513B2C049EF2840BD21D0B3E22D84EBBB89B6D2EF59D");
|
||||||
|
|
||||||
|
result = env.rpc ( "ledger_request", "6" ) [jss::result];
|
||||||
|
BEAST_EXPECT(result[jss::error] == "invalidParams");
|
||||||
|
BEAST_EXPECT(result[jss::status] == "error");
|
||||||
|
BEAST_EXPECT(result[jss::error_message] == "Ledger index too large");
|
||||||
|
}
|
||||||
|
|
||||||
|
void testBadInput()
|
||||||
|
{
|
||||||
|
using namespace test::jtx;
|
||||||
|
Env env { *this };
|
||||||
|
Account const gw { "gateway" };
|
||||||
|
auto const USD = gw["USD"];
|
||||||
|
env.fund(XRP(100000), gw);
|
||||||
|
env.close();
|
||||||
|
|
||||||
|
Json::Value jvParams;
|
||||||
|
jvParams[jss::ledger_hash] = "AB868A6CFEEC779C2FF845C0AF00A642259986AF40C01976A7F842B6918936C7";
|
||||||
|
jvParams[jss::ledger_index] = "1";
|
||||||
|
auto result = env.rpc ("json", "ledger_request", jvParams.toStyledString()) [jss::result];
|
||||||
|
BEAST_EXPECT(result[jss::error] == "invalidParams");
|
||||||
|
BEAST_EXPECT(result[jss::status] == "error");
|
||||||
|
BEAST_EXPECT(result[jss::error_message] == "Exactly one of ledger_hash and ledger_index can be set.");
|
||||||
|
|
||||||
|
// the purpose in this test is to force the ledger expiration/out of
|
||||||
|
// date check to trigger
|
||||||
|
env.timeKeeper().adjustCloseTime(weeks{3});
|
||||||
|
result = env.rpc ( "ledger_request", "1" ) [jss::result];
|
||||||
|
BEAST_EXPECT(result[jss::error] == "noCurrent");
|
||||||
|
BEAST_EXPECT(result[jss::status] == "error");
|
||||||
|
BEAST_EXPECT(result[jss::error_message] == "Current ledger is unavailable.");
|
||||||
|
|
||||||
|
}
|
||||||
|
|
||||||
|
void testMoreThan256Closed()
|
||||||
|
{
|
||||||
|
using namespace test::jtx;
|
||||||
|
Env env {*this};
|
||||||
|
Account const gw {"gateway"};
|
||||||
|
env.app().getLedgerMaster().tune(0, 3600);
|
||||||
|
auto const USD = gw["USD"];
|
||||||
|
env.fund(XRP(100000), gw);
|
||||||
|
|
||||||
|
int const max_limit = 256;
|
||||||
|
|
||||||
|
for (auto i = 0; i < max_limit + 10; i++)
|
||||||
|
{
|
||||||
|
Account const bob {std::string("bob") + std::to_string(i)};
|
||||||
|
env.fund(XRP(1000), bob);
|
||||||
|
env.close();
|
||||||
|
}
|
||||||
|
|
||||||
|
auto result = env.rpc ( "ledger_request", "1" ) [jss::result];
|
||||||
|
BEAST_EXPECT(result[jss::ledger][jss::ledger_index] == "1");
|
||||||
|
BEAST_EXPECT(result[jss::ledger][jss::total_coins] == "100000000000000000");
|
||||||
|
BEAST_EXPECT(result[jss::ledger][jss::closed] == true);
|
||||||
|
BEAST_EXPECT(result[jss::ledger][jss::ledger_hash] == "AB868A6CFEEC779C2FF845C0AF00A642259986AF40C01976A7F842B6918936C7");
|
||||||
|
BEAST_EXPECT(result[jss::ledger][jss::parent_hash] == "0000000000000000000000000000000000000000000000000000000000000000");
|
||||||
|
BEAST_EXPECT(result[jss::ledger][jss::account_hash] == "A21ED30C04C88046FC61DB9DC19375EEDBD365FD8C17286F27127DF804E9CAA6");
|
||||||
|
BEAST_EXPECT(result[jss::ledger][jss::transaction_hash] == "0000000000000000000000000000000000000000000000000000000000000000");
|
||||||
|
}
|
||||||
|
|
||||||
|
void testNonAdmin()
|
||||||
|
{
|
||||||
|
using namespace test::jtx;
|
||||||
|
Env env { *this, makeNonAdminConfig() };
|
||||||
|
Account const gw { "gateway" };
|
||||||
|
auto const USD = gw["USD"];
|
||||||
|
env.fund(XRP(100000), gw);
|
||||||
|
env.close();
|
||||||
|
|
||||||
|
auto const result = env.rpc ( "ledger_request", "1" ) [jss::result];
|
||||||
|
BEAST_EXPECT(result[jss::error] == "noPermission");
|
||||||
|
BEAST_EXPECT(result[jss::status] == "error");
|
||||||
|
BEAST_EXPECT(result[jss::error_message] == "You don't have permission for this command.");
|
||||||
|
}
|
||||||
|
|
||||||
void run ()
|
void run ()
|
||||||
{
|
{
|
||||||
testLedgerRequest ();
|
testLedgerRequest();
|
||||||
|
testEvolution();
|
||||||
|
testBadInput();
|
||||||
|
testMoreThan256Closed();
|
||||||
|
testNonAdmin();
|
||||||
}
|
}
|
||||||
};
|
};
|
||||||
|
|
||||||
|
|||||||
@@ -175,6 +175,12 @@ public:
|
|||||||
return *bundle_.app;
|
return *bundle_.app;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
ManualTimeKeeper&
|
||||||
|
timeKeeper()
|
||||||
|
{
|
||||||
|
return *bundle_.timeKeeper;
|
||||||
|
}
|
||||||
|
|
||||||
/** Returns the current Ripple Network Time
|
/** Returns the current Ripple Network Time
|
||||||
|
|
||||||
@note This is manually advanced when ledgers
|
@note This is manually advanced when ledgers
|
||||||
@@ -183,7 +189,7 @@ public:
|
|||||||
NetClock::time_point
|
NetClock::time_point
|
||||||
now()
|
now()
|
||||||
{
|
{
|
||||||
return app().timeKeeper().now();
|
return timeKeeper().now();
|
||||||
}
|
}
|
||||||
|
|
||||||
/** Returns the connected client. */
|
/** Returns the connected client. */
|
||||||
|
|||||||
@@ -204,7 +204,7 @@ Env::close(NetClock::time_point closeTime,
|
|||||||
{
|
{
|
||||||
// Round up to next distinguishable value
|
// Round up to next distinguishable value
|
||||||
closeTime += closed()->info().closeTimeResolution - 1s;
|
closeTime += closed()->info().closeTimeResolution - 1s;
|
||||||
bundle_.timeKeeper->set(closeTime);
|
timeKeeper().set(closeTime);
|
||||||
// Go through the rpc interface unless we need to simulate
|
// Go through the rpc interface unless we need to simulate
|
||||||
// a specific consensus delay.
|
// a specific consensus delay.
|
||||||
if (consensusDelay)
|
if (consensusDelay)
|
||||||
@@ -214,7 +214,7 @@ Env::close(NetClock::time_point closeTime,
|
|||||||
rpc("ledger_accept");
|
rpc("ledger_accept");
|
||||||
// VFALCO No error check?
|
// VFALCO No error check?
|
||||||
}
|
}
|
||||||
bundle_.timeKeeper->set(
|
timeKeeper().set(
|
||||||
closed()->info().closeTime);
|
closed()->info().closeTime);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|||||||
Reference in New Issue
Block a user