There are currently three folders for tests, tests-qunit
,
tests-mocha
and tests-polyfill
(the latter are also Mocha-based
tests, but at present its W3C tests
only work in Node).
They can be run through a variety of means as described below.
To properly build the files (lint, browserify, and minify), use npm start
or to also keep a web server, run npm run dev
(or grunt dev
). If
you wish to do testing which only rebuilds the browser files, run
npm run dev-browser
and if only testing Node, run npm run dev-node
.
But before release, one should run npm run build
(or npm run dev
).
The tests produce various database files. These are avoided in
.gitignore
and should be cleaned up if the tests pass, but if
you wish to delete them all manually, run npm run clean
.
All QUnit-based tests should pass in modern browsers.
All Mocha-based browser tests should pass except for one test having a problem in Firefox.
Follow all of the steps above to build the project, then run npm test
or npm run sauce-qunit
(or npm run puppeteer-qunit
or
grunt puppeteer-qunit
to avoid using Saucelabs when you have
credentials set up as environmental variables) to run the unit tests.
Note that when not running Saucelabs, the tests are run in grunt-qunit-puppeteer, which uses headless Chromium.
Although it is possible to get the W3C web-platform-tests
runner
working via patches as per
indexeddbshim/IndexedDBShim#249,
allowing tests to be run from the runner without
obtrusive changes to the repository is not yet refined (see also
web-platform-tests/wpt#5133 (comment)).
The now recommended way
for installing web-platform-tests
is:
- (May need to do this first:
pip uninstall virtualenv
) pip install virtualenv
- Add to PATH (e.g.,
sudo nano /etc/paths
and add path to bottom of file)$HOME/Library/Python/2.7/bin
.
Then run (without any process for npm run wpt
running):
./wpt run --headless chrome IndexedDB
or./wpt run --binary=path --headless chrome IndexedDB
, installing any required dependencies.
If you want to run the tests in a normal web browser, you'll need to
spin-up a local web server and then open
tests-qunit/index.html?noglobals
and/or tests-mocha/index.html
in your browser. You can also run npm run dev
and point your
browser to http://localhost:9999/tests-qunit/index.html
or
http://localhost:9999/tests-mocha/index.html
.
Note that, for the Mocha tests, you probably wish to "Switch to IndexedDBShim" when doing the testing since otherwise, it will only test the native implementation.
For the W3C web-platform-tests
tests, individual tests can be run
in these ways.
- The first way currently adds files within
web-platform-tests
but does not modify files. To do this you must run agrunt dev
task or another such test that connects (to port 9999) and also follow the instructions to install and run the server at https://github.com/w3c/web-platform-tests. If you runnpm run w3c-add-wrap
(ornpm run w3c-remove-wrap
to undo), you will be able to add ".any.html" to an IndexedDB file, e.g., http://web-platform.test:8000/IndexedDB/historical.html becomes http://web-platform.test:8000/IndexedDB/historical.html.any.html. - The second way, unlike the first, allows files to be run from the
W3C test runner at http://web-platform.test:8000/tools/runner/index.html,
but it involves modifying files within
web-platform-tests
(you can usegit reset
to undo, however). You can then runnpm run w3c-wrap
and run files in the runner or individually. As above, you must also keep thegrunt dev
task (or the like) running on port 9999 and installweb-platform-tests
. - One may use
./wpt run
with specific paths (See automated testing above).
To run the Node tests, run the following:
npm run node-qunit
- The full test suite sometimes does not complete execution.npm run mocha
npm run tests-polyfill
(or its componentsnpm run fake
,npm run mock
,npm run w3c-old
). Note that onlyfake
is currently passing in full, however.npm run web-platform-tests
(ornpm run wpt
) and in a separate terminal window,npm run w3c
(you must first rungit submodule update --init --recursive
(possibly without init too if using an older version of Git),git submodule foreach --recursive git fetch
, andgit submodule foreach git merge origin master
or possiblygit submodule foreach git pull --ff-only origin master
). For the former three, you can runnpm run submodules
. Note that some of these tests may not be passing because of the test environment not being completely configured for Node. We are working on fixing this. There are some older and less complete W3C tests that can be run withnpm run w3c-old
, but the goal is to remove these once the new ones are configured properly and working in the browser as do the old tests. The W3C Python browser server also ought to be running due to requirements with the URL having permissions. Oncenpm run w3c
has been run once, you may also test against individual tests with:npm run w3c-test -- <test-name>
, e.g.,npm run w3c-test -- idbdatabase_createObjectStore7.js
, or with a starting index and length (so as to break up the many tests into more manageable segments, as may become necessary if there are memory issues, e.g.,0 200
then200 200
).
If you need to rebuild SQLite, you can run npm install
inside of the
node_modules/sqlite3
directory or run the IndexedDBShim sqlite-rebuild
script.
To run a specific Mocha test (which includes the tests-polyfill
tests), run npm --test=... run mocha
.
(Note that the repository as is might no longer be compatible with Cordova/PhoneGap support. Please let us know if you can try or supply any needed fixes.)
If you want to run the tests in a Cordova or PhoneGap app, then you'll need
to create a new Cordova/PhoneGap project, and add the
IndexedDB plug-in.
Then copy the contents of our
tests
directory into your project's www
directory. Delete our
index.html
file and rename
cordova.html
to index.html
.