2020-07-18 20:16:57 +02:00
|
|
|
/**
|
2022-07-05 17:08:35 +02:00
|
|
|
* (C) 2016 - 2021 KISTLER INSTRUMENTE AG, Winterthur, Switzerland
|
|
|
|
|
* (C) 2016 - 2022 Stanislav Angelovic <stanislav.angelovic@protonmail.com>
|
2020-07-18 20:16:57 +02:00
|
|
|
*
|
|
|
|
|
* @file DBusGeneralTests.cpp
|
|
|
|
|
*
|
|
|
|
|
* Created on: Jan 2, 2017
|
|
|
|
|
* Project: sdbus-c++
|
|
|
|
|
* Description: High-level D-Bus IPC C++ library based on sd-bus
|
|
|
|
|
*
|
|
|
|
|
* This file is part of sdbus-c++.
|
|
|
|
|
*
|
|
|
|
|
* sdbus-c++ is free software; you can redistribute it and/or modify it
|
|
|
|
|
* under the terms of the GNU Lesser General Public License as published by
|
|
|
|
|
* the Free Software Foundation, either version 2.1 of the License, or
|
|
|
|
|
* (at your option) any later version.
|
|
|
|
|
*
|
|
|
|
|
* sdbus-c++ is distributed in the hope that it will be useful,
|
|
|
|
|
* but WITHOUT ANY WARRANTY; without even the implied warranty of
|
|
|
|
|
* MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
|
|
|
|
|
* GNU Lesser General Public License for more details.
|
|
|
|
|
*
|
|
|
|
|
* You should have received a copy of the GNU Lesser General Public License
|
|
|
|
|
* along with sdbus-c++. If not, see <http://www.gnu.org/licenses/>.
|
|
|
|
|
*/
|
|
|
|
|
|
|
|
|
|
#include "TestAdaptor.h"
|
|
|
|
|
#include "TestProxy.h"
|
2022-06-17 23:04:07 +02:00
|
|
|
#include "TestFixture.h"
|
2020-07-18 20:16:57 +02:00
|
|
|
#include "sdbus-c++/sdbus-c++.h"
|
|
|
|
|
|
|
|
|
|
#include <gtest/gtest.h>
|
|
|
|
|
#include <gmock/gmock.h>
|
|
|
|
|
#include <string>
|
|
|
|
|
#include <thread>
|
|
|
|
|
#include <tuple>
|
|
|
|
|
#include <chrono>
|
|
|
|
|
#include <fstream>
|
|
|
|
|
#include <future>
|
|
|
|
|
#include <unistd.h>
|
|
|
|
|
|
2022-06-17 23:04:07 +02:00
|
|
|
using ::testing::ElementsAre;
|
|
|
|
|
using ::testing::Eq;
|
|
|
|
|
using namespace std::chrono_literals;
|
2020-07-18 20:16:57 +02:00
|
|
|
using namespace sdbus::test;
|
|
|
|
|
|
2022-06-17 23:04:07 +02:00
|
|
|
using AConnection = TestFixture;
|
|
|
|
|
|
2020-07-18 20:16:57 +02:00
|
|
|
/*-------------------------------------*/
|
|
|
|
|
/* -- TEST CASES -- */
|
|
|
|
|
/*-------------------------------------*/
|
|
|
|
|
|
|
|
|
|
TEST(AdaptorAndProxy, CanBeConstructedSuccesfully)
|
|
|
|
|
{
|
|
|
|
|
auto connection = sdbus::createConnection();
|
2021-10-14 16:08:38 +02:00
|
|
|
connection->requestName(BUS_NAME);
|
2020-07-18 20:16:57 +02:00
|
|
|
|
2021-10-14 15:53:51 +02:00
|
|
|
ASSERT_NO_THROW(TestAdaptor adaptor(*connection, OBJECT_PATH));
|
2021-10-14 16:08:38 +02:00
|
|
|
ASSERT_NO_THROW(TestProxy proxy(BUS_NAME, OBJECT_PATH));
|
2020-07-18 20:16:57 +02:00
|
|
|
}
|
2022-06-17 23:04:07 +02:00
|
|
|
|
|
|
|
|
TEST_F(AConnection, WillCallCallbackHandlerForIncomingMessageMatchingMatchRule)
|
|
|
|
|
{
|
|
|
|
|
auto matchRule = "sender='" + BUS_NAME + "',path='" + OBJECT_PATH + "'";
|
|
|
|
|
std::atomic<bool> matchingMessageReceived{false};
|
|
|
|
|
auto slot = s_proxyConnection->addMatch(matchRule, [&](sdbus::Message& msg)
|
|
|
|
|
{
|
|
|
|
|
if(msg.getPath() == OBJECT_PATH)
|
|
|
|
|
matchingMessageReceived = true;
|
|
|
|
|
});
|
|
|
|
|
|
|
|
|
|
m_adaptor->emitSimpleSignal();
|
|
|
|
|
|
|
|
|
|
ASSERT_TRUE(waitUntil(matchingMessageReceived));
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
TEST_F(AConnection, WillUnsubscribeMatchRuleWhenClientDestroysTheAssociatedSlot)
|
|
|
|
|
{
|
|
|
|
|
auto matchRule = "sender='" + BUS_NAME + "',path='" + OBJECT_PATH + "'";
|
|
|
|
|
std::atomic<bool> matchingMessageReceived{false};
|
|
|
|
|
auto slot = s_proxyConnection->addMatch(matchRule, [&](sdbus::Message& msg)
|
|
|
|
|
{
|
|
|
|
|
if(msg.getPath() == OBJECT_PATH)
|
|
|
|
|
matchingMessageReceived = true;
|
|
|
|
|
});
|
|
|
|
|
slot.reset();
|
|
|
|
|
|
|
|
|
|
m_adaptor->emitSimpleSignal();
|
|
|
|
|
|
|
|
|
|
ASSERT_FALSE(waitUntil(matchingMessageReceived, 2s));
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
TEST_F(AConnection, CanAddFloatingMatchRule)
|
|
|
|
|
{
|
|
|
|
|
auto matchRule = "sender='" + BUS_NAME + "',path='" + OBJECT_PATH + "'";
|
|
|
|
|
std::atomic<bool> matchingMessageReceived{false};
|
|
|
|
|
auto con = sdbus::createSystemBusConnection();
|
|
|
|
|
con->enterEventLoopAsync();
|
|
|
|
|
auto callback = [&](sdbus::Message& msg)
|
|
|
|
|
{
|
|
|
|
|
if(msg.getPath() == OBJECT_PATH)
|
|
|
|
|
matchingMessageReceived = true;
|
|
|
|
|
};
|
|
|
|
|
con->addMatch(matchRule, std::move(callback), sdbus::floating_slot);
|
|
|
|
|
m_adaptor->emitSimpleSignal();
|
|
|
|
|
assert(waitUntil(matchingMessageReceived, 2s));
|
|
|
|
|
matchingMessageReceived = false;
|
|
|
|
|
|
|
|
|
|
con.reset();
|
|
|
|
|
m_adaptor->emitSimpleSignal();
|
|
|
|
|
|
|
|
|
|
ASSERT_FALSE(waitUntil(matchingMessageReceived, 2s));
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
TEST_F(AConnection, WillNotPassToMatchCallbackMessagesThatDoNotMatchTheRule)
|
|
|
|
|
{
|
|
|
|
|
auto matchRule = "type='signal',interface='" + INTERFACE_NAME + "',member='simpleSignal'";
|
|
|
|
|
std::atomic<size_t> numberOfMatchingMessages{};
|
|
|
|
|
auto slot = s_proxyConnection->addMatch(matchRule, [&](sdbus::Message& msg)
|
|
|
|
|
{
|
|
|
|
|
if(msg.getMemberName() == "simpleSignal")
|
|
|
|
|
numberOfMatchingMessages++;
|
|
|
|
|
});
|
|
|
|
|
auto adaptor2 = std::make_unique<TestAdaptor>(*s_adaptorConnection, OBJECT_PATH_2);
|
|
|
|
|
|
|
|
|
|
m_adaptor->emitSignalWithMap({});
|
|
|
|
|
adaptor2->emitSimpleSignal();
|
|
|
|
|
m_adaptor->emitSimpleSignal();
|
|
|
|
|
|
|
|
|
|
ASSERT_TRUE(waitUntil([&](){ return numberOfMatchingMessages == 2; }));
|
|
|
|
|
ASSERT_FALSE(waitUntil([&](){ return numberOfMatchingMessages > 2; }, 1s));
|
|
|
|
|
}
|