import { TestBed } from '@angular/core/testing';
import { provideMockActions } from '@ngrx/effects/testing';
import { hot, cold } from 'jest-marbles';
import { of, Observable } from 'rxjs';
import { AttendeesEffects } from './attendees.effects';
import {
LoadAttendees,
LoadAttendeesSuccess,
AttendeesActions
} from './attendees.actions';
import { Attendee } from '../../../models';
import { EventService } from '../../services/event.service';
describe(`Effect: Attendess`, () => {
let actions: Observable<AttendeesActions>;
let effects: AttendeesEffects;
let service: EventService;
beforeEach(() => {
TestBed.configureTestingModule({
imports: [],
providers: [
AttendeesEffects,
provideMockActions(() => actions),
{
provide: EventService,
useValue: {
getAttendees: jest.fn()
}
}
]
});
service = TestBed.get(EventService);
effects = TestBed.get(AttendeesEffects);
});
it('should return a cold Observable of LoadAttendeesSuccess action', () => {
const fakeAttendees = [
{ name: 'Duncan', attending: false, guests: 0 } as Attendee
];
const action = new LoadAttendees();
const completion = new LoadAttendeesSuccess(fakeAttendees);
jest
.spyOn(service, 'getAttendees')
.mockImplementation(() => of(fakeAttendees));
actions = hot('--a-', { a: action });
const expected = cold('--(b)', { b: completion });
expect(effects.getAttendees$).toBeObservable(expected);
});
});
StackBlitz Link
Extras and Homework
These extra sections are for doing after the course or if you finish a section early. Please move onto the next section if doing this as a workshop when the instructor advises.
WARNING: Some of these extra sections will make it more difficult to copy and paste the code examples later on in the course.
You might need to apply the code snippet examples a little more carefully amongst any "extras section" code you may add. If you are up for some extra challenges these sections are for you.