aboutsummaryrefslogtreecommitdiff
path: root/tests
diff options
context:
space:
mode:
Diffstat (limited to 'tests')
-rw-r--r--tests/notifications-test.cc59
1 files changed, 59 insertions, 0 deletions
diff --git a/tests/notifications-test.cc b/tests/notifications-test.cc
index f7f4876..7f8d49a 100644
--- a/tests/notifications-test.cc
+++ b/tests/notifications-test.cc
@@ -486,3 +486,62 @@ TEST_F(NotificationsTest, ExtendendVolumeNotification) {
ASSERT_EQ(1, notev.size());
EXPECT_GVARIANT_EQ("@i 100", notev[0].hints["value"]);
}
+
+TEST_F(NotificationsTest, WarningRequiresHeadphones) {
+
+ const std::set<VolumeControlActiveOutput> headphones {
+ VOLUME_CONTROL_ACTIVE_OUTPUT_HEADPHONES,
+ VOLUME_CONTROL_ACTIVE_OUTPUT_BLUETOOTH_HEADPHONES,
+ VOLUME_CONTROL_ACTIVE_OUTPUT_USB_HEADPHONES,
+ VOLUME_CONTROL_ACTIVE_OUTPUT_HDMI_HEADPHONES
+ };
+
+ const std::set<VolumeControlActiveOutput> all_outputs {
+ VOLUME_CONTROL_ACTIVE_OUTPUT_SPEAKERS,
+ VOLUME_CONTROL_ACTIVE_OUTPUT_HEADPHONES,
+ VOLUME_CONTROL_ACTIVE_OUTPUT_BLUETOOTH_HEADPHONES,
+ VOLUME_CONTROL_ACTIVE_OUTPUT_BLUETOOTH_SPEAKER,
+ VOLUME_CONTROL_ACTIVE_OUTPUT_USB_SPEAKER,
+ VOLUME_CONTROL_ACTIVE_OUTPUT_USB_HEADPHONES,
+ VOLUME_CONTROL_ACTIVE_OUTPUT_HDMI_SPEAKER,
+ VOLUME_CONTROL_ACTIVE_OUTPUT_HDMI_HEADPHONES,
+ VOLUME_CONTROL_ACTIVE_OUTPUT_CALL_MODE
+ };
+
+ for(const auto& output : all_outputs)
+ {
+ // instantiate the test subjects
+ auto options = optionsMock();
+ auto volumeControl = volumeControlMock(options);
+ auto volumeWarning = volumeWarningMock(options);
+ auto soundService = standardService(volumeControl, playerListMock(), options, volumeWarning);
+
+ // prime them for a volume warning
+ const pa_volume_t volume = 100;
+ options_mock_mock_set_loud_volume(OPTIONS_MOCK(options.get()), volume);
+ options_mock_mock_set_loud_warning_enabled(OPTIONS_MOCK(options.get()), true);
+ volume_warning_mock_set_high_volume_approved(VOLUME_WARNING_MOCK(volumeWarning.get()), false);
+ volume_warning_mock_set_multimedia_volume(VOLUME_WARNING_MOCK(volumeWarning.get()), volume);
+ volume_warning_mock_set_multimedia_active(VOLUME_WARNING_MOCK(volumeWarning.get()), true);
+
+ // cycle through the different outputs
+ notifications->clearNotifications();
+ volume_control_mock_mock_set_active_output(VOLUME_CONTROL_MOCK(volumeControl.get()), output);
+ loop(50);
+
+ auto notev = notifications->getNotifications();
+ if (headphones.count(output)) {
+ EXPECT_TRUE(volume_warning_get_active(volumeWarning.get()));
+ ASSERT_EQ(1, notev.size());
+ EXPECT_GVARIANT_EQ("@s 'true'", notev[0].hints["x-canonical-snap-decisions"]);
+ EXPECT_GVARIANT_EQ(nullptr, notev[0].hints["x-canonical-private-synchronous"]);
+ }
+ else {
+ EXPECT_FALSE(volume_warning_get_active(volumeWarning.get()));
+ ASSERT_EQ(1, notev.size());
+ EXPECT_GVARIANT_EQ(nullptr, notev[0].hints["x-canonical-snap-decisions"]);
+ EXPECT_GVARIANT_EQ("@s 'true'", notev[0].hints["x-canonical-private-synchronous"]);
+ }
+ }
+}
+