mirror of
https://github.com/XRPLF/rippled.git
synced 2025-11-20 11:05:54 +00:00
Add Antithesis intrumentation (#5042)
* Copy Antithesis SDK version 0.4.0 to directory external/ * Add build option `voidstar` to enable instrumentation with Antithesis SDK * Define instrumentation macros ASSERT and UNREACHABLE in terms of regular C assert * Replace asserts with named ASSERT or UNREACHABLE * Add UNREACHABLE to LogicError * Document instrumentation macros in CONTRIBUTING.md
This commit is contained in:
committed by
Ed Hennis
parent
f64cf9187a
commit
d7e949193f
@@ -25,6 +25,7 @@
|
||||
#include <xrpl/basics/Slice.h>
|
||||
#include <xrpl/basics/chrono.h>
|
||||
#include <xrpl/basics/contract.h>
|
||||
#include <xrpl/beast/utility/instrumentation.h>
|
||||
#include <xrpl/protocol/HashPrefix.h>
|
||||
#include <xrpl/protocol/SOTemplate.h>
|
||||
#include <xrpl/protocol/STAmount.h>
|
||||
@@ -35,7 +36,6 @@
|
||||
#include <xrpl/protocol/STVector256.h>
|
||||
#include <xrpl/protocol/detail/STVar.h>
|
||||
#include <boost/iterator/transform_iterator.hpp>
|
||||
#include <cassert>
|
||||
#include <optional>
|
||||
#include <stdexcept>
|
||||
#include <type_traits>
|
||||
@@ -737,7 +737,8 @@ STObject::Proxy<T>::assign(U&& u)
|
||||
t = dynamic_cast<T*>(st_->getPField(*f_, true));
|
||||
else
|
||||
t = dynamic_cast<T*>(st_->makeFieldPresent(*f_));
|
||||
assert(t);
|
||||
ASSERT(
|
||||
t != nullptr, "ripple::STObject::Proxy::assign : type cast succeeded");
|
||||
*t = std::forward<U>(u);
|
||||
}
|
||||
|
||||
@@ -1033,13 +1034,19 @@ STObject::at(TypedField<T> const& f) const
|
||||
if (auto const u = dynamic_cast<T const*>(b))
|
||||
return u->value();
|
||||
|
||||
assert(mType);
|
||||
assert(b->getSType() == STI_NOTPRESENT);
|
||||
ASSERT(
|
||||
mType != nullptr,
|
||||
"ripple::STObject::at(TypedField auto) : field template non-null");
|
||||
ASSERT(
|
||||
b->getSType() == STI_NOTPRESENT,
|
||||
"ripple::STObject::at(TypedField auto) : type not present");
|
||||
|
||||
if (mType->style(f) == soeOPTIONAL)
|
||||
Throw<STObject::FieldErr>("Missing optional field: " + f.getName());
|
||||
|
||||
assert(mType->style(f) == soeDEFAULT);
|
||||
ASSERT(
|
||||
mType->style(f) == soeDEFAULT,
|
||||
"ripple::STObject::at(TypedField auto) : template style is default");
|
||||
|
||||
// Used to help handle the case where value_type is a const reference,
|
||||
// otherwise we would return the address of a temporary.
|
||||
@@ -1057,11 +1064,19 @@ STObject::at(OptionaledField<T> const& of) const
|
||||
auto const u = dynamic_cast<T const*>(b);
|
||||
if (!u)
|
||||
{
|
||||
assert(mType);
|
||||
assert(b->getSType() == STI_NOTPRESENT);
|
||||
ASSERT(
|
||||
mType != nullptr,
|
||||
"ripple::STObject::at(OptionaledField auto) : field template "
|
||||
"non-null");
|
||||
ASSERT(
|
||||
b->getSType() == STI_NOTPRESENT,
|
||||
"ripple::STObject::at(OptionaledField auto) : type not present");
|
||||
if (mType->style(*of.f) == soeOPTIONAL)
|
||||
return std::nullopt;
|
||||
assert(mType->style(*of.f) == soeDEFAULT);
|
||||
ASSERT(
|
||||
mType->style(*of.f) == soeDEFAULT,
|
||||
"ripple::STObject::at(OptionaledField auto) : template style is "
|
||||
"default");
|
||||
return typename T::value_type{};
|
||||
}
|
||||
return u->value();
|
||||
|
||||
Reference in New Issue
Block a user