Browse Source

LIB11: Test - update

LIB-12
heck 3 months ago
parent
commit
c28ecc5764
1 changed files with 106 additions and 72 deletions
  1. +106
    -72
      test/test_group.cc

+ 106
- 72
test/test_group.cc View File

@ -12,39 +12,13 @@
using namespace std;
using namespace pEp;
/*
* Update functions
* ----------------
* Test procedure:
* 1. Create group
* - group_create(Alice)
* 2. Add Bob
* - group_invite_member(Bob)
* - group_join(Bob)
* 3. Add Carol
* - group_invite_member(Carol)
* - group_join(Carol)
* 4. Remove Carol
* - group_remove_member(Carol)
* 5. Rating
* - group_rating() (Just test once, to see it is generally working)
* 6. Disssolve
* - group_dissolve()
*
* Query functions
* ---------------
* Always test all the query functions for correctness between every step above.
* group_query_groups()
* group_query_manager()
* group_query_members
*/
using namespace pEp::Test::Log;
bool debug_info_full = true;
::pEp_identity* alice = nullptr;
::pEp_identity* bob = nullptr;
::pEp_identity* carol = nullptr;
::pEp_identity* grp_ident = nullptr;
::PEP_STATUS status;
/*
@ -72,9 +46,9 @@ bool debug_info_full = true;
* Test Units
*/
void create_alice_me()
void test_create_alice_me()
{
cout << "======== Alice myself()" << endl;
logH2("test_create_alice_me");
alice = ::new_identity("alice@peptest.ch", NULL, "23", "Alice");
assert(alice);
alice->lang[0] = 'e';
@ -85,9 +59,9 @@ void create_alice_me()
cout << "Alice:" << Test::Utils::identity_to_string(alice, debug_info_full) << endl;
}
void create_bob_partner()
void test_create_bob_partner()
{
cout << "======== Bob update_identity()" << endl;
logH2("test_create_bob_partner");
bob = ::new_identity("bob@peptest.ch", NULL, PEP_OWN_USERID, "Bob");
assert(bob);
bob->lang[0] = 'c';
@ -98,9 +72,9 @@ void create_bob_partner()
cout << "Bob:" << Test::Utils::identity_to_string(bob, debug_info_full) << endl;
}
void create_carol_partner()
void test_create_carol_partner()
{
cout << "======== Carol update_identity()" << endl;
logH2("test_create_carol_partner");
carol = ::new_identity("carol@peptest.ch", NULL, PEP_OWN_USERID, "Carol");
assert(carol);
carol->lang[0] = 'f';
@ -111,76 +85,136 @@ void create_carol_partner()
cout << "Carol:" << Test::Utils::identity_to_string(carol, debug_info_full) << endl;
}
void setup_and_start_sync()
void test_setup_and_start_sync()
{
cout << "======== sync_initialize()" << endl;
logH2("test_setup_and_start_sync");
Adapter::sync_initialize(Adapter::SyncModes::Async, &test_messageToSend, &test_notifyHandshake, false);
}
void group_rating()
void test_group_create(::identity_list* idl)
{
cout << "======== 5. Rating" << endl;
// recreate group identity
::pEp_identity* grp_ident = ::new_identity("group1@peptest.ch", NULL, NULL, NULL);
logH2("test_group_create");
cout << "IDL: " << Test::Utils::identitylist_to_string(idl, debug_info_full) << endl;
cout << "create group identity" << endl;
grp_ident = ::new_identity("group1@peptest.ch", NULL, "432", "group1");
assert(grp_ident);
status = ::update_identity(Adapter::session(), grp_ident);
status = ::myself(Adapter::session(), grp_ident);
cout << "STATUS: " << status_to_string(status) << endl;
assert(!status);
cout << "grp_ident:" << Test::Utils::identity_to_string(grp_ident, debug_info_full) << endl;
// Rating
::PEP_rating* rating = nullptr;
cout << "adapter_group_rating()" << endl;
status = ::group_rating(Adapter::session(), grp_ident, alice, rating);
cout << "adapter_group_create()" << endl;
::pEp_group* pep_grp1 = nullptr;
status = ::adapter_group_create(Adapter::session(), grp_ident, alice, idl, &pep_grp1);
cout << "STATUS: " << status_to_string(status) << endl;
cout << "Rating: " << rating << endl;
assert(!status);
assert(pep_grp1);
cout << "GRP: " << Test::Utils::group_to_string(pep_grp1, debug_info_full) << endl;
}
void create_group()
void test_group_invite_member(::pEp_identity* ident)
{
cout << "======== 1. Create group" << endl;
::pEp_group* pep_grp1 = nullptr;
logH2("test_group_invite_member");
status = ::adapter_group_invite_member(Adapter::session(), grp_ident, ident);
cout << "STATUS: " << status_to_string(status) << endl;
assert(!status);
}
// Initial Memberlist
::identity_list* idl = new_identity_list(bob);
::identity_list_add(idl, carol);
cout << "IDL: " << Test::Utils::identitylist_to_string(idl, debug_info_full) << endl;
void test_group_join(::pEp_identity* ident)
{
logH2("test_group_join");
status = ::adapter_group_join(Adapter::session(), grp_ident, ident);
cout << "STATUS: " << status_to_string(status) << endl;
assert(!status);
}
// Group Identity
::pEp_identity* grp_ident = ::new_identity("group1@peptest.ch", NULL, "432", "group1");
assert(grp_ident);
status = ::myself(Adapter::session(), grp_ident);
void test_group_remove_member(::pEp_identity* ident)
{
logH2("test_group_remove_member");
status = ::adapter_group_remove_member(Adapter::session(), grp_ident, ident);
cout << "STATUS: " << status_to_string(status) << endl;
assert(!status);
cout << "grp_ident:" << Test::Utils::identity_to_string(grp_ident, debug_info_full) << endl;
}
// Create group
cout << "adapter_group_create()" << endl;
status = ::adapter_group_create(Adapter::session(), grp_ident, alice, idl, &pep_grp1);
void test_group_rating()
{
logH2("test_group_rating");
// Rating
::PEP_rating* rating = nullptr;
cout << "adapter_group_rating()" << endl;
status = ::group_rating(Adapter::session(), grp_ident, alice, rating);
cout << "STATUS: " << status_to_string(status) << endl;
assert(!status);
assert(pep_grp1);
cout << "GRP: " << Test::Utils::group_to_string(pep_grp1, debug_info_full) << endl;
cout << "Rating: " << rating << endl;
}
void test_group_dissolve()
{
logH2("test_group_dissolve");
status = ::adapter_group_dissolve(Adapter::session(), grp_ident, alice);
cout << "STATUS: " << status_to_string(status) << endl;
assert(!status);
}
/*
* Test Procedure
* It has the advantage that you can comment out one line if a test fails
* Update functions
* ----------------
* Test procedure:
* 1. Create group
* - group_create(Alice)
* 2. Add Bob
* - group_invite_member(Bob)
* - group_join(Bob)
* 3. Add Carol
* - group_invite_member(Carol)
* - group_join(Carol)
* 4. Remove Carol
* - group_remove_member(Carol)
* 5. Rating
* - group_rating() (Just test once, to see it is generally working)
* 6. Dissolve
* - group_dissolve()
*
* Query functions
* ---------------
* Always test all the query functions for correctness between every step above.
* group_query_groups()
* group_query_manager()
* group_query_members
*/
int main(int argc, char** argv)
{
Test::setup(argc, argv);
Adapter::pEpLog::set_enabled(false);
debug_info_full = false;
create_alice_me();
create_bob_partner();
create_carol_partner();
setup_and_start_sync();
create_group();
// group_rating(); // Failing
debug_info_full = true;
// Setup Test Context
test_create_alice_me();
test_create_bob_partner();
test_create_carol_partner();
test_setup_and_start_sync();
logH1("1. Create group");
::identity_list* initial_memberlist = nullptr;
initial_memberlist = new_identity_list(bob);
::identity_list_add(initial_memberlist, carol);
test_group_create(initial_memberlist);
logH1("2. Add Bob");
// test_group_invite_member(bob); // Fails
// test_group_join(bob); // Fails
logH1("3. Add Carol");
// test_group_invite_member(carol);
// test_group_join(carol);
logH1("4. Remove Carol");
// test_group_remove_member(carol);
logH1("5. Rating");
// test_group_rating(); // Failing
logH1("6. Dissolve");
test_group_dissolve();
Adapter::shutdown();
return 0;


Loading…
Cancel
Save