Agent Node JS Testing Library
This library provides a set of utilities for testing Node JS agents.
It's only available for Node JS agents.
It is in alpha version and is subject to breaking changes.
For the moment, it only provides an incomplete set of utilities for integration and unit testing, but it will be
extended in the future.
Installation
npm install @forestadmin-experimental/agent-nodejs-testing
or for Yarn users
yarn add @forestadmin-experimental/agent-nodejs-testing
Integration Tests - Recommended Testing Strategy
Setup
const { createTestableAgent } = require('@forestadmin-experimental/agent-nodejs-testing');
export function addAgentCustomizations(agent) {
agent.addDataSource(createSequelizeDataSource(connection));
}
export async function setupAndStartTestableAgent() {
const testableAgent = await createTestableAgent(addAgentCustomizations);
await testableAgent.start();
return testableAgent;
}
Usage
describe('billing collection', () => {
let testableAgent;
beforeAll(async () => {
testableAgent = await setupAndStartTestableAgent();
});
afterAll(async () => {
await testableAgent?.stop();
});
it('should return all the records of the billing collection', async () => {
const result = await testableAgent.collection('billing').list();
expect(result).toHaveLength(2);
});
});
Examples
Please check the example folder for more examples.
How it works
The createTestableAgent
function creates a testable agent that can be used to test your agent.
The testable agent is a wrapper around your agent that allows you to start and stop it, and to call its collections, actions, charts etc.
It calls the agent by http, so it's a real integration test. It does exactly what the frontend does when it calls your agent.
All the authentication part is mocked, so it doesn't call the forestadmin servers.
It can be run in standalone in your CI for example.
flowchart LR
testableAgent(testable agent)<-->|HTTP|agent
agent(agent with customizations)<-->DATA
agent-.never call.-server(forestadmin server)
Unit Tests
WIP