lokinet/test/regress/2020-06-08-key-backup-bug.cpp

64 lines
2.0 KiB
C++
Raw Normal View History

2020-06-08 12:42:10 +00:00
#include <llarp.h>
#include <llarp.hpp>
#include <config/config.hpp>
#include <router/abstractrouter.hpp>
#include <service/context.hpp>
#include <catch2/catch.hpp>
static llarp_main*
2020-06-08 13:07:49 +00:00
make_context(fs::path keyfile)
2020-06-08 12:42:10 +00:00
{
auto config = llarp_default_config();
config->impl.network.m_endpointType = "null";
2020-06-08 13:07:49 +00:00
config->impl.network.m_keyfile = keyfile;
2020-06-08 12:42:10 +00:00
config->impl.bootstrap.skipBootstrap = true;
auto ptr = llarp_main_init_from_config(config, false);
llarp_config_free(config);
return ptr;
}
TEST_CASE("key backup bug regression test", "[regress]")
{
2020-06-08 13:07:49 +00:00
llarp::SilenceLog([]() {
for (const fs::path& path : {"regress-1.private", "regress-2.private", ""})
{
llarp::service::Address endpointAddress{};
for (size_t index = 0; index < 10; index++)
2020-06-08 12:42:10 +00:00
{
2020-06-08 13:07:49 +00:00
auto context = make_context(path);
REQUIRE(llarp_main_setup(context, false) == 0);
auto ctx = llarp::Context::Get(context);
ctx->CallSafe([ctx, index, &endpointAddress, &path]() {
auto ep = ctx->router->hiddenServiceContext().GetDefault();
REQUIRE(ep != nullptr);
if (index == 0)
{
REQUIRE(endpointAddress.IsZero());
// first iteration, we are getting our identity
endpointAddress = ep->GetIdentity().pub.Addr();
REQUIRE(not endpointAddress.IsZero());
}
else
{
REQUIRE(not endpointAddress.IsZero());
if (path.empty())
{
// we want the keys to shift
REQUIRE(endpointAddress != ep->GetIdentity().pub.Addr());
}
else
{
// after the first iteration we expect the keys to stay the same
REQUIRE(endpointAddress == ep->GetIdentity().pub.Addr());
}
}
ctx->CloseAsync();
});
REQUIRE(llarp_main_run(context, llarp_main_runtime_opts{}) == 0);
llarp_main_free(context);
2020-06-08 12:42:10 +00:00
}
2020-06-08 13:07:49 +00:00
fs::remove(path);
}
});
2020-06-08 12:42:10 +00:00
}