Socket
Socket
Sign inDemoInstall

testling

Package Overview
Dependencies
174
Maintainers
1
Versions
35
Alerts
File Explorer

Advanced tools

Install Socket

Detect and block malicious and high-risk dependencies

Install

    testling

write tests for browser code


Version published
Weekly downloads
201
increased by9.24%
Maintainers
1
Install size
28.6 MB
Created
Weekly downloads
 

Changelog

Source

v1.7.5 - 2024-02-15

Commits

  • [Deps] update object-inspect, resolve, shell-quote eeba066
  • [Fix] render a &lt;br /&gt; instead of a newline, for IE < 8 e7b99cf
  • [Dev Deps] use ^ 74b1923
  • [Deps] update object-inspect, resolve 28ace20
  • [Dev Deps] update tape 6b716f2
  • [Dev Deps] update tape 50ee689
  • [Deps] update resolve a7ab4ee
  • [Dev Deps] update tape 8e2490e

Readme

Source

testling

Run testling-ci tests locally.

example

write a test:

var test = require('tape');

test('beep boop', function (t) {
    t.plan(2);
    t.equal(1+1, 2);
    t.ok(true);
});

run your test in a local headless browser:

$ browserify example/test.js | testling

TAP version 13
# beep boop
ok 1 should be equal
ok 2 (unnamed assert)

1..2
# tests 2
# pass  2

# ok

with an exit code of 0 for successes and non-zero for failures like a good unix citizen

Once you have a package.json with a configured "testling" field, you can just type:

$ testling

to run all your tests locally just like they will be run on testling-ci. This includes mocha harnesses, scripts, and files parameters.

usage

usage: testling {DIRECTORY|-} {OPTIONS}

If there (is no DIRECTORY and stdin is a tty) or the DIRECTORY is "-",
javascript will be read from stdin and executed.

Otherwise, DIRECTORY (or the $CWD) will be checked for a package.json with a
testling field.

OPTIONS are:

     --html  Instead of launching a server, show the generated html.

  --no-show  Don't render the console.log() output to the document body.

         -u  Instead of launching a browser, print the url to visit so you can
             open the browser yourself.

         -x  Launch a browser with an explicit command. By default, chrome or
             firefox is launched by searching your $PATH.

     --host  Set up the testling url on a specific hostname. Default: localhost

     --port  Set up the testling url on a specific port

testling field

Read more about how the package.json "testling" field works.

code coverage

To compute code coverage, just use the coverify transform with -t coverify when you run browserify.

coverify writes coverage data with console.log(), so you can pipe the output of testling through to the coverify command to parse the results and give human-readable output:

$ browserify -t coverify test.js | testling | coverify

TAP version 13
# beep boop
ok 1 should be equal

1..1
# tests 1
# pass  1

# ok

# /home/substack/projects/coverify/example/test.js: line 7, column 16-28

  if (err) deadCode();
           ^^^^^^^^^^^

# /home/substack/projects/coverify/example/foo.js: line 3, column 35-48

  if (i++ === 10 || (false && neverFires())) {
                              ^^^^^^^^^^^^

The exit code of coverify is non-zero when there are unreachable expressions.

dependencies

Make sure you have PhantomJS installed; this is the headless browser that testling will run your tests in if you are not using the -u option.

install

First, install browserify globally so that the testling command can find it when there is no browserify in ./node_modules/.bin:

npm install -g browserify

then do:

npm install -g testling

license

MIT

attack of the testlings!

Keywords

FAQs

Last updated on 15 Feb 2024

Did you know?

Socket for GitHub automatically highlights issues in each pull request and monitors the health of all your open source dependencies. Discover the contents of your packages and block harmful activity before you install or update your dependencies.

Install

Related posts

SocketSocket SOC 2 Logo

Product

  • Package Alerts
  • Integrations
  • Docs
  • Pricing
  • FAQ
  • Roadmap

Stay in touch

Get open source security insights delivered straight into your inbox.


  • Terms
  • Privacy
  • Security

Made with ⚡️ by Socket Inc