diff --git a/Gruntfile.js b/Gruntfile.js index 6f632861d..c66342ddd 100644 --- a/Gruntfile.js +++ b/Gruntfile.js @@ -99,6 +99,7 @@ grunt.initConfig( { "test/only.html", "test/seed.html", "test/overload.html", + "test/preconfigured.html", "test/regex-filter.html", "test/regex-exclude-filter.html", "test/string-filter.html" diff --git a/src/core/config.js b/src/core/config.js index 5ecd0a097..07870738d 100644 --- a/src/core/config.js +++ b/src/core/config.js @@ -1,4 +1,5 @@ -import { sessionStorage } from "../globals"; +import { window, sessionStorage } from "../globals"; +import { extend } from "./utilities"; /** * Config object: Maintain internal state @@ -56,6 +57,10 @@ const config = { storage: sessionStorage }; +// take a predefined QUnit.config and extend the defaults +var globalConfig = window && window.QUnit && window.QUnit.config; +extend( config, globalConfig ); + // Push a loose unnamed module to the modules collection config.modules.push( config.currentModule ); diff --git a/src/export.js b/src/export.js index c885f69ab..4089cfbdf 100644 --- a/src/export.js +++ b/src/export.js @@ -47,7 +47,9 @@ Object.defineProperty( QUnit, "reset", { } ); if ( defined.document ) { - if ( window.QUnit ) { + + // QUnit may be defined when it is preconfigured but then only QUnit and QUnit.config may be defined. + if ( window.QUnit && window.QUnit.version ) { throw new Error( "QUnit has already been defined." ); } diff --git a/test/preconfigured.html b/test/preconfigured.html new file mode 100644 index 000000000..0205b3f02 --- /dev/null +++ b/test/preconfigured.html @@ -0,0 +1,21 @@ + + +
+ +