Skip to content
Snippets Groups Projects
Commit eb628406 authored by Sébastien Blin's avatar Sébastien Blin Committed by Adrien Béraud
Browse files

conversation_module: loadConversations should set removing flag

This fix the error "No conversation detected for..."

Change-Id: I95769b89ceac6c03bc8abab87978e154500a6319
parent 589d1bc2
No related branches found
No related tags found
No related merge requests found
......@@ -1173,6 +1173,10 @@ ConversationModule::loadConversations()
info.members = std::move(members);
info.lastDisplayed = conv->infos()[ConversationMapKeys::LAST_DISPLAYED];
addConvInfo(info);
} else if (convInfo->second.removed) {
// A conversation was removed, but repository still exists
conv->setRemovingFlag();
toRm.insert(repository);
}
auto commits = conv->refreshActiveCalls();
if (!commits.empty()) {
......
......@@ -127,6 +127,7 @@ private:
void testRemoveOneToOneNotInDetails();
void testMessageEdition();
void testMessageReaction();
void testLoadPartiallyRemovedConversation();
CPPUNIT_TEST_SUITE(ConversationTest);
CPPUNIT_TEST(testCreateConversation);
......@@ -179,6 +180,7 @@ private:
CPPUNIT_TEST(testRemoveOneToOneNotInDetails);
CPPUNIT_TEST(testMessageEdition);
CPPUNIT_TEST(testMessageReaction);
CPPUNIT_TEST(testLoadPartiallyRemovedConversation);
CPPUNIT_TEST_SUITE_END();
};
......@@ -3967,6 +3969,69 @@ ConversationTest::testMessageReaction()
CPPUNIT_ASSERT(messageAliceReceived.rbegin()->at("body") == "👋");
}
void
ConversationTest::testLoadPartiallyRemovedConversation()
{
std::cout << "\nRunning test: " << __func__ << std::endl;
auto aliceAccount = Manager::instance().getAccount<JamiAccount>(aliceId);
auto bobAccount = Manager::instance().getAccount<JamiAccount>(bobId);
auto bobUri = bobAccount->getUsername();
auto aliceUri = aliceAccount->getUsername();
std::map<std::string, std::shared_ptr<libjami::CallbackWrapperBase>> confHandlers;
bool requestReceived = false;
confHandlers.insert(
libjami::exportable_callback<libjami::ConfigurationSignal::IncomingTrustRequest>(
[&](const std::string& account_id,
const std::string& /*from*/,
const std::string& /*conversationId*/,
const std::vector<uint8_t>& /*payload*/,
time_t /*received*/) {
if (account_id == bobId)
requestReceived = true;
cv.notify_one();
}));
std::string convId = "";
confHandlers.insert(libjami::exportable_callback<libjami::ConversationSignal::ConversationReady>(
[&](const std::string& accountId, const std::string& conversationId) {
if (accountId == aliceId) {
convId = conversationId;
}
cv.notify_one();
}));
bool conversationRemoved = false;
confHandlers.insert(
libjami::exportable_callback<libjami::ConversationSignal::ConversationRemoved>(
[&](const std::string& accountId, const std::string&) {
if (accountId == aliceId)
conversationRemoved = true;
cv.notify_one();
}));
libjami::registerSignalHandlers(confHandlers);
aliceAccount->addContact(bobUri);
aliceAccount->sendTrustRequest(bobUri, {});
CPPUNIT_ASSERT(cv.wait_for(lk, 30s, [&]() { return requestReceived; }));
// Copy alice's conversation temporary
auto repoPathAlice = fmt::format("{}/{}/conversations/{}", fileutils::get_data_dir(),
aliceAccount->getAccountID(), convId);
std::filesystem::copy(repoPathAlice, fmt::format("./{}", convId), std::filesystem::copy_options::recursive);
// removeContact
aliceAccount->removeContact(bobUri, false);
CPPUNIT_ASSERT(cv.wait_for(lk, 30s, [&]() { return conversationRemoved; }));
std::this_thread::sleep_for(10s); // Wait for connection to close and async tasks to finish
// Copy back alice's conversation
std::filesystem::copy(fmt::format("./{}", convId), repoPathAlice, std::filesystem::copy_options::recursive);
std::filesystem::remove_all(fmt::format("./{}", convId));
// Reloading conversation should remove directory
CPPUNIT_ASSERT(fileutils::isDirectory(repoPathAlice));
aliceAccount->convModule()->loadConversations();
CPPUNIT_ASSERT(!fileutils::isDirectory(repoPathAlice));
}
} // namespace test
} // namespace jami
......
0% Loading or .
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment