mirror of
https://github.com/XRPLF/clio.git
synced 2025-11-20 11:45:53 +00:00
* Implement logging abstraction (#371) Fixes #290 * Fix pre-commit to only check staged files * Implement account ownership check and fix paging (#383) Fixes #222 * Remove the github action package signing step This will be done elsewhere. * include searched_all in error response of tx (#407) * helper function for subscribe to ensure cleanup (#402) * Add closed to header for all paths of ledger_data (#416) Fixes #219 * Add custom error for malformed owner and request (#417) Fixes #274 * Use custom malformedAddress error in ledger_entry (#419) Fixes #272 * Return lgrIdxsInvalid error for ledger_max_index less than ledger_min_index (#339) Fixes #263 * Update headers to use #pragma once * Add custom error for malformed request (#414) Fixes #276 * Return srcCurMalformed on invalid taker_pays in book_offers (#413) Fixes #267 * Fix source_location issue on MacOSX and Debug build (#431) Fixes #428 * Implement always adding git ref to version string (#430) Fixes #427 * add connection counting (#433) * Fix malformed output format over ws rpc (#426) Fixes #405 * Remove branch name from version string (#437) Fixes a bug from #430 * Implement cli parsing using boost::po (#436) Fixes #367 * Update documentation and config with ssl_cert_file and ssl_key_file (#443) Fixes #424 * Fix gateway balances to match rippled output (#441) Fixes #271 * Update README and example config to describe start_sequence (#438) Fixes #250 * Add copyright to top of each source file (#444) Fixes #411 * Increase file descriptor limit (#449) * Update readme with more log configurations (#447) Fixes #446 * Document dos_guard in example config. Log when client surpasses rate limit (#451) * Add unit tests for DOSGuard (#453) Fixes #452 * Build macOS and Ubuntu 22.04 (#456) build release/x.y.z branches * Add time measurement profiler (#458) Rebase * Match format to rippled error code (#461) Fixes #263 * Change error message to match rippled (#463) Fixes #263 * Add requests limit to DosGuard (#462) Fixing #448 * Set version to 1.0.4-rc2 Co-authored-by: Alex Kremer <akremer@ripple.com> Co-authored-by: CJ Cobb <46455409+cjcobb23@users.noreply.github.com> Co-authored-by: Francis Mendoza <francissamuelmendoza7@gmail.com> Co-authored-by: cyan317 <120398799+cindyyan317@users.noreply.github.com>
153 lines
4.9 KiB
C++
153 lines
4.9 KiB
C++
//------------------------------------------------------------------------------
|
|
/*
|
|
This file is part of clio: https://github.com/XRPLF/clio
|
|
Copyright (c) 2022, the clio developers.
|
|
|
|
Permission to use, copy, modify, and distribute this software for any
|
|
purpose with or without fee is hereby granted, provided that the above
|
|
copyright notice and this permission notice appear in all copies.
|
|
|
|
THE SOFTWARE IS PROVIDED "AS IS" AND THE AUTHOR DISCLAIMS ALL WARRANTIES
|
|
WITH REGARD TO THIS SOFTWARE INCLUDING ALL IMPLIED WARRANTIES OF
|
|
MERCHANTABILITY AND FITNESS. IN NO EVENT SHALL THE AUTHOR BE LIABLE FOR
|
|
ANY SPECIAL, DIRECT, INDIRECT, OR CONSEQUENTIAL DAMAGES OR ANY DAMAGES
|
|
WHATSOEVER RESULTING FROM LOSS OF USE, DATA OR PROFITS, WHETHER IN AN
|
|
ACTION OF CONTRACT, NEGLIGENCE OR OTHER TORTIOUS ACTION, ARISING OUT OF
|
|
OR IN CONNECTION WITH THE USE OR PERFORMANCE OF THIS SOFTWARE.
|
|
*/
|
|
//==============================================================================
|
|
|
|
#include <rpc/RPC.h>
|
|
|
|
#include <boost/json.hpp>
|
|
#include <gtest/gtest.h>
|
|
|
|
using namespace RPC;
|
|
using namespace std;
|
|
|
|
namespace {
|
|
void
|
|
check(
|
|
boost::json::object const& j,
|
|
std::string_view error,
|
|
uint32_t errorCode,
|
|
std::string_view errorMessage)
|
|
{
|
|
EXPECT_TRUE(j.contains("error"));
|
|
EXPECT_TRUE(j.contains("error_code"));
|
|
EXPECT_TRUE(j.contains("error_message"));
|
|
EXPECT_TRUE(j.contains("status"));
|
|
EXPECT_TRUE(j.contains("type"));
|
|
|
|
EXPECT_TRUE(j.at("error").is_string());
|
|
EXPECT_TRUE(j.at("error_code").is_uint64());
|
|
EXPECT_TRUE(j.at("error_message").is_string());
|
|
EXPECT_TRUE(j.at("status").is_string());
|
|
EXPECT_TRUE(j.at("type").is_string());
|
|
|
|
EXPECT_STREQ(j.at("status").as_string().c_str(), "error");
|
|
EXPECT_STREQ(j.at("type").as_string().c_str(), "response");
|
|
|
|
EXPECT_STREQ(j.at("error").as_string().c_str(), error.data());
|
|
EXPECT_EQ(j.at("error_code").as_uint64(), errorCode);
|
|
EXPECT_STREQ(
|
|
j.at("error_message").as_string().c_str(), errorMessage.data());
|
|
}
|
|
} // namespace
|
|
|
|
TEST(RPCErrorsTest, StatusAsBool)
|
|
{
|
|
// Only rpcSUCCESS status should return false
|
|
EXPECT_FALSE(Status{RippledError::rpcSUCCESS});
|
|
|
|
// true should be returned for any error state, we just test a few
|
|
CombinedError const errors[]{
|
|
RippledError::rpcINVALID_PARAMS,
|
|
RippledError::rpcUNKNOWN_COMMAND,
|
|
RippledError::rpcTOO_BUSY,
|
|
RippledError::rpcNO_NETWORK,
|
|
RippledError::rpcACT_MALFORMED,
|
|
RippledError::rpcBAD_MARKET,
|
|
ClioError::rpcMALFORMED_CURRENCY,
|
|
};
|
|
|
|
for (auto const& ec : errors)
|
|
EXPECT_TRUE(Status{ec});
|
|
}
|
|
|
|
TEST(RPCErrorsTest, SuccessToJSON)
|
|
{
|
|
auto const status = Status{RippledError::rpcSUCCESS};
|
|
check(makeError(status), "unknown", 0, "An unknown error code.");
|
|
}
|
|
|
|
TEST(RPCErrorsTest, RippledErrorToJSON)
|
|
{
|
|
auto const status = Status{RippledError::rpcINVALID_PARAMS};
|
|
check(makeError(status), "invalidParams", 31, "Invalid parameters.");
|
|
}
|
|
|
|
TEST(RPCErrorsTest, RippledErrorFromStringToJSON)
|
|
{
|
|
auto const j = makeError(Status{"veryCustomError"});
|
|
EXPECT_STREQ(j.at("error").as_string().c_str(), "veryCustomError");
|
|
}
|
|
|
|
TEST(RPCErrorsTest, RippledErrorToJSONCustomMessage)
|
|
{
|
|
auto const status = Status{RippledError::rpcINVALID_PARAMS, "custom"};
|
|
check(makeError(status), "invalidParams", 31, "custom");
|
|
}
|
|
|
|
TEST(RPCErrorsTest, RippledErrorToJSONCustomStrCodeAndMessage)
|
|
{
|
|
auto const status =
|
|
Status{RippledError::rpcINVALID_PARAMS, "customCode", "customMessage"};
|
|
check(makeError(status), "customCode", 31, "customMessage");
|
|
}
|
|
|
|
TEST(RPCErrorsTest, ClioErrorToJSON)
|
|
{
|
|
auto const status = Status{ClioError::rpcMALFORMED_CURRENCY};
|
|
check(makeError(status), "malformedCurrency", 5000, "Malformed currency.");
|
|
}
|
|
|
|
TEST(RPCErrorsTest, ClioErrorToJSONCustomMessage)
|
|
{
|
|
auto const status = Status{ClioError::rpcMALFORMED_CURRENCY, "custom"};
|
|
check(makeError(status), "malformedCurrency", 5000, "custom");
|
|
}
|
|
|
|
TEST(RPCErrorsTest, ClioErrorToJSONCustomStrCodeAndMessage)
|
|
{
|
|
auto const status =
|
|
Status{ClioError::rpcMALFORMED_CURRENCY, "customCode", "customMessage"};
|
|
check(makeError(status), "customCode", 5000, "customMessage");
|
|
}
|
|
|
|
TEST(RPCErrorsTest, InvalidClioErrorToJSON)
|
|
{
|
|
EXPECT_ANY_THROW((void)makeError(static_cast<ClioError>(999999)));
|
|
}
|
|
|
|
TEST(RPCErrorsTest, WarningToJSON)
|
|
{
|
|
auto j = makeWarning(WarningCode::warnRPC_OUTDATED);
|
|
EXPECT_TRUE(j.contains("id"));
|
|
EXPECT_TRUE(j.contains("message"));
|
|
|
|
EXPECT_TRUE(j.at("id").is_int64());
|
|
EXPECT_TRUE(j.at("message").is_string());
|
|
|
|
EXPECT_EQ(
|
|
j.at("id").as_int64(),
|
|
static_cast<uint32_t>(WarningCode::warnRPC_OUTDATED));
|
|
EXPECT_STREQ(
|
|
j.at("message").as_string().c_str(), "This server may be out of date");
|
|
}
|
|
|
|
TEST(RPCErrorsTest, InvalidWarningToJSON)
|
|
{
|
|
EXPECT_ANY_THROW((void)makeWarning(static_cast<WarningCode>(999999)));
|
|
}
|