blob: 65796364732f23a77487230b8e4c643b32c8c528 [file] [log] [blame]
// Copyright 2013 The Chromium Authors. All rights reserved.
// Use of this source code is governed by a BSD-style license that can be
// found in the LICENSE file.
#include "base/file_util.h"
#include "base/path_service.h"
#include "base/strings/stringprintf.h"
#include "chrome/browser/chrome_notification_types.h"
#include "chrome/browser/content_settings/host_content_settings_map.h"
#include "chrome/browser/infobars/infobar.h"
#include "chrome/browser/infobars/infobar_service.h"
#include "chrome/browser/media/webrtc_browsertest_base.h"
#include "chrome/browser/media/webrtc_browsertest_common.h"
#include "chrome/browser/profiles/profile.h"
#include "chrome/browser/ui/browser.h"
#include "chrome/browser/ui/browser_tabstrip.h"
#include "chrome/browser/ui/tabs/tab_strip_model.h"
#include "chrome/common/chrome_switches.h"
#include "chrome/common/content_settings_types.h"
#include "chrome/test/base/in_process_browser_test.h"
#include "chrome/test/base/ui_test_utils.h"
#include "chrome/test/ui/ui_test.h"
#include "content/public/browser/notification_service.h"
#include "content/public/test/browser_test_utils.h"
#include "net/test/spawned_test_server/spawned_test_server.h"
#if defined(OS_WIN) && defined(USE_ASH)
#include "base/win/windows_version.h"
#endif
static const char kMainWebrtcTestHtmlPage[] =
"files/webrtc/webrtc_jsep01_test.html";
// Media stream infobar test for WebRTC.
class MediaStreamInfobarTest : public WebRtcTestBase {
public:
virtual void SetUpCommandLine(CommandLine* command_line) OVERRIDE {
// This test expects to run with fake devices but real UI.
command_line->AppendSwitch(switches::kUseFakeDeviceForMediaStream);
EXPECT_FALSE(command_line->HasSwitch(switches::kUseFakeUIForMediaStream))
<< "Since this test tests the UI we want the real UI!";
}
protected:
content::WebContents* LoadTestPageInTab() {
EXPECT_TRUE(test_server()->Start());
ui_test_utils::NavigateToURL(
browser(), test_server()->GetURL(kMainWebrtcTestHtmlPage));
return browser()->tab_strip_model()->GetActiveWebContents();
}
};
IN_PROC_BROWSER_TEST_F(MediaStreamInfobarTest, TestAllowingUserMedia) {
content::WebContents* tab_contents = LoadTestPageInTab();
GetUserMediaAndAccept(tab_contents);
}
IN_PROC_BROWSER_TEST_F(MediaStreamInfobarTest, TestDenyingUserMedia) {
content::WebContents* tab_contents = LoadTestPageInTab();
GetUserMediaAndDeny(tab_contents);
}
IN_PROC_BROWSER_TEST_F(MediaStreamInfobarTest, TestDismissingInfobar) {
content::WebContents* tab_contents = LoadTestPageInTab();
GetUserMediaAndDismiss(tab_contents);
}
IN_PROC_BROWSER_TEST_F(MediaStreamInfobarTest,
TestAcceptThenDenyWhichShouldBeSticky) {
#if defined(OS_WIN) && defined(USE_ASH)
// Disable this test in Metro+Ash for now (http://crbug.com/262796).
if (base::win::GetVersion() >= base::win::VERSION_WIN8)
return;
#endif
content::WebContents* tab_contents = LoadTestPageInTab();
GetUserMediaAndAccept(tab_contents);
GetUserMediaAndDeny(tab_contents);
// Should fail with permission denied right away with no infobar popping up.
GetUserMedia(tab_contents, kAudioVideoCallConstraints);
EXPECT_TRUE(PollingWaitUntil("obtainGetUserMediaResult()",
kFailedWithErrorPermissionDenied,
tab_contents));
InfoBarService* infobar_service =
InfoBarService::FromWebContents(tab_contents);
EXPECT_EQ(0u, infobar_service->infobar_count());
}
IN_PROC_BROWSER_TEST_F(MediaStreamInfobarTest, TestAcceptIsNotSticky) {
content::WebContents* tab_contents = LoadTestPageInTab();
// If accept were sticky the second call would hang because it hangs if an
// infobar does not pop up.
GetUserMediaAndAccept(tab_contents);
GetUserMediaAndAccept(tab_contents);
}
IN_PROC_BROWSER_TEST_F(MediaStreamInfobarTest, TestDismissIsNotSticky) {
content::WebContents* tab_contents = LoadTestPageInTab();
// If dismiss were sticky the second call would hang because it hangs if an
// infobar does not pop up.
GetUserMediaAndDismiss(tab_contents);
GetUserMediaAndDismiss(tab_contents);
}
IN_PROC_BROWSER_TEST_F(MediaStreamInfobarTest,
TestDenyingThenClearingStickyException) {
content::WebContents* tab_contents = LoadTestPageInTab();
GetUserMediaAndDeny(tab_contents);
HostContentSettingsMap* settings_map =
browser()->profile()->GetHostContentSettingsMap();
settings_map->ClearSettingsForOneType(
CONTENT_SETTINGS_TYPE_MEDIASTREAM_MIC);
settings_map->ClearSettingsForOneType(
CONTENT_SETTINGS_TYPE_MEDIASTREAM_CAMERA);
// If an infobar is not launched now, this will hang.
GetUserMediaAndDeny(tab_contents);
}
IN_PROC_BROWSER_TEST_F(MediaStreamInfobarTest,
DenyingMicDoesNotCauseStickyDenyForCameras) {
content::WebContents* tab_contents = LoadTestPageInTab();
// If mic blocking also blocked cameras, the second call here would hang.
GetUserMediaWithSpecificConstraintsAndDeny(tab_contents,
kAudioOnlyCallConstraints);
GetUserMediaWithSpecificConstraintsAndAccept(tab_contents,
kVideoOnlyCallConstraints);
}
IN_PROC_BROWSER_TEST_F(MediaStreamInfobarTest,
DenyingCameraDoesNotCauseStickyDenyForMics) {
content::WebContents* tab_contents = LoadTestPageInTab();
// If camera blocking also blocked mics, the second call here would hang.
GetUserMediaWithSpecificConstraintsAndDeny(tab_contents,
kVideoOnlyCallConstraints);
GetUserMediaWithSpecificConstraintsAndAccept(tab_contents,
kAudioOnlyCallConstraints);
}
IN_PROC_BROWSER_TEST_F(MediaStreamInfobarTest,
DenyingMicStillSucceedsWithCameraForAudioVideoCalls) {
content::WebContents* tab_contents = LoadTestPageInTab();
// If microphone blocking also blocked a AV call, the second call here
// would hang. The requester should only be granted access to the cam though.
GetUserMediaWithSpecificConstraintsAndDeny(tab_contents,
kAudioOnlyCallConstraints);
GetUserMediaWithSpecificConstraintsAndAccept(tab_contents,
kAudioVideoCallConstraints);
// TODO(phoglund): verify the requester actually only gets video tracks.
}