forked from Green-Sky/tomato
3b6bb15e86
d9b8fa6098d fix: Fake broadcast address for 127.x.x.x aa649165a57 chore: Add code for future netprof TCP testing 9e5693de5ac chore: add to_string functions for netprof enums 52d915e6a90 cleanup: Heap allocate network profile objects 80fabd4a729 feat: Implement Tox network profiler 05abe083cb6 cleanup: Some random cleanups, mostly related to mem. 5cca24513b8 cleanup: Check that onion IP/Port packing worked. e092ecd1244 cleanup: Use tox memory allocator in some more places. 3cfe41c7587 fix: Avoid `memcpy`-ing structs into onion ping id data. e32ac001938 fix: Add more information on why the frame was not sent. ab887003687 fix: Allow TCP connections to fail `connect` calls. 7603170e663 refactor: Use tox memory in group connection allocations. 5bd8a85eb89 cleanup: Align internal logger with external on type of source line. e9bf524d9e1 cleanup: Add missing `#include` to sort_test.cc. d10c966b998 feat: Add `to_string` functions for toxencryptsave errors. 7bfd0dc8003 docs: Update the docs for group join functions 380dde9f2ae test: Add more logging to TCP connection constructor. 0f12f384c8c cleanup: Reduce stack frame sizes to below 4096 bytes. bc43cec0626 chore: Happy new year! fbe78f1702e cleanup: Add a `TOX_HIDE_DEPRECATED` check to hide deprecated symbols. 44d9da07e77 refactor: Use tox memory for group moderation/pack allocations. 7f26d520168 refactor: Use tox memory in group chats allocations. 2f62f3d0e77 refactor: Use tox Memory for group allocations. 8a968162041 chore: Add dispatch/events headers to bazel export. 2bbfb35abf6 docs: Output the error code string instead of int. in toxav logging d55d0e4eaef cleanup: Remove redundant code for checking if group exists 2a6dc643338 chore: Upgrade dependencies for websockify. fc0650601c1 fix: Allow peers to reconnect to group chats using a password git-subtree-dir: external/toxcore/c-toxcore git-subtree-split: d9b8fa6098de6c074038b6664d2572627540b148
135 lines
5.9 KiB
C
135 lines
5.9 KiB
C
/** Auto Tests: basic network profile functionality test (UDP only)
|
|
*/
|
|
|
|
#include <inttypes.h>
|
|
#include <stdint.h>
|
|
#include <stdio.h>
|
|
|
|
#include "../toxcore/tox_private.h"
|
|
#include "../toxcore/util.h"
|
|
|
|
#include "auto_test_support.h"
|
|
#include "check_compat.h"
|
|
|
|
#define NUM_TOXES 2
|
|
|
|
static void test_netprof(AutoTox *autotoxes)
|
|
{
|
|
// Send some messages to create fake traffic
|
|
for (size_t i = 0; i < 256; ++i) {
|
|
for (uint32_t j = 0; j < NUM_TOXES; ++j) {
|
|
tox_friend_send_message(autotoxes[j].tox, 0, TOX_MESSAGE_TYPE_NORMAL, (const uint8_t *)"test", 4, nullptr);
|
|
}
|
|
|
|
iterate_all_wait(autotoxes, NUM_TOXES, ITERATION_INTERVAL);
|
|
}
|
|
|
|
// idle traffic for a while
|
|
for (size_t i = 0; i < 100; ++i) {
|
|
iterate_all_wait(autotoxes, NUM_TOXES, ITERATION_INTERVAL);
|
|
}
|
|
|
|
const Tox *tox1 = autotoxes[0].tox;
|
|
|
|
const uint64_t UDP_count_sent1 = tox_netprof_get_packet_total_count(tox1, TOX_NETPROF_PACKET_TYPE_UDP,
|
|
TOX_NETPROF_DIRECTION_SENT);
|
|
const uint64_t UDP_count_recv1 = tox_netprof_get_packet_total_count(tox1, TOX_NETPROF_PACKET_TYPE_UDP,
|
|
TOX_NETPROF_DIRECTION_RECV);
|
|
const uint64_t TCP_count_sent1 = tox_netprof_get_packet_total_count(tox1, TOX_NETPROF_PACKET_TYPE_TCP,
|
|
TOX_NETPROF_DIRECTION_SENT);
|
|
const uint64_t TCP_count_recv1 = tox_netprof_get_packet_total_count(tox1, TOX_NETPROF_PACKET_TYPE_TCP,
|
|
TOX_NETPROF_DIRECTION_RECV);
|
|
|
|
const uint64_t UDP_bytes_sent1 = tox_netprof_get_packet_total_bytes(tox1, TOX_NETPROF_PACKET_TYPE_UDP,
|
|
TOX_NETPROF_DIRECTION_SENT);
|
|
const uint64_t UDP_bytes_recv1 = tox_netprof_get_packet_total_bytes(tox1, TOX_NETPROF_PACKET_TYPE_UDP,
|
|
TOX_NETPROF_DIRECTION_RECV);
|
|
const uint64_t TCP_bytes_sent1 = tox_netprof_get_packet_total_bytes(tox1, TOX_NETPROF_PACKET_TYPE_TCP,
|
|
TOX_NETPROF_DIRECTION_SENT);
|
|
const uint64_t TCP_bytes_recv1 = tox_netprof_get_packet_total_bytes(tox1, TOX_NETPROF_PACKET_TYPE_TCP,
|
|
TOX_NETPROF_DIRECTION_RECV);
|
|
|
|
ck_assert(UDP_count_recv1 > 0 && UDP_count_sent1 > 0);
|
|
ck_assert(UDP_bytes_recv1 > 0 && UDP_bytes_sent1 > 0);
|
|
|
|
(void)TCP_count_sent1;
|
|
(void)TCP_bytes_sent1;
|
|
(void)TCP_bytes_recv1;
|
|
(void)TCP_count_recv1;
|
|
|
|
uint64_t total_sent_count = 0;
|
|
uint64_t total_recv_count = 0;
|
|
uint64_t total_sent_bytes = 0;
|
|
uint64_t total_recv_bytes = 0;
|
|
|
|
// tox1 makes sure the sum value of all packet ID's is equal to the totals
|
|
for (size_t i = 0; i < 256; ++i) {
|
|
// this id isn't valid for UDP packets but we still want to call the
|
|
// functions and make sure they return some non-zero value
|
|
if (i == TOX_NETPROF_PACKET_ID_TCP_DATA) {
|
|
ck_assert(tox_netprof_get_packet_id_count(tox1, TOX_NETPROF_PACKET_TYPE_UDP, i,
|
|
TOX_NETPROF_DIRECTION_SENT) > 0);
|
|
ck_assert(tox_netprof_get_packet_id_bytes(tox1, TOX_NETPROF_PACKET_TYPE_UDP, i,
|
|
TOX_NETPROF_DIRECTION_SENT) > 0);
|
|
ck_assert(tox_netprof_get_packet_id_bytes(tox1, TOX_NETPROF_PACKET_TYPE_UDP, i,
|
|
TOX_NETPROF_DIRECTION_SENT) > 0);
|
|
ck_assert(tox_netprof_get_packet_id_bytes(tox1, TOX_NETPROF_PACKET_TYPE_UDP, i,
|
|
TOX_NETPROF_DIRECTION_RECV) > 0);
|
|
continue;
|
|
}
|
|
|
|
total_sent_count += tox_netprof_get_packet_id_count(tox1, TOX_NETPROF_PACKET_TYPE_UDP, i,
|
|
TOX_NETPROF_DIRECTION_SENT);
|
|
total_recv_count += tox_netprof_get_packet_id_count(tox1, TOX_NETPROF_PACKET_TYPE_UDP, i,
|
|
TOX_NETPROF_DIRECTION_RECV);
|
|
|
|
total_sent_bytes += tox_netprof_get_packet_id_bytes(tox1, TOX_NETPROF_PACKET_TYPE_UDP, i,
|
|
TOX_NETPROF_DIRECTION_SENT);
|
|
total_recv_bytes += tox_netprof_get_packet_id_bytes(tox1, TOX_NETPROF_PACKET_TYPE_UDP, i,
|
|
TOX_NETPROF_DIRECTION_RECV);
|
|
}
|
|
|
|
const uint64_t total_packets = total_sent_count + total_recv_count;
|
|
ck_assert_msg(total_packets == UDP_count_sent1 + UDP_count_recv1,
|
|
"%" PRIu64 "does not match %" PRIu64 "\n", total_packets, UDP_count_sent1 + UDP_count_recv1);
|
|
|
|
ck_assert_msg(total_sent_count == UDP_count_sent1, "%" PRIu64 " does not match %" PRIu64 "\n", total_sent_count, UDP_count_sent1);
|
|
ck_assert_msg(total_recv_count == UDP_count_recv1, "%" PRIu64 " does not match %" PRIu64"\n", total_recv_count, UDP_count_recv1);
|
|
|
|
|
|
const uint64_t total_bytes = total_sent_bytes + total_recv_bytes;
|
|
ck_assert_msg(total_bytes == UDP_bytes_sent1 + UDP_bytes_recv1,
|
|
"%" PRIu64 "does not match %" PRIu64 "\n", total_bytes, UDP_bytes_sent1 + UDP_bytes_recv1);
|
|
|
|
ck_assert_msg(total_sent_bytes == UDP_bytes_sent1, "%" PRIu64 " does not match %" PRIu64 "\n", total_sent_bytes, UDP_bytes_sent1);
|
|
ck_assert_msg(total_recv_bytes == UDP_bytes_recv1, "%" PRIu64 " does not match %" PRIu64 "\n", total_recv_bytes, UDP_bytes_recv1);
|
|
}
|
|
|
|
int main(void)
|
|
{
|
|
setvbuf(stdout, nullptr, _IONBF, 0);
|
|
|
|
Tox_Err_Options_New options_err;
|
|
struct Tox_Options *tox_opts = tox_options_new(&options_err);
|
|
|
|
ck_assert_msg(options_err == TOX_ERR_OPTIONS_NEW_OK, "Failed to initialize tox options: %d\n", options_err);
|
|
|
|
tox_options_default(tox_opts);
|
|
tox_options_set_udp_enabled(tox_opts, true);
|
|
|
|
Run_Auto_Options autotox_opts = default_run_auto_options();
|
|
autotox_opts.graph = GRAPH_COMPLETE;
|
|
|
|
run_auto_test(tox_opts, NUM_TOXES, test_netprof, 0, &autotox_opts);
|
|
|
|
// TODO(Jfreegman): uncomment this when TCP autotests are fixed
|
|
// tox_options_set_udp_enabled(tox_opts, false);
|
|
// run_auto_test(tox_opts, NUM_TOXES, test_netprof, 0, &autotox_opts);
|
|
|
|
tox_options_free(tox_opts);
|
|
|
|
return 0;
|
|
}
|
|
|
|
#undef NUM_TOXES
|