diff options
author | Ted Gould <ted@gould.cx> | 2015-02-27 22:36:07 +0000 |
---|---|---|
committer | CI Train Bot <ci-train-bot@canonical.com> | 2015-02-27 22:36:07 +0000 |
commit | dff67f240ebfc9fe842383d612948597517d3c83 (patch) | |
tree | 5809fda6f584e7875e863b16c04c8e86a0aeb1a7 /tests | |
parent | a18d5b7b0a4389042af832e5397e1fd731ec7479 (diff) | |
parent | a053aad96cef8673b3be3300825485a511af7d23 (diff) | |
download | ayatana-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.cc | 42 |
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"]); +} + |