Skip to content

Commit

Permalink
fix: [no-issue] fix unit tests
Browse files Browse the repository at this point in the history
  • Loading branch information
Dawid Janusz committed Jun 11, 2024
1 parent 9d16310 commit 5a04d61
Show file tree
Hide file tree
Showing 2 changed files with 25 additions and 25 deletions.
41 changes: 19 additions & 22 deletions src/app/datapoints-graph/charts/custom-measurements.service.spec.ts
Original file line number Diff line number Diff line change
@@ -1,6 +1,7 @@
import { fakeAsync, TestBed, tick } from '@angular/core/testing';
import { FetchClient, ISeries, Realtime } from '@c8y/client';
import { ApiService } from '@c8y/ngx-components/api';
import { firstValueFrom } from 'rxjs';
import { CustomMeasurementService } from './custom-measurements.service';

describe('CustomMeasurementService', () => {
Expand All @@ -26,17 +27,20 @@ describe('CustomMeasurementService', () => {
.mockName('getFetchOptions')
.mockReturnValue(options),
getUrl: jest.fn().mockName('getFetchOptions').mockReturnValue(fullUrl),
fetch: jest.fn().mockName('fetch').mockImplementation(),
fetch: jest
.fn()
.mockName('fetch')
.mockImplementation(() => Promise.resolve(response)),
} as any as FetchClient;
TestBed.configureTestingModule({
providers: [
CustomMeasurementService,
{ provide: FetchClient, useValue: client },
{ provide: Realtime, useValue: {} },
{
provide: ApiService,
useValue: apiService,
},
CustomMeasurementService,
],
});
service = TestBed.inject(CustomMeasurementService);
Expand All @@ -61,36 +65,29 @@ describe('CustomMeasurementService', () => {
});
}));

it('should call onFinish to trigger header loading bar', fakeAsync(() => {
// when
(global as any).fetch = jest
.fn()
.mockImplementationOnce(() => Promise.resolve(response));
service.listSeries$({} as any).subscribe();
tick();
// then
it('should call onFinish to trigger header loading bar', async () => {
(global as any).fetch = jest.fn().mockResolvedValueOnce(response);

await firstValueFrom(service.listSeries$({} as any));
expect(apiService.onFinish).toHaveBeenCalledWith({
options,
method: 'GET',
url: '/measurement/measurements/series',
options,
response,
url: '/measurement/measurements/series',
});
}));
});

it('should return resolved data', fakeAsync(() => {
it('should return resolved data', (done) => {
// when
const values = { [new Date().toString()]: [{ min: 0, max: 1 }] };
(global as any).fetch = jest.fn().mockImplementationOnce(() =>
Promise.resolve({
json: () => ({ values } as ISeries),
})
);
let resolvedData;
service
.listSeries$({} as any)
.subscribe((val) => (resolvedData = val.data));
tick();
// then
expect(resolvedData.values).toEqual(values);
}));
service.listSeries$({} as any).subscribe((val) => {
expect(val.data.values).toEqual(values);
done();
});
});
});
Original file line number Diff line number Diff line change
Expand Up @@ -17,10 +17,12 @@ import { cloneDeep } from 'lodash-es';

@Injectable()
export class CustomMeasurementService extends MeasurementService {
apiService: ApiService;
constructor(client: FetchClient, realtime: Realtime, apiService: ApiService) {
constructor(
client: FetchClient,
realtime: Realtime,
private apiService: ApiService
) {
super(client, realtime);
this.apiService = apiService;
}

listSeries$(params: ISeriesFilter): Observable<IResult<ISeries>> {
Expand Down Expand Up @@ -50,6 +52,7 @@ export class CustomMeasurementService extends MeasurementService {
switchMap(async (res) => {
callOnFinish.response = res;
const data = await res.json();

return { res: res as IFetchResponse, data };
}),
finalize(() => {
Expand Down

0 comments on commit 5a04d61

Please sign in to comment.