Tone.js/test
2018-12-12 20:41:19 -05:00
..
audio testing polyphonic voice handling 2018-06-20 23:12:45 -04:00
component updating test 2018-07-29 09:52:11 -04:00
control linting 2017-12-30 11:26:29 -05:00
core no online testing with safari 2018-08-26 20:06:17 -04:00
effect testing setting convolver buffer twice 2018-10-21 21:28:26 -04:00
event pointing at correct helper/Test 2018-05-18 12:07:20 -04:00
helper no more online tests 2018-12-12 20:33:09 -05:00
html testing the version was correctly added 2018-08-29 23:08:40 -04:00
instrument expanding testing threshold 2018-12-12 20:41:19 -05:00
signal removing signal proxies 2018-06-09 12:55:29 -04:00
source testing that a type can be passed into the constructor as an object 2018-12-09 20:40:46 -05:00
type moving deps to node_modules 2018-05-19 12:17:23 -04:00
index.html invoke test with timeout 2018-05-18 18:03:58 -04:00
README.md only using karma test runner with headless chrome 2017-06-29 17:31:10 -04:00

I am currently using two test runners: mocha and karma + mocha.

From within the gulp folder, run gulp karma-test to collect all of the files, launch a local server and run the tests.

Be sure that the browser window is in focus while tests are running.

Individual files can be tested by running gulp collectTests -f [Tone class name] which will update the test/Main.js with the given class' tests. You can then refresh the test/index.html page to rerun those tests.

You can also test groups of classes by folder by adding another flag. For example to test all of the signals run gulp collectTests --signal. or the shorthand form: gulp collectTests -s.

  • -s = --signal
  • -i = --instrument
  • -o = --source
  • -v = --event
  • -e = --effect
  • -c = --core
  • -m = --component
  • -t = --control

The tests target the latest specification and not any specific browser. I have been keeping a list of which features browsers/versions currently support in test/helper/Supports.js. Some tests are only conditionally run if that feature is supported on the platform.