forked from Green-Sky/tomato
Green Sky
aae086cc65
b03b571272 fix: flaky tcp test This only fixes the symptoms, not the real problem. Sometimes or consistently on some platforms a socket might need a moment before it can be written to. 32e67ab4c2 cleanup: use typedef for private message ID's in callback 7b1db6adc1 feat: add message IDs to private group messages 99e0bcc27d refactor: Observers/ignored peers can now send and receive custom packets b3c3c49d26 fix: Disable IPv6 in Windows cross-compilation tests e742deddff feat: Check hashes of Windows dependencies when cross-compiling dfb9a0b02b fix: Test the current Windows Dockerfile, not an old Dockerhub image 14de93ccec chore: Use WineHQ's Wine as Debian Bookworm's crashes ed37616249 docs: Update the Windows cross-compilation section 9bb79c174f cleanup: Remove a couple of unnecessary misc_tools dependencies 19475adb70 chore: Statically link OpenMP into the cracker fun util on Windows 1be311e51f feat: Build the fun utils when cross-compiling to Windows 88133f8446 chore: Strip Windows binaries 3cc0ae7535 refactor: Copy over all of the required static dependencies c4fa8f7fb1 feat: Generate .def, .exp and .lib files when building for Windows 74bbac5363 feat: Let CMake create the dll instead of doing so ourselves 246642e9ae feat: Harden Windows cross-compilation 8d431c0d11 chore: Bump Windows build dependency versions e519f7998b fix: Remove unnecessary wsock32 dependency on Windows ed2b60c217 chore: Use a specific non-broken slimcc version. d7f21010a1 chore: Update github actions. e71a68b7f2 docs: Update the list of CMake options 77e08876ff chore: Remove mod and founder from group API naming scheme 12bc042767 docs: add the experimental api build option to INSTALL.md e1fa5cae96 refactor: Rename Queries to Query to align with other enums. be82a3ea30 fix: Correct type for conference offline peer numbers. 0627c36716 test: Add pkgsrc build. 92578afe4b test: Add FreeBSD VM action on GitHub. 52ece0f57b test: Build toxcore on NetBSD (VM). 3fe8ee2c11 chore: Only install tox_private.h on request. 9a8dfa06ab fix: save_compatibility_test failing on big-endian systems 86f5e55578 fix: Don't serve files from websockify. 710eb674a5 fix: Correctly pass extended public keys to group moderation code. 021db7031c refactor: Use `struct`s for extended public/secret keys. a1e999fd80 chore: Compile libsodium reference implementation with compcert. fbe3c19cf5 cleanup: correct a few nullable annotations 623e3ee5c3 cleanup: Don't use `memcpy` to cast arbitrary `struct`s to `uint8_t[]`. c71567dc18 fix: Pass array, not array pointer, to `memcmp`. 9b46a08144 cleanup: Never pass `void*` directly to `memcpy`. 5d7b7a7bbc refactor: Use tox rng to seed the keypair generation. 961891d568 cleanup: Small improvements found by PVS Studio. 8201019f0d chore: Disable NGC saving by default, enable through Tox_Options. 5dd9ee3f65 cleanup: Replace pointer arithmetic with explicit `&arr[i]`. ca4606d49d refactor: Use strong typedef for NGC peer id. 442213b722 cleanup: Simplify custom packet length check in NGC. 08d3393def fix: Correct a few potential null derefs in bootstrap daemon. b9877b32b0 fix: Add missing memunlock of local variable when it goes out of scope. dab5fe44b9 fix: Zero out stack-allocated secret key before return. f058103299 refactor: Make prune_gc_sanctions_list more obviously correct. 3ba7a0dec9 docs: Add static analysis tool list to README. 8d0811a0f3 docs: Run prettier-markdown on markdown files. 969e3a2bfc refactor: Fix network test not using the strong typedef 93c83fbc7c refactor: Use strong typedef instead of struct for `Socket`. 9fe18b176f fix: Fix some false positive from PVS Studio. 7c44379ccb cleanup: Check that WINXP macro exists before comparing it. 5c93231bef refactor: Make tox mutex non-recursive. aacff73939 docs: Fix up doxyfile. d55fc85ff5 docs: Add more documentation to crypto_core. 5bdaaaedb6 refactor: Remove `Tox *` from `tox_dispatch`. e202341e76 refactor: Don't rely on tox_dispatch passing tox in tests. 34df938f52 chore: Use C++ mode for clang-tidy. 8b05296a78 chore: Check that both gtest and gmock exist for tests. 42010660e1 test: Add slimcc compiler compatibility test. b473630321 chore: Add some comments to the astyle config. b7404f24f6 cleanup: Remove implicit bool conversions. 4e2dba4d9f chore: Reformat sources with astyle. 4359e3a6bc chore: Rename C++ headers to .hh suffixes. 0c05566e58 cleanup: Further `#include` cleanups. 8d29935b7a chore: Only check the bootstrap daemon checksum on release. f70e588bc6 cleanup: Add more `const` where possible. 511bfe39c8 cleanup: Use Bazel modules to enforce proper `#include` hygiene. 1710a0d091 refactor: Move pack/unpack `IP_Port` from DHT into network module. a975943564 chore: Really fix coverage docker image build. c08409390f chore: Fix post-submit coverage image. 39aadf8922 fix: Don't use `memcmp` to compare `IP_Port`s. d94246a906 fix: partially fix a bug that prevented group part messages from sending. eeaa039222 chore: Fix rpm build; add a CI check for it. 8328449c1a chore: Speed up docker builds a bit by reducing layer count. d6d67d56f3 cleanup: Add `const` where possible in auto tests. 6aa9e6850d cleanup: Minor cleanup of event unpack code. bdf460a3a9 refactor: Rename `system_{memory,...}` to `os_{memory,...}`. 203e1af81e fix: a few off by one errors in group autotests 5c093c4888 cleanup: Remove all uses of `SIZEOF_VLA`. 662c2140f3 test: Add goblint static analyser. 8f07755834 cleanup: Use `memzero(x, s)` instead of `memset(x, 0, s)`. a7258e40cf cleanup: Use explicit 0 instead of `PACKET_ID_PADDING`. 6370d0f15d cleanup: Expand the `Tox_Options` accessor macros. 14a1a0b9bd cleanup: Remove plan9 support. a05dccad13 test: Add a simple new/delete test for Tox. 1cdcf938b9 cleanup: Add comment after every `#endif`. ba99d4dc4b test: Fix comment I broke in the events test PR. e07248debb refactor: Migrate auto_tests to new events API. bdd42b5452 refactor: Add common msgpack array packer with callback. 3c659f5288 cleanup: Rename group to conference in groupav documentation. 89957be230 cleanup: Ensure handler params are named after callback params. c650d9d345 refactor: Pass `this` pointer as first param to s11n callbacks. e7fb91ddb8 refactor: Allow NULL pointers for byte arrays in events. 5e2c8cabc1 cleanup: make some improvements to group moderation test 259de4867e cleanup: Remove `bin_pack_{new,free}`. 21a8ff5895 cleanup: skip a do_gc iteration before removing peers marked for deletion 16809dc36e feat: Add dht_get_nodes_response event to the events system. git-subtree-dir: external/toxcore/c-toxcore git-subtree-split: b03b5712720de9a9901ea12fd741f177327a7021
441 lines
15 KiB
C
441 lines
15 KiB
C
/* Auto Tests: Conferences.
|
|
*/
|
|
|
|
#include <stdlib.h>
|
|
#include <string.h>
|
|
#include <time.h>
|
|
#include <stdint.h>
|
|
|
|
#include "../toxcore/util.h"
|
|
|
|
#include "check_compat.h"
|
|
|
|
#define NUM_GROUP_TOX 16
|
|
#define NUM_DISCONNECT 8
|
|
#define GROUP_MESSAGE "Install Gentoo"
|
|
|
|
#define NAMELEN 9
|
|
#define NAME_FORMAT_STR "Tox #%4u"
|
|
#define NEW_NAME_FORMAT_STR "New #%4u"
|
|
|
|
typedef struct State {
|
|
bool invited_next;
|
|
} State;
|
|
|
|
#include "auto_test_support.h"
|
|
|
|
static void handle_self_connection_status(
|
|
Tox *tox, Tox_Connection connection_status, void *user_data)
|
|
{
|
|
const AutoTox *autotox = (AutoTox *)user_data;
|
|
|
|
if (connection_status != TOX_CONNECTION_NONE) {
|
|
printf("tox #%u: is now connected\n", autotox->index);
|
|
} else {
|
|
printf("tox #%u: is now disconnected\n", autotox->index);
|
|
}
|
|
}
|
|
|
|
static void handle_friend_connection_status(
|
|
Tox *tox, uint32_t friendnumber, Tox_Connection connection_status, void *user_data)
|
|
{
|
|
const AutoTox *autotox = (AutoTox *)user_data;
|
|
|
|
if (connection_status != TOX_CONNECTION_NONE) {
|
|
printf("tox #%u: is now connected to friend %u\n", autotox->index, friendnumber);
|
|
} else {
|
|
printf("tox #%u: is now disconnected from friend %u\n", autotox->index, friendnumber);
|
|
}
|
|
}
|
|
|
|
static void handle_conference_invite(
|
|
Tox *tox, uint32_t friendnumber, Tox_Conference_Type type,
|
|
const uint8_t *data, size_t length, void *user_data)
|
|
{
|
|
const AutoTox *autotox = (AutoTox *)user_data;
|
|
ck_assert_msg(type == TOX_CONFERENCE_TYPE_TEXT, "tox #%u: wrong conference type: %d", autotox->index, type);
|
|
|
|
Tox_Err_Conference_Join err;
|
|
uint32_t g_num = tox_conference_join(autotox->tox, friendnumber, data, length, &err);
|
|
|
|
ck_assert_msg(err == TOX_ERR_CONFERENCE_JOIN_OK, "tox #%u: error joining group: %d", autotox->index, err);
|
|
ck_assert_msg(g_num == 0, "tox #%u: group number was not 0", autotox->index);
|
|
|
|
// Try joining again. We should only be allowed to join once.
|
|
tox_conference_join(autotox->tox, friendnumber, data, length, &err);
|
|
ck_assert_msg(err != TOX_ERR_CONFERENCE_JOIN_OK,
|
|
"tox #%u: joining groupchat twice should be impossible.", autotox->index);
|
|
}
|
|
|
|
static void handle_conference_connected(
|
|
Tox *tox, uint32_t conference_number, void *user_data)
|
|
{
|
|
const AutoTox *autotox = (AutoTox *)user_data;
|
|
State *state = (State *)autotox->state;
|
|
|
|
if (state->invited_next || tox_self_get_friend_list_size(autotox->tox) <= 1) {
|
|
return;
|
|
}
|
|
|
|
Tox_Err_Conference_Invite err;
|
|
tox_conference_invite(autotox->tox, 1, 0, &err);
|
|
ck_assert_msg(err == TOX_ERR_CONFERENCE_INVITE_OK, "tox #%u failed to invite next friend: err = %d", autotox->index,
|
|
err);
|
|
printf("tox #%u: invited next friend\n", autotox->index);
|
|
state->invited_next = true;
|
|
}
|
|
|
|
static uint32_t num_recv;
|
|
|
|
static void handle_conference_message(
|
|
Tox *tox, uint32_t groupnumber, uint32_t peernumber, Tox_Message_Type type,
|
|
const uint8_t *message, size_t length, void *user_data)
|
|
{
|
|
if (length == (sizeof(GROUP_MESSAGE) - 1) && memcmp(message, GROUP_MESSAGE, sizeof(GROUP_MESSAGE) - 1) == 0) {
|
|
++num_recv;
|
|
}
|
|
}
|
|
|
|
static bool toxes_are_disconnected_from_group(uint32_t tox_count, AutoTox *autotoxes,
|
|
const bool *disconnected)
|
|
{
|
|
uint32_t num_disconnected = 0;
|
|
|
|
for (uint32_t i = 0; i < tox_count; ++i) {
|
|
num_disconnected += disconnected[i];
|
|
}
|
|
|
|
for (uint32_t i = 0; i < tox_count; i++) {
|
|
if (disconnected[i]) {
|
|
continue;
|
|
}
|
|
|
|
if (tox_conference_peer_count(autotoxes[i].tox, 0, nullptr) > tox_count - num_disconnected) {
|
|
return false;
|
|
}
|
|
}
|
|
|
|
return true;
|
|
}
|
|
|
|
static void disconnect_toxes(uint32_t tox_count, AutoTox *autotoxes,
|
|
const bool *disconnect, const bool *exclude)
|
|
{
|
|
/* Fake a network outage for a set of peers D by iterating only the other
|
|
* peers D' until the connections time out according to D', then iterating
|
|
* only D until the connections time out according to D. */
|
|
|
|
VLA(bool, disconnect_now, tox_count);
|
|
bool invert = false;
|
|
|
|
do {
|
|
for (uint32_t i = 0; i < tox_count; ++i) {
|
|
disconnect_now[i] = exclude[i] || (invert ^ disconnect[i]);
|
|
}
|
|
|
|
do {
|
|
for (uint32_t i = 0; i < tox_count; ++i) {
|
|
if (!disconnect_now[i]) {
|
|
tox_iterate(autotoxes[i].tox, &autotoxes[i]);
|
|
autotoxes[i].clock += 1000;
|
|
}
|
|
}
|
|
|
|
c_sleep(20);
|
|
} while (!toxes_are_disconnected_from_group(tox_count, autotoxes, disconnect_now));
|
|
|
|
invert = !invert;
|
|
} while (invert);
|
|
}
|
|
|
|
static bool all_connected_to_group(uint32_t tox_count, AutoTox *autotoxes)
|
|
{
|
|
for (uint32_t i = 0; i < tox_count; i++) {
|
|
if (tox_conference_peer_count(autotoxes[i].tox, 0, nullptr) < tox_count) {
|
|
return false;
|
|
}
|
|
}
|
|
|
|
return true;
|
|
}
|
|
|
|
static bool names_propagated(uint32_t tox_count, AutoTox *autotoxes)
|
|
{
|
|
for (uint32_t i = 0; i < tox_count; ++i) {
|
|
for (uint32_t j = 0; j < tox_count; ++j) {
|
|
const size_t len = tox_conference_peer_get_name_size(autotoxes[i].tox, 0, j, nullptr);
|
|
|
|
if (len != NAMELEN) {
|
|
return false;
|
|
}
|
|
}
|
|
}
|
|
|
|
return true;
|
|
}
|
|
|
|
/**
|
|
* returns a random index at which a list of booleans is false
|
|
* (some such index is required to exist)
|
|
*/
|
|
static uint32_t random_false_index(const Random *rng, const bool *list, const uint32_t length)
|
|
{
|
|
uint32_t index;
|
|
|
|
do {
|
|
index = random_u32(rng) % length;
|
|
} while (list[index]);
|
|
|
|
return index;
|
|
}
|
|
|
|
static void run_conference_tests(AutoTox *autotoxes)
|
|
{
|
|
const Random *rng = os_random();
|
|
ck_assert(rng != nullptr);
|
|
/* disabling name change propagation check for now, as it occasionally
|
|
* fails due to disconnections too short to trigger freezing */
|
|
const bool check_name_change_propagation = false;
|
|
|
|
/* each peer should freeze at least its two friends, but freezing more
|
|
* should not be necessary */
|
|
const uint32_t max_frozen = max_u32(2, NUM_DISCONNECT / 2);
|
|
printf("restricting number of frozen peers to %u\n", max_frozen);
|
|
|
|
for (uint16_t i = 0; i < NUM_GROUP_TOX; ++i) {
|
|
Tox_Err_Conference_Set_Max_Offline err;
|
|
tox_conference_set_max_offline(autotoxes[i].tox, 0, max_frozen, &err);
|
|
ck_assert_msg(err == TOX_ERR_CONFERENCE_SET_MAX_OFFLINE_OK,
|
|
"tox #%u failed to set max offline: err = %d", autotoxes[i].index, err);
|
|
}
|
|
|
|
printf("letting random toxes timeout\n");
|
|
bool disconnected[NUM_GROUP_TOX] = {0};
|
|
bool restarting[NUM_GROUP_TOX] = {0};
|
|
|
|
ck_assert(NUM_DISCONNECT < NUM_GROUP_TOX);
|
|
|
|
for (uint32_t i = 0; i < NUM_DISCONNECT; ++i) {
|
|
uint32_t disconnect = random_false_index(rng, disconnected, NUM_GROUP_TOX);
|
|
disconnected[disconnect] = true;
|
|
|
|
if (i < NUM_DISCONNECT / 2) {
|
|
restarting[disconnect] = true;
|
|
printf("Restarting #%u\n", autotoxes[disconnect].index);
|
|
} else {
|
|
printf("Disconnecting #%u\n", autotoxes[disconnect].index);
|
|
}
|
|
}
|
|
|
|
uint8_t *save[NUM_GROUP_TOX];
|
|
size_t save_size[NUM_GROUP_TOX];
|
|
|
|
for (uint32_t i = 0; i < NUM_GROUP_TOX; ++i) {
|
|
if (restarting[i]) {
|
|
save_size[i] = tox_get_savedata_size(autotoxes[i].tox);
|
|
ck_assert_msg(save_size[i] != 0, "save is invalid size %u", (unsigned)save_size[i]);
|
|
save[i] = (uint8_t *)malloc(save_size[i]);
|
|
ck_assert_msg(save[i] != nullptr, "malloc failed");
|
|
tox_get_savedata(autotoxes[i].tox, save[i]);
|
|
tox_kill(autotoxes[i].tox);
|
|
}
|
|
}
|
|
|
|
disconnect_toxes(NUM_GROUP_TOX, autotoxes, disconnected, restarting);
|
|
|
|
for (uint32_t i = 0; i < NUM_GROUP_TOX; ++i) {
|
|
if (restarting[i]) {
|
|
struct Tox_Options *const options = tox_options_new(nullptr);
|
|
ck_assert(options != nullptr);
|
|
tox_options_set_savedata_type(options, TOX_SAVEDATA_TYPE_TOX_SAVE);
|
|
tox_options_set_savedata_data(options, save[i], save_size[i]);
|
|
autotoxes[i].tox = tox_new_log(options, nullptr, &autotoxes[i].index);
|
|
ck_assert(autotoxes[i].tox != nullptr);
|
|
tox_options_free(options);
|
|
free(save[i]);
|
|
|
|
set_mono_time_callback(&autotoxes[i]);
|
|
tox_conference_set_max_offline(autotoxes[i].tox, 0, max_frozen, nullptr);
|
|
}
|
|
}
|
|
|
|
if (check_name_change_propagation) {
|
|
printf("changing names\n");
|
|
|
|
for (uint32_t i = 0; i < NUM_GROUP_TOX; ++i) {
|
|
char name[NAMELEN + 1];
|
|
snprintf(name, NAMELEN + 1, NEW_NAME_FORMAT_STR, autotoxes[i].index);
|
|
tox_self_set_name(autotoxes[i].tox, (const uint8_t *)name, NAMELEN, nullptr);
|
|
}
|
|
}
|
|
|
|
for (uint16_t i = 0; i < NUM_GROUP_TOX; ++i) {
|
|
const uint32_t num_frozen = tox_conference_offline_peer_count(autotoxes[i].tox, 0, nullptr);
|
|
ck_assert_msg(num_frozen <= max_frozen,
|
|
"tox #%u has too many offline peers: %u\n",
|
|
autotoxes[i].index, num_frozen);
|
|
}
|
|
|
|
printf("reconnecting toxes\n");
|
|
|
|
do {
|
|
iterate_all_wait(autotoxes, NUM_GROUP_TOX, ITERATION_INTERVAL);
|
|
} while (!all_connected_to_group(NUM_GROUP_TOX, autotoxes));
|
|
|
|
printf("running conference tests\n");
|
|
|
|
for (uint32_t i = 0; i < NUM_GROUP_TOX; ++i) {
|
|
tox_callback_conference_message(autotoxes[i].tox, &handle_conference_message);
|
|
|
|
iterate_all_wait(autotoxes, NUM_GROUP_TOX, ITERATION_INTERVAL);
|
|
}
|
|
|
|
Tox_Err_Conference_Send_Message err;
|
|
ck_assert_msg(
|
|
tox_conference_send_message(
|
|
autotoxes[random_u32(rng) % NUM_GROUP_TOX].tox, 0, TOX_MESSAGE_TYPE_NORMAL, (const uint8_t *)GROUP_MESSAGE,
|
|
sizeof(GROUP_MESSAGE) - 1, &err) != 0, "failed to send group message");
|
|
ck_assert_msg(
|
|
err == TOX_ERR_CONFERENCE_SEND_MESSAGE_OK, "failed to send group message");
|
|
num_recv = 0;
|
|
|
|
for (uint8_t j = 0; j < NUM_GROUP_TOX * 2; ++j) {
|
|
iterate_all_wait(autotoxes, NUM_GROUP_TOX, ITERATION_INTERVAL);
|
|
}
|
|
|
|
ck_assert_msg(num_recv == NUM_GROUP_TOX, "failed to recv group messages");
|
|
|
|
if (check_name_change_propagation) {
|
|
for (uint32_t i = 0; i < NUM_GROUP_TOX; ++i) {
|
|
for (uint32_t j = 0; j < NUM_GROUP_TOX; ++j) {
|
|
uint8_t name[NAMELEN];
|
|
tox_conference_peer_get_name(autotoxes[i].tox, 0, j, name, nullptr);
|
|
/* Note the toxes will have been reordered */
|
|
ck_assert_msg(memcmp(name, "New", 3) == 0,
|
|
"name of #%u according to #%u not updated", autotoxes[j].index, autotoxes[i].index);
|
|
}
|
|
}
|
|
}
|
|
|
|
for (uint32_t k = NUM_GROUP_TOX; k != 0 ; --k) {
|
|
tox_conference_delete(autotoxes[k - 1].tox, 0, nullptr);
|
|
|
|
for (uint8_t j = 0; j < 10 || j < NUM_GROUP_TOX; ++j) {
|
|
iterate_all_wait(autotoxes, NUM_GROUP_TOX, ITERATION_INTERVAL);
|
|
}
|
|
|
|
for (uint32_t i = 0; i < k - 1; ++i) {
|
|
uint32_t peer_count = tox_conference_peer_count(autotoxes[i].tox, 0, nullptr);
|
|
ck_assert_msg(peer_count == (k - 1), "\n\tBad number of group peers (post check)."
|
|
"\n\t\t\tExpected: %u but tox_instance(%u) only has: %u\n\n",
|
|
k - 1, i, (unsigned)peer_count);
|
|
}
|
|
}
|
|
}
|
|
|
|
static void test_many_group(AutoTox *autotoxes)
|
|
{
|
|
const time_t test_start_time = time(nullptr);
|
|
|
|
for (uint32_t i = 0; i < NUM_GROUP_TOX; ++i) {
|
|
tox_callback_self_connection_status(autotoxes[i].tox, &handle_self_connection_status);
|
|
tox_callback_friend_connection_status(autotoxes[i].tox, &handle_friend_connection_status);
|
|
tox_callback_conference_invite(autotoxes[i].tox, &handle_conference_invite);
|
|
tox_callback_conference_connected(autotoxes[i].tox, &handle_conference_connected);
|
|
|
|
char name[NAMELEN + 1];
|
|
snprintf(name, NAMELEN + 1, NAME_FORMAT_STR, autotoxes[i].index);
|
|
tox_self_set_name(autotoxes[i].tox, (const uint8_t *)name, NAMELEN, nullptr);
|
|
}
|
|
|
|
ck_assert_msg(tox_conference_new(autotoxes[0].tox, nullptr) != UINT32_MAX, "failed to create group");
|
|
printf("tox #%u: inviting its first friend\n", autotoxes[0].index);
|
|
ck_assert_msg(tox_conference_invite(autotoxes[0].tox, 0, 0, nullptr) != 0, "failed to invite friend");
|
|
((State *)autotoxes[0].state)->invited_next = true;
|
|
ck_assert_msg(tox_conference_set_title(autotoxes[0].tox, 0, (const uint8_t *)"Gentoo", sizeof("Gentoo") - 1,
|
|
nullptr) != 0,
|
|
"failed to set group title");
|
|
|
|
printf("waiting for invitations to be made\n");
|
|
uint32_t invited_count = 0;
|
|
|
|
do {
|
|
iterate_all_wait(autotoxes, NUM_GROUP_TOX, ITERATION_INTERVAL);
|
|
|
|
invited_count = 0;
|
|
|
|
for (uint32_t i = 0; i < NUM_GROUP_TOX; ++i) {
|
|
invited_count += ((State *)autotoxes[i].state)->invited_next;
|
|
}
|
|
} while (invited_count != NUM_GROUP_TOX - 1);
|
|
|
|
uint64_t pregroup_clock = autotoxes[0].clock;
|
|
printf("waiting for all toxes to be in the group\n");
|
|
uint32_t fully_connected_count = 0;
|
|
|
|
do {
|
|
fully_connected_count = 0;
|
|
printf("current peer counts: [");
|
|
|
|
iterate_all_wait(autotoxes, NUM_GROUP_TOX, ITERATION_INTERVAL);
|
|
|
|
for (uint32_t i = 0; i < NUM_GROUP_TOX; ++i) {
|
|
Tox_Err_Conference_Peer_Query err;
|
|
uint32_t peer_count = tox_conference_peer_count(autotoxes[i].tox, 0, &err);
|
|
|
|
if (err != TOX_ERR_CONFERENCE_PEER_QUERY_OK) {
|
|
peer_count = 0;
|
|
}
|
|
|
|
fully_connected_count += peer_count == NUM_GROUP_TOX;
|
|
|
|
if (i != 0) {
|
|
printf(", ");
|
|
}
|
|
|
|
printf("%u", peer_count);
|
|
}
|
|
|
|
printf("]\n");
|
|
fflush(stdout);
|
|
} while (fully_connected_count != NUM_GROUP_TOX);
|
|
|
|
for (uint32_t i = 0; i < NUM_GROUP_TOX; ++i) {
|
|
uint32_t peer_count = tox_conference_peer_count(autotoxes[i].tox, 0, nullptr);
|
|
|
|
ck_assert_msg(peer_count == NUM_GROUP_TOX, "\n\tBad number of group peers (pre check)."
|
|
"\n\t\t\tExpected: %d but tox_instance(%u) only has: %u\n\n",
|
|
NUM_GROUP_TOX, i, (unsigned)peer_count);
|
|
|
|
uint8_t title[2048];
|
|
size_t ret = tox_conference_get_title_size(autotoxes[i].tox, 0, nullptr);
|
|
ck_assert_msg(ret == sizeof("Gentoo") - 1, "Wrong title length");
|
|
tox_conference_get_title(autotoxes[i].tox, 0, title, nullptr);
|
|
ck_assert_msg(memcmp("Gentoo", title, ret) == 0, "Wrong title");
|
|
}
|
|
|
|
printf("waiting for names to propagate\n");
|
|
|
|
do {
|
|
iterate_all_wait(autotoxes, NUM_GROUP_TOX, ITERATION_INTERVAL);
|
|
} while (!names_propagated(NUM_GROUP_TOX, autotoxes));
|
|
|
|
printf("group connected, took %d seconds\n", (int)((autotoxes[0].clock - pregroup_clock) / 1000));
|
|
|
|
run_conference_tests(autotoxes);
|
|
|
|
printf("test_many_group succeeded, took %d seconds\n", (int)(time(nullptr) - test_start_time));
|
|
}
|
|
|
|
int main(void)
|
|
{
|
|
setvbuf(stdout, nullptr, _IONBF, 0);
|
|
|
|
Run_Auto_Options options = default_run_auto_options();
|
|
options.graph = GRAPH_LINEAR;
|
|
options.events = false;
|
|
|
|
run_auto_test(nullptr, NUM_GROUP_TOX, test_many_group, sizeof(State), &options);
|
|
return 0;
|
|
}
|