blob: ed838a098d23b8efed5b9e39b9c9329088f95474 [file] [log] [blame]
// Copyright 2014 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 "content/test/webrtc_content_browsertest_base.h"
#include "base/command_line.h"
#include "base/strings/stringprintf.h"
#include "base/strings/utf_string_conversions.h"
#include "build/build_config.h"
#include "content/browser/web_contents/web_contents_impl.h"
#include "content/public/common/content_switches.h"
#include "content/public/test/browser_test_utils.h"
#include "content/public/test/content_browser_test_utils.h"
#include "content/shell/browser/shell.h"
#include "media/base/media_switches.h"
#include "net/test/embedded_test_server/embedded_test_server.h"
#if defined(OS_CHROMEOS)
#include "chromeos/audio/cras_audio_handler.h"
#endif
#if defined(OS_WIN)
#include "base/win/windows_version.h"
#endif
namespace content {
void WebRtcContentBrowserTest::SetUpCommandLine(
base::CommandLine* command_line) {
ASSERT_TRUE(base::CommandLine::ForCurrentProcess()->HasSwitch(
switches::kUseFakeDeviceForMediaStream));
base::CommandLine::ForCurrentProcess()->AppendSwitch(
switches::kEnforceWebRtcIPPermissionCheck);
// Loopback interface is the non-default local address. They should only be in
// the candidate list if the ip handling policy is "default" AND the media
// permission is granted.
base::CommandLine::ForCurrentProcess()->AppendSwitch(
switches::kAllowLoopbackInPeerConnection);
}
void WebRtcContentBrowserTest::SetUp() {
// We need pixel output when we dig pixels out of video tags for verification.
EnablePixelOutput();
#if defined(OS_CHROMEOS)
chromeos::CrasAudioHandler::InitializeForTesting();
#endif
ContentBrowserTest::SetUp();
}
void WebRtcContentBrowserTest::TearDown() {
ContentBrowserTest::TearDown();
#if defined(OS_CHROMEOS)
chromeos::CrasAudioHandler::Shutdown();
#endif
}
void WebRtcContentBrowserTest::AppendUseFakeUIForMediaStreamFlag() {
base::CommandLine::ForCurrentProcess()->AppendSwitch(
switches::kUseFakeUIForMediaStream);
}
// Executes |javascript|. The script is required to use
// window.domAutomationController.send to send a string value back to here.
std::string WebRtcContentBrowserTest::ExecuteJavascriptAndReturnResult(
const std::string& javascript) {
std::string result;
EXPECT_TRUE(ExecuteScriptAndExtractString(
shell()->web_contents(), javascript, &result))
<< "Failed to execute javascript " << javascript << ".";
return result;
}
void WebRtcContentBrowserTest::MakeTypicalCall(const std::string& javascript,
const std::string& html_file) {
ASSERT_TRUE(embedded_test_server()->Start());
GURL url(embedded_test_server()->GetURL(html_file));
NavigateToURL(shell(), url);
ExecuteJavascriptAndWaitForOk(javascript);
}
void WebRtcContentBrowserTest::ExecuteJavascriptAndWaitForOk(
const std::string& javascript) {
std::string result = ExecuteJavascriptAndReturnResult(javascript);
if (result != "OK") {
if (result.empty())
result = "(nothing)";
printf("From javascript: %s\nWhen executing '%s'\n", result.c_str(),
javascript.c_str());
FAIL();
}
}
std::string WebRtcContentBrowserTest::GenerateGetUserMediaCall(
const char* function_name,
int min_width,
int max_width,
int min_height,
int max_height,
int min_frame_rate,
int max_frame_rate) const {
return base::StringPrintf(
"%s({video: {mandatory: {minWidth: %d, maxWidth: %d, "
"minHeight: %d, maxHeight: %d, minFrameRate: %d, maxFrameRate: %d}, "
"optional: []}});",
function_name,
min_width,
max_width,
min_height,
max_height,
min_frame_rate,
max_frame_rate);
}
bool WebRtcContentBrowserTest::OnWinXp() const {
#if defined(OS_WIN)
return base::win::GetVersion() <= base::win::VERSION_XP;
#else
return false;
#endif
}
} // namespace content