Index: chrome/test/functional/gtalk/jsutils.js |
=================================================================== |
--- chrome/test/functional/gtalk/jsutils.js (revision 0) |
+++ chrome/test/functional/gtalk/jsutils.js (revision 0) |
@@ -0,0 +1,85 @@ |
+// Copyright (c) 2011 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. |
+ |
+/** |
+ * @fileoverview JS utilities automatically injected by Quasar PyAuto tests. |
Nirnimesh
2011/11/11 01:01:21
s/Quasar/GTalk/
wud
2011/11/17 21:17:53
Thanks, done.
|
+ */ |
+ |
+$KEYS = { |
+ ENTER: 13, |
+ ESC: 27 |
+}; |
+ |
frankf
2011/11/11 01:35:03
Please add comments describing what these function
wud
2011/11/17 21:17:53
Done.
|
+$VIEW = function(query) { |
+ var views = chrome.extension.getViews(); |
+ for (var i = 0; i < views.length; i++) { |
+ var url = views[i].location.href; |
+ if (url && url.indexOf(query) >= 0) { |
+ return views[i]; |
+ } |
+ } |
+ return null; |
+}; |
+ |
+$BODY = function(opt_window) { |
+ return (opt_window || window).document.body; |
+}; |
+ |
+$FindByTagName = function(element, tag, index) { |
+ var tagElements = element.getElementsByTagName(tag); |
+ if (index < tagElements.length) { |
+ return tagElements[index]; |
+ } |
+ return null; |
+}; |
+ |
+$FindByText = function(baseElement, text) { |
+ var allElements = baseElement.getElementsByTagName('*'); |
+ for (var i = 0; i < allElements.length; i++) { |
+ var element = allElements[i]; |
+ if (element.innerText && element.innerText.indexOf(text) >= 0) { |
+ var child = $FindByText(element, text); |
+ return child != null ? child : element; |
+ } |
+ } |
+ return null; |
+}; |
+ |
+$Click = function(element) { |
+ var mouseEvent = element.ownerDocument.createEvent('MouseEvent'); |
+ mouseEvent.initMouseEvent('click', true, true, window, |
+ 1, 0, 0, 0, 0, false, false, false, false, 0, null); |
+ element.dispatchEvent(mouseEvent); |
+ return true; |
+}; |
+ |
+$Type = function(element, text) { |
+ var keyEvent = element.ownerDocument.createEvent('TextEvent'); |
+ keyEvent.initTextEvent('textInput', true, true, window, text); |
+ element.dispatchEvent(keyEvent); |
+ return true; |
+}; |
+ |
+$Press = function(baseElement, keycode, opt_ctrlKey, opt_shiftKey, |
+ opt_altKey, opt_metaKey) { |
+ var sendKeyEvent = function(element, eventType) { |
+ // Unfortuantely, using the typical KeyboardEvent and initKeyboardEvent |
+ // fails in Chrome due to a webkit bug: |
+ // https://bugs.webkit.org/show_bug.cgi?id=16735 |
+ // We employ a workaround of synthesizing a raw 'Event' suggested here: |
+ // http://code.google.com/p/selenium/issues/detail?id=567 |
+ var keyEvent = element.ownerDocument.createEvent('Events'); |
+ keyEvent.ctrlKey = Boolean(opt_ctrlKey); |
+ keyEvent.shiftKey = Boolean(opt_shiftKey); |
+ keyEvent.altKey = Boolean(opt_altKey); |
+ keyEvent.metaKey = Boolean(opt_metaKey); |
+ keyEvent.initEvent(eventType, true, true); |
+ keyEvent.keyCode = keycode; |
+ element.dispatchEvent(keyEvent); |
+ } |
+ sendKeyEvent(baseElement, 'keydown'); |
+ sendKeyEvent(baseElement, 'keypress'); |
+ sendKeyEvent(baseElement, 'keyup'); |
+ return true; |
+}; |