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

Unified Diff: chrome/test/data/push_messaging/push_test.js

Issue 822203006: Push API: Replace buggy FutureData test helper with ResultQueue (Closed) Base URL: https://chromium.googlesource.com/chromium/src.git@uservisible
Patch Set: Created 5 years, 11 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
« no previous file with comments | « chrome/browser/services/gcm/push_messaging_browsertest.cc ('k') | no next file » | no next file with comments »
Expand Comments ('e') | Collapse Comments ('c') | Show Comments Hide Comments ('s')
Index: chrome/test/data/push_messaging/push_test.js
diff --git a/chrome/test/data/push_messaging/push_test.js b/chrome/test/data/push_messaging/push_test.js
index a02f3aea88cb33d0c9c3a13a5bfa8066daa1d9d1..410a839996cd23f2943e19346f93e01e16080331 100644
--- a/chrome/test/data/push_messaging/push_test.js
+++ b/chrome/test/data/push_messaging/push_test.js
@@ -4,7 +4,7 @@
'use strict';
-var pushData = new FutureData();
+var resultQueue = new ResultQueue();
Peter Beverloo 2015/01/13 16:53:38 nit: since this is Chromium, variables should be n
johnme 2015/01/13 18:03:04 Actually, http://google-styleguide.googlecode.com/
var pushRegistration = null;
// Sends data back to the test. This must be in response to an earlier
@@ -21,36 +21,39 @@ function sendErrorToTest(error) {
sendResultToTest(error.name + ' - ' + error.message);
}
-// A container for a single piece of data. The data does not have to be
-// available yet when the getter is called, as all responses to the test are
-// asynchronous.
-function FutureData() {
- this.data = null;
- this.waiting = false;
+// Queue storing asynchronous results received from the Service Worker. Results
+// are sent to the test when requested.
+function ResultQueue() {
Michael van Ouwerkerk 2015/01/13 11:14:51 I don't mind a more powerful class here, but in th
Peter Beverloo 2015/01/13 16:53:38 Thanks for checking! I think that the additional
+ // Invariant: this.queue.length == 0 || this.pendingGets == 0
+ this.queue = [];
+ this.pendingGets = 0;
}
-// Sends the data to the test if it is available. Otherwise sets the
-// |waiting| flag.
-FutureData.prototype.get = function() {
- if (this.data) {
- sendResultToTest(this.data);
+// Adds a data item to the queue. Will be sent to the test if there are
+// pendingGets.
+ResultQueue.prototype.push = function(data) {
+ if (this.pendingGets > 0) {
+ this.pendingGets--;
+ sendResultToTest(data);
} else {
- this.waiting = true;
+ this.queue.unshift(data);
}
};
-// Sets a new data value. If the |waiting| flag is on, it is turned off and
-// the data is sent to the test.
-FutureData.prototype.set = function(data) {
- this.data = data;
- if (this.waiting) {
- sendResultToTest(data);
- this.waiting = false;
+// Called by native. Sends the next data item to the test if it is available.
+// Otherwise increments pendingGets so it will be delivered when received.
+ResultQueue.prototype.pop = function() {
+ if (this.queue.length) {
+ sendResultToTest(this.queue.pop());
+ } else {
+ this.pendingGets++;
}
};
-FutureData.prototype.getImmediately = function() {
- sendResultToTest(this.data);
+// Called by native. Immediately sends the next data item to the test if it is
+// available, otherwise sends null.
+ResultQueue.prototype.popImmediately = function() {
+ sendResultToTest(this.queue.length ? this.queue.pop() : null);
};
// Notification permission has been coalesced with Push permission. After
@@ -132,7 +135,6 @@ function unregister() {
addEventListener('message', function(event) {
var message = JSON.parse(event.data);
- if (message.type == 'push') {
- pushData.set(message.data);
- }
+ if (message.type == 'push')
+ resultQueue.push(message.data);
}, false);
« no previous file with comments | « chrome/browser/services/gcm/push_messaging_browsertest.cc ('k') | no next file » | no next file with comments »

Powered by Google App Engine
This is Rietveld 408576698