Ng Backend Mocker, is a lightweight api mocker for local test and development of angular applications. It adds an HttpInterceptor tou your HttpClient interceptors, then it kinda hijacks the http call and responds it with appropriate Response.
- It Helps for UI testing and development without being obligated to have a test-backend server or a separated mocker for backend.
- It can be enabled or disabled with environment object.
- It will catch requests based on the request path and method.
npm i ng-backend-mocker
For this to work, you should:
- install the npm package.
- import the NgBackendMockerModule, at your appModule.
- call NgBackendMockerModule.forRoot() method passing an object which contains a boolean property named mockBackend.
- implement the interface
IBackendMockDataProvider
and return an array ofResponseCheckpoint
s. - in your appModule, provide your implementation so it can be injected in as
IBackendMockDataProvider
.
Notes:
- A
IBackendMockDataProvider
, is an interface with one method, which returns an array ofResponseCheckpoint
. This is the way you tell the library which urls must be hijacked and how it should respond to them. - A
ResponseCheckpoint
, is a data object, which keeps information like request-path, request-method, response-body ant etc. - The object being passed to NgBackendMockerModule.forRoot() method, can be any object. If this object is not null and it contains a boolean property named mockBackend with the value 'True', it will enable the library. You can use your Environment object, to use this only with certain environments.
- Skipping the call to
NgBackendMocker.forRoot({mockBackend:true})
, will not cause any problems or errors, but the library would consider that as a production setup and will not intercept requests. - When mocking is disabled by settings the
mockBackend
to false, or omitting theNgBackendMocker.forRoot({mockBackend:true})
call, and also when mocking is enabled but a request is not registered with availableResponseCheckpoint
objects inIBackendMockDataProvider
, the library will pass down the request/response through the pipeline and it will eventually make a real request to the real endpoint.
AppModule
@NgModule({
declarations: [
AppComponent
],
imports: [
BrowserModule,
HttpClientModule,
// Importing the NgBackendMockerModule
// passing the 'environment' object to the library.
NgBackendMockerModule.forRoot(environment)
],
providers: [
{
// Providing an implementation for IBackendMockDataProvider
provide:'IBackendMockDataProvider',
useClass:BackendMockData
}
],
bootstrap: [AppComponent]
})
export class AppModule { }
Implementation of IBackendMockDataProvider
@Injectable()
export class BackendMockData implements IBackendMockDataProvider{
getAllInteractions(): ResponseCheckPoint[] {
return [
new ResponseCheckPoint()
.withPath('/public/v2/posts')
.withBody({ foo: 'bar' })
.withHeader('content-type', 'application/json')
.selectByPathAndMethod()
];
}
}
Environment.dev.ts
export const environment = {
production: false,
mockBackend:true
};
I hope it save's you some time. good luck.
Mani ([email protected])