aboutsummaryrefslogtreecommitdiffstats
path: root/web/src/vendor/qunit
diff options
context:
space:
mode:
authorMaximilian Hils <git@maximilianhils.com>2014-09-13 16:28:45 +0200
committerMaximilian Hils <git@maximilianhils.com>2014-09-13 16:28:45 +0200
commitb59234e25db8418cd53795ce94dda943e54f8ac1 (patch)
tree0fae4d0f0fba8330327a834f0ff2b1ce733fc002 /web/src/vendor/qunit
parent2842f25b82799315c36a81564619cb5467bff61f (diff)
downloadmitmproxy-b59234e25db8418cd53795ce94dda943e54f8ac1.tar.gz
mitmproxy-b59234e25db8418cd53795ce94dda943e54f8ac1.tar.bz2
mitmproxy-b59234e25db8418cd53795ce94dda943e54f8ac1.zip
use bowser-installer
Diffstat (limited to 'web/src/vendor/qunit')
-rw-r--r--web/src/vendor/qunit/.bower.json28
-rw-r--r--web/src/vendor/qunit/AUTHORS.txt90
-rw-r--r--web/src/vendor/qunit/CONTRIBUTING.md5
-rw-r--r--web/src/vendor/qunit/History.md570
-rw-r--r--web/src/vendor/qunit/LICENSE.txt37
-rw-r--r--web/src/vendor/qunit/README.md56
-rw-r--r--web/src/vendor/qunit/bower.json18
-rw-r--r--web/src/vendor/qunit/browserstack.json27
-rw-r--r--web/src/vendor/qunit/build/release.js28
-rw-r--r--web/src/vendor/qunit/external/jsdiff/jsdiff.js146
-rw-r--r--web/src/vendor/qunit/qunit.css (renamed from web/src/vendor/qunit/qunit/qunit.css)0
-rw-r--r--web/src/vendor/qunit/qunit.js (renamed from web/src/vendor/qunit/qunit/qunit.js)0
-rw-r--r--web/src/vendor/qunit/reporter/html.js682
-rw-r--r--web/src/vendor/qunit/src/assert.js180
-rw-r--r--web/src/vendor/qunit/src/core.js695
-rw-r--r--web/src/vendor/qunit/src/dump.js240
-rw-r--r--web/src/vendor/qunit/src/equiv.js218
-rw-r--r--web/src/vendor/qunit/src/export.js54
-rw-r--r--web/src/vendor/qunit/src/intro.js12
-rw-r--r--web/src/vendor/qunit/src/outro.js4
-rw-r--r--web/src/vendor/qunit/src/qunit.css237
-rw-r--r--web/src/vendor/qunit/src/test.js254
22 files changed, 0 insertions, 3581 deletions
diff --git a/web/src/vendor/qunit/.bower.json b/web/src/vendor/qunit/.bower.json
deleted file mode 100644
index 35467e8c..00000000
--- a/web/src/vendor/qunit/.bower.json
+++ /dev/null
@@ -1,28 +0,0 @@
-{
- "name": "qunit",
- "main": [
- "qunit/qunit.js",
- "qunit/qunit.css"
- ],
- "license": "https://github.com/jquery/qunit/blob/master/LICENSE.txt",
- "ignore": [
- "**/.*",
- "!LICENSE.txt",
- "package.json",
- "bower.json",
- "Gruntfile.js",
- "node_modules",
- "test"
- ],
- "version": "1.15.0",
- "homepage": "https://github.com/jquery/qunit",
- "_release": "1.15.0",
- "_resolution": {
- "type": "version",
- "tag": "1.15.0",
- "commit": "fad833435127e51de7fda2975377ac8e91fe7210"
- },
- "_source": "git://github.com/jquery/qunit.git",
- "_target": "*",
- "_originalSource": "qunit"
-} \ No newline at end of file
diff --git a/web/src/vendor/qunit/AUTHORS.txt b/web/src/vendor/qunit/AUTHORS.txt
deleted file mode 100644
index 757952b1..00000000
--- a/web/src/vendor/qunit/AUTHORS.txt
+++ /dev/null
@@ -1,90 +0,0 @@
-Jörn Zaefferer <joern.zaefferer@gmail.com>
-Ariel Flesler <aflesler@gmail.com>
-Scott González <scott.gonzalez@gmail.com>
-Richard Worth <rdworth@gmail.com>
-Philippe Rathé <prathe@gmail.com>
-John Resig <jeresig@gmail.com>
-Will Moffat <will_git@hamstersoup.com>
-Jan Kassens <jan@kassens.net>
-Ziling Zhao <zizhao@cisco.com>
-Ryan Szulczewski <musicmanryan@gmail.com>
-Chris Lloyd <christopher.lloyd@gmail.com>
-Louis-Rémi Babé <lrbabe@gmail.com>
-Jake Archibald <jaffathecake@gmail.com>
-Frances Berriman <frances.berriman@bbc.co.uk>
-Rune Halvorsen <runefh@gmail.com>
-Chris Thatcher <thatcher.christopher@gmail.com>
-Fábio Rehm <fgrehm@gmail.com>
-Leon Sorokin <leeoniya@gmail.com>
-Douglas Neiner <doug@pixelgraphics.us>
-Paul Elliott <paul@hashrocket.com>
-Nikita Vasilyev <me@elv1s.ru>
-Benjamin Lee <leebenjp@gmail.com>
-Paul Irish <paul.irish@gmail.com>
-Oleg Slobodskoi <oleg008@gmail.com>
-Anton Matzneller <obhvsbypqghgc@gmail.com>
-Aurélien Bombo <hellosexyprout@gmail.com>
-Mathias Bynens <mathias@qiwi.be>
-Erik Vold <erikvvold@gmail.com>
-Wesley Walser <waw325@gmail.com>
-Rob Kinninmont <robk@twitter.com>
-Marc Portier <marc.portier@gmail.com>
-Michael Righi <michael@righi.me>
-Timo Tijhof <krinklemail@gmail.com>
-Jan Alonzo <jmalonzo@taguchimail.com>
-Daniel Trebbien <dtrebbien@gmail.com>
-Bob Fanger <bfanger@gmail.com>
-Markus Messner-Chaney <markus.messner-chaney@xing.com>
-Trevor Parscal <trevorparscal@gmail.com>
-Ashar Voultoiz <hashar@free.fr>
-Jimmy Mabey <jimmy@velsoft.com>
-Domenic Denicola <domenic@domenicdenicola.com>
-Mike Sherov <mike.sherov@gmail.com>
-Seong-A Kong <simonz@daumcorp.com>
-Graham Conzett <conzett@gmail.com>
-Niall Smart <niall@pobox.com>
-Johan Sörlin <spocke@moxiecode.com>
-Gijs Kruitbosch <gijskruitbosch@gmail.com>
-Erkan Yilmaz <erkan77@gmail.com>
-Jonathan Sanchez <jsanchezpando@cirb.irisnet.be>
-Keith Cirkel <github@keithcirkel.co.uk>
-Rick Waldron <waldron.rick@gmail.com>
-Herbert Vojčík <herby@mailbox.sk>
-Richard Gibson <richard.gibson@gmail.com>
-Alex J Burke <alex@alexjeffburke.com>
-Sergii Kliuchnyk <sergiikliuchnyk@gmail.com>
-Corey Frang <gnarf@gnarf.net>
-John Reeves <john@jonnyreeves.co.uk>
-Antranig Basman <amb26ohloh@ponder.org.uk>
-Vivin Paliath <vivin.paliath@gmail.com>
-Joshua Niehus <jm.niehus@gmail.com>
-Glen Huang <curvedmark@gmail.com>
-Jochen Ulrich <jochenulrich@t-online.de>
-Jamie Hoover <jamie@ninjaui.com>
-James M. Greene <james.m.greene@gmail.com>
-Rodney Rehm <mail+github@rodneyrehm.de>
-Peter Wagenet <peter.wagenet@gmail.com>
-Clog <flewya@gmail.com>
-Matthew Mirande <itsbusticated@gmail.com>
-Jared Wyles <jared.wyles@gmail.com>
-Dmitry Gusev <dmitry.gusev@gmail.com>
-Ian Wallis <qazzian@gmail.com>
-Dan Andreescu <dan.andreescu@gmail.com>
-Matthew DuVall <mduvall89@gmail.com>
-Dave K. Smith <dave.k.smith@gmail.com>
-David Vollbracht <david.vollbracht@gmail.com>
-Katie Gengler <katie@kmg.io>
-Joshua Peek <josh@joshpeek.com>
-Leonardo Balter <leonardo.balter@gmail.com>
-Jeff Cooper <jeff@kickstorming.com>
-Corey Frang <gnarf37@gmail.com>
-Nathan Dauber <nathan@radialogica.com>
-Michał Gołębiowski <m.goleb@gmail.com>
-XhmikosR <xhmikosr@yahoo.com>
-Patrick Stapleton <github@gdi2290.com>
-DarkPark <darkpark@pisem.net>
-Oleg Gaidarenko <markelog@gmail.com>
-Mike Sidorov <mikes.ekb@gmail.com>
-Don Kirkby <donkirkby@gmail.com>
-don <dkirkby@cfenet.ubc.ca>
-Sean Xu <jseanxu@live.com>
diff --git a/web/src/vendor/qunit/CONTRIBUTING.md b/web/src/vendor/qunit/CONTRIBUTING.md
deleted file mode 100644
index 2bf8a1b4..00000000
--- a/web/src/vendor/qunit/CONTRIBUTING.md
+++ /dev/null
@@ -1,5 +0,0 @@
-Welcome! Thanks for your interest in contributing to QUnit. You're **almost** in the right place. More information on how to contribute to this and all other jQuery Foundation projects is over at [contribute.jquery.org](http://contribute.jquery.org). You'll definitely want to take a look at the articles on contributing [code](http://contribute.jquery.org/code).
-
-You may also want to take a look at our [commit & pull request guide](http://contribute.jquery.org/commits-and-pull-requests/) and [style guides](http://contribute.jquery.org/style-guide/) for instructions on how to maintain your fork and submit your code. Before we can merge any pull request, we'll also need you to sign our [contributor license agreement](http://contribute.jquery.org/cla).
-
-You can find us on [IRC](http://irc.jquery.org), specifically in #jquery-dev should you have any questions. If you've never contributed to open source before, we've put together [a short guide with tips, tricks, and ideas on getting started](http://contribute.jquery.org/open-source/).
diff --git a/web/src/vendor/qunit/History.md b/web/src/vendor/qunit/History.md
deleted file mode 100644
index df60571a..00000000
--- a/web/src/vendor/qunit/History.md
+++ /dev/null
@@ -1,570 +0,0 @@
-1.15.0 / 2014-08-08
-==================
-
-* Assert: Implement Assert constructor with test context. This heavily improves debugging of async tests, since assertions can't leak into other tests anymore. Use the assert argument in your test callbacks to run assertions to get the full benefit of this.
-* Assert: Improved the default message from assert.ok. Now assert.ok() outputs the exact value it received, instead of only saying it wasn't thruthy.
-* Assert: Removal of raises, same and equals. These were deprecated a long time ago and finally removed. Use throws, deepEqual and equal instead.
-* Core: Pass total amount of tests to QUnit.begin callback as totalTests. Will be used by Karma and other reporters.
-* Dump: Move QUnit.jsDump to QUnit.dump. QUnit.jsDump still exists, but will be removed later. Use QUnit.dump.
-* Dump: Output non-enumerable properties of TypeError. Makes it easier to compare properties of error objects.
-* Reporter: Output only assertion count for green tests. Less visual clutter for passing tests.
-* Reporter: Move HTML reporter to a new JS file. The HTML reporter is still bundled, but the code has been refactored to move it to a separate file.
-* Test: Remove deprecated QUnit.current_testEnvironment
-* Throws: support for oldIE native Error types. Error objects in IE are buggy, this works around those issues.
-
-1.14.0 / 2014-01-31
-==================
-
- * Grunt: Run tests on ios browserSet as well
- * Package: Set main property to qunit/qunit.js
- * Grunt: Inline browserSet config for TestSwarm runs
- * CSS: Removing redundancy
- * Core: Add config property for disabling default scroll-to-top
- * Grunt: Remove addons leftovers
- * Addons: Remove last remnants
- * Core: Extend QUnit.config.urlConfig to support select-one dropdowns
- * Assert: Extend throws to accept Error instances
- * Assert: Extend throws to handle errors as strings
- * CSS: Updating qunit.css for consistency
- * Core: Cache window.clearTimeout in case it gets mocked
- * Core: Run multiple tests by test number
- * jshint: add es3 option to ensure oldie support
-
-1.13.0 / 2014-01-04
-==================
-
- * Tests: Stop using the expected argument in test() calls
- * Logging: Add runtime property to testDone, deprecate duration
- * Assert: Remove raises (deprecated 2012), replace with failed assertion
- * Grunt: Add non-browser test as grunt task. Runs existing tests in node.
- * Export: Only export to the variable that we check for.
- * Core: Properly check for existence of document
- * Core: Remove triggerEvent, which isn't used or documented anywhere.
- * Core: Silence addEvent in non-browser env
- * The Grand QUnit Split of 2013
- * Use `id` function for selection elements in two places that were not using it. Closes gh-463
- * Add bower.json. Fixes #461
-
-1.12.0 / 2013-06-21
-===================
-
- * Add a deprecation comment to QUnit.reset. Partial fix for #354
- * Fix mis-match between moduleStart and moduleDone events
- * Removed jQuery.trim optimization. Fixes #424.
- * Use a local setTimeout reference, add separate unit test suite for that. Fixes #432 - Using a setTimeout stub can stop test suite from continuing. Closes gh-433
- * Added CONTRIBUTING.md.
- * Moved 'addons/themes/nv' to 'Krinkle/qunit-theme-nv.git'
- * Moved 'addons/themes/ninja' to 'Krinkle/qunit-theme-ninja.git'
- * Moved 'addons/themes/gabe' to 'Krinkle/qunit-theme-gabe.git'
- * Moved 'addons/canvas' to 'JamesMGreene/qunit-assert-canvas.git'. Tree: https://github.com/JamesMGreene/qunit-assert-canvas/tree/v1.0.0
- * Moved 'addons/close-enough' to 'JamesMGreene/qunit-assert-close.git'. Tree: https://github.com/JamesMGreene/qunit-assert-close/tree/v1.0.0
- * Moved 'addons/step' to 'JamesMGreene/qunit-assert-step.git'. Tree: https://github.com/JamesMGreene/qunit-assert-step/tree/v1.0.0
- * Canvas plugin: Show how to test with images. Closes gh-438.
- * Clear filter and testNumber when choosing a module. Fixes #442.
- * Deprecate QUnit.current_testEnvironment in favour of config.current.testEnvironment.
- * assert.ok: Message shouldn't be undefined in 'log' event.
- * Emit moduleStart before testStart even if test isn't in a module.
- * PhantomJS plugin: Added optional timeout. Closes #415.
- * PhantomJS plugin: Include stack trace for all failed tests. Closes #416.
- * Moved 'addons/composite' to 'jquery/qunit-composite.git'. Tree: https://github.com/jquery/qunit-composite/tree/v1.0.0 Fixes #419.
- * Moved 'addons/junitlogger' to 'jquery/qunit-reporter-junit.git'.
- * Sort the module names so we no longer rely on implicit ordering. Fixes #391. Closes gh-392
- * JUnitLogger: Add a `name` property to the test run. Closes gh-389
- * Improve circular reference logic in equiv - Fixes #397
-
-1.11.0 / 2013-01-20
-==================
-
- * Diff: Fix exception on property "constructor". Fixes #394.
- * Composite Add-on: Test suites can be named by including an obj with name & path props within array param for .testSuites()
- * Fix URL generator to take protocol and host into account to fix usage with file protocol in IE7/8
- * Fix issue with Error.prototype.toString in IE 7
- * Refactor jsDump for "node". Fixes #381.
- * Show contents of text nodes in jsDump.node. Fixes #380.
- * Escape text. Fixes #379.
- * Rewrote most of the JUnitLogger addon as it was in bad shape: unused variables, duplicate effort that QUnit handles internally (e.g. tallying number of total assertions, failed assertions, etc.), sub-optimal XmlWriter implementation, etc.
- * Phantomjs: Include source in assertion details
- * Phantomjs: Removed the polling mechanism in favor of PhantomJS 1.6+'s `WebPage#onCallback`
- * Delay start() until init() happened. Fixes #358. Closes #373.
- * urlConfig: Fix checkbox event for oldIE. Fixes #369. Closes #370.
- * Issue #365: Fix module picker for oldIE. Closes #366.
- * Fixes #344 - Capture and show test duration.
- * Rename tests to assertions in summary. Fixes #336 - Summary counts assertions but mentions 'tests'.
- * Assert: Implement propEqual and notPropEqual. Fixes #317.
- * Canvas addon: Use 0.6 as alpha value to avoid inconsistencies between browsers. Fixes #342
- * Remove global variable "assert". Fixes #341.
- * Add a test for loading tests asynchronously
- * Improve start()-called-too-often fix, initialize semaphore at 1, fixes autostart=false case. Also provide stack for the offending start() call
- * There's type-free objects in Firefox, extend objectType() to allow null match. Fixes #315
- * Push a failing assertion when calling start() while already running. Resets anyway to keep other tests going. Fixes #314
- * Adds Ninja Theme
- * Extend jsdump to output Error objects as such, including the message property. Extend throws to provide 'expected' value when possible. Fixes #307
- * Use classes to collapse assertion groups. Fixes #269
- * Readme for junitlogger addon
- * Better readme for composite addon
- * Make `throws` ES3 compatible
- * Composite: Adds test whether iframe contains content. Fixes #318 - Composite: Raises "global failure" in Opera
- * Apply the same exception handling for test and teardown try/catch as for setup
-
-1.10.0 / 2012-08-30
-==================
-
- * Simplify licensing: Only MIT, no more MIT/GPL dual licensing.
- * Scroll the window back to top after tests finished running. Fixes #304
- * Simplify phantomjs runner to use module property in testDone callback
- * Adds module and test name to the information that is returned in the callback provided to QUnit.log(Function). Fixes #296
- * Make QUnit.expect() (without arguments) a getter. Fixes #226
- * Compare the ES6 sticky (y) property for RegExp. Can't add to tests yet. Fixes #284 - deepEqual for RegExp should compare
- * onerror: force display of global errors despite URL parameters. Fixes #288 - Global failures can be filtered out by test-limiting URL parameters
- * Remove conditional codepath based on jQuery presence from reset().
- * Add module filter to UI
- * Keep a local reference to Date. Fixes #283.
- * Update copyright to jQuery Foundation.
-
-1.9.0 / 2012-07-11
-==================
- * added jsdoc for QUnit.assert functions
- * Styling: radius to 5px and small pass/error border, remove inner shadow
- * Move checkboxes into toolbar and give them labels and descriptions (as tooltip). Fixes #274 - Improve urlFilter API and UI
- * Where we receive no exception in throws() use a relevant message.
- * Also make module filter case-insensitive. Follow-up to #252
- * Banner: Link should ignore "testNumber" and "module". Fixes #270
- * Rename assert.raises to assert.throws. Fixes #267
- * Change package.json name property to 'qunitjs' to avoid conflict with node-qunit; will publish next release to npm
-
-1.8.0 / 2012-06-14
-==================
- * Improve window.onerror handling
- * (issue #260) config.current should be reset at the right time.
- * Filter: Implement 'module' url parameter. Fixes #252
- * raises: ignore global exceptions stemming from test. Fixes #257 - Globally-executed errors sneak past raises in IE
-
-1.7.0 / 2012-06-07
-==================
-
- * Add config.requireExpects. Fixes #207 - Add option to require all tests to call expect().
- * Improve extractStacktrace() implementation. Fixes #254 - Include all relevant stack lines
- * Make filters case-insensitive. Partial fix for #252
- * is() expects lowercase types. Fixes #250 - Expected Date value is not displayed properly
- * Fix phantomjs addon header and add readme. Fixes #239
- * Add some hints to composite addon readme. Fixes #251
- * Track tests by the order in which they were run and create rerun links based on that number. Fixes #241 - Make Rerun link run only a single test.
- * Use QUnit.push for raises implementation. Fixes #243
- * CLI runner for phantomjs
- * Fix jshint validation until they deal with /** */ comments properly
- * Update validTest() : Simplify logic, clarify vars and add comments
- * Refactor assertion helpers into QUnit.assert (backwards compatible)
- * Add Rerun link to placeholders. Fixes #240
-
-1.6.0 / 2012-05-04
-==================
-
- * Save stack for each test, use that for failed expect() results, points at the line where test() was called. Fixes #209
- * Prefix test-output id and ignore that in noglobals check. Fixes #212
- * Only check for an exports object to detect a CommonJS environment. Fixes #237 - Incompatibility with require.js
- * Add testswarm integration as grunt task
- * Added padding on URL config checkboxes.
- * Cleanup composite addon: Use callback registration instead of overwriting them. Set the correct src on rerun link (and dblclick). Remove the composite test itself, as that was a crazy hack not worth maintaining
- * Cleanup reset() test and usage - run testDone callback first, to allow listeneres ignoring reset assertions
- * Double clicking on composite test rows opens individual test page
- * test-message for all message-bearing API reporting details
-
-1.5.0 / 2012-04-04
-==================
-
- * Modify "Running..." to display test name. Fixes #220
- * Fixed clearing of sessionStorage in Firefox 3.6.
- * Fixes #217 by calling "block" with config.current.testEnvironment
- * Add stats results to data. QUnit.jUnitReport function take one argument { xml:'<?xml ...', results:{failed:0, passed:0, total:0, time:0} }
- * Add link to MDN about stack property
-
-1.4.0 / 2012-03-10
-==================
-
- * Prefix test-related session-storage items to make removal more specific. Fixes #213 - Keep hide-passed state when clearing session storage
- * Update grunt.js with separate configs for qunit.js and grunt.js, also add tests but disable for now, not passing yet. Add grunt to devDependencies
- * typo
- * Cleanup grunt.js, no need for the banner
- * Fix lint errors and some formatting issues. Use QUnit.pushFailure for noglobals and global error handler.
- * Fix a missing expect in logs test
- * Add grunt.js configuration and include some usage instructions in the readme
- * Update package.json
- * Partially revert af27eae841c3e1c01c46de72d676f1047e1ee375 - can't move reset around, so also don't wrap in try-catch, as the result of that is effectively swallowed. Can't output the result as the outputting is already done.
- * Add QUnit.pushFailure to log error conditions like exceptions. Accepts stacktrace as second argument, allowing extraction with catched exceptions (useful even in Safari). Remove old fail() function that would just log to console, not useful anymore as regular test output is much more useful by now. Move up QUnit.reset() call to just make that another failed assertion. Used to not make a test fail. Fixes #210
- * Update equals and same deprecations to use QUnit.push to provide correct source lines. Fixes #211
- * Add a test file for narwhal integration. Has to use print instead of console.log. Fails when an assertion fails, something about setInterval...
- * Apply notrycatch option to setup and teardown as well. Fixes #203. Reorder noglobals check to allow teardown to remove globals that were introduced intentionally. Fixes #204
- * Extend exports object with QUnit properties at the end of the file to export everything.
- * Output source line for ok() assertions. Fixes #202
- * Make test fail if no assertions run. Fixes #178
- * Sort object output alphabetically in order to improve diffs of objects where properties were set in a different order. Fixes #206
- * Revert "Change fixture reset behavior", changing #194 and #195 to wontfix.
-
-1.3.0 / 2012-02-26
-==================
-
- * Cleanup test markup
- * Fix the jQuery branch of fixture reset. Would break when no fixture exists.
- * Added initial version of a junitlogger addon.
- * Escape document.title before inserting into markup. Extends fix for #127
- * Catch assertions running outside of test() context, make sure source is provided even for ok(). Fixes #98
- * Improve global object access, based on comments for 1a9120651d5464773256d8a1f2cf2eabe38ea5b3
- * Clear all sessionStorage entries once all tests passed. Helps getting rid of items from renamed tests. Fixes #101
- * Set fixed dimensions for #qunit-fixture. Fixes #114
- * Extend nodejs test runner to check for stacktrace output, twice
- * Extend nodejs test runner to check for stacktrace output
- * Generate more base markup, but allow the user to exclude that completely or choose their own. Fixes #127
- * Add a simple test file to check basic nodejs integration works
- * Check for global object to find setTimeout in node
- * Fix CommonJS export by assigning QUnit to module.exports.
- * Remove the testEnvironmentArg to test(). Most obscure, never used anywhere. test() is still heavily overloaded with argument shifting, this makes it a little more sane. Fixes #172
- * Serialize expected and actual values only when test fails. Speeds up output of valid tests, especially for lots of large objects. Fixes #183
- * Fix sourceFromsTacktrace to get the right line in Firefox. Shift the 'error' line away in Chrome to get a match.
- * Fix references to test/deepEqual.js
- * In autorun mode, moduleDone is called without matching moduleStart. Fix issue #184
- * Fixture test: allow anything falsy in test as getAttribute in oldIE will return empty string instead of null. We don't really care.
- * Keep label and checkbox together ( http://i.imgur.com/5Wk3A.png )
- * Add readme for themes
- * Fix bad global in reset()
- * Some cleanup in theme addons
- * Update headers
- * Update nv.html, add gabe theme based on https://github.com/jquery/qunit/pull/188
- * Experimental custom theme based on https://github.com/jquery/qunit/pull/62 by NV
- * Replace deprecated same and equals aliases with placeholders that just throw errors, providing a hint at what to use instead. Rename test file to match that.
- * Can't rely on outerHTML for Firefox < 11. Use cloneNode instead.
- * Merge remote branch 'conzett/master'
- * Cleanup whitespace
- * Update sessionStorage support test to latest version from Modernizr, trying to setItem to avoid QUOTA_EXCEEDED_EXCEPTION
- * Change fixture reset behavior
- * Merge pull request #181 from simonz/development
- * Escaping test names
- * Show exception stack when test failed
-
-1.2.0 / 2011-11-24
-==================
-
- * remove uses of equals(), as it's deprecated in favor of equal()
- * Code review of "Allow objects with no prototype to be tested against object literals."
- * Allow objects with no prototype to tested against object literals.
- * Fix IE8 "Member not found" error
- * Using node-qunit port, the start/stop function are not exposed so we need to prefix any call to them with 'QUnit'. Aka: start() -> QUnit.start()
- * Remove the 'let teardown clean up globals test' - IE<9 doesn't support (==buggy) deleting window properties, and that's not worth the trouble, as everything else passes just fine. Fixes #155
- * Fix globals in test.js, part 2
- * Fix globals in test.js. ?tell wwalser to use ?noglobals everyonce in a while
- * Extend readme regarding release process
-
-1.1.0 / 2011-10-11
-==================
-
- * Fixes #134 - Add a window.onerror handler. Makes uncaught errors actually fail the testsuite, instead of going by unnoticed.
- * Whitespace cleanup
- * Merge remote branch 'trevorparscal/master'
- * Fixed IE compatibility issues with using toString on NodeList objects, which in some browsers results in [object Object] rather than [object NodeList]. Now using duck typing for NodeList objects based on the presence of length, length being a number, presence of item method (which will be typeof string in IE and function in others, so we just check that it's not undefined) and that item(0) returns the same value as [0], unless it's empty, in which case item(0) will return 0, while [0] would return undefined. Tested in IE6, IE8, Firefox 6, Safari 5 and Chrome 16.
- * Update readme with basic notes on releases
- * More whitespace/parens cleanup
- * Check if setTimeout is available before trying to delay running the next task. Fixes #160
- * Whitespace/formatting fix, remove unnecessary parens
- * Use alias for Object.prototype.toString
- * Merge remote branch 'trevorparscal/master'
- * Merge remote branch 'wwalser/recursionBug'
- * Default 'expected' to null in asyncTest(), same as in test() itself.
- * Whitespace cleanup
- * Merge remote branch 'mmchaney/master'
- * Merge remote branch 'Krinkle/master'
- * Using === instead of ==
- * Added more strict array type detection for dump output, and allowed NodeList objects to be output as arrays
- * Fixes a bug where after an async test, assertions could move between test cases because of internal state (config.current) being incorrectly set
- * Simplified check for assertion count and adjusted whitespace
- * Redo of fixing issue #156 (Support Object.prototype extending environment). * QUnit.diff: Throws exception without this if Object.prototype is set (Property 'length' of undefined. Since Object.prototype.foo doesn't have a property 'rows') * QUnit.url: Without this fix, if Object.prototype.foo is set, the url will be set to ?foo=...&the=rest. * saveGlobals: Without this fix, whenever a member is added to Object.prototype, saveGlobals will think it was a global variable in this loop. --- This time using the call method instead of obj.hasOwnProperty(key), which may fail if the object has that as it's own property (touché!).
- * Handle expect(0) as expected, i.e. expect(0); ok(true, foo); will cause a test to fail
-
-1.0.0 / 2011-10-06
-==================
-
- * Make QUnit work with TestSwarm
- * Run other addons tests as composite addon demo. Need to move that to /test folder once this setup actually works
- * Add-on: New assertion-type: step()
- * added parameter to start and stop allowing a user to increment/decrement the semaphore more than once per call
- * Update readmes with .md extension for GitHub to render them as markdown
- * Update close-enough addon to include readme and match (new) naming conventions
- * Merge remote branch 'righi/close-enough-addon'
- * Canvas addon: Update file references
- * Update canvas addon: Rename files and add README
- * Merge remote branch 'wwalser/composite'
- * Fix #142 - Backslash characters in messages should not be escaped
- * Add module name to testStart and testDone callbacks
- * Removed extra columns in object literals. Closes #153
- * Remove dead links in comments.
- * Merge remote branch 'wwalser/multipleCallbacks'
- * Fixed syntax error and CommonJS incompatibilities in package.json
- * Allow multiple callbacks to be registered.
- * Add placeholder for when Safari may end up providing useful error handling
- * changed file names to match addon naming convention
- * Whitespace
- * Created the composite addon.
- * Using array and object literals.
- * Issue #140: Make toggle system configurable.
- * Merge remote branch 'tweetdeck/master'
- * Adds the 'close enough' addon to determine if numbers are acceptably close enough in value.
- * Fix recursion support in jsDump, along with tests. Fixes #63 and #100
- * Adding a QUnit.config.altertitle flag which will allow users to opt-out of the functionality introduced in 60147ca0164e3d810b8a9bf46981c3d9cc569efc
- * Refactor window.load handler into QUnit.load, makes it possible to call it manually.
- * More whitespace cleanup
- * Merge remote branch 'erikvold/one-chk-in-title'
- * Whitespace
- * Merge remote branch 'wwalser/syncStopCalls'
- * Introducing the first QUnit addon, based on https://github.com/jquery/qunit/pull/84 - adds QUnit.pixelEqual assertion method, along with example tests.
- * Remove config.hidepassed setting in test.js, wasn't intended to land in master.
- * Expose QUnit.config.hidepassed setting. Overrides sessionStorage and enables enabling the feature programmatically. Fixes #133
- * Fix formatting (css whitespace) for tracebacks.
- * Expose extend, id, and addEvent methods.
- * minor comment typo correction
- * Ignore Eclipse WTP .settings
- * Set 'The jQuery Project' as author in package.json
- * Fixes a bug where synchronous calls to stop would cause tests to end before start was called again
- * Point to planning testing wiki in readme
- * only add one checkmark to the document.title
- * Escape the stacktrace output before setting it as innerHTML, since it tends to contain `<` and `>` characters.
- * Cleanup whitespace
- * Run module.teardown before checking for pollution. Fixes #109 - noglobals should run after module teardown
- * Fix accidental global variable "not"
- * Update document.title status to use more robust unicode escape sequences, works even when served with non-utf-8-charset.
- * Modify document.title when suite is done to show success/failure in tab, allows you to see the overall result without seeing the tab content.
- * Merge pull request #107 from sexyprout/master
- * Set a generic font
- * Add/update headers
- * Drop support for deprecated #main in favor of #qunit-fixture. If this breaks your testsuite, replace id="main" with id="qunit-fixture". Fixes #103
- * Remove the same key as the one being set. Partial fix for #101
- * Don't modify expected-count when checking pollution. The failing assertion isn't expected, so shouldn't be counted. And if expect wasn't used, the count is misleading.
- * Fix order of noglobals check to produce correct introduced/delete error messages
- * Prepend module name to sessionStorage keys to avoid conflicts
- * Store filter-tests only when checked
- * Write to sessionStorage only bad tests
- * Moved QUnit.url() definition after QUnit properties are merged into the global scope. Fixes #93 - QUnit url/extend function breaking urls in jQuery ajax test component
- * Add a "Rerun" link to each test to replace the dblclick (still supported, for now).
- * Fixed the regex for parsing the name of a test when double clicking to filter.
- * Merge remote branch 'scottgonzalez/url'
- * Added checkboxes to show which flags are currently on and allow toggling them.
- * Retain all querystring parameters when filtering a test via double click.
- * Added better querystring parsing. Now storing all querystring params in QUnit.urlParams so that we can carry the params forward when filtering to a specific test. This removes the ability to specify multiple filters.
- * Make reordering optional (QUnit.config.reorder = false) and optimize "Hide passed tests" mode by also hiding "Running [testname]" entries.
- * Added missing semicolons and wrapped undefined key in quotes.
- * Optimize test hiding, add class on page load if stored in sessionStorage
- * Optimize the hiding of passed tests.
- * Position test results above test list, making it visible without ever having to scroll. Create a placeholder to avoid pushing down results later.
- * Don't check for existing qunit-testresult element, it gets killed on init anyway.
- * Added URL flag ?notrycatch (ala ?noglobals) for debugging exceptions. Won't try/catch test code, giving better debugging changes on the original exceptions. Fixes #72
- * Always show qunit-toolbar (if at all specified), persist checkbox via sessionStorage. Fixes #47
- * Use non-html testname for calls to fail(). Fixes #77
- * Overhaul of QUnit.callbacks. Consistent single argument with related properties, with additional runtime property for QUnit.done
- * Extended test/logs.html to capture more of the callbacks.
- * Fixed moduleStart/Done callbacks. Added test/logs.html to test these callbacks. To be extended.
- * Update copyright and license header. Fixes #61
- * Formatting fix.
- * Use a semaphore to synchronize stop() and start() calls. Fixes #76
- * Merge branch 'master' of https://github.com/paulirish/qunit into paulirish-master
- * Added two tests for previous QUnit.raises behaviour. For #69
- * add optional 2. arg to QUnit.raises #69.
- * fix references inside Complex Instances Nesting to what was originally intended.
- * Qualify calls to ok() in raises() for compatibility with CLI environments.
- * Fix done() handling, check for blocking, not block property
- * Fix moduleStart/Done and done callbacks.
- * Replacing sessionStorage test with the one from Modernizr/master (instead of current release). Here's hoping it'll work for some time.
- * Updated test for availability of sessionStorage, based on test from Modernizr. Fixes #64
- * Defer test execution when previous run passed, persisted via sessionStorage. Fixes #49
- * Refactored module handling and queuing to enable selective defer of test runs.
- * Move assertions property from config to Test
- * Move expected-tests property from config to Test
- * Refactored test() method to delegate to a Test object to encapsulate all properties and methods of a single test, allowing further modifications.
- * Adding output of sourcefile and linenumber of failed assertions (except ok()). Only limited cross-browser support for now. Fixes #60
- * Drop 'hide missing tests' feature. Fixes #48
- * Adding readme. Fixes #58
- * Merge branch 'prettydiff'
- * Improve jsDump output with formatted diffs.
- * Cleanup whitespace
- * Cleanup whitespace
- * Added additional guards around browser specific code and cleaned up jsDump code
- * Added guards around tests which are only for browsers
- * cleaned up setTimeout undefined checking and double done on test finish
- * fixing .gitignore
- * making window setTimeout query more consistent
- * Moved expect-code back to beginning of function, where it belongs. Fixes #52
- * Bread crumb in header: Link to suite without filters, add link to current page based on the filter, if present. Fixes #50
- * Make the toolbar element optional when checking for show/hide of test results. Fixes #46
- * Adding headless.html to manually test logging and verify that QUnit works without output elements. Keeping #qunit-fixture as a few tests actually use that.
- * Fix for QUnit.moduleDone, get rid of initial bogus log. Fixes #33
- * Pass raw data (result, message, actual, expected) as third argument to QUnit.log. Fixes #32
- * Dump full exception. Not pretty, but functional (see issue Pretty diff for pretty output). Fixes #31
- * Don't let QUnit.reset() cause assertions to run. Manually applied from Scott Gonzalez branch. Fixes #34
- * Added missing semicolons. Fixes #37
- * Show okay/failed instead of undefined. Fixes #38
- * Expose push as QUnit.push to build custom assertions. Fixes #39
- * Respect filter pass selection when writing new results. Fixes #43
- * Cleanup tests, removing asyncTest-undefined check and formatting
- * Reset: Fall back to innerHTML when jQuery isn't available. Fixes #44
- * Merge branch 'master' of github.com:jquery/qunit
- * reset doesn't exist here - fixes #28.
- * - less css cruft, better readability - replaced inline style for test counts with "counts" class - test counts now use a "failed"/"passed" vs "pass"/"fail", shorter/more distinct selectors - pulled all test counts styling together and up (they're always the same regardless of section pass/fail state)
- * Adding .gitignore file
- * Removing diff test - diffing works fine, as the browser collapses whitespace in its output, but the test can't do that and isn't worth fixing.
- * Always synchronize the done-step (it'll set the timeout when necessary), fixes timing race conditions.
- * Insert location.href as an anchor around the header. Fixes issue #29
- * - kill double ;; in escapeHtml. oops
- * Removed html escaping from QUnit.diff, as input is already escaped, only leads to double escaping. Replaced newlines with single whitespace.
- * Optimized and cleaned up CSS file
- * Making the reset-method non-global (only module, test and assertions should be global), and fixing the fixture reset by using jQuery's html() method again, doesn't work with innerHTML, yet
- * Introducing #qunit-fixture element, deprecating the (never documented) #main element. Doesn't require inline styles and is now independent of jQuery.
- * Ammending previous commit: Remove jQuery-core specific resets (will be replaced within jQuery testsuite). Fixes issue #19 - QUnit.reset() removes global jQuery ajax event handlers
- * Remove jQuery-core specific resets (will be replaced within jQuery testsuite). Fixes issue #19 - QUnit.reset() removes global jQuery ajax event handlers
- * Cleaning up rubble from the previous commit.
- * Added raises assertion, reusing some of kensnyder's code.
- * Merged kensnyder's object detection code. Original message: Streamlined object detection and exposed QUnit.objectType as a function.
- * Fixed some bad formatting.
- * Move various QUnit properties below the globals-export to avoid init becoming a global method. Fixes issue #11 - Remove 'init' function from a global namespace
- * Improved output when expected != actual: Output both only then, and add a diff. Fixes issue #10 - Show diff if equal() or deepEqual() failed
- * Expand failed tests on load. Fixes issue #8 - Failed tests expanded on load
- * Set location.search for url-filtering instead of location.href. Fixes issue #7 - Modify location.search instead of location.href on test double-click
- * Add QUnit.begin() callback. Fixes issue #6 - Add 'start' callback.
- * add css style for result (".test-actual") in passed tests
- * Fixed output escaping by using leeoniya's custom escaping along with innerHTML. Also paves the way for outputting diffs.
- * Cleanup
- * Revert "Revert part of bad merge, back to using createTextNode"
- * Revert part of bad merge, back to using createTextNode
- * Fixed doubleclick-handler and filtering to rerun only a single test.
- * Add ability to css style a test's messages, expected and actual results. Merged from Leon Sorokin (leeoniya).
- * Remove space between module name and colon
- * - removed "module" wording from reports (unneeded and cluttery) - added and modified css to make module & test names styleable
- * Logging support for Each test can extend the module testEnvironment
- * Fixing whitespace
- * Update tests to use equal() and deepEqual() rather than the deprecated equals() and same()
- * Consistent argument names for deepEqual
- * Skip DOM part of jsDump test if using a SSJS environment without a DOM
- * Improve async testing by creating the result element before running the test, updating it later. If the test fails, its clear which test is the culprit.
- * Add autostart option to config. Set via QUnit.config.autostart = false; start later via QUnit.start()
- * Expose QUnit.config, but don't make config a global
- * Expose QUnit.config as global to make external workarounds easier
- * Merge branch 'asyncsetup'
- * Allowing async setup and teardown. Fixes http://github.com/jquery/qunit/issues#issue/20
- * Always output expected and actual result (no reason not to). Fixes http://github.com/jquery/qunit/issues#issue/21
- * More changes to the detection of types in jsDump's typeOf.
- * Change the typeOf checks in QUnit to be more accurate.
- * Added test for jsDump and modified its options to properly output results when document.createTextNode is used; currently tests for DOM elements cause a stackoverflow error in IEs, works fine, with the correct output, elsewhere
- * Always use jsDump to output result objects into messages, making the output for passing assertions more useful
- * Make it so that the display is updated, at least, once a second - also prevents scripts from executing for too long and causing problems.
- * added tests and patch for qunit.equiv to avoid circular references in objects and arrays
- * No reason to continue looping, we can stop at this point. Thanks to Chris Thatcher for the suggestion.
- * Use createTextNode instead of innerHTML for showing test result since expected and actual might be something that looks like a tag.
- * 'Test card' design added
- * switched green to blue for top-level pass + reduced padding
- * Bringing the QUnit API in line with the CommonJS API.
- * Explicitly set list-style-position: inside on result LIs.
- * Madness with border-radius.
- * Corrected banner styles for new class names
- * Added rounded corners and removed body rules for embedded tests
- * Resolving merge conflicts.
- * added colouring for value summary
- * adding some extra text colours
- * added styles for toolbar
- * added new styles
- * IE 6 and 7 weren't respecting the CSS rules for the banner, used a different technique instead.
- * Went a bit further and made extra-sure that the target was specified correctly.
- * Fixed problem where double-clicking an entry in IE caused an error to occur.
- * Path for http://dev.jquery.com/ticket/5426 - fix the microformat test result
- * Fixed test() to use 'expected' 2nd param
- * Remove the named function expressions, to stop Safari 2 from freaking out. Fixes #5.
- * Each test can extend the module testEnvironment
- * Extra test for current test environment
- * Make the current testEnvironment available to utility functions
- * typeOf in QUnit.jsDump now uses QUnit.is
- * hoozit in QUnit.equiv now uses QUnit.is
- * Properly set label attributes.
- * Some minor tweaks to RyanS' GETParams change.
- * left a console.log in :(
- * Took into account a fringe case when using qunit with testswarm. Trying to run all the tests with the extra url params from testswarm would make qunit look for a testsuite that did not exist
- * need to set config.currentModule to have correct names and working filters
- * Support logging of testEnvironment
- * async tests aren't possible on rhino
- * Fixed a missing QUnit.reset().
- * The QUnit. prefix was missing from the uses of the start() method.
- * Merged lifecycle object into testEnvironment
- * "replacing totally wrong diff algorithm with a working one" Patch from kassens (manually applied).
- * fixing jslint errors in test.js
- * Fixed: testDone() was always called with 0 failures in CommonJS mode
- * Fixed: moduleDone() was invoked on first call to module()
- * Added a new asyncTest method - removes the need for having to call start() at the beginning of an asynchronous test.
- * Added support for expected numbers in the test method.
- * Fixed broken dynamic loading of tests (can now dynamically load tests and done still works properly).
- * Simplified the logic for calling 'done' and pushing off new tests - was causing too many inconsistencies otherwise.
- * Simplified the markup for the QUnit test test suite.
- * Realized that it's really easy to handle the case where stop() has been called and then an exception is thrown.
- * Added in better logging support. Now handle moduleStart/moduleDone and testStart/testDone. Also make sure that done only fires once at the end.
- * Made it so that you can reset the suite to an initial state (at which point tests can be dynamically loaded and run, for example).
- * Re-worked QUnit to handle dynamic loading of additional code (the 'done' code will be re-run after additional code is loaded).
- * Removed the old SVN version stuff.
- * Moved the QUnit source into a separate directory and updated the test suite/packages files.
- * Added in CommonJS support for exporting the QUnit functionality.
- * Missing quote from package.json.
- * Fixed trailing comma in package.json.
- * Added a CommonJS/Narwhal package.json file.
- * Accidentally reverted the jsDump/equiv changes that had been made.
- * Hide the filter toolbar if it's not needed. Also exposed the jsDump and equiv objects on QUnit.
- * Retooled the QUnit CSS to be more generic.
- * Renamed the QUnit files from testrunner/testsuite to QUnit.
- * Expose QUnit.equiv and QUnit.jsDump in QUnit.
- * Moved the QUnit test directory into the QUnit directory.
- * Reworked the QUnit CSS (moved jQuery-specific stuff out, made all the other selectors more specific).
- * Removed the #main reset for non-jQuery code (QUnit.reset can be overwritten with your own reset code).
- * Moved the QUnit toolbar inline.
- * Switched to using a qunit- prefix for special elements (banner, userAgent, and tests).
- * Missed a case in QUnit where an element was assumed to exist.
- * QUnit's isSet and isObj are no longer needed - you should use same instead.
- * Make sure that QUnit's equiv entity escaping is enabled by default (otherwise the output gets kind of crazy).
- * Refactored QUnit, completely reorganized the structure of the file. Additionally made it so that QUnit can run outside of a browser (inside Rhino, for example).
- * Removed some legacy and jQuery-specific test methods.
- * Added callbacks for tests and modules. It's now possible to reproduce the full display of the testrunner without using the regular rendering.
- * QUnit no longer depends upon rendering the results (it can work simply by using the logging callbacks).
- * Made QUnit no longer require jQuery (it is now a standalone, framework independent, test runner).
- * Reverted the noglobals changed from QUnit - causing chaos in the jQuery test suite.
- * qunit: removed noglobals flag, instead always check for globals after teardown; if a test has to introduce a global "myVar", use delete window.myVar in teardown or at the end of a test
- * qunit: don't child selectors when IE should behave nicely, too
- * qunit: improvement for the test-scope: create a new object and call setup, the test, and teardown in the scope of that object - allows you to provide test fixtures to each test without messing with global data; kudos to Martin Häcker for the contribution
- * qunit: added missing semicolons
- * qunit: fixed a semicolon, that should have been a comma
- * QUnit: implemented error handling for Opera as proposed by #3628
- * qunit: fix for http://dev.jquery.com/ticket/3215 changing wording of testresults, to something more positive (x of y passed, z failed)
- * QUnit: testrunner.js: Ensures equality of types (String, Boolean, Number) declared with the 'new' prefix. See comments #3, #4 and #5 on http://philrathe.com/articles/equiv
- * qunit: wrap name of test in span when a module is used for better styling
- * qunit: auto-prepend default mark (#header, #banner, #userAgent, #tests) when not present
- * Landing some changes to add logging to QUnit (so that it's easier to hook in to when a test finishes).
- * Added checkbox for hiding missing tests (tests that fail with the text 'missing test - untested code is broken code')
- * qunit: eol-style:native and mime-type
- * HTML being injected for the test result wasn't valid HTML.
- * qunit: setting mimetype for testsuite.css
- * qunit: update to Ariel's noglobals patch to support async tests as well
- * Landing Ariel's change - checks for global variable leakage.
- * qunit: run module-teardown in its own synchronize block to synchronize with async tests (ugh)
- * qunit: same: equiv - completely refactored in the testrunner.
- * testrunner.js: - Update equiv to support Date and RegExp. - Change behavior when comparing function: - abort when in an instance of Object (when references comparison failed) - skip otherwise (like before)
- * qunit: code refactoring and cleanup
- * QUnit: update equiv to latest version, handling multiple arguments and NaN, see http://philrathe.com/articles/equiv
- * QUnit: cleanup, deprecating compare, compare2 and serialArray: usage now throws an error with a helpful message
- * QUnit: optional timeout argument for stop, while making tests undetermined, useful for debugging
- * QUnit: added toolbar with "hide passed tests" checkbox to help focus on failed tests
- * QUnit: minor output formatting
- * QUnit: adding same-assertion for a recursive comparison of primitive values, arrays and objects, thanks to Philippe Rathé for the contribution, including tests
- * QUnit: adding same-assertion for a recursive comparison of primitive values, arrays and objects, thanks to Philippe Rathé for the contribution, including tests
- * QUnit: adding same-assertion for a recursive comparison of primitive values, arrays and objects, thanks to Philippe Rathé for the contribution, including tests
- * qunit: use window.load to initialize tests, allowing other code to run on document-ready before starting to run tests
- * qunit: allow either setup or teardown, instead of both or nothing
- * qunit: make everything private by default, expose only public API; removed old timeout-option (non-deterministic, disabled for a long time anyway); use local $ reference instead of global jQuery reference; minor code cleanup (var config instead of _config; queue.shift instead of slice)
- * qunit: added support for module level setup/teardown callbacks
- * qunit: modified example for equals to avoid confusion with parameter ordering
- * qunit: added id/classes to result element to enable integration with browser automation tools, see http://docs.jquery.com/QUnit#Integration_into_Browser_Automation_Tools
- * qunit: replaced $ alias with jQuery (merged from jquery/test/data/testrunner.js)
- * qunit: fixed inline documentation for equals
- * qunit testrunner - catch and log possible error during reset()
- * QUnit: Switched out Date and Rev for Id.
- * qunit: when errors are thrown in a test, the message is successfully show on all browsers.
- * qunit: added license header
- * qunit: moved jquery testrunner to top-level project, see http://docs.jquery.com/QUnit
- * Share project 'qunit' into 'https://jqueryjs.googlecode.com/svn'
diff --git a/web/src/vendor/qunit/LICENSE.txt b/web/src/vendor/qunit/LICENSE.txt
deleted file mode 100644
index c22db4d8..00000000
--- a/web/src/vendor/qunit/LICENSE.txt
+++ /dev/null
@@ -1,37 +0,0 @@
-Copyright 2006, 2014 jQuery Foundation and other contributors,
-https://jquery.org/
-
-This software consists of voluntary contributions made by many
-individuals. For exact contribution history, see the revision history
-available at https://github.com/jquery/qunit
-
-The following license applies to all parts of this software except as
-documented below:
-
-====
-
-Permission is hereby granted, free of charge, to any person obtaining
-a copy of this software and associated documentation files (the
-"Software"), to deal in the Software without restriction, including
-without limitation the rights to use, copy, modify, merge, publish,
-distribute, sublicense, and/or sell copies of the Software, and to
-permit persons to whom the Software is furnished to do so, subject to
-the following conditions:
-
-The above copyright notice and this permission notice shall be
-included in all copies or substantial portions of the Software.
-
-THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND,
-EXPRESS OR IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF
-MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE AND
-NONINFRINGEMENT. IN NO EVENT SHALL THE AUTHORS OR COPYRIGHT HOLDERS BE
-LIABLE FOR ANY CLAIM, DAMAGES OR OTHER LIABILITY, WHETHER IN AN ACTION
-OF CONTRACT, TORT OR OTHERWISE, ARISING FROM, OUT OF OR IN CONNECTION
-WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE SOFTWARE.
-
-====
-
-All files located in the node_modules and external directories are
-externally maintained libraries used by this software which have their
-own licenses; we recommend you read them, as their terms may differ from
-the terms above.
diff --git a/web/src/vendor/qunit/README.md b/web/src/vendor/qunit/README.md
deleted file mode 100644
index 8c224c40..00000000
--- a/web/src/vendor/qunit/README.md
+++ /dev/null
@@ -1,56 +0,0 @@
-[![Build Status](http://jenkins.jquery.com/job/QUnit/badge/icon)](http://jenkins.jquery.com/job/QUnit/)
-[![Coverage Status](https://coveralls.io/repos/jquery/qunit/badge.png)](https://coveralls.io/r/jquery/qunit)
-
-# [QUnit](http://qunitjs.com) - A JavaScript Unit Testing Framework.
-
-QUnit is a powerful, easy-to-use, JavaScript unit testing framework. It's used by the jQuery
-project to test its code and plugins but is capable of testing any generic
-JavaScript code (and even capable of testing JavaScript code on the server-side).
-
-QUnit is especially useful for regression testing: Whenever a bug is reported,
-write a test that asserts the existence of that particular bug. Then fix it and
-commit both. Every time you work on the code again, run the tests. If the bug
-comes up again - a regression - you'll spot it immediately and know how to fix
-it, because you know what code you just changed.
-
-Having good unit test coverage makes safe refactoring easy and cheap. You can
-run the tests after each small refactoring step and always know what change
-broke something.
-
-QUnit is similar to other unit testing frameworks like JUnit, but makes use of
-the features JavaScript provides and helps with testing code in the browser, e.g.
-with its stop/start facilities for testing asynchronous code.
-
-If you are interested in helping developing QUnit, you are in the right place.
-For related discussions, visit the
-[QUnit and Testing forum](http://forum.jquery.com/qunit-and-testing).
-
-## Development
-
-To submit patches, fork the repository, create a branch for the change. Then implement
-the change, run `grunt` to lint and test it, then commit, push and create a pull request.
-
-Include some background for the change in the commit message and `Fixes #nnn`, referring
-to the issue number you're addressing.
-
-To run `grunt`, you need [Node.js](http://nodejs.org/download/), which includes `npm`, then `npm install -g grunt-cli`. That gives you a global grunt binary. For additional grunt tasks, also run `npm install`.
-
-## Releases
-
-Use [jquery-release](https://github.com/jquery/jquery-release). The following aren't yet handled there:
-
-* Install [git-extras](https://github.com/visionmedia/git-extras) and run `git changelog` to update History.md. Clean up the changelog, removing merge commits or whitespace cleanups.
-* Run `grunt authors` and add any new authors to AUTHORS.txt
-* Update the version property in `package.json` to have the right -pre version. Not necessary for patch releases.
-
-Commit these, then run the script.
-
-Update web sites, replacing previous versions with new ones:
-
-* jquery/jquery-wp-content themes/jquery/footer-qunit.php
-* jquery/qunitjs.com pages/index.html
-
-Finally announce on Twitter @qunitjs
-
- Released @VERSION: https://github.com/jquery/qunit/tree/@VERSION
- Changelog: https://github.com/jquery/qunit/blob/@VERSION/History.md
diff --git a/web/src/vendor/qunit/bower.json b/web/src/vendor/qunit/bower.json
deleted file mode 100644
index 0fe13e2e..00000000
--- a/web/src/vendor/qunit/bower.json
+++ /dev/null
@@ -1,18 +0,0 @@
-{
- "name": "qunit",
- "main": [
- "qunit/qunit.js",
- "qunit/qunit.css"
- ],
- "license": "https://github.com/jquery/qunit/blob/master/LICENSE.txt",
- "ignore": [
- "**/.*",
- "!LICENSE.txt",
- "package.json",
- "bower.json",
- "Gruntfile.js",
- "node_modules",
- "test"
- ],
- "version": "1.15.0"
-}
diff --git a/web/src/vendor/qunit/browserstack.json b/web/src/vendor/qunit/browserstack.json
deleted file mode 100644
index 86f836e6..00000000
--- a/web/src/vendor/qunit/browserstack.json
+++ /dev/null
@@ -1,27 +0,0 @@
-{
- "username": "BROWSERSTACK_USERNAME",
- "key": "BROWSERSTACK_KEY",
- "test_framework": "qunit",
- "test_path": [
- "test/index.html",
- "test/async.html",
- "test/logs.html",
- "test/setTimeout.html"
- ],
- "browsers": [
- "chrome_previous",
- "chrome_latest",
- "firefox_previous",
- "firefox_latest",
- "opera_previous",
- "opera_latest",
- "safari_previous",
- "safari_latest",
- "ie_6",
- "ie_7",
- "ie_8",
- "ie_9",
- "ie_10",
- "ie_11"
- ]
-}
diff --git a/web/src/vendor/qunit/build/release.js b/web/src/vendor/qunit/build/release.js
deleted file mode 100644
index d5d46ac8..00000000
--- a/web/src/vendor/qunit/build/release.js
+++ /dev/null
@@ -1,28 +0,0 @@
-/*jshint node:true */
-module.exports = function( Release ) {
-
-var shell = require( "shelljs" );
-
-Release.define({
- npmPublish: true,
- issueTracker: "github",
- changelogShell: function() {
- return "# Changelog for QUnit v" + Release.newVersion + "\n";
- },
-
- generateArtifacts: function( done ) {
- Release.exec( "grunt", "Grunt command failed" );
- shell.mkdir( "-p", "qunit" );
- shell.cp( "-r", "dist/*", "qunit/" );
- shell.mkdir( "-p", "dist/cdn" );
- shell.cp( "dist/qunit.js", "dist/cdn/qunit-" + Release.newVersion + ".js" );
- shell.cp( "dist/qunit.css", "dist/cdn/qunit-" + Release.newVersion + ".css" );
- done([ "qunit/qunit.js", "qunit/qunit.css" ]);
- }
-});
-
-};
-
-module.exports.dependencies = [
- "shelljs@0.2.6"
-];
diff --git a/web/src/vendor/qunit/external/jsdiff/jsdiff.js b/web/src/vendor/qunit/external/jsdiff/jsdiff.js
deleted file mode 100644
index 42e7ff64..00000000
--- a/web/src/vendor/qunit/external/jsdiff/jsdiff.js
+++ /dev/null
@@ -1,146 +0,0 @@
-/*
- * Javascript Diff Algorithm
- * By John Resig (http://ejohn.org/)
- * Modified by Chu Alan "sprite"
- *
- * Released under the MIT license.
- *
- * More Info:
- * http://ejohn.org/projects/javascript-diff-algorithm/
- *
- * Usage: QUnit.diff(expected, actual)
- *
- * QUnit.diff( "the quick brown fox jumped over", "the quick fox jumps over" ) == "the quick <del>brown </del> fox <del>jumped </del><ins>jumps </ins> over"
- */
-QUnit.diff = (function() {
- var hasOwn = Object.prototype.hasOwnProperty;
-
- /*jshint eqeqeq:false, eqnull:true */
- function diff( o, n ) {
- var i,
- ns = {},
- os = {};
-
- for ( i = 0; i < n.length; i++ ) {
- if ( !hasOwn.call( ns, n[ i ] ) ) {
- ns[ n[ i ] ] = {
- rows: [],
- o: null
- };
- }
- ns[ n[ i ] ].rows.push( i );
- }
-
- for ( i = 0; i < o.length; i++ ) {
- if ( !hasOwn.call( os, o[ i ] ) ) {
- os[ o[ i ] ] = {
- rows: [],
- n: null
- };
- }
- os[ o[ i ] ].rows.push( i );
- }
-
- for ( i in ns ) {
- if ( hasOwn.call( ns, i ) ) {
- if ( ns[ i ].rows.length === 1 && hasOwn.call( os, i ) && os[ i ].rows.length === 1 ) {
- n[ ns[ i ].rows[ 0 ] ] = {
- text: n[ ns[ i ].rows[ 0 ] ],
- row: os[ i ].rows[ 0 ]
- };
- o[ os[ i ].rows[ 0 ] ] = {
- text: o[ os[ i ].rows[ 0 ] ],
- row: ns[ i ].rows[ 0 ]
- };
- }
- }
- }
-
- for ( i = 0; i < n.length - 1; i++ ) {
- if ( n[ i ].text != null && n[ i + 1 ].text == null && n[ i ].row + 1 < o.length && o[ n[ i ].row + 1 ].text == null &&
- n[ i + 1 ] == o[ n[ i ].row + 1 ] ) {
-
- n[ i + 1 ] = {
- text: n[ i + 1 ],
- row: n[ i ].row + 1
- };
- o[ n[ i ].row + 1 ] = {
- text: o[ n[ i ].row + 1 ],
- row: i + 1
- };
- }
- }
-
- for ( i = n.length - 1; i > 0; i-- ) {
- if ( n[ i ].text != null && n[ i - 1 ].text == null && n[ i ].row > 0 && o[ n[ i ].row - 1 ].text == null &&
- n[ i - 1 ] == o[ n[ i ].row - 1 ] ) {
-
- n[ i - 1 ] = {
- text: n[ i - 1 ],
- row: n[ i ].row - 1
- };
- o[ n[ i ].row - 1 ] = {
- text: o[ n[ i ].row - 1 ],
- row: i - 1
- };
- }
- }
-
- return {
- o: o,
- n: n
- };
- }
-
- return function( o, n ) {
- o = o.replace( /\s+$/, "" );
- n = n.replace( /\s+$/, "" );
-
- var i, pre,
- str = "",
- out = diff( o === "" ? [] : o.split( /\s+/ ), n === "" ? [] : n.split( /\s+/ ) ),
- oSpace = o.match( /\s+/g ),
- nSpace = n.match( /\s+/g );
-
- if ( oSpace == null ) {
- oSpace = [ " " ];
- } else {
- oSpace.push( " " );
- }
-
- if ( nSpace == null ) {
- nSpace = [ " " ];
- } else {
- nSpace.push( " " );
- }
-
- if ( out.n.length === 0 ) {
- for ( i = 0; i < out.o.length; i++ ) {
- str += "<del>" + out.o[ i ] + oSpace[ i ] + "</del>";
- }
- } else {
- if ( out.n[ 0 ].text == null ) {
- for ( n = 0; n < out.o.length && out.o[ n ].text == null; n++ ) {
- str += "<del>" + out.o[ n ] + oSpace[ n ] + "</del>";
- }
- }
-
- for ( i = 0; i < out.n.length; i++ ) {
- if ( out.n[ i ].text == null ) {
- str += "<ins>" + out.n[ i ] + nSpace[ i ] + "</ins>";
- } else {
-
- // `pre` initialized at top of scope
- pre = "";
-
- for ( n = out.n[ i ].row + 1; n < out.o.length && out.o[ n ].text == null; n++ ) {
- pre += "<del>" + out.o[ n ] + oSpace[ n ] + "</del>";
- }
- str += " " + out.n[ i ].text + nSpace[ i ] + pre;
- }
- }
- }
-
- return str;
- };
-}());
diff --git a/web/src/vendor/qunit/qunit/qunit.css b/web/src/vendor/qunit/qunit.css
index 9437b4b6..9437b4b6 100644
--- a/web/src/vendor/qunit/qunit/qunit.css
+++ b/web/src/vendor/qunit/qunit.css
diff --git a/web/src/vendor/qunit/qunit/qunit.js b/web/src/vendor/qunit/qunit.js
index 474cfe55..474cfe55 100644
--- a/web/src/vendor/qunit/qunit/qunit.js
+++ b/web/src/vendor/qunit/qunit.js
diff --git a/web/src/vendor/qunit/reporter/html.js b/web/src/vendor/qunit/reporter/html.js
deleted file mode 100644
index afa5e81d..00000000
--- a/web/src/vendor/qunit/reporter/html.js
+++ /dev/null
@@ -1,682 +0,0 @@
-(function() {
-
-// Deprecated QUnit.init - Ref #530
-// Re-initialize the configuration options
-QUnit.init = function() {
- var tests, banner, result, qunit,
- config = QUnit.config;
-
- config.stats = { all: 0, bad: 0 };
- config.moduleStats = { all: 0, bad: 0 };
- config.started = 0;
- config.updateRate = 1000;
- config.blocking = false;
- config.autostart = true;
- config.autorun = false;
- config.filter = "";
- config.queue = [];
- config.semaphore = 1;
-
- // Return on non-browser environments
- // This is necessary to not break on node tests
- if ( typeof window === "undefined" ) {
- return;
- }
-
- qunit = id( "qunit" );
- if ( qunit ) {
- qunit.innerHTML =
- "<h1 id='qunit-header'>" + escapeText( document.title ) + "</h1>" +
- "<h2 id='qunit-banner'></h2>" +
- "<div id='qunit-testrunner-toolbar'></div>" +
- "<h2 id='qunit-userAgent'></h2>" +
- "<ol id='qunit-tests'></ol>";
- }
-
- tests = id( "qunit-tests" );
- banner = id( "qunit-banner" );
- result = id( "qunit-testresult" );
-
- if ( tests ) {
- tests.innerHTML = "";
- }
-
- if ( banner ) {
- banner.className = "";
- }
-
- if ( result ) {
- result.parentNode.removeChild( result );
- }
-
- if ( tests ) {
- result = document.createElement( "p" );
- result.id = "qunit-testresult";
- result.className = "result";
- tests.parentNode.insertBefore( result, tests );
- result.innerHTML = "Running...<br/>&nbsp;";
- }
-};
-
-// Resets the test setup. Useful for tests that modify the DOM.
-/*
-DEPRECATED: Use multiple tests instead of resetting inside a test.
-Use testStart or testDone for custom cleanup.
-This method will throw an error in 2.0, and will be removed in 2.1
-*/
-QUnit.reset = function() {
-
- // Return on non-browser environments
- // This is necessary to not break on node tests
- if ( typeof window === "undefined" ) {
- return;
- }
-
- var fixture = id( "qunit-fixture" );
- if ( fixture ) {
- fixture.innerHTML = config.fixture;
- }
-};
-
-// Don't load the HTML Reporter on non-Browser environments
-if ( typeof window === "undefined" ) {
- return;
-}
-
-var config = QUnit.config,
- hasOwn = Object.prototype.hasOwnProperty,
- defined = {
- document: typeof window.document !== "undefined",
- sessionStorage: (function() {
- var x = "qunit-test-string";
- try {
- sessionStorage.setItem( x, x );
- sessionStorage.removeItem( x );
- return true;
- } catch ( e ) {
- return false;
- }
- }())
- };
-
-/**
-* Escape text for attribute or text content.
-*/
-function escapeText( s ) {
- if ( !s ) {
- return "";
- }
- s = s + "";
-
- // Both single quotes and double quotes (for attributes)
- return s.replace( /['"<>&]/g, function( s ) {
- switch ( s ) {
- case "'":
- return "&#039;";
- case "\"":
- return "&quot;";
- case "<":
- return "&lt;";
- case ">":
- return "&gt;";
- case "&":
- return "&amp;";
- }
- });
-}
-
-/**
- * @param {HTMLElement} elem
- * @param {string} type
- * @param {Function} fn
- */
-function addEvent( elem, type, fn ) {
- if ( elem.addEventListener ) {
-
- // Standards-based browsers
- elem.addEventListener( type, fn, false );
- } else if ( elem.attachEvent ) {
-
- // support: IE <9
- elem.attachEvent( "on" + type, fn );
- }
-}
-
-/**
- * @param {Array|NodeList} elems
- * @param {string} type
- * @param {Function} fn
- */
-function addEvents( elems, type, fn ) {
- var i = elems.length;
- while ( i-- ) {
- addEvent( elems[ i ], type, fn );
- }
-}
-
-function hasClass( elem, name ) {
- return ( " " + elem.className + " " ).indexOf( " " + name + " " ) >= 0;
-}
-
-function addClass( elem, name ) {
- if ( !hasClass( elem, name ) ) {
- elem.className += ( elem.className ? " " : "" ) + name;
- }
-}
-
-function toggleClass( elem, name ) {
- if ( hasClass( elem, name ) ) {
- removeClass( elem, name );
- } else {
- addClass( elem, name );
- }
-}
-
-function removeClass( elem, name ) {
- var set = " " + elem.className + " ";
-
- // Class name may appear multiple times
- while ( set.indexOf( " " + name + " " ) >= 0 ) {
- set = set.replace( " " + name + " ", " " );
- }
-
- // trim for prettiness
- elem.className = typeof set.trim === "function" ? set.trim() : set.replace( /^\s+|\s+$/g, "" );
-}
-
-function id( name ) {
- return defined.document && document.getElementById && document.getElementById( name );
-}
-
-function getUrlConfigHtml() {
- var i, j, val,
- escaped, escapedTooltip,
- selection = false,
- len = config.urlConfig.length,
- urlConfigHtml = "";
-
- for ( i = 0; i < len; i++ ) {
- val = config.urlConfig[ i ];
- if ( typeof val === "string" ) {
- val = {
- id: val,
- label: val
- };
- }
-
- escaped = escapeText( val.id );
- escapedTooltip = escapeText( val.tooltip );
-
- config[ val.id ] = QUnit.urlParams[ val.id ];
- if ( !val.value || typeof val.value === "string" ) {
- urlConfigHtml += "<input id='qunit-urlconfig-" + escaped +
- "' name='" + escaped + "' type='checkbox'" +
- ( val.value ? " value='" + escapeText( val.value ) + "'" : "" ) +
- ( config[ val.id ] ? " checked='checked'" : "" ) +
- " title='" + escapedTooltip + "'><label for='qunit-urlconfig-" + escaped +
- "' title='" + escapedTooltip + "'>" + val.label + "</label>";
- } else {
- urlConfigHtml += "<label for='qunit-urlconfig-" + escaped +
- "' title='" + escapedTooltip + "'>" + val.label +
- ": </label><select id='qunit-urlconfig-" + escaped +
- "' name='" + escaped + "' title='" + escapedTooltip + "'><option></option>";
-
- if ( QUnit.is( "array", val.value ) ) {
- for ( j = 0; j < val.value.length; j++ ) {
- escaped = escapeText( val.value[ j ] );
- urlConfigHtml += "<option value='" + escaped + "'" +
- ( config[ val.id ] === val.value[ j ] ?
- ( selection = true ) && " selected='selected'" : "" ) +
- ">" + escaped + "</option>";
- }
- } else {
- for ( j in val.value ) {
- if ( hasOwn.call( val.value, j ) ) {
- urlConfigHtml += "<option value='" + escapeText( j ) + "'" +
- ( config[ val.id ] === j ?
- ( selection = true ) && " selected='selected'" : "" ) +
- ">" + escapeText( val.value[ j ] ) + "</option>";
- }
- }
- }
- if ( config[ val.id ] && !selection ) {
- escaped = escapeText( config[ val.id ] );
- urlConfigHtml += "<option value='" + escaped +
- "' selected='selected' disabled='disabled'>" + escaped + "</option>";
- }
- urlConfigHtml += "</select>";
- }
- }
-
- return urlConfigHtml;
-}
-
-function toolbarUrlConfigContainer() {
- var urlConfigContainer = document.createElement( "span" );
-
- urlConfigContainer.innerHTML = getUrlConfigHtml();
-
- // For oldIE support:
- // * Add handlers to the individual elements instead of the container
- // * Use "click" instead of "change" for checkboxes
- // * Fallback from event.target to event.srcElement
- addEvents( urlConfigContainer.getElementsByTagName( "input" ), "click", function( event ) {
- var params = {},
- target = event.target || event.srcElement;
- params[ target.name ] = target.checked ?
- target.defaultValue || true :
- undefined;
- window.location = QUnit.url( params );
- });
- addEvents( urlConfigContainer.getElementsByTagName( "select" ), "change", function( event ) {
- var params = {},
- target = event.target || event.srcElement;
- params[ target.name ] = target.options[ target.selectedIndex ].value || undefined;
- window.location = QUnit.url( params );
- });
-
- return urlConfigContainer;
-}
-
-function getModuleNames() {
- var i,
- moduleNames = [];
-
- for ( i in config.modules ) {
- if ( config.modules.hasOwnProperty( i ) ) {
- moduleNames.push( i );
- }
- }
-
- moduleNames.sort(function( a, b ) {
- return a.localeCompare( b );
- });
-
- return moduleNames;
-}
-
-function toolbarModuleFilterHtml() {
- var i,
- moduleFilterHtml = "",
- moduleNames = getModuleNames();
-
- if ( moduleNames.length <= 1 ) {
- return false;
- }
-
- moduleFilterHtml += "<label for='qunit-modulefilter'>Module: </label>" +
- "<select id='qunit-modulefilter' name='modulefilter'><option value='' " +
- ( config.module === undefined ? "selected='selected'" : "" ) +
- ">< All Modules ></option>";
-
- for ( i = 0; i < moduleNames.length; i++ ) {
- moduleFilterHtml += "<option value='" +
- escapeText( encodeURIComponent( moduleNames[ i ] ) ) + "' " +
- ( config.module === moduleNames[ i ] ? "selected='selected'" : "" ) +
- ">" + escapeText( moduleNames[ i ] ) + "</option>";
- }
- moduleFilterHtml += "</select>";
-
- return moduleFilterHtml;
-}
-
-function toolbarModuleFilter() {
- var moduleFilter = document.createElement( "span" ),
- moduleFilterHtml = toolbarModuleFilterHtml();
-
- if ( !moduleFilterHtml ) {
- return false;
- }
-
- moduleFilter.setAttribute( "id", "qunit-modulefilter-container" );
- moduleFilter.innerHTML = moduleFilterHtml;
-
- addEvent( moduleFilter.lastChild, "change", function() {
- var selectBox = moduleFilter.getElementsByTagName( "select" )[ 0 ],
- selectedModule = decodeURIComponent( selectBox.options[ selectBox.selectedIndex ].value );
-
- window.location = QUnit.url({
- module: ( selectedModule === "" ) ? undefined : selectedModule,
-
- // Remove any existing filters
- filter: undefined,
- testNumber: undefined
- });
- });
-
- return moduleFilter;
-}
-
-function toolbarFilter() {
- var testList = id( "qunit-tests" ),
- filter = document.createElement( "input" );
-
- filter.type = "checkbox";
- filter.id = "qunit-filter-pass";
-
- addEvent( filter, "click", function() {
- if ( filter.checked ) {
- addClass( testList, "hidepass" );
- if ( defined.sessionStorage ) {
- sessionStorage.setItem( "qunit-filter-passed-tests", "true" );
- }
- } else {
- removeClass( testList, "hidepass" );
- if ( defined.sessionStorage ) {
- sessionStorage.removeItem( "qunit-filter-passed-tests" );
- }
- }
- });
-
- if ( config.hidepassed || defined.sessionStorage &&
- sessionStorage.getItem( "qunit-filter-passed-tests" ) ) {
- filter.checked = true;
-
- addClass( testList, "hidepass" );
- }
-
- return filter;
-}
-
-function toolbarLabel() {
- var label = document.createElement( "label" );
- label.setAttribute( "for", "qunit-filter-pass" );
- label.setAttribute( "title", "Only show tests and assertions that fail. Stored in sessionStorage." );
- label.innerHTML = "Hide passed tests";
-
- return label;
-}
-
-function appendToolbar() {
- var moduleFilter,
- toolbar = id( "qunit-testrunner-toolbar" );
-
- if ( toolbar ) {
- toolbar.appendChild( toolbarFilter() );
- toolbar.appendChild( toolbarLabel() );
- toolbar.appendChild( toolbarUrlConfigContainer() );
-
- moduleFilter = toolbarModuleFilter();
- if ( moduleFilter ) {
- toolbar.appendChild( moduleFilter );
- }
- }
-}
-
-function appendBanner() {
- var banner = id( "qunit-banner" );
-
- if ( banner ) {
- banner.className = "";
- banner.innerHTML = "<a href='" +
- QUnit.url({ filter: undefined, module: undefined, testNumber: undefined }) +
- "'>" + banner.innerHTML + "</a> ";
- }
-}
-
-function appendTestResults() {
- var tests = id( "qunit-tests" ),
- result = id( "qunit-testresult" );
-
- if ( result ) {
- result.parentNode.removeChild( result );
- }
-
- if ( tests ) {
- tests.innerHTML = "";
- result = document.createElement( "p" );
- result.id = "qunit-testresult";
- result.className = "result";
- tests.parentNode.insertBefore( result, tests );
- result.innerHTML = "Running...<br>&nbsp;";
- }
-}
-
-function storeFixture() {
- var fixture = id( "qunit-fixture" );
- if ( fixture ) {
- config.fixture = fixture.innerHTML;
- }
-}
-
-function appendUserAgent() {
- var userAgent = id( "qunit-userAgent" );
- if ( userAgent ) {
- userAgent.innerHTML = navigator.userAgent;
- }
-}
-
-// HTML Reporter initialization and load
-QUnit.begin(function() {
- var qunit = id( "qunit" );
-
- if ( qunit ) {
- qunit.innerHTML =
- "<h1 id='qunit-header'>" + escapeText( document.title ) + "</h1>" +
- "<h2 id='qunit-banner'></h2>" +
- "<div id='qunit-testrunner-toolbar'></div>" +
- "<h2 id='qunit-userAgent'></h2>" +
- "<ol id='qunit-tests'></ol>";
- }
-
- appendBanner();
- appendTestResults();
- appendUserAgent();
- appendToolbar();
- storeFixture();
-});
-
-QUnit.done(function( details ) {
- var i, key,
- banner = id( "qunit-banner" ),
- tests = id( "qunit-tests" ),
- html = [
- "Tests completed in ",
- details.runtime,
- " milliseconds.<br>",
- "<span class='passed'>",
- details.passed,
- "</span> assertions of <span class='total'>",
- details.total,
- "</span> passed, <span class='failed'>",
- details.failed,
- "</span> failed."
- ].join( "" );
-
- if ( banner ) {
- banner.className = details.failed ? "qunit-fail" : "qunit-pass";
- }
-
- if ( tests ) {
- id( "qunit-testresult" ).innerHTML = html;
- }
-
- if ( config.altertitle && defined.document && document.title ) {
-
- // show ✖ for good, ✔ for bad suite result in title
- // use escape sequences in case file gets loaded with non-utf-8-charset
- document.title = [
- ( details.failed ? "\u2716" : "\u2714" ),
- document.title.replace( /^[\u2714\u2716] /i, "" )
- ].join( " " );
- }
-
- // clear own sessionStorage items if all tests passed
- if ( config.reorder && defined.sessionStorage && details.failed === 0 ) {
- for ( i = 0; i < sessionStorage.length; i++ ) {
- key = sessionStorage.key( i++ );
- if ( key.indexOf( "qunit-test-" ) === 0 ) {
- sessionStorage.removeItem( key );
- }
- }
- }
-
- // scroll back to top to show results
- if ( config.scrolltop && window.scrollTo ) {
- window.scrollTo( 0, 0 );
- }
-});
-
-function getNameHtml( name, module ) {
- var nameHtml = "";
-
- if ( module ) {
- nameHtml = "<span class='module-name'>" + escapeText( module ) + "</span>: ";
- }
-
- nameHtml += "<span class='test-name'>" + escapeText( name ) + "</span>";
-
- return nameHtml;
-}
-
-QUnit.testStart(function( details ) {
- var a, b, li, running, assertList,
- name = getNameHtml( details.name, details.module ),
- tests = id( "qunit-tests" );
-
- if ( tests ) {
- b = document.createElement( "strong" );
- b.innerHTML = name;
-
- a = document.createElement( "a" );
- a.innerHTML = "Rerun";
- a.href = QUnit.url({ testNumber: details.testNumber });
-
- li = document.createElement( "li" );
- li.appendChild( b );
- li.appendChild( a );
- li.className = "running";
- li.id = "qunit-test-output" + details.testNumber;
-
- assertList = document.createElement( "ol" );
- assertList.className = "qunit-assert-list";
-
- li.appendChild( assertList );
-
- tests.appendChild( li );
- }
-
- running = id( "qunit-testresult" );
- if ( running ) {
- running.innerHTML = "Running: <br>" + name;
- }
-
-});
-
-QUnit.log(function( details ) {
- var assertList, assertLi,
- message, expected, actual,
- testItem = id( "qunit-test-output" + details.testNumber );
-
- if ( !testItem ) {
- return;
- }
-
- message = escapeText( details.message ) || ( details.result ? "okay" : "failed" );
- message = "<span class='test-message'>" + message + "</span>";
-
- // pushFailure doesn't provide details.expected
- // when it calls, it's implicit to also not show expected and diff stuff
- // Also, we need to check details.expected existence, as it can exist and be undefined
- if ( !details.result && hasOwn.call( details, "expected" ) ) {
- expected = escapeText( QUnit.dump.parse( details.expected ) );
- actual = escapeText( QUnit.dump.parse( details.actual ) );
- message += "<table><tr class='test-expected'><th>Expected: </th><td><pre>" +
- expected +
- "</pre></td></tr>";
-
- if ( actual !== expected ) {
- message += "<tr class='test-actual'><th>Result: </th><td><pre>" +
- actual + "</pre></td></tr>" +
- "<tr class='test-diff'><th>Diff: </th><td><pre>" +
- QUnit.diff( expected, actual ) + "</pre></td></tr>";
- }
-
- if ( details.source ) {
- message += "<tr class='test-source'><th>Source: </th><td><pre>" +
- escapeText( details.source ) + "</pre></td></tr>";
- }
-
- message += "</table>";
-
- // this occours when pushFailure is set and we have an extracted stack trace
- } else if ( !details.result && details.source ) {
- message += "<table>" +
- "<tr class='test-source'><th>Source: </th><td><pre>" +
- escapeText( details.source ) + "</pre></td></tr>" +
- "</table>";
- }
-
- assertList = testItem.getElementsByTagName( "ol" )[ 0 ];
-
- assertLi = document.createElement( "li" );
- assertLi.className = details.result ? "pass" : "fail";
- assertLi.innerHTML = message;
- assertList.appendChild( assertLi );
-});
-
-QUnit.testDone(function( details ) {
- var testTitle, time, testItem, assertList,
- good, bad, testCounts,
- tests = id( "qunit-tests" );
-
- // QUnit.reset() is deprecated and will be replaced for a new
- // fixture reset function on QUnit 2.0/2.1.
- // It's still called here for backwards compatibility handling
- QUnit.reset();
-
- if ( !tests ) {
- return;
- }
-
- testItem = id( "qunit-test-output" + details.testNumber );
- assertList = testItem.getElementsByTagName( "ol" )[ 0 ];
-
- good = details.passed;
- bad = details.failed;
-
- // store result when possible
- if ( config.reorder && defined.sessionStorage ) {
- if ( bad ) {
- sessionStorage.setItem( "qunit-test-" + details.module + "-" + details.name, bad );
- } else {
- sessionStorage.removeItem( "qunit-test-" + details.module + "-" + details.name );
- }
- }
-
- if ( bad === 0 ) {
- addClass( assertList, "qunit-collapsed" );
- }
-
- // testItem.firstChild is the test name
- testTitle = testItem.firstChild;
-
- testCounts = bad ?
- "<b class='failed'>" + bad + "</b>, " + "<b class='passed'>" + good + "</b>, " :
- "";
-
- testTitle.innerHTML += " <b class='counts'>(" + testCounts +
- details.assertions.length + ")</b>";
-
- addEvent( testTitle, "click", function() {
- toggleClass( assertList, "qunit-collapsed" );
- });
-
- time = document.createElement( "span" );
- time.className = "runtime";
- time.innerHTML = details.runtime + " ms";
-
- testItem.className = bad ? "fail" : "pass";
-
- testItem.insertBefore( time, assertList );
-});
-
-if ( !defined.document || document.readyState === "complete" ) {
- config.autorun = true;
-}
-
-if ( defined.document ) {
- addEvent( window, "load", QUnit.load );
-}
-
-})();
diff --git a/web/src/vendor/qunit/src/assert.js b/web/src/vendor/qunit/src/assert.js
deleted file mode 100644
index abded8e6..00000000
--- a/web/src/vendor/qunit/src/assert.js
+++ /dev/null
@@ -1,180 +0,0 @@
-function Assert( testContext ) {
- this.test = testContext;
-}
-
-// Assert helpers
-QUnit.assert = Assert.prototype = {
-
- // Specify the number of expected assertions to guarantee that failed test (no assertions are run at all) don't slip through.
- expect: function( asserts ) {
- if ( arguments.length === 1 ) {
- this.test.expected = asserts;
- } else {
- return this.test.expected;
- }
- },
-
- // Exports test.push() to the user API
- push: function() {
- var assert = this;
-
- // Backwards compatibility fix.
- // Allows the direct use of global exported assertions and QUnit.assert.*
- // Although, it's use is not recommended as it can leak assertions
- // to other tests from async tests, because we only get a reference to the current test,
- // not exactly the test where assertion were intended to be called.
- if ( !QUnit.config.current ) {
- throw new Error( "assertion outside test context, in " + sourceFromStacktrace( 2 ) );
- }
- if ( !( assert instanceof Assert ) ) {
- assert = QUnit.config.current.assert;
- }
- return assert.test.push.apply( assert.test, arguments );
- },
-
- /**
- * Asserts rough true-ish result.
- * @name ok
- * @function
- * @example ok( "asdfasdf".length > 5, "There must be at least 5 chars" );
- */
- ok: function( result, message ) {
- message = message || ( result ? "okay" : "failed, expected argument to be truthy, was: " +
- QUnit.dump.parse( result ) );
- if ( !!result ) {
- this.push( true, result, true, message );
- } else {
- this.test.pushFailure( message, null, result );
- }
- },
-
- /**
- * Assert that the first two arguments are equal, with an optional message.
- * Prints out both actual and expected values.
- * @name equal
- * @function
- * @example equal( format( "Received {0} bytes.", 2), "Received 2 bytes.", "format() replaces {0} with next argument" );
- */
- equal: function( actual, expected, message ) {
- /*jshint eqeqeq:false */
- this.push( expected == actual, actual, expected, message );
- },
-
- /**
- * @name notEqual
- * @function
- */
- notEqual: function( actual, expected, message ) {
- /*jshint eqeqeq:false */
- this.push( expected != actual, actual, expected, message );
- },
-
- /**
- * @name propEqual
- * @function
- */
- propEqual: function( actual, expected, message ) {
- actual = objectValues( actual );
- expected = objectValues( expected );
- this.push( QUnit.equiv( actual, expected ), actual, expected, message );
- },
-
- /**
- * @name notPropEqual
- * @function
- */
- notPropEqual: function( actual, expected, message ) {
- actual = objectValues( actual );
- expected = objectValues( expected );
- this.push( !QUnit.equiv( actual, expected ), actual, expected, message );
- },
-
- /**
- * @name deepEqual
- * @function
- */
- deepEqual: function( actual, expected, message ) {
- this.push( QUnit.equiv( actual, expected ), actual, expected, message );
- },
-
- /**
- * @name notDeepEqual
- * @function
- */
- notDeepEqual: function( actual, expected, message ) {
- this.push( !QUnit.equiv( actual, expected ), actual, expected, message );
- },
-
- /**
- * @name strictEqual
- * @function
- */
- strictEqual: function( actual, expected, message ) {
- this.push( expected === actual, actual, expected, message );
- },
-
- /**
- * @name notStrictEqual
- * @function
- */
- notStrictEqual: function( actual, expected, message ) {
- this.push( expected !== actual, actual, expected, message );
- },
-
- "throws": function( block, expected, message ) {
- var actual, expectedType,
- expectedOutput = expected,
- ok = false;
-
- // 'expected' is optional unless doing string comparison
- if ( message == null && typeof expected === "string" ) {
- message = expected;
- expected = null;
- }
-
- this.test.ignoreGlobalErrors = true;
- try {
- block.call( this.test.testEnvironment );
- } catch (e) {
- actual = e;
- }
- this.test.ignoreGlobalErrors = false;
-
- if ( actual ) {
- expectedType = QUnit.objectType( expected );
-
- // we don't want to validate thrown error
- if ( !expected ) {
- ok = true;
- expectedOutput = null;
-
- // expected is a regexp
- } else if ( expectedType === "regexp" ) {
- ok = expected.test( errorString( actual ) );
-
- // expected is a string
- } else if ( expectedType === "string" ) {
- ok = expected === errorString( actual );
-
- // expected is a constructor, maybe an Error constructor
- } else if ( expectedType === "function" && actual instanceof expected ) {
- ok = true;
-
- // expected is an Error object
- } else if ( expectedType === "object" ) {
- ok = actual instanceof expected.constructor &&
- actual.name === expected.name &&
- actual.message === expected.message;
-
- // expected is a validation function which returns true if validation passed
- } else if ( expectedType === "function" && expected.call( {}, actual ) === true ) {
- expectedOutput = null;
- ok = true;
- }
-
- this.push( ok, actual, expectedOutput, message );
- } else {
- this.test.pushFailure( message, null, "No exception was thrown." );
- }
- }
-};
diff --git a/web/src/vendor/qunit/src/core.js b/web/src/vendor/qunit/src/core.js
deleted file mode 100644
index 08f9b024..00000000
--- a/web/src/vendor/qunit/src/core.js
+++ /dev/null
@@ -1,695 +0,0 @@
-var QUnit,
- config,
- onErrorFnPrev,
- fileName = ( sourceFromStacktrace( 0 ) || "" ).replace( /(:\d+)+\)?/, "" ).replace( /.+\//, "" ),
- toString = Object.prototype.toString,
- hasOwn = Object.prototype.hasOwnProperty,
- // Keep a local reference to Date (GH-283)
- Date = window.Date,
- now = Date.now || function() {
- return new Date().getTime();
- },
- setTimeout = window.setTimeout,
- clearTimeout = window.clearTimeout,
- defined = {
- document: typeof window.document !== "undefined",
- setTimeout: typeof window.setTimeout !== "undefined",
- sessionStorage: (function() {
- var x = "qunit-test-string";
- try {
- sessionStorage.setItem( x, x );
- sessionStorage.removeItem( x );
- return true;
- } catch ( e ) {
- return false;
- }
- }())
- },
- /**
- * Provides a normalized error string, correcting an issue
- * with IE 7 (and prior) where Error.prototype.toString is
- * not properly implemented
- *
- * Based on http://es5.github.com/#x15.11.4.4
- *
- * @param {String|Error} error
- * @return {String} error message
- */
- errorString = function( error ) {
- var name, message,
- errorString = error.toString();
- if ( errorString.substring( 0, 7 ) === "[object" ) {
- name = error.name ? error.name.toString() : "Error";
- message = error.message ? error.message.toString() : "";
- if ( name && message ) {
- return name + ": " + message;
- } else if ( name ) {
- return name;
- } else if ( message ) {
- return message;
- } else {
- return "Error";
- }
- } else {
- return errorString;
- }
- },
- /**
- * Makes a clone of an object using only Array or Object as base,
- * and copies over the own enumerable properties.
- *
- * @param {Object} obj
- * @return {Object} New object with only the own properties (recursively).
- */
- objectValues = function( obj ) {
- var key, val,
- vals = QUnit.is( "array", obj ) ? [] : {};
- for ( key in obj ) {
- if ( hasOwn.call( obj, key ) ) {
- val = obj[ key ];
- vals[ key ] = val === Object( val ) ? objectValues( val ) : val;
- }
- }
- return vals;
- };
-
-// Root QUnit object.
-// `QUnit` initialized at top of scope
-QUnit = {
-
- // call on start of module test to prepend name to all tests
- module: function( name, testEnvironment ) {
- config.currentModule = name;
- config.currentModuleTestEnvironment = testEnvironment;
- config.modules[ name ] = true;
- },
-
- asyncTest: function( testName, expected, callback ) {
- if ( arguments.length === 2 ) {
- callback = expected;
- expected = null;
- }
-
- QUnit.test( testName, expected, callback, true );
- },
-
- test: function( testName, expected, callback, async ) {
- var test;
-
- if ( arguments.length === 2 ) {
- callback = expected;
- expected = null;
- }
-
- test = new Test({
- testName: testName,
- expected: expected,
- async: async,
- callback: callback,
- module: config.currentModule,
- moduleTestEnvironment: config.currentModuleTestEnvironment,
- stack: sourceFromStacktrace( 2 )
- });
-
- if ( !validTest( test ) ) {
- return;
- }
-
- test.queue();
- },
-
- start: function( count ) {
- var message;
-
- // QUnit hasn't been initialized yet.
- // Note: RequireJS (et al) may delay onLoad
- if ( config.semaphore === undefined ) {
- QUnit.begin(function() {
- // This is triggered at the top of QUnit.load, push start() to the event loop, to allow QUnit.load to finish first
- setTimeout(function() {
- QUnit.start( count );
- });
- });
- return;
- }
-
- config.semaphore -= count || 1;
- // don't start until equal number of stop-calls
- if ( config.semaphore > 0 ) {
- return;
- }
-
- // Set the starting time when the first test is run
- QUnit.config.started = QUnit.config.started || now();
- // ignore if start is called more often then stop
- if ( config.semaphore < 0 ) {
- config.semaphore = 0;
-
- message = "Called start() while already started (QUnit.config.semaphore was 0 already)";
-
- if ( config.current ) {
- QUnit.pushFailure( message, sourceFromStacktrace( 2 ) );
- } else {
- throw new Error( message );
- }
-
- return;
- }
- // A slight delay, to avoid any current callbacks
- if ( defined.setTimeout ) {
- setTimeout(function() {
- if ( config.semaphore > 0 ) {
- return;
- }
- if ( config.timeout ) {
- clearTimeout( config.timeout );
- }
-
- config.blocking = false;
- process( true );
- }, 13 );
- } else {
- config.blocking = false;
- process( true );
- }
- },
-
- stop: function( count ) {
- config.semaphore += count || 1;
- config.blocking = true;
-
- if ( config.testTimeout && defined.setTimeout ) {
- clearTimeout( config.timeout );
- config.timeout = setTimeout(function() {
- QUnit.ok( false, "Test timed out" );
- config.semaphore = 1;
- QUnit.start();
- }, config.testTimeout );
- }
- }
-};
-
-// We use the prototype to distinguish between properties that should
-// be exposed as globals (and in exports) and those that shouldn't
-(function() {
- function F() {}
- F.prototype = QUnit;
- QUnit = new F();
-
- // Make F QUnit's constructor so that we can add to the prototype later
- QUnit.constructor = F;
-}());
-
-/**
- * Config object: Maintain internal state
- * Later exposed as QUnit.config
- * `config` initialized at top of scope
- */
-config = {
- // The queue of tests to run
- queue: [],
-
- // block until document ready
- blocking: true,
-
- // when enabled, show only failing tests
- // gets persisted through sessionStorage and can be changed in UI via checkbox
- hidepassed: false,
-
- // by default, run previously failed tests first
- // very useful in combination with "Hide passed tests" checked
- reorder: true,
-
- // by default, modify document.title when suite is done
- altertitle: true,
-
- // by default, scroll to top of the page when suite is done
- scrolltop: true,
-
- // when enabled, all tests must call expect()
- requireExpects: false,
-
- // add checkboxes that are persisted in the query-string
- // when enabled, the id is set to `true` as a `QUnit.config` property
- urlConfig: [
- {
- id: "noglobals",
- label: "Check for Globals",
- tooltip: "Enabling this will test if any test introduces new properties on the `window` object. Stored as query-strings."
- },
- {
- id: "notrycatch",
- label: "No try-catch",
- tooltip: "Enabling this will run tests outside of a try-catch block. Makes debugging exceptions in IE reasonable. Stored as query-strings."
- }
- ],
-
- // Set of all modules.
- modules: {},
-
- callbacks: {}
-};
-
-// Initialize more QUnit.config and QUnit.urlParams
-(function() {
- var i, current,
- location = window.location || { search: "", protocol: "file:" },
- params = location.search.slice( 1 ).split( "&" ),
- length = params.length,
- urlParams = {};
-
- if ( params[ 0 ] ) {
- for ( i = 0; i < length; i++ ) {
- current = params[ i ].split( "=" );
- current[ 0 ] = decodeURIComponent( current[ 0 ] );
-
- // allow just a key to turn on a flag, e.g., test.html?noglobals
- current[ 1 ] = current[ 1 ] ? decodeURIComponent( current[ 1 ] ) : true;
- if ( urlParams[ current[ 0 ] ] ) {
- urlParams[ current[ 0 ] ] = [].concat( urlParams[ current[ 0 ] ], current[ 1 ] );
- } else {
- urlParams[ current[ 0 ] ] = current[ 1 ];
- }
- }
- }
-
- QUnit.urlParams = urlParams;
-
- // String search anywhere in moduleName+testName
- config.filter = urlParams.filter;
-
- // Exact match of the module name
- config.module = urlParams.module;
-
- config.testNumber = [];
- if ( urlParams.testNumber ) {
-
- // Ensure that urlParams.testNumber is an array
- urlParams.testNumber = [].concat( urlParams.testNumber );
- for ( i = 0; i < urlParams.testNumber.length; i++ ) {
- current = urlParams.testNumber[ i ];
- config.testNumber.push( parseInt( current, 10 ) );
- }
- }
-
- // Figure out if we're running the tests from a server or not
- QUnit.isLocal = location.protocol === "file:";
-}());
-
-extend( QUnit, {
-
- config: config,
-
- // Safe object type checking
- is: function( type, obj ) {
- return QUnit.objectType( obj ) === type;
- },
-
- objectType: function( obj ) {
- if ( typeof obj === "undefined" ) {
- return "undefined";
- }
-
- // Consider: typeof null === object
- if ( obj === null ) {
- return "null";
- }
-
- var match = toString.call( obj ).match( /^\[object\s(.*)\]$/ ),
- type = match && match[ 1 ] || "";
-
- switch ( type ) {
- case "Number":
- if ( isNaN( obj ) ) {
- return "nan";
- }
- return "number";
- case "String":
- case "Boolean":
- case "Array":
- case "Date":
- case "RegExp":
- case "Function":
- return type.toLowerCase();
- }
- if ( typeof obj === "object" ) {
- return "object";
- }
- return undefined;
- },
-
- url: function( params ) {
- params = extend( extend( {}, QUnit.urlParams ), params );
- var key,
- querystring = "?";
-
- for ( key in params ) {
- if ( hasOwn.call( params, key ) ) {
- querystring += encodeURIComponent( key ) + "=" +
- encodeURIComponent( params[ key ] ) + "&";
- }
- }
- return window.location.protocol + "//" + window.location.host +
- window.location.pathname + querystring.slice( 0, -1 );
- },
-
- extend: extend
-});
-
-/**
- * @deprecated: Created for backwards compatibility with test runner that set the hook function
- * into QUnit.{hook}, instead of invoking it and passing the hook function.
- * QUnit.constructor is set to the empty F() above so that we can add to it's prototype here.
- * Doing this allows us to tell if the following methods have been overwritten on the actual
- * QUnit object.
- */
-extend( QUnit.constructor.prototype, {
-
- // Logging callbacks; all receive a single argument with the listed properties
- // run test/logs.html for any related changes
- begin: registerLoggingCallback( "begin" ),
-
- // done: { failed, passed, total, runtime }
- done: registerLoggingCallback( "done" ),
-
- // log: { result, actual, expected, message }
- log: registerLoggingCallback( "log" ),
-
- // testStart: { name }
- testStart: registerLoggingCallback( "testStart" ),
-
- // testDone: { name, failed, passed, total, runtime }
- testDone: registerLoggingCallback( "testDone" ),
-
- // moduleStart: { name }
- moduleStart: registerLoggingCallback( "moduleStart" ),
-
- // moduleDone: { name, failed, passed, total }
- moduleDone: registerLoggingCallback( "moduleDone" )
-});
-
-QUnit.load = function() {
- runLoggingCallbacks( "begin", {
- totalTests: Test.count
- });
-
- // Initialize the configuration options
- extend( config, {
- stats: { all: 0, bad: 0 },
- moduleStats: { all: 0, bad: 0 },
- started: 0,
- updateRate: 1000,
- autostart: true,
- filter: "",
- semaphore: 1
- }, true );
-
- config.blocking = false;
-
- if ( config.autostart ) {
- QUnit.start();
- }
-};
-
-// `onErrorFnPrev` initialized at top of scope
-// Preserve other handlers
-onErrorFnPrev = window.onerror;
-
-// Cover uncaught exceptions
-// Returning true will suppress the default browser handler,
-// returning false will let it run.
-window.onerror = function( error, filePath, linerNr ) {
- var ret = false;
- if ( onErrorFnPrev ) {
- ret = onErrorFnPrev( error, filePath, linerNr );
- }
-
- // Treat return value as window.onerror itself does,
- // Only do our handling if not suppressed.
- if ( ret !== true ) {
- if ( QUnit.config.current ) {
- if ( QUnit.config.current.ignoreGlobalErrors ) {
- return true;
- }
- QUnit.pushFailure( error, filePath + ":" + linerNr );
- } else {
- QUnit.test( "global failure", extend(function() {
- QUnit.pushFailure( error, filePath + ":" + linerNr );
- }, { validTest: validTest } ) );
- }
- return false;
- }
-
- return ret;
-};
-
-function done() {
- config.autorun = true;
-
- // Log the last module results
- if ( config.previousModule ) {
- runLoggingCallbacks( "moduleDone", {
- name: config.previousModule,
- failed: config.moduleStats.bad,
- passed: config.moduleStats.all - config.moduleStats.bad,
- total: config.moduleStats.all
- });
- }
- delete config.previousModule;
-
- var runtime = now() - config.started,
- passed = config.stats.all - config.stats.bad;
-
- runLoggingCallbacks( "done", {
- failed: config.stats.bad,
- passed: passed,
- total: config.stats.all,
- runtime: runtime
- });
-}
-
-/** @return Boolean: true if this test should be ran */
-function validTest( test ) {
- var include,
- filter = config.filter && config.filter.toLowerCase(),
- module = config.module && config.module.toLowerCase(),
- fullName = ( test.module + ": " + test.testName ).toLowerCase();
-
- // Internally-generated tests are always valid
- if ( test.callback && test.callback.validTest === validTest ) {
- delete test.callback.validTest;
- return true;
- }
-
- if ( config.testNumber.length > 0 ) {
- if ( inArray( test.testNumber, config.testNumber ) < 0 ) {
- return false;
- }
- }
-
- if ( module && ( !test.module || test.module.toLowerCase() !== module ) ) {
- return false;
- }
-
- if ( !filter ) {
- return true;
- }
-
- include = filter.charAt( 0 ) !== "!";
- if ( !include ) {
- filter = filter.slice( 1 );
- }
-
- // If the filter matches, we need to honour include
- if ( fullName.indexOf( filter ) !== -1 ) {
- return include;
- }
-
- // Otherwise, do the opposite
- return !include;
-}
-
-// Doesn't support IE6 to IE9
-// See also https://developer.mozilla.org/en/JavaScript/Reference/Global_Objects/Error/Stack
-function extractStacktrace( e, offset ) {
- offset = offset === undefined ? 4 : offset;
-
- var stack, include, i;
-
- if ( e.stacktrace ) {
-
- // Opera 12.x
- return e.stacktrace.split( "\n" )[ offset + 3 ];
- } else if ( e.stack ) {
-
- // Firefox, Chrome, Safari 6+, IE10+, PhantomJS and Node
- stack = e.stack.split( "\n" );
- if ( /^error$/i.test( stack[ 0 ] ) ) {
- stack.shift();
- }
- if ( fileName ) {
- include = [];
- for ( i = offset; i < stack.length; i++ ) {
- if ( stack[ i ].indexOf( fileName ) !== -1 ) {
- break;
- }
- include.push( stack[ i ] );
- }
- if ( include.length ) {
- return include.join( "\n" );
- }
- }
- return stack[ offset ];
- } else if ( e.sourceURL ) {
-
- // Safari < 6
- // exclude useless self-reference for generated Error objects
- if ( /qunit.js$/.test( e.sourceURL ) ) {
- return;
- }
-
- // for actual exceptions, this is useful
- return e.sourceURL + ":" + e.line;
- }
-}
-function sourceFromStacktrace( offset ) {
- try {
- throw new Error();
- } catch ( e ) {
- return extractStacktrace( e, offset );
- }
-}
-
-function synchronize( callback, last ) {
- config.queue.push( callback );
-
- if ( config.autorun && !config.blocking ) {
- process( last );
- }
-}
-
-function process( last ) {
- function next() {
- process( last );
- }
- var start = now();
- config.depth = config.depth ? config.depth + 1 : 1;
-
- while ( config.queue.length && !config.blocking ) {
- if ( !defined.setTimeout || config.updateRate <= 0 || ( ( now() - start ) < config.updateRate ) ) {
- config.queue.shift()();
- } else {
- setTimeout( next, 13 );
- break;
- }
- }
- config.depth--;
- if ( last && !config.blocking && !config.queue.length && config.depth === 0 ) {
- done();
- }
-}
-
-function saveGlobal() {
- config.pollution = [];
-
- if ( config.noglobals ) {
- for ( var key in window ) {
- if ( hasOwn.call( window, key ) ) {
- // in Opera sometimes DOM element ids show up here, ignore them
- if ( /^qunit-test-output/.test( key ) ) {
- continue;
- }
- config.pollution.push( key );
- }
- }
- }
-}
-
-function checkPollution() {
- var newGlobals,
- deletedGlobals,
- old = config.pollution;
-
- saveGlobal();
-
- newGlobals = diff( config.pollution, old );
- if ( newGlobals.length > 0 ) {
- QUnit.pushFailure( "Introduced global variable(s): " + newGlobals.join( ", " ) );
- }
-
- deletedGlobals = diff( old, config.pollution );
- if ( deletedGlobals.length > 0 ) {
- QUnit.pushFailure( "Deleted global variable(s): " + deletedGlobals.join( ", " ) );
- }
-}
-
-// returns a new Array with the elements that are in a but not in b
-function diff( a, b ) {
- var i, j,
- result = a.slice();
-
- for ( i = 0; i < result.length; i++ ) {
- for ( j = 0; j < b.length; j++ ) {
- if ( result[ i ] === b[ j ] ) {
- result.splice( i, 1 );
- i--;
- break;
- }
- }
- }
- return result;
-}
-
-function extend( a, b, undefOnly ) {
- for ( var prop in b ) {
- if ( hasOwn.call( b, prop ) ) {
-
- // Avoid "Member not found" error in IE8 caused by messing with window.constructor
- if ( !( prop === "constructor" && a === window ) ) {
- if ( b[ prop ] === undefined ) {
- delete a[ prop ];
- } else if ( !( undefOnly && typeof a[ prop ] !== "undefined" ) ) {
- a[ prop ] = b[ prop ];
- }
- }
- }
- }
-
- return a;
-}
-
-function registerLoggingCallback( key ) {
-
- // Initialize key collection of logging callback
- if ( QUnit.objectType( config.callbacks[ key ] ) === "undefined" ) {
- config.callbacks[ key ] = [];
- }
-
- return function( callback ) {
- config.callbacks[ key ].push( callback );
- };
-}
-
-function runLoggingCallbacks( key, args ) {
- var i, l, callbacks;
-
- callbacks = config.callbacks[ key ];
- for ( i = 0, l = callbacks.length; i < l; i++ ) {
- callbacks[ i ]( args );
- }
-}
-
-// from jquery.js
-function inArray( elem, array ) {
- if ( array.indexOf ) {
- return array.indexOf( elem );
- }
-
- for ( var i = 0, length = array.length; i < length; i++ ) {
- if ( array[ i ] === elem ) {
- return i;
- }
- }
-
- return -1;
-}
diff --git a/web/src/vendor/qunit/src/dump.js b/web/src/vendor/qunit/src/dump.js
deleted file mode 100644
index 7f14ebda..00000000
--- a/web/src/vendor/qunit/src/dump.js
+++ /dev/null
@@ -1,240 +0,0 @@
-// Based on jsDump by Ariel Flesler
-// http://flesler.blogspot.com/2008/05/jsdump-pretty-dump-of-any-javascript.html
-QUnit.dump = (function() {
- function quote( str ) {
- return "\"" + str.toString().replace( /"/g, "\\\"" ) + "\"";
- }
- function literal( o ) {
- return o + "";
- }
- function join( pre, arr, post ) {
- var s = dump.separator(),
- base = dump.indent(),
- inner = dump.indent( 1 );
- if ( arr.join ) {
- arr = arr.join( "," + s + inner );
- }
- if ( !arr ) {
- return pre + post;
- }
- return [ pre, inner + arr, base + post ].join( s );
- }
- function array( arr, stack ) {
- var i = arr.length,
- ret = new Array( i );
- this.up();
- while ( i-- ) {
- ret[ i ] = this.parse( arr[ i ], undefined, stack );
- }
- this.down();
- return join( "[", ret, "]" );
- }
-
- var reName = /^function (\w+)/,
- dump = {
- // type is used mostly internally, you can fix a (custom)type in advance
- parse: function( obj, type, stack ) {
- stack = stack || [];
- var inStack, res,
- parser = this.parsers[ type || this.typeOf( obj ) ];
-
- type = typeof parser;
- inStack = inArray( obj, stack );
-
- if ( inStack !== -1 ) {
- return "recursion(" + ( inStack - stack.length ) + ")";
- }
- if ( type === "function" ) {
- stack.push( obj );
- res = parser.call( this, obj, stack );
- stack.pop();
- return res;
- }
- return ( type === "string" ) ? parser : this.parsers.error;
- },
- typeOf: function( obj ) {
- var type;
- if ( obj === null ) {
- type = "null";
- } else if ( typeof obj === "undefined" ) {
- type = "undefined";
- } else if ( QUnit.is( "regexp", obj ) ) {
- type = "regexp";
- } else if ( QUnit.is( "date", obj ) ) {
- type = "date";
- } else if ( QUnit.is( "function", obj ) ) {
- type = "function";
- } else if ( typeof obj.setInterval !== undefined && typeof obj.document !== "undefined" && typeof obj.nodeType === "undefined" ) {
- type = "window";
- } else if ( obj.nodeType === 9 ) {
- type = "document";
- } else if ( obj.nodeType ) {
- type = "node";
- } else if (
-
- // native arrays
- toString.call( obj ) === "[object Array]" ||
-
- // NodeList objects
- ( typeof obj.length === "number" && typeof obj.item !== "undefined" && ( obj.length ? obj.item( 0 ) === obj[ 0 ] : ( obj.item( 0 ) === null && typeof obj[ 0 ] === "undefined" ) ) )
- ) {
- type = "array";
- } else if ( obj.constructor === Error.prototype.constructor ) {
- type = "error";
- } else {
- type = typeof obj;
- }
- return type;
- },
- separator: function() {
- return this.multiline ? this.HTML ? "<br />" : "\n" : this.HTML ? "&nbsp;" : " ";
- },
- // extra can be a number, shortcut for increasing-calling-decreasing
- indent: function( extra ) {
- if ( !this.multiline ) {
- return "";
- }
- var chr = this.indentChar;
- if ( this.HTML ) {
- chr = chr.replace( /\t/g, " " ).replace( / /g, "&nbsp;" );
- }
- return new Array( this.depth + ( extra || 0 ) ).join( chr );
- },
- up: function( a ) {
- this.depth += a || 1;
- },
- down: function( a ) {
- this.depth -= a || 1;
- },
- setParser: function( name, parser ) {
- this.parsers[ name ] = parser;
- },
- // The next 3 are exposed so you can use them
- quote: quote,
- literal: literal,
- join: join,
- //
- depth: 1,
- // This is the list of parsers, to modify them, use dump.setParser
- parsers: {
- window: "[Window]",
- document: "[Document]",
- error: function( error ) {
- return "Error(\"" + error.message + "\")";
- },
- unknown: "[Unknown]",
- "null": "null",
- "undefined": "undefined",
- "function": function( fn ) {
- var ret = "function",
- // functions never have name in IE
- name = "name" in fn ? fn.name : ( reName.exec( fn ) || [] )[ 1 ];
-
- if ( name ) {
- ret += " " + name;
- }
- ret += "( ";
-
- ret = [ ret, dump.parse( fn, "functionArgs" ), "){" ].join( "" );
- return join( ret, dump.parse( fn, "functionCode" ), "}" );
- },
- array: array,
- nodelist: array,
- "arguments": array,
- object: function( map, stack ) {
- /*jshint forin:false */
- var ret = [], keys, key, val, i, nonEnumerableProperties;
- dump.up();
- keys = [];
- for ( key in map ) {
- keys.push( key );
- }
-
- // Some properties are not always enumerable on Error objects.
- nonEnumerableProperties = [ "message", "name" ];
- for ( i in nonEnumerableProperties ) {
- key = nonEnumerableProperties[ i ];
- if ( key in map && !( key in keys ) ) {
- keys.push( key );
- }
- }
- keys.sort();
- for ( i = 0; i < keys.length; i++ ) {
- key = keys[ i ];
- val = map[ key ];
- ret.push( dump.parse( key, "key" ) + ": " + dump.parse( val, undefined, stack ) );
- }
- dump.down();
- return join( "{", ret, "}" );
- },
- node: function( node ) {
- var len, i, val,
- open = dump.HTML ? "&lt;" : "<",
- close = dump.HTML ? "&gt;" : ">",
- tag = node.nodeName.toLowerCase(),
- ret = open + tag,
- attrs = node.attributes;
-
- if ( attrs ) {
- for ( i = 0, len = attrs.length; i < len; i++ ) {
- val = attrs[ i ].nodeValue;
-
- // IE6 includes all attributes in .attributes, even ones not explicitly set.
- // Those have values like undefined, null, 0, false, "" or "inherit".
- if ( val && val !== "inherit" ) {
- ret += " " + attrs[ i ].nodeName + "=" + dump.parse( val, "attribute" );
- }
- }
- }
- ret += close;
-
- // Show content of TextNode or CDATASection
- if ( node.nodeType === 3 || node.nodeType === 4 ) {
- ret += node.nodeValue;
- }
-
- return ret + open + "/" + tag + close;
- },
-
- // function calls it internally, it's the arguments part of the function
- functionArgs: function( fn ) {
- var args,
- l = fn.length;
-
- if ( !l ) {
- return "";
- }
-
- args = new Array( l );
- while ( l-- ) {
-
- // 97 is 'a'
- args[ l ] = String.fromCharCode( 97 + l );
- }
- return " " + args.join( ", " ) + " ";
- },
- // object calls it internally, the key part of an item in a map
- key: quote,
- // function calls it internally, it's the content of the function
- functionCode: "[code]",
- // node calls it internally, it's an html attribute value
- attribute: quote,
- string: quote,
- date: quote,
- regexp: literal,
- number: literal,
- "boolean": literal
- },
- // if true, entities are escaped ( <, >, \t, space and \n )
- HTML: false,
- // indentation unit
- indentChar: " ",
- // if true, items in a collection, are separated by a \n, else just a space.
- multiline: true
- };
-
- return dump;
-}());
-
-// back compat
-QUnit.jsDump = QUnit.dump;
diff --git a/web/src/vendor/qunit/src/equiv.js b/web/src/vendor/qunit/src/equiv.js
deleted file mode 100644
index 1fd05da9..00000000
--- a/web/src/vendor/qunit/src/equiv.js
+++ /dev/null
@@ -1,218 +0,0 @@
-// Test for equality any JavaScript type.
-// Author: Philippe Rathé <prathe@gmail.com>
-QUnit.equiv = (function() {
-
- // Call the o related callback with the given arguments.
- function bindCallbacks( o, callbacks, args ) {
- var prop = QUnit.objectType( o );
- if ( prop ) {
- if ( QUnit.objectType( callbacks[ prop ] ) === "function" ) {
- return callbacks[ prop ].apply( callbacks, args );
- } else {
- return callbacks[ prop ]; // or undefined
- }
- }
- }
-
- // the real equiv function
- var innerEquiv,
-
- // stack to decide between skip/abort functions
- callers = [],
-
- // stack to avoiding loops from circular referencing
- parents = [],
- parentsB = [],
-
- getProto = Object.getPrototypeOf || function( obj ) {
- /* jshint camelcase: false, proto: true */
- return obj.__proto__;
- },
- callbacks = (function() {
-
- // for string, boolean, number and null
- function useStrictEquality( b, a ) {
-
- /*jshint eqeqeq:false */
- if ( b instanceof a.constructor || a instanceof b.constructor ) {
-
- // to catch short annotation VS 'new' annotation of a
- // declaration
- // e.g. var i = 1;
- // var j = new Number(1);
- return a == b;
- } else {
- return a === b;
- }
- }
-
- return {
- "string": useStrictEquality,
- "boolean": useStrictEquality,
- "number": useStrictEquality,
- "null": useStrictEquality,
- "undefined": useStrictEquality,
-
- "nan": function( b ) {
- return isNaN( b );
- },
-
- "date": function( b, a ) {
- return QUnit.objectType( b ) === "date" && a.valueOf() === b.valueOf();
- },
-
- "regexp": function( b, a ) {
- return QUnit.objectType( b ) === "regexp" &&
-
- // the regex itself
- a.source === b.source &&
-
- // and its modifiers
- a.global === b.global &&
-
- // (gmi) ...
- a.ignoreCase === b.ignoreCase &&
- a.multiline === b.multiline &&
- a.sticky === b.sticky;
- },
-
- // - skip when the property is a method of an instance (OOP)
- // - abort otherwise,
- // initial === would have catch identical references anyway
- "function": function() {
- var caller = callers[ callers.length - 1 ];
- return caller !== Object && typeof caller !== "undefined";
- },
-
- "array": function( b, a ) {
- var i, j, len, loop, aCircular, bCircular;
-
- // b could be an object literal here
- if ( QUnit.objectType( b ) !== "array" ) {
- return false;
- }
-
- len = a.length;
- if ( len !== b.length ) {
- // safe and faster
- return false;
- }
-
- // track reference to avoid circular references
- parents.push( a );
- parentsB.push( b );
- for ( i = 0; i < len; i++ ) {
- loop = false;
- for ( j = 0; j < parents.length; j++ ) {
- aCircular = parents[ j ] === a[ i ];
- bCircular = parentsB[ j ] === b[ i ];
- if ( aCircular || bCircular ) {
- if ( a[ i ] === b[ i ] || aCircular && bCircular ) {
- loop = true;
- } else {
- parents.pop();
- parentsB.pop();
- return false;
- }
- }
- }
- if ( !loop && !innerEquiv( a[ i ], b[ i ] ) ) {
- parents.pop();
- parentsB.pop();
- return false;
- }
- }
- parents.pop();
- parentsB.pop();
- return true;
- },
-
- "object": function( b, a ) {
-
- /*jshint forin:false */
- var i, j, loop, aCircular, bCircular,
- // Default to true
- eq = true,
- aProperties = [],
- bProperties = [];
-
- // comparing constructors is more strict than using
- // instanceof
- if ( a.constructor !== b.constructor ) {
-
- // Allow objects with no prototype to be equivalent to
- // objects with Object as their constructor.
- if ( !( ( getProto( a ) === null && getProto( b ) === Object.prototype ) ||
- ( getProto( b ) === null && getProto( a ) === Object.prototype ) ) ) {
- return false;
- }
- }
-
- // stack constructor before traversing properties
- callers.push( a.constructor );
-
- // track reference to avoid circular references
- parents.push( a );
- parentsB.push( b );
-
- // be strict: don't ensure hasOwnProperty and go deep
- for ( i in a ) {
- loop = false;
- for ( j = 0; j < parents.length; j++ ) {
- aCircular = parents[ j ] === a[ i ];
- bCircular = parentsB[ j ] === b[ i ];
- if ( aCircular || bCircular ) {
- if ( a[ i ] === b[ i ] || aCircular && bCircular ) {
- loop = true;
- } else {
- eq = false;
- break;
- }
- }
- }
- aProperties.push( i );
- if ( !loop && !innerEquiv( a[ i ], b[ i ] ) ) {
- eq = false;
- break;
- }
- }
-
- parents.pop();
- parentsB.pop();
- callers.pop(); // unstack, we are done
-
- for ( i in b ) {
- bProperties.push( i ); // collect b's properties
- }
-
- // Ensures identical properties name
- return eq && innerEquiv( aProperties.sort(), bProperties.sort() );
- }
- };
- }());
-
- innerEquiv = function() { // can take multiple arguments
- var args = [].slice.apply( arguments );
- if ( args.length < 2 ) {
- return true; // end transition
- }
-
- return ( (function( a, b ) {
- if ( a === b ) {
- return true; // catch the most you can
- } else if ( a === null || b === null || typeof a === "undefined" ||
- typeof b === "undefined" ||
- QUnit.objectType( a ) !== QUnit.objectType( b ) ) {
-
- // don't lose time with error prone cases
- return false;
- } else {
- return bindCallbacks( a, callbacks, [ b, a ] );
- }
-
- // apply transition with (1..n) arguments
- }( args[ 0 ], args[ 1 ] ) ) && innerEquiv.apply( this, args.splice( 1, args.length - 1 ) ) );
- };
-
- return innerEquiv;
-}());
diff --git a/web/src/vendor/qunit/src/export.js b/web/src/vendor/qunit/src/export.js
deleted file mode 100644
index c3b61182..00000000
--- a/web/src/vendor/qunit/src/export.js
+++ /dev/null
@@ -1,54 +0,0 @@
-// For browser, export only select globals
-if ( typeof window !== "undefined" ) {
-
- // Deprecated
- // Extend assert methods to QUnit and Global scope through Backwards compatibility
- (function() {
- var i,
- assertions = Assert.prototype;
-
- function applyCurrent( current ) {
- return function() {
- var assert = new Assert( QUnit.config.current );
- current.apply( assert, arguments );
- };
- }
-
- for ( i in assertions ) {
- QUnit[ i ] = applyCurrent( assertions[ i ] );
- }
- })();
-
- (function() {
- var i, l,
- keys = [
- "test",
- "module",
- "expect",
- "asyncTest",
- "start",
- "stop",
- "ok",
- "equal",
- "notEqual",
- "propEqual",
- "notPropEqual",
- "deepEqual",
- "notDeepEqual",
- "strictEqual",
- "notStrictEqual",
- "throws"
- ];
-
- for ( i = 0, l = keys.length; i < l; i++ ) {
- window[ keys[ i ] ] = QUnit[ keys[ i ] ];
- }
- })();
-
- window.QUnit = QUnit;
-}
-
-// For CommonJS environments, export everything
-if ( typeof module !== "undefined" && module.exports ) {
- module.exports = QUnit;
-}
diff --git a/web/src/vendor/qunit/src/intro.js b/web/src/vendor/qunit/src/intro.js
deleted file mode 100644
index 8a0f3d46..00000000
--- a/web/src/vendor/qunit/src/intro.js
+++ /dev/null
@@ -1,12 +0,0 @@
-/*!
- * QUnit @VERSION
- * http://qunitjs.com/
- *
- * Copyright 2014 jQuery Foundation and other contributors
- * Released under the MIT license
- * http://jquery.org/license
- *
- * Date: @DATE
- */
-
-(function( window ) {
diff --git a/web/src/vendor/qunit/src/outro.js b/web/src/vendor/qunit/src/outro.js
deleted file mode 100644
index 6ad46d81..00000000
--- a/web/src/vendor/qunit/src/outro.js
+++ /dev/null
@@ -1,4 +0,0 @@
-// Get a reference to the global object, like window in browsers
-}( (function() {
- return this;
-})() ));
diff --git a/web/src/vendor/qunit/src/qunit.css b/web/src/vendor/qunit/src/qunit.css
deleted file mode 100644
index ca8fe389..00000000
--- a/web/src/vendor/qunit/src/qunit.css
+++ /dev/null
@@ -1,237 +0,0 @@
-/*!
- * QUnit @VERSION
- * http://qunitjs.com/
- *
- * Copyright 2014 jQuery Foundation and other contributors
- * Released under the MIT license
- * http://jquery.org/license
- *
- * Date: @DATE
- */
-
-/** Font Family and Sizes */
-
-#qunit-tests, #qunit-header, #qunit-banner, #qunit-testrunner-toolbar, #qunit-userAgent, #qunit-testresult {
- font-family: "Helvetica Neue Light", "HelveticaNeue-Light", "Helvetica Neue", Calibri, Helvetica, Arial, sans-serif;
-}
-
-#qunit-testrunner-toolbar, #qunit-userAgent, #qunit-testresult, #qunit-tests li { font-size: small; }
-#qunit-tests { font-size: smaller; }
-
-
-/** Resets */
-
-#qunit-tests, #qunit-header, #qunit-banner, #qunit-userAgent, #qunit-testresult, #qunit-modulefilter {
- margin: 0;
- padding: 0;
-}
-
-
-/** Header */
-
-#qunit-header {
- padding: 0.5em 0 0.5em 1em;
-
- color: #8699A4;
- background-color: #0D3349;
-
- font-size: 1.5em;
- line-height: 1em;
- font-weight: 400;
-
- border-radius: 5px 5px 0 0;
-}
-
-#qunit-header a {
- text-decoration: none;
- color: #C2CCD1;
-}
-
-#qunit-header a:hover,
-#qunit-header a:focus {
- color: #FFF;
-}
-
-#qunit-testrunner-toolbar label {
- display: inline-block;
- padding: 0 0.5em 0 0.1em;
-}
-
-#qunit-banner {
- height: 5px;
-}
-
-#qunit-testrunner-toolbar {
- padding: 0.5em 1em 0.5em 1em;
- color: #5E740B;
- background-color: #EEE;
- overflow: hidden;
-}
-
-#qunit-userAgent {
- padding: 0.5em 1em 0.5em 1em;
- background-color: #2B81AF;
- color: #FFF;
- text-shadow: rgba(0, 0, 0, 0.5) 2px 2px 1px;
-}
-
-#qunit-modulefilter-container {
- float: right;
-}
-
-/** Tests: Pass/Fail */
-
-#qunit-tests {
- list-style-position: inside;
-}
-
-#qunit-tests li {
- padding: 0.4em 1em 0.4em 1em;
- border-bottom: 1px solid #FFF;
- list-style-position: inside;
-}
-
-#qunit-tests.hidepass li.pass, #qunit-tests.hidepass li.running {
- display: none;
-}
-
-#qunit-tests li strong {
- cursor: pointer;
-}
-
-#qunit-tests li a {
- padding: 0.5em;
- color: #C2CCD1;
- text-decoration: none;
-}
-#qunit-tests li a:hover,
-#qunit-tests li a:focus {
- color: #000;
-}
-
-#qunit-tests li .runtime {
- float: right;
- font-size: smaller;
-}
-
-.qunit-assert-list {
- margin-top: 0.5em;
- padding: 0.5em;
-
- background-color: #FFF;
-
- border-radius: 5px;
-}
-
-.qunit-collapsed {
- display: none;
-}
-
-#qunit-tests table {
- border-collapse: collapse;
- margin-top: 0.2em;
-}
-
-#qunit-tests th {
- text-align: right;
- vertical-align: top;
- padding: 0 0.5em 0 0;
-}
-
-#qunit-tests td {
- vertical-align: top;
-}
-
-#qunit-tests pre {
- margin: 0;
- white-space: pre-wrap;
- word-wrap: break-word;
-}
-
-#qunit-tests del {
- background-color: #E0F2BE;
- color: #374E0C;
- text-decoration: none;
-}
-
-#qunit-tests ins {
- background-color: #FFCACA;
- color: #500;
- text-decoration: none;
-}
-
-/*** Test Counts */
-
-#qunit-tests b.counts { color: #000; }
-#qunit-tests b.passed { color: #5E740B; }
-#qunit-tests b.failed { color: #710909; }
-
-#qunit-tests li li {
- padding: 5px;
- background-color: #FFF;
- border-bottom: none;
- list-style-position: inside;
-}
-
-/*** Passing Styles */
-
-#qunit-tests li li.pass {
- color: #3C510C;
- background-color: #FFF;
- border-left: 10px solid #C6E746;
-}
-
-#qunit-tests .pass { color: #528CE0; background-color: #D2E0E6; }
-#qunit-tests .pass .test-name { color: #366097; }
-
-#qunit-tests .pass .test-actual,
-#qunit-tests .pass .test-expected { color: #999; }
-
-#qunit-banner.qunit-pass { background-color: #C6E746; }
-
-/*** Failing Styles */
-
-#qunit-tests li li.fail {
- color: #710909;
- background-color: #FFF;
- border-left: 10px solid #EE5757;
- white-space: pre;
-}
-
-#qunit-tests > li:last-child {
- border-radius: 0 0 5px 5px;
-}
-
-#qunit-tests .fail { color: #000; background-color: #EE5757; }
-#qunit-tests .fail .test-name,
-#qunit-tests .fail .module-name { color: #000; }
-
-#qunit-tests .fail .test-actual { color: #EE5757; }
-#qunit-tests .fail .test-expected { color: #008000; }
-
-#qunit-banner.qunit-fail { background-color: #EE5757; }
-
-
-/** Result */
-
-#qunit-testresult {
- padding: 0.5em 1em 0.5em 1em;
-
- color: #2B81AF;
- background-color: #D2E0E6;
-
- border-bottom: 1px solid #FFF;
-}
-#qunit-testresult .module-name {
- font-weight: 700;
-}
-
-/** Fixture */
-
-#qunit-fixture {
- position: absolute;
- top: -10000px;
- left: -10000px;
- width: 1000px;
- height: 1000px;
-}
diff --git a/web/src/vendor/qunit/src/test.js b/web/src/vendor/qunit/src/test.js
deleted file mode 100644
index 1c4464bb..00000000
--- a/web/src/vendor/qunit/src/test.js
+++ /dev/null
@@ -1,254 +0,0 @@
-function Test( settings ) {
- extend( this, settings );
- this.assert = new Assert( this );
- this.assertions = [];
- this.testNumber = ++Test.count;
-}
-
-Test.count = 0;
-
-Test.prototype = {
- setup: function() {
- if (
-
- // Emit moduleStart when we're switching from one module to another
- this.module !== config.previousModule ||
-
- // They could be equal (both undefined) but if the previousModule property doesn't
- // yet exist it means this is the first test in a suite that isn't wrapped in a
- // module, in which case we'll just emit a moduleStart event for 'undefined'.
- // Without this, reporters can get testStart before moduleStart which is a problem.
- !hasOwn.call( config, "previousModule" )
- ) {
- if ( hasOwn.call( config, "previousModule" ) ) {
- runLoggingCallbacks( "moduleDone", {
- name: config.previousModule,
- failed: config.moduleStats.bad,
- passed: config.moduleStats.all - config.moduleStats.bad,
- total: config.moduleStats.all
- });
- }
- config.previousModule = this.module;
- config.moduleStats = { all: 0, bad: 0 };
- runLoggingCallbacks( "moduleStart", {
- name: this.module
- });
- }
-
- config.current = this;
-
- this.testEnvironment = extend({
- setup: function() {},
- teardown: function() {}
- }, this.moduleTestEnvironment );
-
- this.started = now();
- runLoggingCallbacks( "testStart", {
- name: this.testName,
- module: this.module,
- testNumber: this.testNumber
- });
-
- if ( !config.pollution ) {
- saveGlobal();
- }
- if ( config.notrycatch ) {
- this.testEnvironment.setup.call( this.testEnvironment, this.assert );
- return;
- }
- try {
- this.testEnvironment.setup.call( this.testEnvironment, this.assert );
- } catch ( e ) {
- this.pushFailure( "Setup failed on " + this.testName + ": " + ( e.message || e ), extractStacktrace( e, 0 ) );
- }
- },
- run: function() {
- config.current = this;
-
- if ( this.async ) {
- QUnit.stop();
- }
-
- this.callbackStarted = now();
-
- if ( config.notrycatch ) {
- this.callback.call( this.testEnvironment, this.assert );
- this.callbackRuntime = now() - this.callbackStarted;
- return;
- }
-
- try {
- this.callback.call( this.testEnvironment, this.assert );
- this.callbackRuntime = now() - this.callbackStarted;
- } catch ( e ) {
- this.callbackRuntime = now() - this.callbackStarted;
-
- this.pushFailure( "Died on test #" + ( this.assertions.length + 1 ) + " " + this.stack + ": " + ( e.message || e ), extractStacktrace( e, 0 ) );
-
- // else next test will carry the responsibility
- saveGlobal();
-
- // Restart the tests if they're blocking
- if ( config.blocking ) {
- QUnit.start();
- }
- }
- },
- teardown: function() {
- config.current = this;
- if ( config.notrycatch ) {
- if ( typeof this.callbackRuntime === "undefined" ) {
- this.callbackRuntime = now() - this.callbackStarted;
- }
- this.testEnvironment.teardown.call( this.testEnvironment, this.assert );
- return;
- } else {
- try {
- this.testEnvironment.teardown.call( this.testEnvironment, this.assert );
- } catch ( e ) {
- this.pushFailure( "Teardown failed on " + this.testName + ": " + ( e.message || e ), extractStacktrace( e, 0 ) );
- }
- }
- checkPollution();
- },
- finish: function() {
- config.current = this;
- if ( config.requireExpects && this.expected === null ) {
- this.pushFailure( "Expected number of assertions to be defined, but expect() was not called.", this.stack );
- } else if ( this.expected !== null && this.expected !== this.assertions.length ) {
- this.pushFailure( "Expected " + this.expected + " assertions, but " + this.assertions.length + " were run", this.stack );
- } else if ( this.expected === null && !this.assertions.length ) {
- this.pushFailure( "Expected at least one assertion, but none were run - call expect(0) to accept zero assertions.", this.stack );
- }
-
- var i,
- bad = 0;
-
- this.runtime = now() - this.started;
- config.stats.all += this.assertions.length;
- config.moduleStats.all += this.assertions.length;
-
- for ( i = 0; i < this.assertions.length; i++ ) {
- if ( !this.assertions[ i ].result ) {
- bad++;
- config.stats.bad++;
- config.moduleStats.bad++;
- }
- }
-
- runLoggingCallbacks( "testDone", {
- name: this.testName,
- module: this.module,
- failed: bad,
- passed: this.assertions.length - bad,
- total: this.assertions.length,
- runtime: this.runtime,
-
- // HTML Reporter use
- assertions: this.assertions,
- testNumber: this.testNumber,
-
- // DEPRECATED: this property will be removed in 2.0.0, use runtime instead
- duration: this.runtime
- });
-
- config.current = undefined;
- },
-
- queue: function() {
- var bad,
- test = this;
-
- function run() {
- // each of these can by async
- synchronize(function() {
- test.setup();
- });
- synchronize(function() {
- test.run();
- });
- synchronize(function() {
- test.teardown();
- });
- synchronize(function() {
- test.finish();
- });
- }
-
- // `bad` initialized at top of scope
- // defer when previous test run passed, if storage is available
- bad = QUnit.config.reorder && defined.sessionStorage &&
- +sessionStorage.getItem( "qunit-test-" + this.module + "-" + this.testName );
-
- if ( bad ) {
- run();
- } else {
- synchronize( run, true );
- }
- },
-
- push: function( result, actual, expected, message ) {
- var source,
- details = {
- module: this.module,
- name: this.testName,
- result: result,
- message: message,
- actual: actual,
- expected: expected,
- testNumber: this.testNumber
- };
-
- if ( !result ) {
- source = sourceFromStacktrace();
-
- if ( source ) {
- details.source = source;
- }
- }
-
- runLoggingCallbacks( "log", details );
-
- this.assertions.push({
- result: !!result,
- message: message
- });
- },
-
- pushFailure: function( message, source, actual ) {
- if ( !this instanceof Test ) {
- throw new Error( "pushFailure() assertion outside test context, was " + sourceFromStacktrace( 2 ) );
- }
-
- var details = {
- module: this.module,
- name: this.testName,
- result: false,
- message: message || "error",
- actual: actual || null,
- testNumber: this.testNumber
- };
-
- if ( source ) {
- details.source = source;
- }
-
- runLoggingCallbacks( "log", details );
-
- this.assertions.push({
- result: false,
- message: message
- });
- }
-};
-
-QUnit.pushFailure = function() {
- if ( !QUnit.config.current ) {
- throw new Error( "pushFailure() assertion outside test context, in " + sourceFromStacktrace( 2 ) );
- }
-
- // Gets current test obj
- var currentTest = QUnit.config.current.assert.test;
-
- return currentTest.pushFailure.apply( currentTest, arguments );
-};