Skip to content
Snippets Groups Projects
Commit 172d685b authored by Aline Gondim Santos's avatar Aline Gondim Santos
Browse files

account details: add test to check deviceId presence

Change-Id: I971bd0821b358085c6d664b22818e54a24db5d2a
parent 7aaad7bb
No related branches found
No related tags found
No related merge requests found
...@@ -21,17 +21,33 @@ ...@@ -21,17 +21,33 @@
#include <cppunit/TestFixture.h> #include <cppunit/TestFixture.h>
#include <cppunit/extensions/HelperMacros.h> #include <cppunit/extensions/HelperMacros.h>
#include <condition_variable>
#include "account_factory.h" #include "account_factory.h"
#include "../../test_runner.h" #include "../../test_runner.h"
#include "jami.h" #include "jami.h"
#include "account_const.h" #include "account_const.h"
#include "manager.h"
#include "account_const.h"
#include "account_schema.h"
#include "common.h"
#include "jamidht/jamiaccount.h"
using namespace std::literals::chrono_literals;
namespace jami { namespace test { namespace jami { namespace test {
class Account_factoryTest : public CppUnit::TestFixture { class Account_factoryTest : public CppUnit::TestFixture {
public: public:
static std::string name() { return "account_factory"; } Account_factoryTest()
{
// Init daemon
libjami::init(libjami::InitFlag(libjami::LIBJAMI_FLAG_DEBUG | libjami::LIBJAMI_FLAG_CONSOLE_LOG));
if (not Manager::instance().initialized)
CPPUNIT_ASSERT(libjami::start("dring-sample.yml"));
}
~Account_factoryTest() { libjami::fini(); }
static std::string name() { return "Account_factory"; }
void setUp(); void setUp();
void tearDown(); void tearDown();
...@@ -48,7 +64,12 @@ private: ...@@ -48,7 +64,12 @@ private:
const std::string SIP_ID = "SIP_ID"; const std::string SIP_ID = "SIP_ID";
const std::string RING_ID = "RING_ID"; const std::string RING_ID = "RING_ID";
std::unique_ptr<AccountFactory> accountFactory; bool sipReady, ringReady, accountsRemoved;
size_t initialAccounts;
std::map<std::string, std::shared_ptr<libjami::CallbackWrapperBase>> confHandlers;
std::mutex mtx;
std::unique_lock<std::mutex> lk {mtx};
std::condition_variable cv;
}; };
CPPUNIT_TEST_SUITE_NAMED_REGISTRATION(Account_factoryTest, Account_factoryTest::name()); CPPUNIT_TEST_SUITE_NAMED_REGISTRATION(Account_factoryTest, Account_factoryTest::name());
...@@ -56,81 +77,110 @@ CPPUNIT_TEST_SUITE_NAMED_REGISTRATION(Account_factoryTest, Account_factoryTest:: ...@@ -56,81 +77,110 @@ CPPUNIT_TEST_SUITE_NAMED_REGISTRATION(Account_factoryTest, Account_factoryTest::
void void
Account_factoryTest::setUp() Account_factoryTest::setUp()
{ {
// Init daemon sipReady = false;
libjami::init(libjami::InitFlag(libjami::LIBJAMI_FLAG_DEBUG | libjami::LIBJAMI_FLAG_CONSOLE_LOG)); ringReady = false;
CPPUNIT_ASSERT(libjami::start("jami-sample.yml")); accountsRemoved = false;
initialAccounts = Manager::instance().accountCount();
accountFactory.reset(new AccountFactory);
confHandlers.insert(
libjami::exportable_callback<libjami::ConfigurationSignal::VolatileDetailsChanged>(
[&](const std::string& accountID,
const std::map<std::string, std::string>& details) {
if (accountID != RING_ID && accountID != SIP_ID) {
return;
}
try {
ringReady |= accountID == RING_ID
&& details.at(jami::Conf::CONFIG_ACCOUNT_REGISTRATION_STATUS) == "REGISTERED"
&& details.at(libjami::Account::VolatileProperties::DEVICE_ANNOUNCED) == "true";
sipReady |= accountID == SIP_ID
&& details.at(jami::Conf::CONFIG_ACCOUNT_REGISTRATION_STATUS) == "READY";
} catch (const std::out_of_range&) {}
}));
confHandlers.insert(
libjami::exportable_callback<libjami::ConfigurationSignal::AccountsChanged>([&]() {
if (jami::Manager::instance().getAccountList().size() <= initialAccounts) {
accountsRemoved = true;
}
}));
libjami::registerSignalHandlers(confHandlers);
} }
void void
Account_factoryTest::tearDown() Account_factoryTest::tearDown()
{ {
// Stop daemon libjami::unregisterSignalHandlers();
libjami::fini();
} }
void void
Account_factoryTest::testAddRemoveSIPAccount() Account_factoryTest::testAddRemoveSIPAccount()
{ {
// verify if there is no account at the beginning AccountFactory* accountFactory = &Manager::instance().accountFactory;
CPPUNIT_ASSERT(accountFactory->empty());
CPPUNIT_ASSERT(accountFactory->accountCount()==0);
accountFactory->createAccount(libjami::Account::ProtocolNames::SIP, SIP_ID); auto accDetails = libjami::getAccountTemplate("SIP");
auto newAccount = Manager::instance().addAccount(accDetails, SIP_ID);
CPPUNIT_ASSERT(cv.wait_for(lk, 30s, [&] {
return sipReady;
}));
CPPUNIT_ASSERT(accountFactory->hasAccount(SIP_ID)); CPPUNIT_ASSERT(accountFactory->hasAccount(SIP_ID));
CPPUNIT_ASSERT(!accountFactory->hasAccount(RING_ID)); CPPUNIT_ASSERT(!accountFactory->hasAccount(RING_ID));
CPPUNIT_ASSERT(!accountFactory->empty()); CPPUNIT_ASSERT(!accountFactory->empty());
CPPUNIT_ASSERT(accountFactory->accountCount()==1); CPPUNIT_ASSERT(accountFactory->accountCount() == 1 + initialAccounts);
auto details = Manager::instance().getVolatileAccountDetails(SIP_ID);
CPPUNIT_ASSERT(details.find(libjami::Account::ConfProperties::DEVICE_ID) == details.end());
accountFactory->removeAccount(SIP_ID); Manager::instance().removeAccount(SIP_ID, true);
CPPUNIT_ASSERT(accountFactory->empty()); CPPUNIT_ASSERT(cv.wait_for(lk, 30s, [&] { return accountsRemoved; }));
CPPUNIT_ASSERT(accountFactory->accountCount()==0);
} }
void void
Account_factoryTest::testAddRemoveRINGAccount() Account_factoryTest::testAddRemoveRINGAccount()
{ {
// verify if there is no account at the beginning AccountFactory* accountFactory = &Manager::instance().accountFactory;
CPPUNIT_ASSERT(accountFactory->empty());
CPPUNIT_ASSERT(accountFactory->accountCount()==0);
accountFactory->createAccount(libjami::Account::ProtocolNames::RING, RING_ID); auto accDetails = libjami::getAccountTemplate("RING");
auto newAccount = Manager::instance().addAccount(accDetails, RING_ID);
CPPUNIT_ASSERT(cv.wait_for(lk, 30s, [&] {
return ringReady;
}));
CPPUNIT_ASSERT(accountFactory->hasAccount(RING_ID)); CPPUNIT_ASSERT(accountFactory->hasAccount(RING_ID));
CPPUNIT_ASSERT(!accountFactory->hasAccount(SIP_ID)); CPPUNIT_ASSERT(!accountFactory->hasAccount(SIP_ID));
CPPUNIT_ASSERT(!accountFactory->empty()); CPPUNIT_ASSERT(!accountFactory->empty());
CPPUNIT_ASSERT(accountFactory->accountCount()==1); CPPUNIT_ASSERT(accountFactory->accountCount() == 1 + initialAccounts);
accountFactory->removeAccount(RING_ID); auto details = Manager::instance().getVolatileAccountDetails(RING_ID);
CPPUNIT_ASSERT(details.find(libjami::Account::ConfProperties::DEVICE_ID) != details.end());
CPPUNIT_ASSERT(accountFactory->empty()); Manager::instance().removeAccount(RING_ID, true);
CPPUNIT_ASSERT(accountFactory->accountCount()==0); CPPUNIT_ASSERT(cv.wait_for(lk, 30s, [&] { return accountsRemoved; }));
} }
void void
Account_factoryTest::testClear() Account_factoryTest::testClear()
{ {
AccountFactory accountFactory;
// verify if there is no account at the beginning // verify if there is no account at the beginning
CPPUNIT_ASSERT(accountFactory->empty()); CPPUNIT_ASSERT(accountFactory.empty());
CPPUNIT_ASSERT(accountFactory->accountCount()==0); CPPUNIT_ASSERT(accountFactory.accountCount() == 0);
const int nbrAccount = 5; const int nbrAccount = 5;
for(int i = 0; i < nbrAccount ; ++i) { for(int i = 0; i < nbrAccount ; ++i) {
accountFactory->createAccount(libjami::Account::ProtocolNames::RING, RING_ID+std::to_string(i)); accountFactory.createAccount(libjami::Account::ProtocolNames::RING, RING_ID+std::to_string(i));
} }
CPPUNIT_ASSERT(accountFactory->accountCount()==nbrAccount); CPPUNIT_ASSERT(accountFactory.accountCount()==nbrAccount);
CPPUNIT_ASSERT(!accountFactory->empty()); CPPUNIT_ASSERT(!accountFactory.empty());
accountFactory->clear(); accountFactory.clear();
CPPUNIT_ASSERT(accountFactory->empty()); CPPUNIT_ASSERT(accountFactory.empty());
CPPUNIT_ASSERT(accountFactory->accountCount()==0); CPPUNIT_ASSERT(accountFactory.accountCount()==0);
} }
}} // namespace jami::test }} // namespace jami::test
......
0% Loading or .
You are about to add 0 people to the discussion. Proceed with caution.
Please register or to comment