diff options
Diffstat (limited to 'test/components/transport_manager/src/transport_manager_test.cc')
-rw-r--r-- | test/components/transport_manager/src/transport_manager_test.cc | 285 |
1 files changed, 0 insertions, 285 deletions
diff --git a/test/components/transport_manager/src/transport_manager_test.cc b/test/components/transport_manager/src/transport_manager_test.cc deleted file mode 100644 index be31dbdd5..000000000 --- a/test/components/transport_manager/src/transport_manager_test.cc +++ /dev/null @@ -1,285 +0,0 @@ -/* - * Copyright (c) 2013, Ford Motor Company - * All rights reserved. - * - * Redistribution and use in source and binary forms, with or without - * modification, are permitted provided that the following conditions are met: - * - * Redistributions of source code must retain the above copyright notice, this - * list of conditions and the following disclaimer. - * - * Redistributions in binary form must reproduce the above copyright notice, - * this list of conditions and the following - * disclaimer in the documentation and/or other materials provided with the - * distribution. - * - * Neither the name of the Ford Motor Company nor the names of its contributors - * may be used to endorse or promote products derived from this software - * without specific prior written permission. - * - * THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS "AS IS" - * AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE - * IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE - * ARE DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT HOLDER OR CONTRIBUTORS BE - * LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR - * CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF - * SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS - * INTERRUPTION) HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN - * CONTRACT, STRICT LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) - * ARISING IN ANY WAY OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE - * POSSIBILITY OF SUCH DAMAGE. - */ -#include <pthread.h> - -#include <gtest/gtest.h> -#include <gmock/gmock.h> - -#include "protocol/common.h" -#include "transport_manager/info.h" -#include "transport_manager/common.h" -#include "transport_manager/transport_manager_impl.h" - -#include "transport_manager/raw_message_matcher.h" -#include "transport_manager/mock_transport_adapter.h" -#include "transport_manager/mock_device.h" -#include "transport_manager/mock_transport_manager_listener.h" -#include "transport_manager/transport_manager_listener_empty.h" - -using ::testing::_; -using ::testing::AtLeast; - -using ::transport_manager::ApplicationHandle; -using ::transport_manager::DeviceHandle; -using ::transport_manager::TransportManager; -using ::transport_manager::TransportManagerImpl; -using ::transport_manager::DeviceUID; -using ::transport_manager::DeviceInfo; - -namespace test { -namespace components { -namespace transport_manager { - -ACTION_P(SignalTest, test) { - if (test->thread_id != pthread_self()) { - pthread_mutex_lock(&test->test_mutex); - pthread_cond_signal(&test->test_cond); - pthread_mutex_unlock(&test->test_mutex); - } else { - test->one_thread = true; - } -} - -class TransportManagerTest : public ::testing::Test { - public: - volatile bool one_thread; - pthread_t thread_id; - static pthread_mutex_t test_mutex; - static pthread_cond_t test_cond; - int number; - - protected: - static TransportManagerImpl *tm; - static MockTransportAdapter *mock_adapter; - static MockTransportManagerListener *tm_listener; - - static void SetUpTestCase() { - pthread_mutex_init(&test_mutex, NULL); - pthread_cond_init(&test_cond, NULL); - mock_adapter = new MockTransportAdapter(); - mock_adapter->Init(); - //TransportManagerAttr cfg{0}; - tm = new TransportManagerImpl(); - - tm_listener = new MockTransportManagerListener(); - tm->AddEventListener(tm_listener); - tm->AddTransportAdapter(mock_adapter); - tm->Init(); - } - - static void TearDownTestCase() { - tm->Stop(); - delete tm_listener; - pthread_cond_destroy(&test_cond); - pthread_mutex_destroy(&test_mutex); - } - - virtual void SetUp() { - one_thread = false; - thread_id = pthread_self(); - mock_adapter->reset(); - pthread_mutex_lock(&test_mutex); - } - - virtual void TearDown() { pthread_mutex_unlock(&test_mutex); } - - bool waitCond(int seconds) { - if (one_thread) return true; - timespec elapsed; - clock_gettime(CLOCK_REALTIME, &elapsed); - elapsed.tv_sec += seconds; - return pthread_cond_timedwait(&test_cond, &test_mutex, &elapsed) != - ETIMEDOUT; - } -}; - -TransportManagerImpl *TransportManagerTest::tm; - -class MyTransportListener - : public ::transport_manager::TransportManagerListenerEmpty { - public: - explicit MyTransportListener(TransportManagerTest *test) - : TransportManagerListenerEmpty(), - connection(0), - device_handle(0), - test(test) {} - ConnectionUID connection; - DeviceHandle device_handle; - void OnConnectionEstablished(const DeviceInfo &device, - const ConnectionUID &connection_id) { - connection = connection_id; - - pthread_mutex_lock(&test->test_mutex); - pthread_cond_signal(&test->test_cond); - pthread_mutex_unlock(&test->test_mutex); - } - - void OnDeviceFound(const DeviceInfo &device_info) { - device_handle = device_info.device_handle(); - } - - void OnScanDevicesFinished() { - pthread_mutex_lock(&test->test_mutex); - pthread_cond_signal(&test->test_cond); - pthread_mutex_unlock(&test->test_mutex); - } - - void OnTMMessageReceived(const RawMessagePtr message) { - static int count = 0; - if (++count == 100) { - pthread_mutex_lock(&test->test_mutex); - pthread_cond_signal(&test->test_cond); - pthread_mutex_unlock(&test->test_mutex); - } - } - - void OnTMMessageSend(const RawMessagePtr message) { - } - - private: - TransportManagerTest *test; -}; - -pthread_mutex_t TransportManagerTest::test_mutex; -pthread_cond_t TransportManagerTest::test_cond; - -MockTransportAdapter *TransportManagerTest::mock_adapter = NULL; -MockTransportManagerListener *TransportManagerTest::tm_listener = NULL; - -TEST_F(TransportManagerTest, ScanDeviceFailed) { - EXPECT_CALL(*tm_listener, OnDeviceFound(_)).Times(0); - EXPECT_CALL(*tm_listener, OnScanDevicesFailed(_)).Times(1).WillOnce( - SignalTest(this)); - - mock_adapter->get_device_scanner()->fail_further_search(); - tm->SearchDevices(); - EXPECT_TRUE(waitCond(1)); - mock_adapter->get_device_scanner()->reset(); -} - -TEST_F(TransportManagerTest, ScanDeviceNoFound) { - EXPECT_CALL(*tm_listener, OnScanDevicesFailed(_)).Times(0); - EXPECT_CALL(*tm_listener, OnDeviceFound(_)).Times(0); - EXPECT_CALL(*tm_listener, OnScanDevicesFinished()).Times(1).WillOnce( - SignalTest(this)); - - tm->SearchDevices(); - EXPECT_TRUE(waitCond(1)); - mock_adapter->get_device_scanner()->reset(); -} - -TEST_F(TransportManagerTest, ScanDeviceDone) { - EXPECT_CALL(*tm_listener, OnScanDevicesFailed(_)).Times(0); - EXPECT_CALL(*tm_listener, OnDeviceFound(_)).Times(1); - EXPECT_CALL(*tm_listener, OnScanDevicesFinished()).Times(1).WillOnce( - SignalTest(this)); - - mock_adapter->get_device_scanner()->AddDevice("TestDevice", "MA:CA:DR:ES:S"); - tm->SearchDevices(); - EXPECT_TRUE(waitCond(1)); - mock_adapter->get_device_scanner()->reset(); -} - -TEST_F(TransportManagerTest, ScanManyDeviceDone) { - EXPECT_CALL(*tm_listener, OnScanDevicesFailed(_)).Times(0); - EXPECT_CALL(*tm_listener, OnDeviceFound(_)).Times(2); - EXPECT_CALL(*tm_listener, OnScanDevicesFinished()).Times(1).WillOnce( - SignalTest(this)); - mock_adapter->get_device_scanner()->AddDevice("TestDevice1", - "MA:CA:DR:ES:S1"); - mock_adapter->get_device_scanner()->AddDevice("TestDevice2", - "MA:CA:DR:ES:S2"); - tm->SearchDevices(); - EXPECT_TRUE(waitCond(1)); - mock_adapter->get_device_scanner()->reset(); -} - -TEST_F(TransportManagerTest, ConnectDisconnectSendReciveDone) { - const DeviceInfo kInfo(1, "MA:CA:DR:ES:S", "TestDeviceName", "BTMAC"); - const ConnectionUID kConnection = 1; - - EXPECT_CALL(*tm_listener, OnDeviceFound(_)).Times(1); - EXPECT_CALL(*tm_listener, OnScanDevicesFinished()).Times(1); - MyTransportListener *myListener = new MyTransportListener(this); - mock_adapter->get_device_scanner()->AddDevice(kInfo.name(), - kInfo.mac_address()); - tm->AddEventListener(myListener); - tm->SearchDevices(); - EXPECT_TRUE(waitCond(10)); - - EXPECT_CALL(*tm_listener, OnConnectionFailed(_, _)).Times(0); - EXPECT_CALL(*tm_listener, OnConnectionEstablished(kInfo, kConnection)) - .Times(1); - tm->ConnectDevice(kInfo.device_handle()); - EXPECT_TRUE(waitCond(10)); - - const int kTimes = 100; // Times of send message - const unsigned int kVersionProtocol = 1; - EXPECT_CALL(*tm_listener, OnTMMessageSendFailed(_, _)).Times(0); - EXPECT_CALL(*tm_listener, OnTMMessageReceiveFailed(_, _)).Times(0); - EXPECT_CALL(*tm_listener, OnConnectionClosed(kConnection)).Times(0); - // EXPECT_CALL(*tm_listener, OnTMMessageSend()).Times(kTimes); // FIXME - // (dchmerev@luxoft.com): make proper expect_call - EXPECT_CALL(*tm_listener, OnTMMessageReceived(_)).Times(kTimes); - - const unsigned int kSize = 12; - unsigned char data[kSize] = {0x20, 0x07, 0x01, 0x00, 0x00, 0x00, - 0x00, 0x00, 0x00, 0x00, 0x00, 0x00}; - for (int i = 0; i < kTimes; ++i) { - const RawMessagePtr kMessage = - new RawMessage(kConnection, kVersionProtocol, data, kSize); - tm->SendMessageToDevice(kMessage); - usleep(1000); - } - EXPECT_TRUE(waitCond(10)); - - EXPECT_CALL(*tm_listener, OnConnectionClosedFailure(_, _)).Times(0); - EXPECT_CALL(*tm_listener, OnDisconnectFailed(kInfo.device_handle(), _)) - .Times(0); - EXPECT_CALL(*tm_listener, OnConnectionClosed(kConnection)).Times(1).WillOnce( - SignalTest(this)); - tm->DisconnectDevice(kInfo.device_handle()); - EXPECT_TRUE(waitCond(10)); - - tm->Stop(); - delete myListener; - mock_adapter->get_device_scanner()->reset(); -} - -} // namespace transport_manager -} // namespace components -} // namespace test - -int main(int argc, char **argv) { - testing::InitGoogleTest(&argc, argv); - return RUN_ALL_TESTS(); -} |