22#include <xrpl/beast/unit_test.h>
23#include <xrpl/json/json_reader.h>
24#include <xrpl/json/to_string.h>
25#include <xrpl/protocol/SecretKey.h>
26#include <xrpl/protocol/jss.h>
27#include <xrpl/protocol/st.h>
48 testcase(
"parse json array invalid children");
64 "\"ModifiedNode\":{\"Sequence\":1}, "
65 "\"DeletedNode\":{\"Sequence\":1}"
73 BEAST_EXPECT(!parsed.
object);
87 "{\"Template\":[{\"ModifiedNode\":{\"Sequence\":1}}]}");
94 BEAST_EXPECT(parsed.
object);
97 BEAST_EXPECT(serialized ==
json);
101 fail(
"Couldn't parse json: " +
json);
111 std::string const goodJson(R
"({"CloseResolution":19,"Method":250,)"
112 R"("TransactionResult":"tecFROZEN"})");
118 if (BEAST_EXPECT(parsed.
object))
122 BEAST_EXPECT(serialized == goodJson);
129 R
"({"CloseResolution":19,"Method":"250",)"
130 R"("TransactionResult":"tecFROZEN"})");
132 R
"({"CloseResolution":19,"Method":250,)"
133 R"("TransactionResult":"tecFROZEN"})");
142 if (BEAST_EXPECT(parsed.
object))
146 BEAST_EXPECT(serialized == expectedJson);
153 R"("TransactionResult":"terQUEUED"})");
159 BEAST_EXPECT(!parsed.
object);
160 BEAST_EXPECT(parsed.
error);
161 BEAST_EXPECT(parsed.
error[jss::error] ==
"invalidParams");
163 parsed.
error[jss::error_message] ==
164 "Field 'test.TransactionResult' is out of range.");
170 R"("TransactionResult":"tesSUCCESS"})");
176 BEAST_EXPECT(!parsed.
object);
177 BEAST_EXPECT(parsed.
error);
178 BEAST_EXPECT(parsed.
error[jss::error] ==
"invalidParams");
180 parsed.
error[jss::error_message] ==
181 "Field 'test.Method' has bad type.");
187 R
"({"CloseResolution":19,"Method":3294967296,)"
188 R"("TransactionResult":"tesSUCCESS"})");
194 BEAST_EXPECT(!parsed.
object);
195 BEAST_EXPECT(parsed.
error);
196 BEAST_EXPECT(parsed.
error[jss::error] ==
"invalidParams");
198 parsed.
error[jss::error_message] ==
199 "Field 'test.Method' is out of range.");
205 R"("TransactionResult":"tesSUCCESS"})");
211 BEAST_EXPECT(!parsed.
object);
212 BEAST_EXPECT(parsed.
error);
213 BEAST_EXPECT(parsed.
error[jss::error] ==
"invalidParams");
215 parsed.
error[jss::error_message] ==
216 "Field 'test.CloseResolution' is out of range.");
222 R
"({"CloseResolution":19,"Method":3.141592653,)"
223 R"("TransactionResult":"tesSUCCESS"})");
229 BEAST_EXPECT(!parsed.
object);
230 BEAST_EXPECT(parsed.
error);
231 BEAST_EXPECT(parsed.
error[jss::error] ==
"invalidParams");
233 parsed.
error[jss::error_message] ==
234 "Field 'test.Method' has bad type.");
247 except<std::runtime_error>(
256 BEAST_EXPECT(shouldBeInvalid ==
sfInvalid);
258 testInvalid(STI_VL, 255);
259 testInvalid(STI_UINT256, 255);
260 testInvalid(STI_UINT32, 255);
261 testInvalid(STI_VECTOR256, 255);
262 testInvalid(STI_OBJECT, 255);
266 except<std::runtime_error>(
271 except<std::runtime_error>([&]() {
280 SField const& sfTestVL = sfMasterSignature;
281 SField const& sfTestH256 = sfCheckID;
282 SField const& sfTestU32 = sfSettleDelay;
283 SField const& sfTestV256 = sfAmendments;
284 SField const& sfTestObject = sfMajority;
294 STObject object1(elements, sfTestObject);
317 fail(
"STObject error 4");
338 unexpected(copy.isFieldPresent(sfTestH256),
"STObject error 9");
342 "STObject error 10");
344 copy.setFieldU32(sfTestU32, 1);
348 "STObject error 11");
350 for (
int i = 0; i < 1000; i++)
360 STObject object3(elements, it, sfTestObject);
370 for (
int i = 0; i < uints.
capacity(); ++i)
380 STObject object3(elements, it, sfTestObject);
385 BEAST_EXPECT(uints1 == uints3);
395 auto const& sf1Outer = sfSequence;
396 auto const& sf2Outer = sfExpiration;
397 auto const& sf3Outer = sfQualityIn;
398 auto const& sf4Outer = sfAmount;
399 auto const& sf4 = sfSignature;
400 auto const& sf5 = sfPublicKey;
405 auto const st = [&]() {
412 BEAST_EXPECT(st[sf1Outer] == 1);
413 BEAST_EXPECT(st[sf2Outer] == 2);
414 except<STObject::FieldErr>([&]() { st[sf3Outer]; });
415 BEAST_EXPECT(*st[~sf1Outer] == 1);
416 BEAST_EXPECT(*st[~sf2Outer] == 2);
417 BEAST_EXPECT(st[~sf3Outer] == std::nullopt);
418 BEAST_EXPECT(!!st[~sf1Outer]);
419 BEAST_EXPECT(!!st[~sf2Outer]);
420 BEAST_EXPECT(!st[~sf3Outer]);
421 BEAST_EXPECT(st[sf1Outer] != st[sf2Outer]);
422 BEAST_EXPECT(st[~sf1Outer] != st[~sf2Outer]);
436 auto const st = [&]() {
443 BEAST_EXPECT(st[sf1Outer] == 1);
444 BEAST_EXPECT(st[sf2Outer] == 2);
445 BEAST_EXPECT(st[sf3Outer] == 0);
446 BEAST_EXPECT(*st[~sf1Outer] == 1);
447 BEAST_EXPECT(*st[~sf2Outer] == 2);
448 BEAST_EXPECT(*st[~sf3Outer] == 0);
449 BEAST_EXPECT(!!st[~sf1Outer]);
450 BEAST_EXPECT(!!st[~sf2Outer]);
451 BEAST_EXPECT(!!st[~sf3Outer]);
459 except([&]() {
return st[sf1Outer] == 0; });
460 BEAST_EXPECT(st[~sf1Outer] == std::nullopt);
463 BEAST_EXPECT(!st[~sf1Outer]);
465 BEAST_EXPECT(st[sf1Outer] == 2);
466 BEAST_EXPECT(st[~sf1Outer] != std::nullopt);
468 BEAST_EXPECT(!!st[~sf1Outer]);
470 BEAST_EXPECT(st[sf1Outer] == 1);
471 BEAST_EXPECT(!!st[sf1Outer]);
472 BEAST_EXPECT(!!st[~sf1Outer]);
474 BEAST_EXPECT(!st[sf1Outer]);
475 BEAST_EXPECT(!!st[~sf1Outer]);
476 st[~sf1Outer] = std::nullopt;
477 BEAST_EXPECT(!st[~sf1Outer]);
478 BEAST_EXPECT(st[~sf1Outer] == std::nullopt);
480 st[~sf1Outer] = std::nullopt;
481 BEAST_EXPECT(!st[~sf1Outer]);
482 except([&]() {
return st[sf1Outer] == 0; });
483 except([&]() {
return *st[~sf1Outer]; });
485 BEAST_EXPECT(st[sf1Outer] == 1);
486 BEAST_EXPECT(!!st[sf1Outer]);
487 BEAST_EXPECT(!!st[~sf1Outer]);
489 st[sf2Outer] = st[sf1Outer];
490 BEAST_EXPECT(st[sf1Outer] == 3);
491 BEAST_EXPECT(st[sf2Outer] == 3);
492 BEAST_EXPECT(st[sf2Outer] == st[sf1Outer]);
494 st[sf2Outer] = st[sf1Outer];
495 BEAST_EXPECT(st[sf1Outer] == 4);
496 BEAST_EXPECT(st[sf2Outer] == 4);
497 BEAST_EXPECT(st[sf2Outer] == st[sf1Outer]);
499 BEAST_EXPECT(st[sf1Outer] == 5);
501 BEAST_EXPECT(st[sf4Outer] ==
STAmount{1});
503 BEAST_EXPECT(st[sf4Outer] ==
STAmount{2});
505 BEAST_EXPECT(st[sf1Outer] == 4);
507 BEAST_EXPECT(st[sf4Outer] ==
STAmount{1});
514 BEAST_EXPECT(!!st[~sf1Outer]);
515 BEAST_EXPECT(st[~sf1Outer] != std::nullopt);
516 BEAST_EXPECT(st[sf1Outer] == 0);
517 BEAST_EXPECT(*st[~sf1Outer] == 0);
518 BEAST_EXPECT(!st[~sf2Outer]);
519 BEAST_EXPECT(st[~sf2Outer] == std::nullopt);
520 except([&]() {
return st[sf2Outer] == 0; });
521 BEAST_EXPECT(!!st[~sf3Outer]);
522 BEAST_EXPECT(st[~sf3Outer] != std::nullopt);
523 BEAST_EXPECT(st[sf3Outer] == 0);
524 except([&]() { st[~sf1Outer] = std::nullopt; });
526 BEAST_EXPECT(st[sf1Outer] == 1);
527 BEAST_EXPECT(*st[~sf1Outer] == 1);
528 BEAST_EXPECT(!!st[~sf1Outer]);
530 BEAST_EXPECT(st[sf1Outer] == 0);
531 BEAST_EXPECT(*st[~sf1Outer] == 0);
532 BEAST_EXPECT(!!st[~sf1Outer]);
534 BEAST_EXPECT(st[sf2Outer] == 2);
535 BEAST_EXPECT(*st[~sf2Outer] == 2);
536 BEAST_EXPECT(!!st[~sf2Outer]);
537 st[~sf2Outer] = std::nullopt;
538 except([&]() {
return *st[~sf2Outer]; });
539 BEAST_EXPECT(!st[~sf2Outer]);
541 BEAST_EXPECT(st[sf3Outer] == 3);
542 BEAST_EXPECT(*st[~sf3Outer] == 3);
543 BEAST_EXPECT(!!st[~sf3Outer]);
545 BEAST_EXPECT(st[sf3Outer] == 2);
546 BEAST_EXPECT(*st[~sf3Outer] == 2);
547 BEAST_EXPECT(!!st[~sf3Outer]);
549 BEAST_EXPECT(st[sf3Outer] == 0);
550 BEAST_EXPECT(*st[~sf3Outer] == 0);
551 BEAST_EXPECT(!!st[~sf3Outer]);
552 except([&]() { st[~sf3Outer] = std::nullopt; });
553 BEAST_EXPECT(st[sf3Outer] == 0);
554 BEAST_EXPECT(*st[~sf3Outer] == 0);
555 BEAST_EXPECT(!!st[~sf3Outer]);
557 BEAST_EXPECT(st[sf1Outer] == 1);
559 BEAST_EXPECT(st[sf4Outer] ==
STAmount{1});
561 BEAST_EXPECT(st[sf4Outer] ==
STAmount{2});
563 BEAST_EXPECT(st[sf1Outer] == 0);
565 BEAST_EXPECT(st[sf4Outer] ==
STAmount{1});
572 auto const v = ~st[~sf1Outer];
598 BEAST_EXPECT(!b.
empty());
599 st[sf4] = std::move(b);
600 BEAST_EXPECT(b.
empty());
601 BEAST_EXPECT(
Slice(st[sf4]).size() == 1);
602 st[~sf4] = std::nullopt;
603 BEAST_EXPECT(!~st[~sf4]);
606 BEAST_EXPECT(b.
size() == 2);
607 BEAST_EXPECT(
Slice(st[sf4]).size() == 2);
609 BEAST_EXPECT(
Slice(st[sf4]).size() == 2);
610 BEAST_EXPECT(
Slice(st[sf5]).size() == 2);
614 BEAST_EXPECT(st[sf5] ==
Slice{});
615 BEAST_EXPECT(!!st[~sf5]);
616 BEAST_EXPECT(!!~st[~sf5]);
618 st[sf5] = std::move(b);
619 BEAST_EXPECT(b.
empty());
620 BEAST_EXPECT(
Slice(st[sf5]).size() == 1);
621 st[~sf4] = std::nullopt;
622 BEAST_EXPECT(!~st[~sf4]);
630 BEAST_EXPECT(!st[~sf5]);
634 st[~sf5] = std::nullopt;
640 auto const& sf = sfIndexes;
646 st[sf] = std::move(v);
647 auto const& cst = st;
648 BEAST_EXPECT(cst[sf].size() == 2);
649 BEAST_EXPECT(cst[~sf]->size() == 2);
650 BEAST_EXPECT(cst[sf][0] == 1);
651 BEAST_EXPECT(cst[sf][1] == 2);
654 decltype(cst[sfIndexes]),
662 auto const& sf1 = sfIndexes;
663 auto const& sf2 = sfHashes;
664 auto const& sf3 = sfAmendments;
673 BEAST_EXPECT(cst[sf1].size() == 0);
674 BEAST_EXPECT(!cst[~sf2]);
675 BEAST_EXPECT(cst[sf3].size() == 0);
679 BEAST_EXPECT(cst[sf1].size() == 1);
680 BEAST_EXPECT(cst[sf1][0] ==
uint256{1});
682 BEAST_EXPECT(cst[sf2].size() == 1);
683 BEAST_EXPECT(cst[sf2][0] ==
uint256{1});
684 st[~sf2] = std::nullopt;
685 BEAST_EXPECT(!st[~sf2]);
687 BEAST_EXPECT(cst[sf3].size() == 1);
688 BEAST_EXPECT(cst[sf3][0] ==
uint256{1});
690 BEAST_EXPECT(cst[sf3].size() == 0);
697 testcase(
"Malformed serialized forms");
702 {0xe9, 0x12, 0xab, 0xcd, 0x12, 0xfe, 0xdc}};
704 auto obj = std::make_shared<STArray>(sit, sfMetadata);
709 BEAST_EXPECT(strcmp(e.
what(),
"Duplicate field detected") == 0);
716 auto obj = std::make_shared<STObject>(sit, sfMetadata);
721 BEAST_EXPECT(strcmp(e.
what(),
"Duplicate field detected") == 0);
Unserialize a JSON document into a Value.
bool parse(std::string const &document, Value &root)
Read a Value from a JSON document.
log_os< char > log
Logging output stream.
void pass()
Record a successful test condition.
bool unexpected(Condition shouldBeFalse, String const &reason)
testcase_t testcase
Memberspace for declaring test cases.
bool unexcept(F &&f, String const &reason)
bool except(F &&f, String const &reason)
void fail(String const &reason, char const *file, int line)
Record a failure.
Like std::vector<char> but better.
std::size_t size() const noexcept
Returns the number of bytes in the buffer.
bool empty() const noexcept
static SField const & getField(int fieldCode)
Defines the fields and their attributes within a STObject.
void testParseJSONEdgeCases()
void testParseJSONArrayWithInvalidChildrenObjects()
void run() override
Runs the suite.
void testParseJSONArray()
bool parseJSONString(std::string const &json, Json::Value &to)
Blob getFieldVL(SField const &field) const
void makeFieldAbsent(SField const &field)
Serializer getSerializer() const
STBase * makeFieldPresent(SField const &field)
void add(Serializer &s) const override
bool isFieldPresent(SField const &field) const
void setFieldV256(SField const &field, STVector256 const &v)
Json::Value getJson(JsonOptions=JsonOptions::none) const override
void setFieldU32(SField const &field, std::uint32_t)
void setFieldVL(SField const &field, Blob const &)
std::uint32_t getFlags() const
uint256 getFieldH256(SField const &field) const
STVector256 const & getFieldV256(SField const &field) const
Holds the serialized result of parsing an input JSON object.
std::optional< STObject > object
The STObject if the parse was successful.
Json::Value error
On failure, an appropriate set of error values.
Slice slice() const noexcept
An immutable linear range of bytes.
A transaction testing environment.
T emplace_back(T... args)
Use hash_* containers for keys that do not need a cryptographically secure hashing algorithm.
base_uint< 160, detail::AccountIDTag > AccountID
A 160-bit unsigned that uniquely identifies an account.
std::pair< PublicKey, SecretKey > generateKeyPair(KeyType type, Seed const &seed)
Generate a key pair deterministically.
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)
std::string to_string(base_uint< Bits, Tag > const &a)
Seed generateSeed(std::string const &passPhrase)
Generate a seed deterministically.