From 51ebb96b1da5217d6742ba05ea67a66c7787f0da Mon Sep 17 00:00:00 2001 From: "Thiago Marcos P. Santos" Date: Mon, 10 Apr 2017 20:34:39 +0300 Subject: [node] Add map.cancel() Cancels an ongoing rendering. --- platform/node/test/benchmark.js | 22 +++---- platform/node/test/js/cancel.test.js | 116 +++++++++++++++++++++++++++++++++++ platform/node/test/js/map.test.js | 1 + 3 files changed, 128 insertions(+), 11 deletions(-) create mode 100644 platform/node/test/js/cancel.test.js (limited to 'platform/node/test') diff --git a/platform/node/test/benchmark.js b/platform/node/test/benchmark.js index 38c416ed34..50f6353bca 100644 --- a/platform/node/test/benchmark.js +++ b/platform/node/test/benchmark.js @@ -9,8 +9,8 @@ var firstRequest = "mapbox://sprites/mapbox/streets-v9@2x.json"; var params = { mapPoolSize: 10, numRenderings: 1000, - failurePercentage: 0, - timeoutPercentage: 0, + failurePercentage: 10, + timeoutPercentage: 10, renderingTimeout: 5000, ratio: 2 }; @@ -20,7 +20,7 @@ test('Benchmark', function(t) { var renderCount = 0; var failureCount = 0; - var timeoutCount = 0; + var cancelCount = 0; var options = { request: function(req, callback) { @@ -70,15 +70,13 @@ test('Benchmark', function(t) { t.end(); console.timeEnd('Time'); console.log('Failures: ' + failureCount); - console.log('Timeouts: ' + timeoutCount); + console.log('Canceled: ' + cancelCount); return; } var mapTimeout = setTimeout(function() { - map.release(); - mapPool.push(new mbgl.Map(options)); - timeoutCount += 1; + map.cancel(); }, params.renderingTimeout); map.render({ zoom: 16 }, function(err, pixels) { @@ -89,13 +87,15 @@ test('Benchmark', function(t) { failureCount += 1; } + if (err.message == 'Canceled') { + cancelCount += 1; + } + + // We cancel the request before it gets a + // timeout error from the file source. if (err.message == 'Timeout') { t.fail('should never happen'); } - - map.release(); - mapPool.push(new mbgl.Map(options)); - return; } mapPool.push(map); diff --git a/platform/node/test/js/cancel.test.js b/platform/node/test/js/cancel.test.js new file mode 100644 index 0000000000..17525fb863 --- /dev/null +++ b/platform/node/test/js/cancel.test.js @@ -0,0 +1,116 @@ +'use strict'; + +var mockfs = require('./../mockfs'); +var mbgl = require('../../index'); +var test = require('tape'); + +var options = { + request: function(req, callback) { + callback(null, { data: mockfs.dataForRequest(req) }); + }, + ratio: 1, +}; + +test('Cancel', function(t) { + t.test('sanity', function(t) { + var renderCount = 0; + var cancelCount = 0; + var map = new mbgl.Map(options); + + var renderCallback = function(err, pixels) { + if (err) { + cancelCount++; + } else { + renderCount++; + } + }; + + map.load(mockfs.style_vector); + + map.render({ zoom: 16 }, renderCallback); + map.cancel(); + + map.render({ zoom: 16 }, renderCallback); + map.cancel(); + + map.render({ zoom: 16 }, renderCallback); + map.cancel(); + + t.equal(renderCount, 0); + t.equal(cancelCount, 3); + + t.end(); + }); + + t.test('render after cancel', function(t) { + var map = new mbgl.Map(options); + var renderCallback = function(err, pixels) { if (!err) t.end(); }; + + map.load(mockfs.style_vector); + + map.render({ zoom: 16 }, renderCallback); + map.cancel(); + + map.render({ zoom: 16 }, renderCallback); + }); + + t.test('cancel after cancel', function(t) { + var cancelCount = 0; + var map = new mbgl.Map(options); + + map.load(mockfs.style_vector); + map.render({ zoom: 16 }, function(err, pixels) { + cancelCount++; + }); + + map.cancel(); + + t.throws(function() { + map.cancel(); + }, 'already canceled'); + + t.equal(cancelCount, 1); + + t.end(); + }); + + t.test('cancel without rendering', function(t) { + var cancelCount = 0; + var map = new mbgl.Map(options); + + map.load(mockfs.style_vector); + + t.throws(function() { + map.cancel(); + }, 'nothing to cancel'); + + t.end(); + }); + + t.test('release after cancel', function(t) { + var map = new mbgl.Map(options); + + map.load(mockfs.style_vector); + map.render({ zoom: 16 }, function(err, pixels) {}); + + map.cancel(); + map.release(); + + t.end(); + }); + + t.test('cancel after release', function(t) { + var map = new mbgl.Map(options); + + map.load(mockfs.style_vector); + map.render({ zoom: 16 }, function(err, pixels) {}); + + map.release(); + + t.throws(function() { + map.cancel(); + }, 'map resources already released'); + + t.end(); + }); +}) diff --git a/platform/node/test/js/map.test.js b/platform/node/test/js/map.test.js index e5c756adb6..4ab76b937a 100644 --- a/platform/node/test/js/map.test.js +++ b/platform/node/test/js/map.test.js @@ -107,6 +107,7 @@ test('Map', function(t) { 'loaded', 'render', 'release', + 'cancel', 'addClass', 'addSource', 'addLayer', -- cgit v1.2.1