aboutsummaryrefslogtreecommitdiff
path: root/tests
diff options
context:
space:
mode:
authorTed Gould <ted@gould.cx>2015-02-27 22:36:07 +0000
committerCI Train Bot <ci-train-bot@canonical.com>2015-02-27 22:36:07 +0000
commitdff67f240ebfc9fe842383d612948597517d3c83 (patch)
tree5809fda6f584e7875e863b16c04c8e86a0aeb1a7 /tests
parenta18d5b7b0a4389042af832e5397e1fd731ec7479 (diff)
parenta053aad96cef8673b3be3300825485a511af7d23 (diff)
downloadayatana-indicator-sound-dff67f240ebfc9fe842383d612948597517d3c83.tar.gz
ayatana-indicator-sound-dff67f240ebfc9fe842383d612948597517d3c83.tar.bz2
ayatana-indicator-sound-dff67f240ebfc9fe842383d612948597517d3c83.zip
Use max volume in calculating notification value Fixes: #1422745
Approved by: Charles Kerr, PS Jenkins bot
Diffstat (limited to 'tests')
-rw-r--r--tests/notifications-test.cc42
1 files changed, 42 insertions, 0 deletions
diff --git a/tests/notifications-test.cc b/tests/notifications-test.cc
index 88ed6c6..21a9312 100644
--- a/tests/notifications-test.cc
+++ b/tests/notifications-test.cc
@@ -356,3 +356,45 @@ TEST_F(NotificationsTest, HighVolume) {
EXPECT_EQ("High volume", notev[0].body);
EXPECT_GVARIANT_EQ("@s 'true'", notev[0].hints["x-canonical-value-bar-tint"]);
}
+
+TEST_F(NotificationsTest, ExtendendVolumeNotification) {
+ auto volumeControl = volumeControlMock();
+ auto soundService = standardService(volumeControl, playerListMock());
+
+ /* Set a volume */
+ notifications->clearNotifications();
+ setMockVolume(volumeControl, 0.50);
+ loop(50);
+ auto notev = notifications->getNotifications();
+ ASSERT_EQ(1, notev.size());
+ EXPECT_EQ("indicator-sound", notev[0].app_name);
+ EXPECT_EQ("Volume", notev[0].summary);
+ EXPECT_EQ(0, notev[0].actions.size());
+ EXPECT_GVARIANT_EQ("@s 'true'", notev[0].hints["x-canonical-private-synchronous"]);
+ EXPECT_GVARIANT_EQ("@i 50", notev[0].hints["value"]);
+
+ /* Allow an amplified volume */
+ notifications->clearNotifications();
+ indicator_sound_service_set_allow_amplified_volume(soundService.get(), TRUE);
+ loop(50);
+ notev = notifications->getNotifications();
+ ASSERT_EQ(1, notev.size());
+ EXPECT_GVARIANT_EQ("@i 33", notev[0].hints["value"]);
+
+ /* Set to 'over max' */
+ notifications->clearNotifications();
+ setMockVolume(volumeControl, 1.525);
+ loop(50);
+ notev = notifications->getNotifications();
+ ASSERT_EQ(1, notev.size());
+ EXPECT_GVARIANT_EQ("@i 100", notev[0].hints["value"]);
+
+ /* Put back */
+ notifications->clearNotifications();
+ indicator_sound_service_set_allow_amplified_volume(soundService.get(), FALSE);
+ loop(50);
+ notev = notifications->getNotifications();
+ ASSERT_EQ(1, notev.size());
+ EXPECT_GVARIANT_EQ("@i 100", notev[0].hints["value"]);
+}
+