• Stars
    star
    147
  • Rank 246,031 (Top 5 %)
  • Language
    TypeScript
  • License
    MIT License
  • Created about 9 years ago
  • Updated over 1 year ago

Reviews

There are no reviews yet. Be the first to send feedback to the community and the maintainers!

Repository Details

Checks a given object against a given specification to keep you from writing boilerplate tests.

spok

Checks a given object against a given set of specifications to keep you from writing boilerplate tests.

const test = require('node:test') 
// or: const test = require('tape') 
// or: const test = require('tap') 
const spok = require('spok')

// this would be returned from a function you are testing
const object = {
    one          : 1
  , two          : 2
  , three        : 3
  , four         : 4
  , helloWorld   : 'hello world'
  , anyNum       : 999
  , anotherNum   : 888
  , anArray      : [ 1, 2 ]
  , anotherArray : [ 1, 2, 3 ]
  , anObject     : {}
}

// custom specification
function hasThreeElements(a) {
  return a.length === 3
}

test('my object meets the specifications', (t) => {
  spok(t, object, {
      $topic      : 'spok-example'
    , one          : spok.ge(1)
    , two          : 2
    , three        : spok.range(2, 4)
    , four         : spok.lt(5)
    , helloWorld   : spok.startsWith('hello')
    , anyNum       : spok.type('number')
    , anotherNum   : spok.number
    , anArray      : spok.array
    , anotherArray : hasThreeElements
    , anObject     : spok.ne(undefined)
  })
})

shot

Installation

npm install spok

Node.js Test Runner

Since Node.js 16.x it includes a built-in test runner.

Spok support this out of the box as follows:

  • it uses the build-in assert module to assert the values
  • it uses the passed t: TestContext to print diagnostic messages that detail the assertions mad

See ./example/node-test.js and ./example/node-test-nested.jsfor a full examples.

Colors

spok detects if colors should be used in the output in order to avoid breaking TAP compatibility when needed as follows:

  • if FORCE_COLOR env var is set to 1|true colors are ALWAYS
  • if NO_COLOR env var is set to 1|true colors are NEVER used
  • if tests are executed via node --test mytest.js and FORCE_COLOR is not set then colorse are disabled
  • if tests are executed via node mytest.js and NO_COLOR is not set then colors are enabled

Tap/Tape

  • tap and tape provide a t which mirrors the assert module and also prints results and the diagnostics message to the console, thus spok uses t to perform assertions

See ./example/tape.js and ./example/tape-nested.jsfor a full examples.

Cypress/Chai Expect Support

Spok can be used out of the box with expect, for instance when running tests with cypress.io.

Simply create a custom assert function and pass it to spok. The main difference to running tests with tape is that if a single property in the compared object doesn't match the test fails immediately.

import spok from 'spok'
const t = spok.adapters.chaiExpect(expect)
spok(t, meta, {
  err: null,
  fee: 5000,
  status: {
    Ok: null,
  },
})

cypress-passing

spok(t, meta, {
  err: null,
  fee: 4000,
  status: {
    Ok: null,
  },
})

cypress-failing

Why not just deepEqual?

deepEqual works great for most cases, but in some cases you need more control, i.e.

  • values don't exactly match, but are in a given range
  • you want to provide a predicate to determine if a value is correct or not
  • you only want to check a subset of values contained in the object

Adjusting Print Details

By default spok prints the specification that a particular assertion satisified, i.e. satisfies: spok.range(2, 4). You can turn that off via spok.printSpec = false.

On the other hand if you want more details about the satisified spec do spok.printDescription = true instead to get spok to print things like satisfies: spok.range(2, 4) 2 <= value <= 4.

Specs and descriptions are printed in gray so you can focus on the actual values of the test output.

Table of Contents generated with DocToc

spok provides a few common specification functions. However you can write your own functions as well, just return true if specification was satisfied and false if not (see example above).

If you write a specification function that would be useful to others please add it along with a test and provide a PR.

spok.* comparison function names are derived from bash comparison operators to make them easier to remember.

API

spok

Checks the given specifications against the object.

When the tests are run the actual values are printed to verify visually while each provided specification is validated and a test failure caused if one of them fails.

Parameters

  • t Object which has assertion functions equal and deepEqual (to compare objects) - use tap, tape, assert, Node.js TestContext or any other library that has those and thus is compatible
  • obj Object the object to verify the specifications against
  • specifications Object the specifications to verify

spok.any

Version of spok that is less strict about the relation of the specification type, namely it allows overriding the type manually or derives it from the supplied parameter.

Use ONLY when you cannot adjust the types, so plain spok works.

spok.range

Specififies that the given number is within the given range, i.e. min<= x <=max.

var spec = {
 x: spok.range(1, 2)   // specifies that x should be >=1 and <=2
}

Parameters

spok.gt

Specififies that a number is greater than the given criteria.

var spec = {
 x: spok.gt(1)  // specifies that x should be >1
}

Parameters

spok.ge

Specififies that a number is greater or equal the given criteria.

var spec = {
 x: spok.ge(1)  // specifies that x should be >=1
}

Parameters

spok.lt

Specififies that a number is less than the given criteria.

var spec = {
 x: spok.lt(1)  // specifies that x should be < 1
}

Parameters

spok.le

Specififies that a number is less or equal the given criteria.

var spec = {
 x: spok.le(1)  // specifies that x should be <=1
}

Parameters

spok.ne

Specifies that the value is not equal another.

var spec = {
 x: spok.ne(undefined)  // specifies that x should be defined
}

Parameters

  • value Any criteria

spok.gtz

Specifies that the value is greater than zero

var spec = {
  x: spok.gtz
}

spok.gez

Specifies that the value is greater or equal zero

var spec = {
  x: spok.gez
}

spok.ltz

Specifies that the value is less than zero

var spec = {
  x: spok.ltz
}

spok.lez

Specifies that the value is less or equal zero

var spec = {
  x: spok.lez
}

spok.type

Specifies that the input is of a given type.

var spec = {
 x: spok.type('number')  // specifies that x should be a Number
}

Parameters

spok.array

Specifies that the input is an array.

var spec = {
 x: spok.array  // specifies that x should be an Array
}

spok.arrayElements

Specifies that the input is an array with a specific number of elements

var spec = { x: spok.arrayElements(2) // specifies that x should be an Array with 2 elements }

Parameters

spok.arrayElementsRange

Specifies that the input is an array with a number of elements in a given range

var spec = { x: spok.arrayElementsRange(2, 4) // specifies that x should be an Array with 2-4 elements }

Parameters

  • min Number min number of elements
  • max Number max number of elements

spok.number

Specifies that the input of type number and isNaN(x) returns false.

var spec = {
 x: spok.number  // specifies that x should be a Number
}

spok.string

Specifies that the input is a string.

var spec = {
  x: spok.string  // specifies that x should be a String
}

spok.function

Specifies that the input is a function.

var spec = {
  x: spok.function  // specifies that x should be a function
}

spok.definedObject

Specifies that the input is an object and it is not null.

var spec = {
 x: spok.definedObject  // specifies that x is a non-null object
}

spok.startsWith

Specifies that the string starts with the specified substring.

NOTE: only available with node.js which has an ES6 startsWith function

var spec = {
 x: spok.startsWith('hello')  // specifies that x should start with 'hello'
}

Parameters

  • what String substring the given string should start with

spok.endsWith

Specifies that the string ends with the specified substring.

NOTE: only available with node.js which has an ES6 endsWith function

var spec = {
 x: spok.endsWith('hello')  // specifies that x should start with 'hello'
}

Parameters

  • what String substring the given string should start with

spok.test

Specifies that the string needs to match the given regular expression.

var spec = {
  x: spok.test(/hello$/) // specifies that x should match /hello$/
}

Parameters

  • regex RegExp regular expression against which the string is checked via test

spok.defined

Specifies that a value is defined, i.e. it is neither null nor undefined.

var spec = {
  x: spok.defined
}

spok.notDefined

Specifies that a value is notDefined, i.e. it is either null or notDefined.

var spec = {
  x: spok.notDefined
}

License

MIT

More Repositories

1

doctoc

📜 Generates table of contents for markdown files inside local git repository. Links are compatible with anchors generated by github or other sites.
JavaScript
4,176
star
2

proxyquire

🔮 Proxies nodejs require in order to allow overriding dependencies during testing.
JavaScript
2,741
star
3

v8-perf

⏱️ Notes and resources related to v8 and thus Node.js performance
JavaScript
2,193
star
4

deoptigate

⏱️ Investigates v8/Node.js function deoptimizations.
JavaScript
1,148
star
5

brace

📔 browserify compatible version of the ace editor.
JavaScript
1,056
star
6

browserify-shim

📩 Makes CommonJS incompatible files browserifyable.
JavaScript
935
star
7

learnuv

Learn uv for fun and profit, a self guided workshop to the library that powers Node.js.
C
711
star
8

es6ify

browserify >=v2 transform to compile JavaScript.next (ES6) to JavaScript.current (ES5) on the fly.
JavaScript
595
star
9

visulator

A machine emulator that visualizes how each instruction is processed
JavaScript
381
star
10

exorcist

Externalizes the source map found inside a stream to an external .js.map file
JavaScript
332
star
11

parse-link-header

Parses a link header and returns paging information for each contained link.
JavaScript
298
star
12

libuv-dox

Documenting types and methods of libuv, mostly by reading 'uv.h'.
247
star
13

rid-examples

Examples showing how to use Rid in order to build Dart/Flutter apps integrated with Rust.
Dart
215
star
14

replpad

Pipes content of files to a node repl whenever they change to enable a highly interactive coding experience.
JavaScript
213
star
15

browserify-ftw

Converts an entire project that uses requirejs amd into on that uses nodejs common modules so it can be browserified.
JavaScript
188
star
16

cardinal

Syntax highlights JavaScript code with ANSI colors to be printed to the terminal.
JavaScript
175
star
17

turbolizer

Turbolizer tool from the v8 repository with added support to preload a profile
JavaScript
175
star
18

convert-source-map

Converts a source-map from/to different formats.
JavaScript
168
star
19

cpuprofilify

Converts output of various profiling/sampling tools to the .cpuprofile format so it can be loaded into Chrome DevTools.
JavaScript
167
star
20

flamegraph

Generates flamegraphs with Node.js or in the browser.
HTML
164
star
21

proxyquireify

browserify >= v2 version of proxyquire. Mocks out browserify's require to allow stubbing out dependencies while testing.
JavaScript
153
star
22

batufo

UFO mutli-player game using Flutter.
Dart
152
star
23

v8-flags

Configures v8 flags at runtime.
C
119
star
24

wasm2js

Compile WebAssembly .wasm files to a commonjs module.
JavaScript
110
star
25

browserify-markdown-editor

A demo showing how to build a markdown editor with browserify and marked.
JavaScript
91
star
26

combine-source-map

Add source maps of multiple files, offset them and then combine them into one source map.
JavaScript
78
star
27

nad

Node Addon Developer, a tool to inject your addon code into a copy of the node codebase in order to integrate with IDEs and debuggers easily.
JavaScript
76
star
28

irish-pub

Feel like npm is drunk or maybe you are and want to verify what gets published via `npm publish`? irish-pub has you covered.
JavaScript
69
star
29

hypernal

Renders terminal output as html to simplify reusing server side modules in the browser.
JavaScript
64
star
30

rid

Rust integrated Dart framework providing an easy way to build Flutter apps with Rust.
Rust
64
star
31

exposify

browserify transform that exposes globals added via a script tag as modules so they can be required.
JavaScript
63
star
32

nif

node --inspect a file and open devtool url in chrome via chrome-cli.
JavaScript
59
star
33

active-handles

Prints out information about the process's active handles, including function source and location
JavaScript
58
star
34

doctoc-web

This is the source of the DocToc web application.
JavaScript
56
star
35

traceviewify

Converts .cpuprofile format to trace viewer JSON object format to allow analysing the data in chrome://tracing.
JavaScript
55
star
36

readline-vim

Adds vim bindings to nodejs readline.
JavaScript
55
star
37

docme

Generates github compatible API documentation from your project's jsdocs and adds them to your Readme.
JavaScript
54
star
38

bunyan-format

Writable stream that formats bunyan records that are piped into it
JavaScript
51
star
39

wicked

Generates github wiki compatible API documentation from your project's jsdocs and adds them to your wiki.
JavaScript
49
star
40

lldb-jbt

Adds JavaScript symbols to lldb stack traces
Python
48
star
41

phe

Poker hand evaluator
JavaScript
47
star
42

d3-gauge

Gauge visualization built on top of d3.
CSS
45
star
43

dev-null

/dev/null for node streams
JavaScript
43
star
44

WebToInk

Downloads and converts a properly set up Html book or a blog into mobi format
Haskell
40
star
45

docmac

Install docker on Mac including VirtualBox and boot2docker dependencies with one simple command.
Shell
39
star
46

stack-mapper

Initialize it with a source map, then feed it error stacks to have the trace locations mapped to the original files.
JavaScript
39
star
47

stream-viz

Visualizes streams in the browser.
JavaScript
37
star
48

dotfiles

My vim and bash related dotfiles.
Shell
36
star
49

iojs-inspect-entire-stack

Demonstrating how to inspect the entire io.js stack
JavaScript
36
star
50

hermit

Prints html in the terminal using colors and simple layout to reflect the document structure.
JavaScript
36
star
51

v8-map-processor

Processes and visualizes maps (aka hidden classes) created by v8 during execution.
HTML
35
star
52

mold-source-map

Mold a source map that is almost perfect for you into one that is.
JavaScript
35
star
53

bromote

Tool to setup and require remote scripts with browserify.
JavaScript
35
star
54

log.h

Minimal yet colorful logging lib.
C
34
star
55

inline-source-map

Adds source mappings and base64 encodes them, so they can be inlined in your generated file.
JavaScript
34
star
56

testlingify

Adds github hooks and browser config for testling.
JavaScript
33
star
57

browserify-swap

A transform that swaps out modules according to a config in your package.json selected via an environment variable.
JavaScript
32
star
58

v8-profiling

Exploring how to hook into the various v8 profilers
C++
32
star
59

scriptie-talkie

Makes your code tell you what the intermediate results are when executing a script.
JavaScript
31
star
60

ee.c

EventEmitter in C.
C
30
star
61

resolve-bin

Resolves the full path to the bin file of a given package by inspecting the \"bin\" field in its package.json.
JavaScript
30
star
62

node-syntaxhighlighter

Node friendly version of Alex Gorbachev's great SyntaxHighlighter.
CSS
29
star
63

v8-runtime-functions

Exposing and documenting v8 runtime functions.
JavaScript
27
star
64

hyperwatch

Streams server side log messages to the browser and renders them inside your page.
JavaScript
27
star
65

sass-resolve

Resolves all sass files in current project and all dependencies to create one sass file which includes them all.
JavaScript
26
star
66

ansicolors

Functions that surround a string with ansicolor codes so it prints in color.
JavaScript
26
star
67

dockerify

Prepares any tarball containing a project so that a docker image can be built from it.
JavaScript
26
star
68

spinup

Spins up multiple versions of your app, each in its own docker container
JavaScript
25
star
69

redeyed

Takes JavaScript code, along with a config and returns the original code with tokens wrapped and/or replaced as configured.
JavaScript
25
star
70

anchor-markdown-header

Generates an anchor for a markdown header.
JavaScript
25
star
71

nasmx

The NASMX Project (manually maintained mirror) Documentation: https://thlorenz.github.io/nasmx
Assembly
25
star
72

find-parent-dir

Finds the first parent directory that contains a given file or directory.
JavaScript
24
star
73

dox

Notes and cheat sheets on various topics
DTrace
23
star
74

benchgraph

Runs {io,node}.js benchmarks and generates pretty graphs
JavaScript
22
star
75

kebab

Half queue half pubsub. Super small (< 30 loc) and simple queue that supports subscribers.
JavaScript
22
star
76

pong.asm

pong game written in assembly for i386 (32-bit) architecture.
Assembly
22
star
77

linuxasmtools

This package is part of AsmTools (a collection of programs for assembler development on Linux X86 cpu's.)
Assembly
22
star
78

peacock

JavaScript syntax highlighter that generates pygments compatible html and therefore supports pygments styles.
CSS
22
star
79

talks

Numerous talks I gave at meetups and conferences some based on reveal.js.
HTML
20
star
80

valiquire

Validates that all require statements in a project point to an existing path and are correctly cased.
JavaScript
20
star
81

prange

Parses poker hand range short notation into a range array.
JavaScript
19
star
82

jsdoc-githubify

A transform that adapts html files generated with jsdoc to be rendered in a github wiki or readme.
JavaScript
19
star
83

chromium-remote-debugging-proxy

A proxy that sits in between a chromium devtools frontend and the remote chromium being debugged and logs requests, responses and websocket messages that are exchanged.
JavaScript
19
star
84

ocat

Inspect an object various ways in order to easily generate test cases.
JavaScript
17
star
85

v8-sandbox

C++
17
star
86

hhp

Poker HandHistory Parser
JavaScript
16
star
87

node-traceur

Mirror of experimental ES6 to ES5 compiler that is kept in sync with code on google.
JavaScript
16
star
88

v8-ic-processor

Processes and visualizes IC (inline cache) information collected for functions in your application
HTML
16
star
89

pec

Poker equity calculator. Compares two combos or one combo against a range to compute winning equity.
JavaScript
16
star
90

floodgate

Throttles a stream to pass one value per given interval.
JavaScript
16
star
91

level-dump

Dumps all values and/or keys of a level db or a sublevel to the console.
JavaScript
15
star
92

tap-stream

Taps a nodejs stream and logs the data that's coming through
JavaScript
14
star
93

parse-key

Parses strings into key objects of the same format as the ones emitted by nodejs readline.
JavaScript
14
star
94

dockops

docker convenience functions on top of dockerode
JavaScript
14
star
95

nf-rated

Store and process Netflix movies including IMDB rating.
Rust
14
star
96

lib.asm

Collection of assembly routines in one place to facilitate reuse.
Assembly
13
star
97

sql-escape-string

Simple SQL string escape.
JavaScript
13
star
98

caching-coffeeify

A coffeeify version that caches previously compiled coffee-script to optimize the coffee-script compilation step.
JavaScript
13
star
99

cathode

Example for react server side rendering without the fluff
JavaScript
11
star
100

dog

Developer blOGgin Engine, markdown based, made to be simple and fast, yet feature rich.
JavaScript
11
star