3.1.20 • Published 1 month ago

@tapjs/nock v3.1.20

Weekly downloads
-
License
BlueOak-1.0.0
Repository
github
Last release
1 month ago

@tapjs/nock

A tap extension that integrates nock.

Features

  • t.nock()
    • automatically calls nock.disableNetConnect()
    • arguments are passed directly to nock, and the result from nock returned
    • asserts all nock scopes created within a test have been consumed
    • cleans only the nock scopes created within the current test, keeping nocks from parent tests
    • if no parent tests have nocks, calls nock.enableNetConnect() in teardown
  • t.nock.snapshot()
    • when snapshots are enabled, sends real requests and records responses to a fixture
    • when snapshots are not enabled, loads fixture data and sets up nock scopes for you

Usage

Load the @tapjs/nock plugin in your tap config.

For example, in .taprc:

plugins:
  - @tapjs/nock

Or in package.json:

{
  "tap": {
    "plugins": ["@tapjs/nock"]
  }
}

Then use it in your tests like so:

import t from 'tap'

t.test('sends a request', async t => {
  t.nock('https://registry.npmjs.org')
    .get('/')
    .reply(200, { hello: 'world' })

  const res = await fetch('https://registry.npmjs.org')
  t.equal(res.status, 200)
  const body = await res.json()
  t.same(body, { hello: 'world' })
})

// when snapshots are enabled, this test will send a real request
// and record the response
// when they are disabled, the recorded response will be
// automatically loaded into a nock scope, and the test will
// receive that response
// This requires that the @tapjs/snapshot plugin is enabled.
t.test('snapshots a request', async t => {
  t.nock.snapshot()

  const res = await fetch('https://registry.npmjs.org')
  t.equal(res.status, 200)
  const body = await res.json()
  t.match(body, { db_name: 'registry' })
})

You may use it directly, though that is a bit more clunky, because it won't be automatically applied to child tests, but it can be good if you only need nock in a small number of tests.

import tapNock from '@tapjs/nock'
import t from 'tap'

t.test('sends a request', async t => {
  const tn = tapNock(t)
  tn.nock('https://registry.npmjs.org')
    .get('/')
    .reply(200, { hello: 'world' })

  const res = await fetch('https://registry.npmjs.org')
  t.equal(res.status, 200)
  const body = await res.json()
  t.same(body, { hello: 'world' })
})

// when snapshots are enabled, this test will send a real request
// and record the response
// when they are disabled, the recorded response will be
// automatically loaded into a nock scope, and the test will
// receive that response
// This requires that the @tapjs/snapshot plugin is enabled.
t.test('snapshots a request', async t => {
  const tn = tapNock(t)
  tn.nock.snapshot()

  const res = await fetch('https://registry.npmjs.org')
  t.equal(res.status, 200)
  const body = await res.json()
  t.match(body, { db_name: 'registry' })
})

Credits

This plugin was originally developed by nlf as the standalone extension @npmcli/tap-nock, and the use case was a major inspiration for tap's plugin eventual architecture.

3.1.20

1 month ago

3.1.19

2 months ago

3.1.18

3 months ago

3.1.17

6 months ago

3.1.16

6 months ago

3.1.15

6 months ago

3.1.14

6 months ago

3.1.13

7 months ago

3.1.12

7 months ago

3.1.11

7 months ago

3.1.10

7 months ago

3.1.9

7 months ago

3.1.8

7 months ago

3.1.7

7 months ago

3.1.6

7 months ago

3.1.5

7 months ago

3.1.4

7 months ago

3.1.3

7 months ago

3.1.2

7 months ago

3.1.1

7 months ago

3.1.0

7 months ago

3.0.7

7 months ago

3.0.6

7 months ago

3.0.5

7 months ago

3.0.4

7 months ago

3.0.3

8 months ago

3.0.2

8 months ago

3.0.1

8 months ago

3.0.0

8 months ago

3.0.0-22

8 months ago

3.0.0-21

8 months ago

3.0.0-20

8 months ago

3.0.0-19

8 months ago

3.0.0-18

8 months ago

3.0.0-17

8 months ago

3.0.0-16

8 months ago

3.0.0-15

8 months ago

3.0.0-14

9 months ago

3.0.0-13

9 months ago

3.0.0-12

9 months ago

3.0.0-11

9 months ago

3.0.0-10

9 months ago

3.0.0-9

9 months ago

3.0.0-8

9 months ago

3.0.0-7

9 months ago

3.0.0-6

9 months ago

3.0.0-5

9 months ago

3.0.0-4

9 months ago

3.0.0-3

9 months ago

3.0.0-2

9 months ago

3.0.0-1

9 months ago