Huge News!Announcing our $40M Series B led by Abstract Ventures.Learn More
Socket
Sign inDemoInstall
Socket

test-drive

Package Overview
Dependencies
Maintainers
3
Versions
190
Alerts
File Explorer

Advanced tools

Socket logo

Install Socket

Detect and block malicious and high-risk dependencies

Install

test-drive

Opinionated library for writing web component tests

  • 0.5.0
  • Source
  • npm
  • Socket score

Version published
Weekly downloads
298
increased by210.42%
Maintainers
3
Weekly downloads
 
Created
Source

Test Drive

Build Status

Test Drive is an opinionated, yet framework-agnostic collection of tools, matchers and helpers for efficient Test Driven Development of web applications, GUIs and client-side components. Based on existing Open Source projects, as well as original contributions and ideas, it provides not only practical and efficient solutions for writing reliable tests, but also methodological guidelines based on long-term experimentation and hard-won lessons.

How to write tests

waitFor(), waitForDOM()

Both return Promise which is fulfilled when specific set of actions (typically assertions) pass without throwing exception. If this doesn't happen before the timeout expires, the Promise will fail with the last exception thrown.

In both cases, the action is executed for the first time straight off, in a synchronous way.

waitFor(assertion, timeout = 500, pollingInterval = 10)

will re-execute the assertion sequentially (as specified by the pollingInterval in miliseconds), until it either passes or the timeout expires.

function waitForDom(domRoot, assertion, timeout = 500)

assumes the assertion is related to the state of the DOM (contained in domRoot) and, therefore, will be retried every time the relevant subtree changes.

Example:


    return waitFor(() => expect(someVariable).to.equal(666), 1000);

    return waitForDom(document.body, (dom) => expect(dom.querySelector('#myId')).not.to.be.null);

Locating your DOM parts: selectDOM()

selectDom(container: Element, attrName: string = 'data-automation-id')

Returns DOM selector function for the container, using attribute attrName. DOM selector is a function accepting one or more string identifiers.

Example:

    const select = selectDOM(document.body, 'my-id');
    const element = select('panel1', 'button-ok');

This code will find, inside the document body, element with attribute "myId" containing word "panel1" and inside it element with the same attribute containing word "button-ok".

element will be null, if such path cannot be resolved ("button-ok" or even "panel1" cannot be found).

The function select will throw an exception, if the path is ambiguous (e.g., "panel1" contains more than one "button-ok").

The .present() and .absent() matchers

Often, components have parts which are sometimes present, sometimes absent, depending on their configuration or state. As there are many possibilities how such "re-appearance" can be implemented, this kit provides a matcher that abstracts such internal implementation away.

Example:


    expect(element).to.be.present();
    expect(element).to.be.absent();

    expect(element).not.to.be.present();
    expect(element).not.to.be.absent();

"Presence" is defined as follows:

  • "element" is not null
  • "element" is an instance of Element
  • some part of "element" has real size (defined as ClientRect whose both width and height are greater than zero)

(This definition is inspired by [jQuery's :visible selector] (https://api.jquery.com/visible-selector/), but not necessarily compliant with it.)

Event Triggering

The trigger.* module lets you trigger native DOM events, enabling emulation of user interactions in interface tests.

trigger.change(target, "newValue")

will set "newValue" as a new .value of an input element (input, select and textarea elements are supported), and trigger focus, input and change events.

Layout Matchers

Using layout matchers, component developers can implement tests which assert relations between various parts of the component in terms of position in the document. Layout matchers abstract away the actual DOM structure and CSS rules, as they are based solely on absolute location of bounding rectangles. With the right combination of layout matchers, one should be able describe most of spatial relationships within components.

The parts are passed as references to HTMLElement.

Tests of layout matchers should provide exhaustive examples on how to use the matchers.

Placement

.insideOf(x) asserts that the subject is completely within the boundaries of element x.

.outsideOf(x) asserts the the subject is completely outside the boundaries of element x.

If the subject is partly inside and partly outside, none of the matchers passes.

Example:

expect(button).to.be.insideOf(panel);

Box Properties

Box properties of an element (width, height, left, top, right, bottom) can be measured and asserted with numeric matchers, such as:

expect(button1).to.have.width.equal(10);

Elements can also be compared with greaterThan(), above(), lessThan(), below(), at.least() and at.most():

expect(button1).to.have.height.greaterThan(button2);

At the same time, numeric comparisons will still work:

expect(button1).to.have.height.greaterThan(10);

Note that top and bottom will be compared as numbers. So bottom = 50 will still be "below" bottom = 100, even though visually it will, of course, appear "above".

Alignment

.horizontallyAligned("left" | "center" | "right, tolerance = 0.0)

.verticallyAligned("top" | "center" | "bottom", tolerance = 0.0)

The alignment matchers assert that all elements within a list are properly aligned with each other, with optional tolerance range.

Example:

expect([button1, button2, button3]).to.be.verticallyAligned("top", 1.5);

Sequence

.inHorizontalSequence({ distance = 0.0, tolerance = 1.0 })

.inVerticalSequence({ distance = 0.0, tolerance = 1.0 })

Asserts that all elements within a list form uninterrupted sequence, one adjacent to the other, without gaps.

Example:

expect([button1, button2, button3]).to.be.inHorizontalSequence({ distance: 10.0 });

FAQs

Package last updated on 29 Jun 2017

Did you know?

Socket

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
  • Changelog

Packages

npm

Stay in touch

Get open source security insights delivered straight into your inbox.


  • Terms
  • Privacy
  • Security

Made with ⚡️ by Socket Inc