diff options
author | Ted Gould <ted@gould.cx> | 2015-02-09 15:25:54 -0600 |
---|---|---|
committer | Ted Gould <ted@gould.cx> | 2015-02-09 15:25:54 -0600 |
commit | 6808a4cb98497c61e3d6a202f94f09469f7a20a2 (patch) | |
tree | 02e618eea49930aa6017d472755efa5d4d6b4290 | |
parent | ea846294e73c242b6574085533a9899a585eecf9 (diff) | |
download | ayatana-indicator-sound-6808a4cb98497c61e3d6a202f94f09469f7a20a2.tar.gz ayatana-indicator-sound-6808a4cb98497c61e3d6a202f94f09469f7a20a2.tar.bz2 ayatana-indicator-sound-6808a4cb98497c61e3d6a202f94f09469f7a20a2.zip |
Creating a skeleton to start testing
-rw-r--r-- | tests/CMakeLists.txt | 21 | ||||
-rw-r--r-- | tests/notifications-mock.h | 2 | ||||
-rw-r--r-- | tests/notifications-test.cc | 91 |
3 files changed, 114 insertions, 0 deletions
diff --git a/tests/CMakeLists.txt b/tests/CMakeLists.txt index 38a76ae..f6f8644 100644 --- a/tests/CMakeLists.txt +++ b/tests/CMakeLists.txt @@ -65,6 +65,10 @@ vala_add(vala-mocks media-player-mock.vala ) +vala_add(vala-mocks + volume-control-mock.vala +) + vala_finish(vala-mocks SOURCES vala_mocks_VALA_SOURCES @@ -184,6 +188,23 @@ target_link_libraries ( add_test(sound-menu-test sound-menu-test) ########################### +# Notification Test +########################### + +include_directories(${CMAKE_SOURCE_DIR}/src) +add_executable (notifications-test notifications-test.cc) +target_link_libraries ( + notifications-test + indicator-sound-service-lib + vala-mocks-lib + gtest + ${SOUNDSERVICE_LIBRARIES} + ${TEST_LIBRARIES} +) + +add_test(notifications-test notifications-test) + +########################### # Accounts Service User ########################### diff --git a/tests/notifications-mock.h b/tests/notifications-mock.h index 6abe9d8..0298f8c 100644 --- a/tests/notifications-mock.h +++ b/tests/notifications-mock.h @@ -16,6 +16,8 @@ * Authors: * Ted Gould <ted@canonical.com> */ + +#include <algorithm> #include <map> #include <memory> #include <type_traits> diff --git a/tests/notifications-test.cc b/tests/notifications-test.cc new file mode 100644 index 0000000..05a5da5 --- /dev/null +++ b/tests/notifications-test.cc @@ -0,0 +1,91 @@ +/* + * Copyright © 2015 Canonical Ltd. + * + * This program is free software; you can redistribute it and/or modify + * it under the terms of the GNU General Public License as published by + * the Free Software Foundation; version 3. + * + * This program 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 General Public License for more details. + * + * You should have received a copy of the GNU General Public License + * along with this program. If not, see <http://www.gnu.org/licenses/>. + * + * Authors: + * Ted Gould <ted@canonical.com> + */ + +#include <gtest/gtest.h> +#include <gio/gio.h> +#include <libdbustest/dbus-test.h> + +#include "notifications-mock.h" + +extern "C" { +#include "indicator-sound-service.h" +#include "vala-mocks.h" +} + +class NotificationsTest : public ::testing::Test +{ + protected: + DbusTestService * service = NULL; + DbusTestDbusMock * mock = NULL; + + GDBusConnection * session = NULL; + std::shared_ptr<NotificationsMock> notifications; + + virtual void SetUp() { + service = dbus_test_service_new(NULL); + dbus_test_service_set_bus(service, DBUS_TEST_SERVICE_BUS_BOTH); + + notifications = std::make_shared<NotificationsMock>(); + + dbus_test_service_add_task(service, (DbusTestTask*)*notifications); + dbus_test_service_start_tasks(service); + + session = g_bus_get_sync(G_BUS_TYPE_SESSION, NULL, NULL); + ASSERT_NE(nullptr, session); + g_dbus_connection_set_exit_on_close(session, FALSE); + g_object_add_weak_pointer(G_OBJECT(session), (gpointer *)&session); + } + + virtual void TearDown() { + g_clear_object(&mock); + g_clear_object(&service); + + g_object_unref(session); + + unsigned int cleartry = 0; + while (session != NULL && cleartry < 100) { + loop(100); + cleartry++; + } + + ASSERT_EQ(nullptr, session); + } + + static gboolean timeout_cb (gpointer user_data) { + GMainLoop * loop = static_cast<GMainLoop *>(user_data); + g_main_loop_quit(loop); + return G_SOURCE_REMOVE; + } + + void loop (unsigned int ms) { + GMainLoop * loop = g_main_loop_new(NULL, FALSE); + g_timeout_add(ms, timeout_cb, loop); + g_main_loop_run(loop); + g_main_loop_unref(loop); + } + + static int unref_idle (gpointer user_data) { + g_variant_unref(static_cast<GVariant *>(user_data)); + return G_SOURCE_REMOVE; + } +}; + +TEST_F(NotificationsTest, BasicObject) { + +} |