Files
tomato-testing/toxcore/tox_events_test.cc
Green Sky 565efa4f39 Squashed 'external/toxcore/c-toxcore/' changes from 1828c5356..c9cdae001
c9cdae001 fix(toxav): remove extra copy of video frame on encode
4f6d4546b test: Improve the fake network library.
a2581e700 refactor(toxcore): generate `Friend_Request` and `Dht_Nodes_Response`
2aaa11770 refactor(toxcore): use Tox_Memory in generated events
5c367452b test(toxcore): fix incorrect mutex in tox_scenario_get_time
8f92e710f perf: Add a timed limit of number of cookie requests.
695b6417a test: Add some more simulated network support.
815ae9ce9 test(toxcore): fix thread-safety in scenario framework
6d85c754e test(toxcore): add unit tests for net_crypto
9c22e79cc test(support): add SimulatedEnvironment for deterministic testing
f34fcb195 chore: Update windows Dockerfile to debian stable (trixie).
ece0e8980 fix(group_moderation): allow validating unsorted sanction list signatures
a4fa754d7 refactor: rename struct Packet to struct Net_Packet
d6f330f85 cleanup: Fix some warnings from coverity.
e206bffa2 fix(group_chats): fix sync packets reverting topics
0e4715598 test: Add new scenario testing framework.
668291f44 refactor(toxcore): decouple Network_Funcs from sockaddr via IP_Port
fc4396cef fix: potential division by zero in toxav and unsafe hex parsing
8e8b352ab refactor: Add nullable annotations to struct members.
7740bb421 refactor: decouple net_crypto from DHT
1936d4296 test: add benchmark for toxav audio and video
46bfdc2df fix: correct printf format specifiers for unsigned integers
REVERT: 1828c5356 fix(toxav): remove extra copy of video frame on encode

git-subtree-dir: external/toxcore/c-toxcore
git-subtree-split: c9cdae001341e701fca980c9bb9febfeb95d2902
2026-01-11 14:42:31 +01:00

80 lines
2.4 KiB
C++

// clang-format off
#include "../testing/support/public/simulated_environment.hh"
#include "tox_events.h"
// clang-format on
#include <gtest/gtest.h>
#include <array>
#include <vector>
#include "crypto_core.h"
#include "tox_private.h"
namespace {
using tox::test::SimulatedEnvironment;
TEST(ToxEvents, UnpackRandomDataDoesntCrash)
{
SimulatedEnvironment env;
auto node = env.create_node(33445);
ASSERT_NE(node->system.rng, nullptr);
std::array<uint8_t, 128> data;
random_bytes(node->system.rng, data.data(), data.size());
tox_events_free(tox_events_load(&node->system, data.data(), data.size()));
}
TEST(ToxEvents, UnpackEmptyDataFails)
{
SimulatedEnvironment env;
auto node = env.create_node(33445);
std::array<uint8_t, 1> data;
Tox_Events *events = tox_events_load(&node->system, data.end(), 0);
EXPECT_EQ(events, nullptr);
}
TEST(ToxEvents, UnpackEmptyArrayCreatesEmptyEvents)
{
SimulatedEnvironment env;
auto node = env.create_node(33445);
std::array<uint8_t, 1> data{0x90}; // empty msgpack array
Tox_Events *events = tox_events_load(&node->system, data.data(), data.size());
ASSERT_NE(events, nullptr);
EXPECT_EQ(tox_events_get_size(events), 0);
tox_events_free(events);
}
TEST(ToxEvents, NullEventsPacksToEmptyArray)
{
std::array<uint8_t, 1> bytes;
ASSERT_EQ(tox_events_bytes_size(nullptr), bytes.size());
tox_events_get_bytes(nullptr, bytes.data());
EXPECT_EQ(bytes, (std::array<uint8_t, 1>{0x90}));
}
TEST(ToxEvents, PackedEventsCanBeUnpacked)
{
SimulatedEnvironment env;
auto node = env.create_node(33445);
// [[0, 1]] == Tox_Self_Connection_Status { .connection_status = TOX_CONNECTION_TCP }
std::array<uint8_t, 6> packed{0x91, 0x92, 0xcc, 0x00, 0xcc, 0x01};
Tox_Events *events = tox_events_load(&node->system, packed.data(), packed.size());
ASSERT_NE(events, nullptr);
std::array<uint8_t, 4> bytes;
ASSERT_EQ(tox_events_bytes_size(events), bytes.size());
tox_events_get_bytes(events, bytes.data());
EXPECT_EQ(bytes, (std::array<uint8_t, 4>{0x91, 0x92, 0x00, 0x01}));
tox_events_free(events);
}
TEST(ToxEvents, DealsWithHugeMsgpackArrays)
{
SimulatedEnvironment env;
auto node = env.create_node(33445);
std::vector<uint8_t> data{0xdd, 0xff, 0xff, 0xff, 0xff};
EXPECT_EQ(tox_events_load(&node->system, data.data(), data.size()), nullptr);
}
} // namespace