mirror of
https://github.com/XRPLF/clio.git
synced 2025-11-26 14:45:52 +00:00
1.0.4 Release Candidate 2 (#465)
* 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>
This commit is contained in:
108
unittests/ProfilerTest.cpp
Normal file
108
unittests/ProfilerTest.cpp
Normal file
@@ -0,0 +1,108 @@
|
||||
//------------------------------------------------------------------------------
|
||||
/*
|
||||
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 <gtest/gtest.h>
|
||||
#include <thread>
|
||||
#include <util/Profiler.h>
|
||||
|
||||
using namespace util;
|
||||
TEST(TimedTest, HasReturnValue)
|
||||
{
|
||||
auto [ret, time] = timed([]() {
|
||||
std::this_thread::sleep_for(std::chrono::milliseconds(5));
|
||||
return 8;
|
||||
});
|
||||
|
||||
ASSERT_EQ(ret, 8);
|
||||
ASSERT_NE(time, 0);
|
||||
}
|
||||
|
||||
TEST(TimedTest, ReturnVoid)
|
||||
{
|
||||
auto time = timed(
|
||||
[]() { std::this_thread::sleep_for(std::chrono::milliseconds(5)); });
|
||||
|
||||
ASSERT_NE(time, 0);
|
||||
}
|
||||
|
||||
struct FunctorTest
|
||||
{
|
||||
void
|
||||
operator()() const
|
||||
{
|
||||
std::this_thread::sleep_for(std::chrono::milliseconds(5));
|
||||
}
|
||||
};
|
||||
|
||||
TEST(TimedTest, Functor)
|
||||
{
|
||||
auto time = timed(FunctorTest());
|
||||
|
||||
ASSERT_NE(time, 0);
|
||||
}
|
||||
|
||||
TEST(TimedTest, MovedLambda)
|
||||
{
|
||||
auto f = []() {
|
||||
std::this_thread::sleep_for(std::chrono::milliseconds(5));
|
||||
return 8;
|
||||
};
|
||||
auto [ret, time] = timed(std::move(f));
|
||||
|
||||
ASSERT_EQ(ret, 8);
|
||||
ASSERT_NE(time, 0);
|
||||
}
|
||||
|
||||
TEST(TimedTest, ChangeToNs)
|
||||
{
|
||||
auto f = []() {
|
||||
std::this_thread::sleep_for(std::chrono::milliseconds(5));
|
||||
return 8;
|
||||
};
|
||||
auto [ret, time] = timed<std::chrono::nanoseconds>(std::move(f));
|
||||
ASSERT_EQ(ret, 8);
|
||||
ASSERT_GE(time, 5 * 1000000);
|
||||
}
|
||||
|
||||
TEST(TimedTest, NestedLambda)
|
||||
{
|
||||
double timeNested;
|
||||
auto f = [&]() {
|
||||
std::this_thread::sleep_for(std::chrono::milliseconds(5));
|
||||
timeNested = timed([]() {
|
||||
std::this_thread::sleep_for(std::chrono::milliseconds(5));
|
||||
});
|
||||
return 8;
|
||||
};
|
||||
auto [ret, time] = timed<std::chrono::nanoseconds>(std::move(f));
|
||||
ASSERT_EQ(ret, 8);
|
||||
ASSERT_GE(timeNested, 5);
|
||||
ASSERT_GE(time, 10 * 1000000);
|
||||
}
|
||||
|
||||
TEST(TimedTest, FloatSec)
|
||||
{
|
||||
auto f = []() {
|
||||
std::this_thread::sleep_for(std::chrono::milliseconds(5));
|
||||
return 8;
|
||||
};
|
||||
auto [ret, time] = timed<std::chrono::duration<double>>(std::move(f));
|
||||
ASSERT_EQ(ret, 8);
|
||||
ASSERT_GE(time, 0);
|
||||
}
|
||||
Reference in New Issue
Block a user