Skip to main content
Version: 4.0.0

JavaScript integration

Preface

The server provides a JavaScript API that enables you to control it and to tap into, modify, or extend its internal behavior. It provides its JavaScript core instance to plugins, middlewares and other system elements.

Using the core instance

Apart from creating your own core instance programmatically, you can also use it from other system elements, because it is passed as an argument to them. Some elements to which the core instance is passed are:

  • Plugins: A plugin receives the core instance as a parameter on its constructor and in all of its standardized methods. Read plugins development for further info.
  • Variant handlers: A variant handler receives the core instance as a parameter on its constructor. Read variant handlers development for further info.
    • middleware variants: The core is passed from the middleware variant handler to the middleware functions defined in that type of variants. So, it can be used directly in Express middlewares. Read the middleware variant chapter for further info.
tip

Read the plugins development and variant handlers development chapters for further info.

Creating your own instance

The server can be also instantiated and started programmatically.

const { createServer } = require("@mocks-server/main");
const { routes, collections } = require("./fixtures");

const server = createServer();

server.start().then(async () => {
const { loadRoutes, loadCollections } = server.mock.createLoaders();
loadRoutes(routes);
loadCollections(collections);

server.mock.collections.select("collection-a");
});
caution

The example above shows how to use the createServer method provided by the @mocks-server/main package to create a server instance optimized for its programmatic usage, so it does not load files from the mocks folder nor configuration files, etc. Read the API chapter for further info about how to create a server instance programmatically enabling all of the features you may want.

tip

Read the API chapter for further info about core available methods

Use cases

Starting the server using JavaScript may be useful for:

tip

It is also possible to tap into, modify, or extend the server internal behavior without having to start it by your own. You can also create a plugin and load it using the configuration file.

Example with Jest

You can start, control and stop the mock server programmatically from your NodeJs unit tests.

You can load all configuration and fixtures programmatically. And, using configuration, you could also enable loading routes, variants and collections from files in the "/mocks" folder.

const { createServer } = require("@mocks-server/main");
const { routes, collections } = require("./fixtures");

beforeAll(async () => {
const server = createServer();

const { loadRoutes, loadCollections } = server.mock.createLoaders();
loadRoutes(routes);
loadCollections(collections);

await server.start();
});

afterAll(async () => {
await server.stop();
});

describe("users API client", () => {
it("getUsers method should return 3 users", async () => {
// Select the collection returning the expected data, and wait for the mock to be ready
await server.mock.collections.select("3-users", { check: true });

// configure the unit under test
const usersApiClient = new UsersService('http://localhost:3100/api/users');

// call your unit under test, which invokes the mock
const users = await usersApiClient.getUsers();

// assert values returned by the mock
expect(users.length).toEqual(3);
});
});

Creating your own distribution

The main distribution of Mocks Server (@mocks-server/main) includes some preinstalled plugins. But you could also create your own distribution with the plugins of your choice or predefined configuration in case you need to reuse those presets in many projects, for example. To achieve it, you should use the @mocks-server/core package, and start it by your own providing the configuration that you need. Using the "programmatic" configuration still allows the end user to modify it using other configuration methods, such as the configuration file, environment variables, etc.

const Core = require("@mocks-server/core");
const PluginProxy = require("@mocks-server/plugin-proxy");

const MyPlugin = require("./MyPlugin");

const createServer = () => {
return new Core(
{
plugins: {
register: [PluginProxy, MyPlugin],
},
},
);
};

module.exports = createServer;

Customization using plugins

If you only want tap into, modify, or extend the server internal behavior, then you probably don't need to start the server by your own. You can use the main distribution and use the configuration file to add your own plugin, which provides to you access to the whole server core JavaScript API.

tip

Read the plugins chapter for further info about how to create plugins.