Chromium Code Reviews
chromiumcodereview-hr@appspot.gserviceaccount.com (chromiumcodereview-hr) | Please choose your nickname with Settings | Help | Chromium Project | Gerrit Changes | Sign out
(5952)

Unified Diff: chrome/browser/media/webrtc/webrtc_getmediadevices_browsertest.cc

Issue 2487943002: Revert of Reenable media-device enumeration integration test. (Closed)
Patch Set: Created 4 years, 1 month ago
Use n/p to move between diff chunks; N/P to move between comments. Draft comments are only viewable by you.
Jump to:
View side-by-side diff with in-line comments
Download patch
« no previous file with comments | « no previous file | chrome/test/data/webrtc/media_devices.js » ('j') | no next file with comments »
Expand Comments ('e') | Collapse Comments ('c') | Show Comments Hide Comments ('s')
Index: chrome/browser/media/webrtc/webrtc_getmediadevices_browsertest.cc
diff --git a/chrome/browser/media/webrtc/webrtc_getmediadevices_browsertest.cc b/chrome/browser/media/webrtc/webrtc_getmediadevices_browsertest.cc
index 48492e6b00f0a4f630399c6b7874942567dc98b2..6f10b78337918ab2a301a6e103bf6c8fb96f88aa 100644
--- a/chrome/browser/media/webrtc/webrtc_getmediadevices_browsertest.cc
+++ b/chrome/browser/media/webrtc/webrtc_getmediadevices_browsertest.cc
@@ -15,7 +15,6 @@
#include "chrome/test/base/ui_test_utils.h"
#include "content/public/common/content_switches.h"
#include "content/public/test/browser_test_utils.h"
-#include "media/audio/audio_device_description.h"
#include "media/audio/audio_manager.h"
#include "media/base/media_switches.h"
#include "net/test/embedded_test_server/embedded_test_server.h"
@@ -28,9 +27,12 @@
const char kDeviceKindVideoInput[] = "videoinput";
const char kDeviceKindAudioOutput[] = "audiooutput";
+const char kSourceKindAudioInput[] = "audio";
+const char kSourceKindVideoInput[] = "video";
+
} // namespace
-// Integration test for WebRTC enumerateDevices. It always uses fake devices.
+// Integration test for WebRTC getMediaDevices. It always uses fake devices.
// It needs to be a browser test (and not content browser test) to be able to
// test that labels are cleared or not depending on if access to devices has
// been granted.
@@ -63,9 +65,27 @@
std::string group_id;
};
- void EnumerateDevices(content::WebContents* tab,
- std::vector<MediaDeviceInfo>* devices) {
- std::string devices_as_json = ExecuteJavascript("enumerateDevices()", tab);
+ bool HasOutputDevices() {
+ // There's no fake audio output devices supported yet. We can't test audio
+ // output devices on bots with no output devices, so skip testing for that
+ // on such bots. We cache the result since querying for devices can take
+ // considerable time.
+ if (!has_audio_output_devices_initialized_) {
+ has_audio_output_devices_ =
+ media::AudioManager::Get()->HasAudioOutputDevices();
+ has_audio_output_devices_initialized_ = true;
+ }
+ return has_audio_output_devices_;
+ }
+
+ // If |get_sources| is true, use getSources API and leave groupId empty,
+ // otherwise use getMediaDevices API.
+ void GetMediaDevicesOrSources(content::WebContents* tab,
+ std::vector<MediaDeviceInfo>* devices,
+ bool get_sources) {
+ std::string devices_as_json =
+ ExecuteJavascript(get_sources ? "getSources()" : "getMediaDevices()",
+ tab);
EXPECT_FALSE(devices_as_json.empty());
int error_code;
@@ -89,34 +109,41 @@
const base::DictionaryValue* dict;
MediaDeviceInfo device;
ASSERT_TRUE((*it)->GetAsDictionary(&dict));
- ASSERT_TRUE(dict->GetString("deviceId", &device.device_id));
+ ASSERT_TRUE(dict->GetString(get_sources ? "id" : "deviceId",
+ &device.device_id));
ASSERT_TRUE(dict->GetString("kind", &device.kind));
ASSERT_TRUE(dict->GetString("label", &device.label));
- ASSERT_TRUE(dict->GetString("groupId", &device.group_id));
+ if (!get_sources)
+ ASSERT_TRUE(dict->GetString("groupId", &device.group_id));
// Should be HMAC SHA256.
- if (!media::AudioDeviceDescription::IsDefaultDevice(device.device_id) &&
- !(device.device_id ==
- media::AudioDeviceDescription::kCommunicationsDeviceId)) {
- EXPECT_EQ(64ul, device.device_id.length());
- EXPECT_TRUE(
- base::ContainsOnlyChars(device.device_id, "0123456789abcdef"));
+ EXPECT_EQ(64ul, device.device_id.length());
+ EXPECT_TRUE(base::ContainsOnlyChars(device.device_id,
+ "0123456789abcdef"));
+
+ const char* kAudioInputKind =
+ get_sources ? kSourceKindAudioInput : kDeviceKindAudioInput;
+ const char* kVideoInputKind =
+ get_sources ? kSourceKindVideoInput : kDeviceKindVideoInput;
+ if (get_sources) {
+ EXPECT_TRUE(device.kind == kAudioInputKind ||
+ device.kind == kVideoInputKind);
+ } else {
+ EXPECT_TRUE(device.kind == kAudioInputKind ||
+ device.kind == kVideoInputKind ||
+ device.kind == kDeviceKindAudioOutput);
}
-
- EXPECT_TRUE(device.kind == kDeviceKindAudioInput ||
- device.kind == kDeviceKindVideoInput ||
- device.kind == kDeviceKindAudioOutput);
- if (device.kind == kDeviceKindAudioInput) {
+ if (device.kind == kAudioInputKind) {
found_audio_input = true;
- } else if (device.kind == kDeviceKindVideoInput) {
+ } else if (device.kind == kVideoInputKind) {
found_video_input = true;
} else {
found_audio_output = true;
}
- // enumerateDevices doesn't have group ID support for video input devices.
- // TODO(guidou): remove this once http://crbug.com/627793 is fixed.
- if (device.kind == kDeviceKindVideoInput) {
+ // getSources doesn't have group ID support. getMediaDevices doesn't have
+ // group ID support for video input devices.
+ if (get_sources || device.kind == kDeviceKindVideoInput) {
EXPECT_TRUE(device.group_id.empty());
} else {
EXPECT_FALSE(device.group_id.empty());
@@ -127,6 +154,21 @@
EXPECT_TRUE(found_audio_input);
EXPECT_TRUE(found_video_input);
+ if (get_sources) {
+ EXPECT_FALSE(found_audio_output);
+ } else {
+ EXPECT_EQ(HasOutputDevices(), found_audio_output);
+ }
+ }
+
+ void GetMediaDevices(content::WebContents* tab,
+ std::vector<MediaDeviceInfo>* devices) {
+ GetMediaDevicesOrSources(tab, devices, false);
+ }
+
+ void GetSources(content::WebContents* tab,
+ std::vector<MediaDeviceInfo>* sources) {
+ GetMediaDevicesOrSources(tab, sources, true);
}
bool has_audio_output_devices_initialized_;
@@ -138,16 +180,18 @@
WebRtcGetMediaDevicesBrowserTest,
testing::ValuesIn(kParamsToRunTestsWith));
-IN_PROC_BROWSER_TEST_P(WebRtcGetMediaDevicesBrowserTest,
- EnumerateDevicesWithoutAccess) {
- ASSERT_TRUE(embedded_test_server()->Start());
- GURL url(embedded_test_server()->GetURL(kMainWebrtcTestHtmlPage));
- ui_test_utils::NavigateToURL(browser(), url);
- content::WebContents* tab =
- browser()->tab_strip_model()->GetActiveWebContents();
-
- std::vector<MediaDeviceInfo> devices;
- EnumerateDevices(tab, &devices);
+// getMediaDevices has been removed and will be replaced
+// MediaDevices.enumerateDevices. http://crbug.com/388648.
+IN_PROC_BROWSER_TEST_P(WebRtcGetMediaDevicesBrowserTest,
+ DISABLED_GetMediaDevicesWithoutAccess) {
+ ASSERT_TRUE(embedded_test_server()->Start());
+ GURL url(embedded_test_server()->GetURL(kMainWebrtcTestHtmlPage));
+ ui_test_utils::NavigateToURL(browser(), url);
+ content::WebContents* tab =
+ browser()->tab_strip_model()->GetActiveWebContents();
+
+ std::vector<MediaDeviceInfo> devices;
+ GetMediaDevices(tab, &devices);
// Labels should be empty if access has not been allowed.
for (std::vector<MediaDeviceInfo>::iterator it = devices.begin();
@@ -156,8 +200,11 @@
}
}
-IN_PROC_BROWSER_TEST_P(WebRtcGetMediaDevicesBrowserTest,
- EnumerateDevicesWithAccess) {
+// getMediaDevices has been removed and will be replaced
+// MediaDevices.enumerateDevices. http://crbug.com/388648.
+// Disabled, fails due to http://crbug.com/382391.
+IN_PROC_BROWSER_TEST_P(WebRtcGetMediaDevicesBrowserTest,
+ DISABLED_GetMediaDevicesWithAccess) {
ASSERT_TRUE(embedded_test_server()->Start());
GURL url(embedded_test_server()->GetURL(kMainWebrtcTestHtmlPage));
ui_test_utils::NavigateToURL(browser(), url);
@@ -167,7 +214,7 @@
EXPECT_TRUE(GetUserMediaAndAccept(tab));
std::vector<MediaDeviceInfo> devices;
- EnumerateDevices(tab, &devices);
+ GetMediaDevices(tab, &devices);
// Labels should be non-empty if access has been allowed.
for (std::vector<MediaDeviceInfo>::iterator it = devices.begin();
@@ -175,3 +222,74 @@
EXPECT_TRUE(!it->label.empty());
}
}
+
+// getMediaDevices has been removed and will be replaced
+// MediaDevices.enumerateDevices. http://crbug.com/388648.
+IN_PROC_BROWSER_TEST_P(WebRtcGetMediaDevicesBrowserTest,
+ DISABLED_GetMediaDevicesEqualsGetSourcesWithoutAccess) {
+ ASSERT_TRUE(embedded_test_server()->Start());
+ GURL url(embedded_test_server()->GetURL(kMainWebrtcTestHtmlPage));
+ ui_test_utils::NavigateToURL(browser(), url);
+ content::WebContents* tab =
+ browser()->tab_strip_model()->GetActiveWebContents();
+
+ std::vector<MediaDeviceInfo> devices;
+ GetMediaDevices(tab, &devices);
+
+ std::vector<MediaDeviceInfo> sources;
+ GetSources(tab, &sources);
+
+ std::vector<MediaDeviceInfo>::iterator sources_it = sources.begin();
+ for (std::vector<MediaDeviceInfo>::iterator devices_it = devices.begin();
+ devices_it != devices.end(); ++devices_it) {
+ if (devices_it->kind == kDeviceKindAudioOutput)
+ continue;
+ EXPECT_STREQ(devices_it->device_id.c_str(), sources_it->device_id.c_str());
+ if (devices_it->kind == kDeviceKindAudioInput) {
+ EXPECT_STREQ(kSourceKindAudioInput, sources_it->kind.c_str());
+ } else {
+ EXPECT_STREQ(kSourceKindVideoInput, sources_it->kind.c_str());
+ }
+ EXPECT_TRUE(devices_it->label.empty());
+ EXPECT_TRUE(sources_it->label.empty());
+ ++sources_it;
+ }
+ EXPECT_EQ(sources.end(), sources_it);
+}
+
+// getMediaDevices has been removed and will be replaced
+// MediaDevices.enumerateDevices. http://crbug.com/388648.
+// Disabled, fails due to http://crbug.com/382391.
+IN_PROC_BROWSER_TEST_P(WebRtcGetMediaDevicesBrowserTest,
+ DISABLED_GetMediaDevicesEqualsGetSourcesWithAccess) {
+ ASSERT_TRUE(embedded_test_server()->Start());
+ GURL url(embedded_test_server()->GetURL(kMainWebrtcTestHtmlPage));
+ ui_test_utils::NavigateToURL(browser(), url);
+ content::WebContents* tab =
+ browser()->tab_strip_model()->GetActiveWebContents();
+
+ EXPECT_TRUE(GetUserMediaAndAccept(tab));
+
+ std::vector<MediaDeviceInfo> devices;
+ GetMediaDevices(tab, &devices);
+
+ std::vector<MediaDeviceInfo> sources;
+ GetSources(tab, &sources);
+
+ std::vector<MediaDeviceInfo>::iterator sources_it = sources.begin();
+ for (std::vector<MediaDeviceInfo>::iterator devices_it = devices.begin();
+ devices_it != devices.end(); ++devices_it) {
+ if (devices_it->kind == kDeviceKindAudioOutput)
+ continue;
+ EXPECT_STREQ(devices_it->device_id.c_str(), sources_it->device_id.c_str());
+ if (devices_it->kind == kDeviceKindAudioInput) {
+ EXPECT_STREQ(kSourceKindAudioInput, sources_it->kind.c_str());
+ } else {
+ EXPECT_STREQ(kSourceKindVideoInput, sources_it->kind.c_str());
+ }
+ EXPECT_TRUE(!devices_it->label.empty());
+ EXPECT_STREQ(devices_it->label.c_str(), sources_it->label.c_str());
+ ++sources_it;
+ }
+ EXPECT_EQ(sources.end(), sources_it);
+}
« no previous file with comments | « no previous file | chrome/test/data/webrtc/media_devices.js » ('j') | no next file with comments »

Powered by Google App Engine
This is Rietveld 408576698