Git Product home page Git Product logo

wiremock-rest-client's Introduction

WireMock REST Client

The WireMock REST client is a lightweight module to interact with a running WireMock server based on the OpenAPI 3.0 spec via REST.

Installation

npm install wiremock-rest-client

Usage

The WireMockRestClient has 5 services which correspond with request paths as specified in the OpenAPI spec.

  • global - Global operations
  • mappings - Operations on stub mappings
  • recordings - Stub mapping record and snapshot functions
  • requests - Logged requests and responses received
  • scenarios - Scenarios support modeling of stateful behavior

See the API for the available methods. All methods are related to available operations on the WireMock server endpoints.

import { WireMockRestClient } from 'wiremock-rest-client';

const wireMock = new WireMockRestClient('http://localhost:8080');

const stubMappings = await wireMock.mappings.getAllMappings();

console.log(stubMappings);

await wireMock.global.shutdown();

API

Global

  • updateGlobalSettings(delayDefinition: DelayDefinition): Promise<void>
  • resetAll(): Promise<void>
  • shutdown(): Promise<void>

Example:

await wireMockRestClient.global.resetAll();

Stub mappings

  • getAllMappings(): Promise<StubMappings>
  • createMapping(stubMapping: StubMapping): Promise<StubMapping>
  • createMappingFromFile(fileName: string): Promise<StubMapping>
  • createMappingsFromDir(directoryName: string): Promise<any>
  • deleteAllMappings(): Promise<void>
  • resetAllMappings(): Promise<void>
  • getMapping(uuid: string): Promise<StubMapping>
  • updateMapping(uuid: string, stubMapping: StubMapping): Promise<StubMapping>
  • deleteMapping(uuid: string): Promise<void>
  • saveAllMappings(): Promise<void>
  • findByMetaData(contentPattern: ContentPattern): Promise<StubMappings>
  • removeByMetaData(contentPattern: ContentPattern): Promise<void>

Example:

await wireMockRestClient.mappings.resetAllMappings();

const stubMapping = {
    "request": {
        "method": "GET",
        "urlPathPattern": "/api/helloworld"
    },
    "response": {
        "status": 200,
        "jsonBody": {"hello": "world"},
        "headers": {
            "Content-Type": "application/json"
        }
    }
};

const response = await wireMock.mappings.createMapping(stubMapping);

// Create mapping from current working directory
await wireMock.mappings.createMappingFromFile('stubs/hello-world.json');

// Create mappings from a directory recursively (based on current working directory)
await wireMock.mappings.createMappingsFromDir('stubs');

Recordings

  • startRecording(recordSpec: RecordSpec): Promise<void>
  • stopRecording(): Promise<StubMappings>
  • getRecordingStatus(): Promise<any>
  • takeSnapshotRecording(snapshotSpec: RecordSpec): Promise<StubMappings>

Example:

const recordingStatus = wireMockRestClient.recordings.getRecordingStatus();

Requests

  • getAllRequests(): Promise<any>
  • deleteAllRequests(): Promise<void>
  • getRequest(uuid: string): Promise<any>
  • deleteRequest(uuid: string): Promise<void>
  • resetAllRequests(): Promise<void>
  • getCount(requestPattern: RequestPattern): Promise<any>
  • removeRequests(requestPattern: RequestPattern): Promise<any>
  • removeRequestsByMetadata(contentPattern: ContentPattern): Promise<any>
  • findRequests(requestPattern: RequestPattern): Promise<any>
  • getUnmatchedRequests(): Promise<any>
  • getUnmatchedNearMisses(): Promise<LoggedRequest[]>
  • getNearMissesByRequest(loggedRequest: LoggedRequest): Promise<any>
  • getNearMissesByRequestPattern(requestPattern: RequestPattern): Promise<any>

Example:

const requests = await wireMockRestClient.requests.getAllRequests();

Scenarios

  • getAllScenarios(): Promise<Scenario[]>
  • resetAllScenarios(): Promise<void>

Example:

await wireMockRestClient.scenarios.resetAllScenarios();

Configuration

The following optional configuration options are available, to be set via options or environment variables.

Configuration option Default Options property Environment variable
Proxy No proxy proxy WRC_HTTP_PROXY
Log level info logLevel WRC_LOG_LEVEL
Continue on failure false continueOnFailure WRC_CONTINUE_ON_FAILURE

Example using options:

const wireMock = new WireMockRestClient('http://localhost:8080', {
    proxy: 'http://mycorporateproxy.com',
    logLevel: 'debug',
    continueOnFailure: true
});

Note: Environment variables have the highest priority

Proxy

The proxy URL can be HTTP or HTTPS. Credentials for authentication can be passed in the URL.

Example:

WRC_HTTP_PROXY=http://username:[email protected]

Log level

  • Default log level is info
  • Each log line contains a unique id to trace logs for a single request
  • Log level debug will log the request body for each request.

A different log level can be configured by setting the environment variable WRC_LOG_LEVEL to specific a log level (trace/debug/info/warn/error/silent)

2019-12-11T20:43:18.157Z INFO wiremock-rest-client: [Uub8jVUBq91F3MIyKXrON] Request: [POST] http://localhost:8080/__admin/mappings
2019-12-11T20:43:18.157Z DEBUG wiremock-rest-client: [Uub8jVUBq91F3MIyKXrON] Request body:  {"request":{"method":"GET","urlPathPattern":"/api/helloworld"},"response":{"status":200,"jsonBody":{"hello":"world"},"headers":{"Content-Type":"application/json"}}}
2019-12-11T20:43:18.158Z INFO wiremock-rest-client: [Uub8jVUBq91F3MIyKXrON] Response: [201] Created
2019-12-11T20:43:18.158Z INFO wiremock-rest-client: [EDYjmman5BLb7tgws-VGg] Request: [POST] http://localhost:8080/__admin/shutdown
2019-12-11T20:43:18.161Z INFO wiremock-rest-client: [EDYjmman5BLb7tgws-VGg] Response: [200] OK

Continue on failure

  • By default the node process is exited in case of a failure
  • To change this behavior to continue on failure, set the value to true

CLI

A small CLI is available to load data from the command line by passing the folder which contains the stub mappings to be loaded. By default it will reset all stub mappings first (configurable).

$ wrc load --help

Usage: wrc load [options]

Options:
  -f, --folders <folders>  Comma separated list of folders containing stub mappings to be loaded
  --no-reset               Skip resetting all stub mappings
  -u, --uri [uri]          WireMock base URI (default: "http://localhost:8080")
  -h, --help               display help for command

wiremock-rest-client's People

Contributors

dependabot[bot] avatar kwoding avatar

Watchers

 avatar

Recommend Projects

  • React photo React

    A declarative, efficient, and flexible JavaScript library for building user interfaces.

  • Vue.js photo Vue.js

    ๐Ÿ–– Vue.js is a progressive, incrementally-adoptable JavaScript framework for building UI on the web.

  • Typescript photo Typescript

    TypeScript is a superset of JavaScript that compiles to clean JavaScript output.

  • TensorFlow photo TensorFlow

    An Open Source Machine Learning Framework for Everyone

  • Django photo Django

    The Web framework for perfectionists with deadlines.

  • D3 photo D3

    Bring data to life with SVG, Canvas and HTML. ๐Ÿ“Š๐Ÿ“ˆ๐ŸŽ‰

Recommend Topics

  • javascript

    JavaScript (JS) is a lightweight interpreted programming language with first-class functions.

  • web

    Some thing interesting about web. New door for the world.

  • server

    A server is a program made to process requests and deliver data to clients.

  • Machine learning

    Machine learning is a way of modeling and interpreting data that allows a piece of software to respond intelligently.

  • Game

    Some thing interesting about game, make everyone happy.

Recommend Org

  • Facebook photo Facebook

    We are working to build community through open source technology. NB: members must have two-factor auth.

  • Microsoft photo Microsoft

    Open source projects and samples from Microsoft.

  • Google photo Google

    Google โค๏ธ Open Source for everyone.

  • D3 photo D3

    Data-Driven Documents codes.