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

Side by Side Diff: chrome/test/data/prerender/prerender_events_common.js

Issue 142013004: Re-enable prerender RemovingLink browser tests. (Closed) Base URL: svn://svn.chromium.org/chrome/trunk/src
Patch Set: New test, and machinery to support said test. Created 6 years, 10 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 unified diff | Download patch | Annotate | Revision Log
OLDNEW
1 // Copyright (c) 2012 The Chromium Authors. All rights reserved. 1 // Copyright (c) 2012 The Chromium Authors. All rights reserved.
2 // Use of this source code is governed by a BSD-style license that can be 2 // Use of this source code is governed by a BSD-style license that can be
3 // found in the LICENSE file. 3 // found in the LICENSE file.
4 4
5 // Common js for prerender loaders; defines the helper functions that put 5 // Common js for prerender loaders; defines the helper functions that put
6 // event handlers on prerenders and track the events for browser tests. 6 // event handlers on prerenders and track the events for browser tests.
7 7
8 // TODO(gavinp): Put more common loader logic in here. 8 // TODO(gavinp): Put more common loader logic in here.
9 9
10 // Currently only errors with the ordering of Prerender events are caught. 10 // Currently only errors with the ordering of Prerender events are caught.
11 var hadPrerenderEventErrors = false; 11 var hadPrerenderEventErrors = false;
12 12
13 var receivedPrerenderStartEvents = []; 13 var receivedPrerenderEvents = {
14 var receivedPrerenderLoadEvents = []; 14 'webkitprerenderstart': [],
15 var receivedPrerenderStopEvents = []; 15 'webkitprerenderload': [],
16 'webkitprerenderstop': [],
17 }
18 var prerenderEventCallbacks = [];
16 19
17 function PrerenderStartHandler(index) { 20 function GetPrerenderEventCount(index, type) {
18 if (receivedPrerenderStartEvents[index] || 21 return receivedPrerenderEvents[type][index] || 0;
19 receivedPrerenderLoadEvents[index] ||
20 receivedPrerenderStopEvents[index]) {
21 hadPrerenderEventErrors = true;
22 return;
23 }
24 receivedPrerenderStartEvents[index] = true;
25 } 22 }
26 23
27 function PrerenderLoadHandler(index) { 24 function PrerenderEventHandler(index, ev) {
28 if (!receivedPrerenderStartEvents[index] || 25 // Check for errors.
29 receivedPrerenderStopEvents[index]) { 26 if (ev.type == 'webkitprerenderstart') {
30 hadPrerenderEventErrors = true; 27 if (GetPrerenderEventCount(index, 'webkitprerenderstart') ||
31 return; 28 GetPrerenderEventCount(index, 'webkitprerenderload') ||
29 GetPrerenderEventCount(index, 'webkitprerenderstop')) {
30 hadPrerenderEventErrors = true;
31 }
32 } else if (ev.type == 'webkitprerenderload') {
33 if (!GetPrerenderEventCount(index, 'webkitprerenderstart') ||
34 GetPrerenderEventCount(index, 'webkitprerenderstop')) {
mmenke 2014/02/13 16:34:33 Can we get multiple load events? I guess if a pag
davidben 2014/02/14 01:01:13 Done. Yeah, multiple loads are possible.
35 hadPrerenderEventErrors = true;
mmenke 2014/02/14 17:33:01 Why did you delete this block?
davidben 2014/02/14 19:18:26 The check for all the events other than webkitprer
mmenke 2014/02/14 19:25:44 Good point.
36 }
37 } else if (ev.type == 'webkitprerenderstop') {
38 if (!GetPrerenderEventCount(index, 'webkitprerenderstart') ||
39 GetPrerenderEventCount(index, 'webkitprerenderstop')) {
mmenke 2014/02/13 16:34:33 Think it's worth commenting that there may or may
davidben 2014/02/14 01:01:13 Done.
40 hadPrerenderEventErrors = true;
41 }
32 } 42 }
33 if (!receivedPrerenderLoadEvents[index]) 43
34 receivedPrerenderLoadEvents[index] = 0; 44 // Update count.
35 receivedPrerenderLoadEvents[index]++; 45 receivedPrerenderEvents[ev.type][index] =
46 (receivedPrerenderEvents[ev.type][index] || 0) + 1;
mmenke 2014/02/13 16:34:33 nit: +2 indent.
davidben 2014/02/14 01:01:13 Done.
47
48 // Run all callbacks. Remove the ones that are done.
mmenke 2014/02/13 16:34:33 There's no documentation of how these callbacks sh
davidben 2014/02/14 01:01:13 Done.
49 prerenderEventCallbacks = prerenderEventCallbacks.filter(function(cb) {
mmenke 2014/02/13 16:34:33 nit: "cb" is more often writen out.
davidben 2014/02/14 01:01:13 Done.
50 return !cb();
51 });
36 } 52 }
37 53
38 function PrerenderStopHandler(index) { 54 // Calls |callback| when at least |count| instances of event |type| have been
39 if (!receivedPrerenderStartEvents[index] || 55 // observed for prerender |index|.
40 receivedPrerenderStopEvents[index]) { 56 function WaitForPrerenderEventCount(index, type, count, callback) {
41 hadPrerenderEventErrors = true; 57 var checkCount = function() {
42 return; 58 if (GetPrerenderEventCount(index, type) >= count) {
43 } 59 callback();
44 receivedPrerenderStopEvents[index] = true; 60 return true;
61 }
62 return false;
63 };
64 if (!checkCount())
65 prerenderEventCallbacks.push(checkCount);
45 } 66 }
46 67
47 function AddEventHandlersToLinkElement(link, index) { 68 function AddEventHandlersToLinkElement(link, index) {
48 link.addEventListener('webkitprerenderstart', 69 link.addEventListener('webkitprerenderstart',
49 PrerenderStartHandler.bind(null, index), false); 70 PrerenderEventHandler.bind(null, index), false);
50 link.addEventListener('webkitprerenderload', 71 link.addEventListener('webkitprerenderload',
51 PrerenderLoadHandler.bind(null, index), false); 72 PrerenderEventHandler.bind(null, index), false);
52 link.addEventListener('webkitprerenderstop', 73 link.addEventListener('webkitprerenderstop',
53 PrerenderStopHandler.bind(null, index), false); 74 PrerenderEventHandler.bind(null, index), false);
54 } 75 }
55 76
56 function AddPrerender(url, index) { 77 function AddPrerender(url, index) {
57 var link = document.createElement('link'); 78 var link = document.createElement('link');
79 link.id = 'prerenderElement' + index;
58 link.rel = 'prerender'; 80 link.rel = 'prerender';
59 link.href = url; 81 link.href = url;
60 AddEventHandlersToLinkElement(link, index); 82 AddEventHandlersToLinkElement(link, index);
61 document.body.appendChild(link); 83 document.body.appendChild(link);
62 return link; 84 return link;
63 } 85 }
64 86
87 function RemoveLinkElement(index) {
88 var link = document.getElementById('prerenderElement' + index);
89 link.parentElement.removeChild(link);
90 }
91
92 function ExtractGetParameterBadlyAndInsecurely(param, defaultValue) {
93 var re = RegExp('[&?]' + param + '=([^&?#]*)');
94 var result = re.exec(document.location);
95 if (result)
96 return result[1];
97 return defaultValue;
98 }
99
65 function AddAnchor(href, target) { 100 function AddAnchor(href, target) {
66 var a = document.createElement('a'); 101 var a = document.createElement('a');
67 a.href = href; 102 a.href = href;
68 if (target) 103 if (target)
69 a.target = target; 104 a.target = target;
70 document.body.appendChild(a); 105 document.body.appendChild(a);
71 return a; 106 return a;
72 } 107 }
73 108
74 function Click(url) { 109 function Click(url) {
(...skipping 74 matching lines...) Expand 10 before | Expand all | Expand 10 after
149 cancelable: true, 184 cancelable: true,
150 detail: 1, 185 detail: 1,
151 metaKey: true, 186 metaKey: true,
152 shiftKey: true 187 shiftKey: true
153 })); 188 }));
154 } 189 }
155 190
156 function WindowOpen(url) { 191 function WindowOpen(url) {
157 window.open(url); 192 window.open(url);
158 } 193 }
OLDNEW

Powered by Google App Engine
This is Rietveld 408576698