mirror of
https://github.com/openseadragon/openseadragon.git
synced 2025-01-19 17:21:50 +03:00
206 lines
7.2 KiB
JavaScript
206 lines
7.2 KiB
JavaScript
/* global module, asyncTest, $, ok, equal, notEqual, start, test, Util */
|
|
|
|
(function () {
|
|
|
|
// ----------
|
|
window.Util = {
|
|
// ----------
|
|
simulateViewerClickWithDrag: function ( args ) {
|
|
// args = { viewer, widthFactor, heightFactor, dragCount, dragDx, dragDy }
|
|
|
|
if ( args.hasOwnProperty( 'dragCount' ) ) {
|
|
args.dragDx = args.dragDx || 1;
|
|
args.dragDy = args.dragDy || 1;
|
|
}
|
|
else {
|
|
args.dragCount = 0;
|
|
}
|
|
|
|
if ( args.widthFactor === undefined ) {
|
|
args.widthFactor = 0.5;
|
|
}
|
|
|
|
//TODO Redefine to be the middle by default
|
|
if ( args.heightFactor === undefined ) {
|
|
args.heightFactor = 0.5;
|
|
}
|
|
|
|
args.widthFactor = Math.min( 1, Math.max( 0, args.widthFactor ) );
|
|
//TODO Fix this. The max height should be 1/AR
|
|
args.heightFactor = Math.min( 1, Math.max( 0, args.heightFactor ) );
|
|
|
|
var $canvas = $( args.viewer.element ).find( '.openseadragon-canvas' ).not( '.navigator .openseadragon-canvas' );
|
|
var offset = $canvas.offset();
|
|
var event = {
|
|
clientX: offset.left + Math.floor( $canvas.width() * args.widthFactor ),
|
|
clientY: offset.top + Math.floor( $canvas.height() * args.heightFactor )
|
|
};
|
|
|
|
$canvas
|
|
.simulate( OpenSeadragon.MouseTracker.haveMouseEnter ? 'mouseenter' : 'mouseover', event )
|
|
.simulate( 'mousedown', event );
|
|
for ( var i = 0; i < args.dragCount; i++ ) {
|
|
event.clientX += args.dragDx;
|
|
event.clientY += args.dragDy;
|
|
$canvas
|
|
.simulate( "mousemove", event );
|
|
}
|
|
$canvas
|
|
.simulate( 'mouseup', event )
|
|
.simulate( OpenSeadragon.MouseTracker.haveMouseEnter ? 'mouseleave' : 'mouseout', event );
|
|
},
|
|
|
|
// ----------
|
|
initializeTestDOM: function () {
|
|
$( "#qunit-fixture" )
|
|
.append( '<div><div id="example"></div><div id="exampleNavigator"></div></div>' )
|
|
.append( '<div id="wideexample"></div>' )
|
|
.append( '<div id="tallexample"></div>' );
|
|
},
|
|
|
|
// ----------
|
|
equalsWithVariance: function ( value1, value2, variance ) {
|
|
return Math.abs( value1 - value2 ) <= variance;
|
|
},
|
|
|
|
// ----------
|
|
assessNumericValue: function ( value1, value2, variance, message ) {
|
|
ok( Util.equalsWithVariance( value1, value2, variance ), message + " Expected:" + value1 + " Found: " + value2 + " Variance: " + variance );
|
|
},
|
|
|
|
// ----------
|
|
assertPointsEquals: function (pointA, pointB, precision, message) {
|
|
Util.assessNumericValue(pointA.x, pointB.x, precision, message + " x: ");
|
|
Util.assessNumericValue(pointA.y, pointB.y, precision, message + " y: ");
|
|
},
|
|
|
|
// ----------
|
|
assertRectangleEquals: function (rectA, rectB, precision, message) {
|
|
Util.assessNumericValue(rectA.x, rectB.x, precision, message + " x: ");
|
|
Util.assessNumericValue(rectA.y, rectB.y, precision, message + " y: ");
|
|
Util.assessNumericValue(rectA.width, rectB.width, precision,
|
|
message + " width: ");
|
|
Util.assessNumericValue(rectA.height, rectB.height, precision,
|
|
message + " height: ");
|
|
Util.assessNumericValue(rectA.degrees, rectB.degrees, precision,
|
|
message + " degrees: ");
|
|
},
|
|
|
|
// ----------
|
|
timeWatcher: function ( time ) {
|
|
time = time || 2000;
|
|
var finished = false;
|
|
|
|
setTimeout( function () {
|
|
if ( !finished ) {
|
|
finished = true;
|
|
ok( false, 'finishes in ' + time + 'ms' );
|
|
start();
|
|
}
|
|
}, time );
|
|
|
|
return {
|
|
done: function () {
|
|
if ( !finished ) {
|
|
finished = true;
|
|
start();
|
|
}
|
|
}
|
|
};
|
|
},
|
|
|
|
// ----------
|
|
spyOnce: function(obj, functionName, callback) {
|
|
var original = obj[functionName];
|
|
obj[functionName] = function() {
|
|
obj[functionName] = original;
|
|
var result = callback.apply(this, arguments);
|
|
if (result === undefined) {
|
|
result = original.apply(this, arguments);
|
|
}
|
|
|
|
return result;
|
|
};
|
|
},
|
|
|
|
// ----------
|
|
testDeprecation: function(obj0, member0, obj1, member1) {
|
|
var called = false;
|
|
var errored = false;
|
|
|
|
if (obj1 && member1) {
|
|
this.spyOnce(obj1, member1, function() {
|
|
called = true;
|
|
return false;
|
|
});
|
|
} else {
|
|
called = true;
|
|
}
|
|
|
|
this.spyOnce(OpenSeadragon.console, 'error', function(message) {
|
|
if (/deprecated/.test(message)) {
|
|
errored = true;
|
|
}
|
|
});
|
|
|
|
obj0[member0]();
|
|
equal(called, true, 'called through for ' + member0);
|
|
equal(errored, true, 'errored for ' + member0);
|
|
}
|
|
};
|
|
|
|
/*
|
|
Test console log capture
|
|
|
|
1. Only the OpenSeadragon.console logger is touched
|
|
2. All log messages are stored in window.testLog in arrays keyed on the logger name (e.g. log,
|
|
warning, error, etc.) as JSON-serialized strings to simplify comparisons
|
|
3. The captured log arrays have a custom contains() method for ease of testing
|
|
4. testLog.reset() will clear all of the message arrays, intended for use in test setup routines
|
|
*/
|
|
var testConsole = window.testConsole = {},
|
|
testLog = window.testLog = {
|
|
log: [],
|
|
debug: [],
|
|
info: [],
|
|
warn: [],
|
|
error: [],
|
|
reset: function () {
|
|
for ( var i in testLog ) {
|
|
if ( testLog.hasOwnProperty( i ) && 'length' in testLog[i] && 'push' in testLog[i] ) {
|
|
testLog[i].length = 0;
|
|
}
|
|
}
|
|
}
|
|
};
|
|
|
|
for ( var i in testLog ) {
|
|
if ( testLog.hasOwnProperty( i ) && testLog[i].push ) {
|
|
testConsole[i] = ( function ( arr ) {
|
|
return function () {
|
|
var args = Array.prototype.slice.call( arguments, 0 ); // Coerce to true Array
|
|
arr.push( JSON.stringify( args ) ); // Store as JSON to avoid tedious array-equality tests
|
|
};
|
|
} )( testLog[i] );
|
|
|
|
testLog[i].contains = function ( needle ) {
|
|
for ( var i = 0; i < this.length; i++ ) {
|
|
if ( this[i] == needle ) {
|
|
return true;
|
|
}
|
|
}
|
|
return false;
|
|
};
|
|
}
|
|
}
|
|
|
|
testConsole.assert = function(condition, message) {
|
|
if (condition) {
|
|
testConsole.error(message);
|
|
}
|
|
};
|
|
|
|
OpenSeadragon.console = testConsole;
|
|
} )();
|
|
|