mirror of
https://github.com/XRPLF/clio.git
synced 2026-04-29 15:37:53 +00:00
138
tests/unit/data/BackendInterfaceTests.cpp
Normal file
138
tests/unit/data/BackendInterfaceTests.cpp
Normal file
@@ -0,0 +1,138 @@
|
||||
//------------------------------------------------------------------------------
|
||||
/*
|
||||
This file is part of clio: https://github.com/XRPLF/clio
|
||||
Copyright (c) 2024, 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 "etl/CorruptionDetector.hpp"
|
||||
#include "etl/SystemState.hpp"
|
||||
#include "util/Fixtures.hpp"
|
||||
#include "util/MockPrometheus.hpp"
|
||||
#include "util/TestObject.hpp"
|
||||
|
||||
#include <gmock/gmock.h>
|
||||
#include <gtest/gtest.h>
|
||||
#include <ripple/basics/Blob.h>
|
||||
#include <ripple/basics/XRPAmount.h>
|
||||
#include <ripple/basics/base_uint.h>
|
||||
#include <ripple/protocol/Indexes.h>
|
||||
|
||||
#include <optional>
|
||||
#include <vector>
|
||||
|
||||
using namespace data;
|
||||
using namespace util::prometheus;
|
||||
using namespace testing;
|
||||
|
||||
constexpr static auto MAXSEQ = 30;
|
||||
constexpr static auto MINSEQ = 10;
|
||||
|
||||
struct BackendInterfaceTest : MockBackendTestNaggy, SyncAsioContextTest, WithPrometheus {};
|
||||
|
||||
TEST_F(BackendInterfaceTest, FetchFeesSuccessPath)
|
||||
{
|
||||
using namespace ripple;
|
||||
backend->setRange(MINSEQ, MAXSEQ);
|
||||
|
||||
// New fee setting (after XRPFees amendment)
|
||||
EXPECT_CALL(*backend, doFetchLedgerObject(keylet::fees().key, MAXSEQ, _))
|
||||
.WillRepeatedly(Return(CreateFeeSettingBlob(XRPAmount(1), XRPAmount(2), XRPAmount(3), 0)));
|
||||
|
||||
runSpawn([this](auto yield) {
|
||||
auto fees = backend->fetchFees(MAXSEQ, yield);
|
||||
|
||||
EXPECT_TRUE(fees.has_value());
|
||||
EXPECT_EQ(fees->base, XRPAmount(1));
|
||||
EXPECT_EQ(fees->increment, XRPAmount(2));
|
||||
EXPECT_EQ(fees->reserve, XRPAmount(3));
|
||||
});
|
||||
}
|
||||
|
||||
TEST_F(BackendInterfaceTest, FetchFeesLegacySuccessPath)
|
||||
{
|
||||
using namespace ripple;
|
||||
backend->setRange(MINSEQ, MAXSEQ);
|
||||
|
||||
// Legacy fee setting (before XRPFees amendment)
|
||||
EXPECT_CALL(*backend, doFetchLedgerObject(keylet::fees().key, MAXSEQ, _))
|
||||
.WillRepeatedly(Return(CreateLegacyFeeSettingBlob(1, 2, 3, 4, 0)));
|
||||
|
||||
runSpawn([this](auto yield) {
|
||||
auto fees = backend->fetchFees(MAXSEQ, yield);
|
||||
|
||||
EXPECT_TRUE(fees.has_value());
|
||||
EXPECT_EQ(fees->base, XRPAmount(1));
|
||||
EXPECT_EQ(fees->increment, XRPAmount(2));
|
||||
EXPECT_EQ(fees->reserve, XRPAmount(3));
|
||||
});
|
||||
}
|
||||
|
||||
TEST_F(BackendInterfaceTest, FetchLedgerPageSuccessPath)
|
||||
{
|
||||
using namespace ripple;
|
||||
backend->setRange(MINSEQ, MAXSEQ);
|
||||
|
||||
auto state = etl::SystemState{};
|
||||
backend->setCorruptionDetector(etl::CorruptionDetector{state, backend->cache()});
|
||||
|
||||
EXPECT_FALSE(backend->cache().isDisabled());
|
||||
EXPECT_CALL(*backend, doFetchSuccessorKey(_, _, _))
|
||||
.Times(10)
|
||||
.WillRepeatedly(Return(uint256{"1FFFFFFFFFFFFFFFFFFFFFFFFFFFFFFF1FFFFFFFFFFFFFFFFFFFFFFFFFFFFFFF"}));
|
||||
EXPECT_CALL(*backend, doFetchLedgerObjects(_, _, _)).WillOnce(Return(std::vector<Blob>(10, Blob{'s'})));
|
||||
|
||||
runSpawn([this](auto yield) { backend->fetchLedgerPage(std::nullopt, MAXSEQ, 10, false, yield); });
|
||||
EXPECT_FALSE(backend->cache().isDisabled());
|
||||
}
|
||||
|
||||
TEST_F(BackendInterfaceTest, FetchLedgerPageDisablesCacheOnMissingData)
|
||||
{
|
||||
using namespace ripple;
|
||||
backend->setRange(MINSEQ, MAXSEQ);
|
||||
|
||||
auto state = etl::SystemState{};
|
||||
backend->setCorruptionDetector(etl::CorruptionDetector{state, backend->cache()});
|
||||
|
||||
EXPECT_FALSE(backend->cache().isDisabled());
|
||||
EXPECT_CALL(*backend, doFetchSuccessorKey(_, _, _))
|
||||
.Times(10)
|
||||
.WillRepeatedly(Return(uint256{"1FFFFFFFFFFFFFFFFFFFFFFFFFFFFFFF1FFFFFFFFFFFFFFFFFFFFFFFFFFFFFFF"}));
|
||||
EXPECT_CALL(*backend, doFetchLedgerObjects(_, _, _))
|
||||
.WillOnce(Return(std::vector<Blob>{
|
||||
Blob{'s'}, Blob{'s'}, Blob{'s'}, Blob{'s'}, Blob{'s'}, Blob{'s'}, Blob{'s'}, Blob{'s'}, Blob{'s'}, Blob{}
|
||||
}));
|
||||
|
||||
runSpawn([this](auto yield) { backend->fetchLedgerPage(std::nullopt, MAXSEQ, 10, false, yield); });
|
||||
EXPECT_TRUE(backend->cache().isDisabled());
|
||||
}
|
||||
|
||||
TEST_F(BackendInterfaceTest, FetchLedgerPageWithoutCorruptionDetectorDoesNotDisableCacheOnMissingData)
|
||||
{
|
||||
using namespace ripple;
|
||||
backend->setRange(MINSEQ, MAXSEQ);
|
||||
|
||||
EXPECT_FALSE(backend->cache().isDisabled());
|
||||
EXPECT_CALL(*backend, doFetchSuccessorKey(_, _, _))
|
||||
.Times(10)
|
||||
.WillRepeatedly(Return(uint256{"1FFFFFFFFFFFFFFFFFFFFFFFFFFFFFFF1FFFFFFFFFFFFFFFFFFFFFFFFFFFFFFF"}));
|
||||
EXPECT_CALL(*backend, doFetchLedgerObjects(_, _, _))
|
||||
.WillOnce(Return(std::vector<Blob>{
|
||||
Blob{'s'}, Blob{'s'}, Blob{'s'}, Blob{'s'}, Blob{'s'}, Blob{'s'}, Blob{'s'}, Blob{'s'}, Blob{'s'}, Blob{}
|
||||
}));
|
||||
|
||||
runSpawn([this](auto yield) { backend->fetchLedgerPage(std::nullopt, MAXSEQ, 10, false, yield); });
|
||||
EXPECT_FALSE(backend->cache().isDisabled());
|
||||
}
|
||||
Reference in New Issue
Block a user