Fix handling of native classes in tests again

Reverting breaking change in 10bdafa826
This commit is contained in:
Jürg Lehni 2019-06-09 14:34:32 +02:00
parent 5cb93ec46e
commit 1e2bbbdef2
2 changed files with 15 additions and 7 deletions

View file

@ -36,6 +36,12 @@ if (typeof window === 'object') {
// the code the 2nd time around. // the code the 2nd time around.
load(root + 'src/load.js'); load(root + 'src/load.js');
} else { } else {
// Some native javascript classes have name collisions with Paper.js
// classes. Store them to be able to use them later in tests.
this.nativeClasses = {
Event: window.Event,
MouseEvent: window.MouseEvent
};
include('options.js'); include('options.js');
// Load constants.js, required by the on-the-fly preprocessing: // Load constants.js, required by the on-the-fly preprocessing:
include('constants.js'); include('constants.js');

View file

@ -35,10 +35,10 @@ if (isNode) {
} }
// Some native javascript classes have name collisions with Paper.js classes. // Some native javascript classes have name collisions with Paper.js classes.
// Store them before `paper.install()` to be able to use them later in tests. // If they have not already been stored in `src/load.js`, do it now:
var nativeClasses = { var nativeClasses = this.nativeClasses || {
Event: Event, Event: this.Event || {},
MouseEvent: MouseEvent MouseEvent: this.MouseEvent || {}
}; };
// The unit-tests expect the paper classes to be global. // The unit-tests expect the paper classes to be global.
@ -678,10 +678,12 @@ var triggerMouseEvent = function(type, point, target) {
target = target || (type === 'mousedown' ? view.element : document); target = target || (type === 'mousedown' ? view.element : document);
// If `gulp load` was run, there is a name collision between paper Event / // If `gulp load` was run, there is a name collision between paper Event /
// MouseEvent and native javascript classes. In this case, we need to use // MouseEvent and native javascript classes. In this case, we need to use
// native classes stored in global NativeClasses object instead. // native classes stored in the nativeClasses object instead.
// MouseEvent class does not exist in PhantomJS, so in that case, we need to // MouseEvent class does not exist in PhantomJS, so in that case, we need to
// use a polyfill method. // use a polyfill method, see: https://stackoverflow.com/questions/42929639
var MouseEvent = nativeClasses.MouseEvent || MouseEventPolyfill; var MouseEvent = typeof nativeClasses.MouseEvent === 'function'
? nativeClasses.MouseEvent
: MouseEventPolyfill;
var event = new MouseEvent(type, { var event = new MouseEvent(type, {
bubbles: true, bubbles: true,
cancelable: true, cancelable: true,