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

Unified Diff: chrome/test/functional/webrtc_brutality_test.py

Issue 10830159: Added a new test which aims to be really, really mean to WebRTC. Hopefully this will cover some cra… (Closed) Base URL: svn://svn.chromium.org/chrome/trunk/src
Patch Set: Created 8 years, 4 months 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
Index: chrome/test/functional/webrtc_brutality_test.py
diff --git a/chrome/test/functional/webrtc_brutality_test.py b/chrome/test/functional/webrtc_brutality_test.py
new file mode 100755
index 0000000000000000000000000000000000000000..61b7a1716e07e1aebe2ee693b95a39b34377ee24
--- /dev/null
+++ b/chrome/test/functional/webrtc_brutality_test.py
@@ -0,0 +1,79 @@
+#!/usr/bin/env python
+# Copyright (c) 2012 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.
Nirnimesh 2012/08/03 18:32:13 Leave a blank line after this
phoglund_chromium 2012/08/06 15:02:18 Done.
+import pyauto_functional
+import webrtc_test_base
+
Nirnimesh 2012/08/03 18:32:13 need another blank line here
phoglund_chromium 2012/08/06 15:02:18 Done.
+class WebrtcBrutalityTest(webrtc_test_base.WebrtcTestBase):
+ """This test class tests how WebRTC deals with inconvenient reloads, etc."""
Nirnimesh 2012/08/03 18:32:13 Remove "This test class" It's redundant
phoglund_chromium 2012/08/06 15:02:18 Done.
+
+ def testReloadsAfterGetUserMedia(self):
+ """Tests how we deal with reloads.
+
+ This test will quickly reload the page after running getUserMedia, which
+ will remove the pending request. This crashed the browser before the fix
+ for crbug.com/135043.
+
+ The test will make repeated getUserMedia requests with refreshes between
+ them. Sometimes it will click past the bar and then refresh.
+ """
+ url = self.GetFileURLForDataPath('webrtc', 'webrtc_jsep_test.html')
+ self.NavigateToURL(url)
+
+ tab = self.GetBrowserWindow(0).GetTab(0)
Nirnimesh 2012/08/03 18:32:13 This format has been deprecated. Use the ReloadTab
phoglund_chromium 2012/08/06 15:02:18 Done.
+ for i in range(1, 100):
+ if i % 10 == 0:
+ self.GetUserMedia(tab_index=0, action='allow')
+ else:
+ self._GetUserMediaWithoutTakingAction(tab_index=0)
+ tab.Reload()
+
+ def testRepeatedGetUserMediaRequests(self):
+ """Tests how we deal with lots of consecutive getUserMedia requests.
+
+ The test will alternate unanswered requests with requests that get answered.
+ """
+ url = self.GetFileURLForDataPath('webrtc', 'webrtc_jsep_test.html')
+ self.NavigateToURL(url)
+
+ for i in range(1, 100):
+ if i % 10 == 0:
+ self.GetUserMedia(tab_index=0, action='allow')
+ else:
+ self._GetUserMediaWithoutTakingAction(tab_index=0)
+
+ def testSuccessfulGetUserMediaAndThenReload(self):
+ """Waits for WebRTC to respond, and immediately reloads the tab."""
+ url = self.GetFileURLForDataPath('webrtc', 'webrtc_jsep_test.html')
+ self.NavigateToURL(url)
+
+ tab = self.GetBrowserWindow(0).GetTab(0)
+ self.GetUserMedia(tab_index=0, action='allow')
+ tab.Reload()
Nirnimesh 2012/08/03 18:32:13 ditto
phoglund_chromium 2012/08/06 15:02:18 Done.
+
+ def testClosingTabAfterGetUserMedia(self):
+ """Tests closing the tab right after a getUserMedia call."""
+ url = self.GetFileURLForDataPath('webrtc', 'webrtc_jsep_test.html')
+ self.NavigateToURL(url)
+
+ tab = self.GetBrowserWindow(0).GetTab(0)
phoglund_chromium 2012/08/06 15:02:18 I need to do this for Close() though, right?
Nirnimesh 2012/08/06 20:52:11 For now, yes. Craig is in the middle of replacing
+ self.GetUserMedia(tab_index=0, action='allow')
+ tab.Close()
+
+ def testSuccessfulGetUserMediaAndThenClose(self):
+ """Waits for WebRTC to respond, and closes the tab."""
+ url = self.GetFileURLForDataPath('webrtc', 'webrtc_jsep_test.html')
+ self.NavigateToURL(url)
+
+ tab = self.GetBrowserWindow(0).GetTab(0)
+ self.GetUserMedia(tab_index=0, action='allow')
+ tab.Close()
+
+ def _GetUserMediaWithoutTakingAction(self, tab_index):
+ self.assertEquals('ok-requested', self.ExecuteJavascript(
+ 'getUserMedia(true, true)', tab_index=0))
Nirnimesh 2012/08/03 18:32:13 indent by 2 more spaces
+
+
+if __name__ == '__main__':
+ pyauto_functional.Main()

Powered by Google App Engine
This is Rietveld 408576698