1
0
mirror of https://github.com/matrix-org/matrix-js-sdk.git synced 2025-11-26 17:03:12 +03:00

Add local echo tests.

This commit is contained in:
Kegan Dougal
2015-06-25 15:24:56 +01:00
parent 21df000604
commit c4c68a0287
2 changed files with 195 additions and 9 deletions

View File

@@ -19,25 +19,35 @@ function HttpBackend() {
HttpBackend.prototype = {
/**
* Respond to all of the requests (flush the queue).
* @param {string} path The path to flush (optional) default: all.
* @param {integer} numToFlush The number of things to flush (optional), default: all.
* @return {Promise} resolved when there is nothing left to flush.
*/
flush: function() {
flush: function(path, numToFlush) {
var defer = q.defer();
var self = this;
console.log("HTTP backend flushing...");
var flushed = 0;
console.log("HTTP backend flushing... (path=%s numToFlush=%s)", path, numToFlush);
var tryFlush = function() {
// if there's more real requests and more expected requests, flush 'em.
console.log(
" trying to flush queue => reqs=%s expected=%s",
self.requests.length, self.expectedRequests.length
" trying to flush queue => reqs=%s expected=%s [%s]",
self.requests.length, self.expectedRequests.length, path
);
if (self._takeFromQueue()) {
if (self._takeFromQueue(path)) {
// try again on the next tick.
console.log(" flushed. Trying for more.");
setTimeout(tryFlush, 0);
console.log(" flushed. Trying for more. [%s]", path);
flushed += 1;
if (numToFlush && flushed === numToFlush) {
console.log(" [%s] Flushed assigned amount: %s", path, numToFlush);
defer.resolve();
}
else {
setTimeout(tryFlush, 0);
}
}
else {
console.log(" no more flushes.");
console.log(" no more flushes. [%s]", path);
defer.resolve();
}
};
@@ -49,9 +59,10 @@ HttpBackend.prototype = {
/**
* Attempts to resolve requests/expected requests.
* @param {string} path The path to flush (optional) default: all.
* @return {boolean} true if something was resolved.
*/
_takeFromQueue: function() {
_takeFromQueue: function(path) {
var req = null;
var i, j;
var matchingReq, expectedReq, testResponse = null;
@@ -59,6 +70,7 @@ HttpBackend.prototype = {
req = this.requests[i];
for (j = 0; j < this.expectedRequests.length; j++) {
expectedReq = this.expectedRequests[j];
if (path && path !== expectedReq.path) { continue; }
if (expectedReq.method === req.method &&
req.path.indexOf(expectedReq.path) !== -1) {
if (!expectedReq.data || (JSON.stringify(expectedReq.data) ===
@@ -84,6 +96,7 @@ HttpBackend.prototype = {
req.callback(
testResponse.err, testResponse.response, testResponse.body
);
matchingReq = null;
}
}
if (testResponse) { // flushed something