Skip to content

Commit

Permalink
MtQ: giveup integrate with dom
Browse files Browse the repository at this point in the history
  • Loading branch information
fchn289 committed Oct 6, 2024
1 parent 264a217 commit 639d1fb
Show file tree
Hide file tree
Showing 4 changed files with 7 additions and 117 deletions.
24 changes: 1 addition & 23 deletions src/thread/MtInQueue.cpp
Original file line number Diff line number Diff line change
Expand Up @@ -44,13 +44,6 @@ deque<ELE_TID>::iterator MtInQueue::begin_()
return cache_.begin();
}

// ***********************************************************************************************
void MtInQueue::clearHdlrPool()
{
tid_hdlr_S_.clear();
setHdlrOK();
}

// ***********************************************************************************************
size_t MtInQueue::handleCacheEle_()
{
Expand All @@ -63,7 +56,7 @@ size_t MtInQueue::handleCacheEle_()
auto&& id_hdlr = tid_hdlr_S_.find(ele_tid.second);
if (id_hdlr == tid_hdlr_S_.end())
{
defaultHdlr_(ele_tid);
WRN("(MtQ) discard 1 ele(=" << ele_tid.second.name() << ") since no handler.");
continue;
}
id_hdlr->second(ele_tid.first);
Expand Down Expand Up @@ -129,21 +122,6 @@ ELE_TID MtInQueue::pop()
return ele_tid;
}

// ***********************************************************************************************
bool MtInQueue::setHdlrOK(const DftHdlr& aHdlr)
{
if (aHdlr)
{
defaultHdlr_ = aHdlr;
return true;
}
else
{
WRN("(MtQ) why set null hdlr?");
return false;
}
}

// ***********************************************************************************************
MtInQueue& mt_getQ()
{
Expand Down
13 changes: 3 additions & 10 deletions src/thread/MtInQueue.hpp
Original file line number Diff line number Diff line change
Expand Up @@ -39,14 +39,12 @@ namespace rlib
// - ele & its type_index(==/!= ok, but type_info* & hash_code nok)
// - shared_ptr is safe to cast void since type_index (but not safe as SafePtr's create)
using ELE_TID = std::pair<UniPtr, std::type_index>;
using EleHdlr = std::function<void(UniPtr)>; // NO exception allowed
using DftHdlr = std::function<void(ELE_TID&)>; // NO exception allowed
using EleHdlr = std::function<void(UniPtr)>; // NO exception allowed

// ***********************************************************************************************
class MtInQueue
{
public:
MtInQueue() { setHdlrOK(); }
~MtInQueue();

// aEle may not mt-safe, so here mv
Expand All @@ -62,13 +60,9 @@ class MtInQueue

// shall be called in main thread ONLY!!!
template<class aEleType> bool setHdlrOK(const EleHdlr&);
bool setHdlrOK(const DftHdlr& aHdlr = [](ELE_TID& aEle_tid)
{
WRN("(MtQ) discard 1 ele(=" << aEle_tid.second.name() << ") since no handler");
});
size_t handleAllEle();
auto nHdlr() const { return tid_hdlr_S_.size(); }
void clearHdlrPool();
void clearHdlrPool() { tid_hdlr_S_.clear(); }

private:
std::deque<ELE_TID>::iterator begin_();
Expand All @@ -80,7 +74,6 @@ class MtInQueue
std::mutex mutex_;

std::unordered_map<std::type_index, EleHdlr> tid_hdlr_S_;
DftHdlr defaultHdlr_;

// -------------------------------------------------------------------------------------------
#ifdef IN_GTEST
Expand Down Expand Up @@ -179,5 +172,5 @@ MtInQueue& mt_getQ();
// 2023-10-29 CSZ - integrate handler
// 2024-02-15 CSZ 3)use SafePtr (mem-safe); shared_ptr is not mem-safe
// 2024-03-10 CSZ - enhance safe of setHdlrOK()
// 2024-10-05 CSZ - integrate with domino
// 2024-10-05 CSZ - integrate with domino (giveup since multi-same-type)
// ***********************************************************************************************
32 changes: 0 additions & 32 deletions src/thread/MtInQueueWithDom.hpp

This file was deleted.

55 changes: 3 additions & 52 deletions ut/thread/MtInQueueTest.cpp
Original file line number Diff line number Diff line change
Expand Up @@ -4,7 +4,6 @@
* SPDX-License-Identifier: BSD-3-Clause
*/
// ***********************************************************************************************
#include <functional>
#include <future>
#include <gtest/gtest.h>
#include <queue>
Expand All @@ -14,19 +13,12 @@
#include "MT_Semaphore.hpp"
#include "UniLog.hpp"

#include "Domino.hpp"
#include "DataDomino.hpp"
#include "HdlrDomino.hpp"
using Dom = rlib::DataDomino<rlib::HdlrDomino<rlib::Domino>>;
#define DAT_DOM (rlib::ObjAnywhere::getObj<Dom>())

#define IN_GTEST
#include "MT_PingMainTH.hpp"
#include "MtInQueueWithDom.hpp"
#include "MtInQueue.hpp"
#undef IN_GTEST

using namespace std;
using namespace std::placeholders;
using namespace testing;

namespace rlib
Expand All @@ -36,14 +28,11 @@ struct MtInQueueTest : public Test, public UniLog
{
MtInQueueTest()
: UniLog(UnitTest::GetInstance()->current_test_info()->name())
{
ObjAnywhere::init();
}
{}
~MtInQueueTest()
{
mt_getQ().mt_clearElePool(); // not impact other testcase
mt_getQ().clearHdlrPool(); // not impact other testcase
ObjAnywhere::deinit();
GTEST_LOG_FAIL
}
};
Expand Down Expand Up @@ -298,51 +287,13 @@ TEST_F(MtInQueueTest, handle_via_base)
mt_getQ().handleAllEle();
EXPECT_EQ(0u, mt_getQ().mt_size(true)) << "req: Base & Derive are handled correctly";
}

#define DEFAULT_HDLR
// ***********************************************************************************************
TEST_F(MtInQueueTest, noHdlrEle_default)
TEST_F(MtInQueueTest, noHdlrEle_discard)
{
mt_getQ().mt_push<int>(MAKE_PTR<int>(1));
EXPECT_EQ(1u, mt_getQ().mt_size(true));

mt_getQ().handleAllEle();
EXPECT_EQ(0u, mt_getQ().mt_size(true)) << "REQ: discard ele w/o hdlr - simple & no leak/crash";
}
TEST_F(MtInQueueTest, noHdlrEle_setInvalidDefaultHdlr)
{
EXPECT_FALSE(mt_getQ().setHdlrOK(nullptr));

mt_getQ().mt_push<int>(MAKE_PTR<int>(1));
EXPECT_EQ(1u, mt_getQ().mt_size(true));
mt_getQ().handleAllEle();
EXPECT_EQ(0u, mt_getQ().mt_size(true)) << "REQ: discard ele w/o hdlr - simple & no leak/crash";
}
TEST_F(MtInQueueTest, GOLD_noHdlrEle_setDefaultHdlr)
{
// domino
auto msgSelf = make_safe<MsgSelf>();
ObjAnywhere::emplaceObjOK(msgSelf);
ObjAnywhere::emplaceObjOK(make_safe<Dom>());
const auto en = string(EN_MTQ) + 'i';
bool isCalled = false;
DAT_DOM->setHdlr(en, [&isCalled]{ isCalled = true; });

// MtQ:
EXPECT_TRUE(mt_getQ().setHdlrOK(bind(&defaultHdlr, _1)));
mt_getQ().mt_push<int>(MAKE_PTR<int>(1));
mt_getQ().handleAllEle();
EXPECT_EQ(1, *dynamic_pointer_cast<int>(DAT_DOM->getData(en)).get())
<< "REQ: new MtQ default hdlr works";
msgSelf->handleAllMsg();
EXPECT_TRUE(isCalled) << "REQ: domino hdlr called";

mt_getQ().clearHdlrPool(); // reset default hdlr
isCalled = false;
mt_getQ().mt_push<int>(MAKE_PTR<int>(1));
mt_getQ().handleAllEle();
msgSelf->handleAllMsg();
EXPECT_FALSE(isCalled) << "REQ: domino hdlr NOT called";
}

} // namespace

0 comments on commit 639d1fb

Please sign in to comment.