datasurvey/src/main/webapp/app/account/register/register.component.spec.ts

144 lines
4.1 KiB
TypeScript
Raw Normal View History

2021-07-03 21:48:27 +00:00
jest.mock('@ngx-translate/core');
import { ComponentFixture, TestBed, waitForAsync, inject, tick, fakeAsync } from '@angular/core/testing';
import { HttpClientTestingModule } from '@angular/common/http/testing';
import { FormBuilder } from '@angular/forms';
import { of, throwError } from 'rxjs';
import { TranslateService } from '@ngx-translate/core';
import { EMAIL_ALREADY_USED_TYPE, LOGIN_ALREADY_USED_TYPE } from 'app/config/error.constants';
import { RegisterService } from './register.service';
import { RegisterComponent } from './register.component';
describe('Component Tests', () => {
describe('RegisterComponent', () => {
let fixture: ComponentFixture<RegisterComponent>;
let comp: RegisterComponent;
beforeEach(
waitForAsync(() => {
TestBed.configureTestingModule({
imports: [HttpClientTestingModule],
declarations: [RegisterComponent],
providers: [FormBuilder, TranslateService],
})
.overrideTemplate(RegisterComponent, '')
.compileComponents();
})
);
beforeEach(() => {
fixture = TestBed.createComponent(RegisterComponent);
comp = fixture.componentInstance;
});
it('should ensure the two passwords entered match', () => {
comp.registerForm.patchValue({
password: 'password',
confirmPassword: 'non-matching',
});
comp.register();
expect(comp.doNotMatch).toBe(true);
});
it('should update success to true after creating an account', inject(
[RegisterService, TranslateService],
fakeAsync((service: RegisterService, mockLanguageService: TranslateService) => {
jest.spyOn(service, 'save').mockReturnValue(of({}));
mockLanguageService.currentLang = 'es';
comp.registerForm.patchValue({
password: 'password',
confirmPassword: 'password',
});
comp.register();
tick();
expect(service.save).toHaveBeenCalledWith({
email: '',
password: 'password',
login: '',
langKey: 'es',
2021-07-04 07:25:47 +00:00
name: '',
profileIcon: 1,
2021-07-03 21:48:27 +00:00
});
expect(comp.success).toBe(true);
expect(comp.errorUserExists).toBe(false);
expect(comp.errorEmailExists).toBe(false);
expect(comp.error).toBe(false);
})
));
it('should notify of user existence upon 400/login already in use', inject(
[RegisterService],
fakeAsync((service: RegisterService) => {
jest.spyOn(service, 'save').mockReturnValue(
throwError({
status: 400,
error: { type: LOGIN_ALREADY_USED_TYPE },
})
);
comp.registerForm.patchValue({
password: 'password',
confirmPassword: 'password',
});
comp.register();
tick();
expect(comp.errorUserExists).toBe(true);
expect(comp.errorEmailExists).toBe(false);
expect(comp.error).toBe(false);
})
));
it('should notify of email existence upon 400/email address already in use', inject(
[RegisterService],
fakeAsync((service: RegisterService) => {
jest.spyOn(service, 'save').mockReturnValue(
throwError({
status: 400,
error: { type: EMAIL_ALREADY_USED_TYPE },
})
);
comp.registerForm.patchValue({
password: 'password',
confirmPassword: 'password',
});
comp.register();
tick();
expect(comp.errorEmailExists).toBe(true);
expect(comp.errorUserExists).toBe(false);
expect(comp.error).toBe(false);
})
));
it('should notify of generic error', inject(
[RegisterService],
fakeAsync((service: RegisterService) => {
jest.spyOn(service, 'save').mockReturnValue(
throwError({
status: 503,
})
);
comp.registerForm.patchValue({
password: 'password',
confirmPassword: 'password',
});
comp.register();
tick();
expect(comp.errorUserExists).toBe(false);
expect(comp.errorEmailExists).toBe(false);
expect(comp.error).toBe(true);
})
));
});
});