2017-12-06 17:20:39 -08:00
|
|
|
/* global QUnit, $, Util, testLog */
|
2014-11-18 16:28:08 -08:00
|
|
|
|
|
|
|
(function() {
|
|
|
|
var viewer;
|
|
|
|
|
2017-12-06 17:20:39 -08:00
|
|
|
QUnit.module('Drawer', {
|
|
|
|
beforeEach: function () {
|
|
|
|
$('<div id="example"></div>').appendTo("#qunit-fixture");
|
2014-11-18 16:28:08 -08:00
|
|
|
|
|
|
|
testLog.reset();
|
|
|
|
},
|
2017-12-06 17:20:39 -08:00
|
|
|
afterEach: function () {
|
2014-11-18 16:28:08 -08:00
|
|
|
if (viewer && viewer.close) {
|
|
|
|
viewer.close();
|
|
|
|
}
|
|
|
|
|
|
|
|
viewer = null;
|
|
|
|
}
|
|
|
|
});
|
|
|
|
|
2014-11-20 14:25:17 -08:00
|
|
|
// ----------
|
|
|
|
var createViewer = function(options) {
|
|
|
|
options = options || {};
|
2022-12-02 15:52:53 -08:00
|
|
|
// eslint-disable-next-line new-cap
|
2014-11-20 14:25:17 -08:00
|
|
|
viewer = OpenSeadragon(OpenSeadragon.extend({
|
|
|
|
id: 'example',
|
|
|
|
prefixUrl: '/build/openseadragon/images/',
|
|
|
|
springStiffness: 100 // Faster animation = faster tests
|
|
|
|
}, options));
|
|
|
|
};
|
|
|
|
|
2014-11-18 16:28:08 -08:00
|
|
|
// ----------
|
2017-12-06 17:20:39 -08:00
|
|
|
QUnit.test('basics', function(assert) {
|
|
|
|
var done = assert.async();
|
2014-11-20 14:25:17 -08:00
|
|
|
createViewer();
|
2017-12-06 17:20:39 -08:00
|
|
|
assert.ok(viewer.drawer, 'Drawer exists');
|
|
|
|
assert.equal(viewer.drawer.canRotate(), OpenSeadragon.supportsCanvas, 'we can rotate if we have canvas');
|
|
|
|
done();
|
2014-11-18 16:28:08 -08:00
|
|
|
});
|
|
|
|
|
2014-11-20 14:25:17 -08:00
|
|
|
// ----------
|
2017-12-06 17:20:39 -08:00
|
|
|
QUnit.test('rotation', function(assert) {
|
|
|
|
var done = assert.async();
|
2014-11-20 14:25:17 -08:00
|
|
|
createViewer({
|
|
|
|
tileSources: '/test/data/testpattern.dzi'
|
|
|
|
});
|
|
|
|
|
|
|
|
viewer.addHandler('open', function handler(event) {
|
2022-12-05 19:38:46 -05:00
|
|
|
viewer.viewport.setRotation(30, true);
|
2014-11-20 14:25:17 -08:00
|
|
|
Util.spyOnce(viewer.drawer.context, 'rotate', function() {
|
2017-12-06 17:20:39 -08:00
|
|
|
assert.ok(true, 'drawing with new rotation');
|
|
|
|
done();
|
2014-11-20 14:25:17 -08:00
|
|
|
});
|
|
|
|
});
|
|
|
|
});
|
|
|
|
|
|
|
|
// ----------
|
2017-12-06 17:20:39 -08:00
|
|
|
QUnit.test('debug', function(assert) {
|
|
|
|
var done = assert.async();
|
2014-11-20 14:25:17 -08:00
|
|
|
createViewer({
|
|
|
|
tileSources: '/test/data/testpattern.dzi',
|
|
|
|
debugMode: true
|
|
|
|
});
|
|
|
|
|
|
|
|
Util.spyOnce(viewer.drawer, 'drawDebugInfo', function() {
|
2017-12-06 17:20:39 -08:00
|
|
|
assert.ok(true, 'drawDebugInfo is called');
|
|
|
|
done();
|
2014-11-20 14:25:17 -08:00
|
|
|
});
|
|
|
|
});
|
2014-11-18 16:28:08 -08:00
|
|
|
|
2015-04-22 20:12:38 -04:00
|
|
|
// ----------
|
2017-12-06 17:20:39 -08:00
|
|
|
QUnit.test('sketchCanvas', function(assert) {
|
|
|
|
var done = assert.async();
|
2015-04-22 20:12:38 -04:00
|
|
|
createViewer({
|
|
|
|
tileSources: '/test/data/testpattern.dzi'
|
|
|
|
});
|
|
|
|
var drawer = viewer.drawer;
|
|
|
|
|
|
|
|
viewer.addHandler('tile-drawn', function noOpacityHandler() {
|
|
|
|
viewer.removeHandler('tile-drawn', noOpacityHandler);
|
2017-12-06 17:20:39 -08:00
|
|
|
assert.equal(drawer.sketchCanvas, null,
|
2015-04-22 20:12:38 -04:00
|
|
|
'The sketch canvas should be null if no decimal opacity is used.');
|
2017-12-06 17:20:39 -08:00
|
|
|
assert.equal(drawer.sketchContext, null,
|
2015-04-22 20:12:38 -04:00
|
|
|
'The sketch context should be null if no decimal opacity is used.');
|
|
|
|
testOpacityDecimal();
|
|
|
|
});
|
|
|
|
|
|
|
|
function testOpacityDecimal() {
|
|
|
|
var tiledImage;
|
|
|
|
viewer.addTiledImage({
|
|
|
|
tileSource: '/test/data/testpattern.dzi',
|
|
|
|
opacity: 0.5,
|
|
|
|
success: function(event) {
|
|
|
|
tiledImage = event.item;
|
|
|
|
}
|
|
|
|
});
|
|
|
|
|
|
|
|
viewer.addHandler('tile-drawn', function opacityDecimalHandler(event) {
|
|
|
|
if (tiledImage !== event.tiledImage) {
|
|
|
|
return;
|
|
|
|
}
|
|
|
|
viewer.removeHandler('tile-drawn', opacityDecimalHandler);
|
2017-12-06 17:20:39 -08:00
|
|
|
assert.notEqual(drawer.sketchCanvas, null,
|
2015-04-22 20:12:38 -04:00
|
|
|
'The sketch canvas should not be null once a decimal opacity has been used.');
|
2017-12-06 17:20:39 -08:00
|
|
|
assert.notEqual(drawer.sketchContext, null,
|
2015-04-22 20:12:38 -04:00
|
|
|
'The sketch context should not be null once a decimal opacity has been used.');
|
2017-12-06 17:20:39 -08:00
|
|
|
done();
|
2015-04-22 20:12:38 -04:00
|
|
|
});
|
|
|
|
}
|
|
|
|
});
|
|
|
|
|
2014-11-20 14:25:17 -08:00
|
|
|
// ----------
|
2017-12-06 17:20:39 -08:00
|
|
|
QUnit.test('deprecations', function(assert) {
|
|
|
|
var done = assert.async();
|
|
|
|
|
2015-04-22 20:12:38 -04:00
|
|
|
createViewer({
|
|
|
|
tileSources: '/test/data/testpattern.dzi'
|
|
|
|
});
|
|
|
|
viewer.world.addHandler('add-item', function() {
|
2017-12-06 17:20:39 -08:00
|
|
|
Util.testDeprecation(assert, viewer.drawer, 'addOverlay', viewer, 'addOverlay');
|
|
|
|
Util.testDeprecation(assert, viewer.drawer, 'updateOverlay', viewer, 'updateOverlay');
|
|
|
|
Util.testDeprecation(assert, viewer.drawer, 'removeOverlay', viewer, 'removeOverlay');
|
|
|
|
Util.testDeprecation(assert, viewer.drawer, 'clearOverlays', viewer, 'clearOverlays');
|
|
|
|
Util.testDeprecation(assert, viewer.drawer, 'needsUpdate', viewer.world, 'needsDraw');
|
|
|
|
Util.testDeprecation(assert, viewer.drawer, 'numTilesLoaded', viewer.tileCache, 'numTilesLoaded');
|
|
|
|
Util.testDeprecation(assert, viewer.drawer, 'reset', viewer.world, 'resetItems');
|
|
|
|
Util.testDeprecation(assert, viewer.drawer, 'update', viewer.world, 'draw');
|
|
|
|
Util.testDeprecation(assert, viewer.drawer, 'setOpacity', viewer.world.getItemAt(0), 'setOpacity');
|
|
|
|
Util.testDeprecation(assert, viewer.drawer, 'getOpacity', viewer.world.getItemAt(0), 'getOpacity');
|
|
|
|
done();
|
2015-04-22 20:12:38 -04:00
|
|
|
});
|
2014-11-18 16:28:08 -08:00
|
|
|
});
|
|
|
|
|
|
|
|
})();
|