Skip to content

Instantly share code, notes, and snippets.

@rwherrmann
Last active November 12, 2022 10:52
Show Gist options
  • Star 0 You must be signed in to star a gist
  • Fork 2 You must be signed in to fork a gist
  • Save rwherrmann/ed1fef93151a7150764e136e7c5eecd8 to your computer and use it in GitHub Desktop.
Save rwherrmann/ed1fef93151a7150764e136e7c5eecd8 to your computer and use it in GitHub Desktop.
/* tslint:disable:no-unused-variable */
import { TestBed, async, inject } from '@angular/core/testing';
import { LoginComponent } from './login.component';
import { UserService } from '../services/user.service';
import { Router, RouterOutlet } from '@angular/router';
import { RouterTestingModule } from '@angular/router/testing';
import { FormsModule } from '@angular/forms';
import { Observable } from 'RxJs';
import { HttpModule } from '@angular/http';
import { SecureHttp } from '../shared/secure-http';
describe('Component: Login', () => {
beforeEach(async(() => {
TestBed.configureTestingModule({
declarations: [
LoginComponent
],
imports: [
FormsModule, HttpModule
],
providers: [
{ provide: UserService, useClass: UserService },
{ provide: Router, useClass: RouterStub },
{ provide: SecureHttp, useClass: SecureHttp }
]
});
}));
it('should create an instance', inject([Router, UserService], (router: Router, userService: UserService) => {
let component = new LoginComponent(router, userService);
expect(component).toBeTruthy();
}));
describe('when the login page loads', () => {
it('then the login name should be defaulted', inject([Router, UserService], (router: Router, userService: UserService) => {
let component = new LoginComponent(router, userService);
expect(component.login.username).toEqual('');
}));
it('then the error message should not be displayed', inject([Router, UserService], (router: Router, userService: UserService) => {
let component = new LoginComponent(router, userService);
expect(component.showErrorMessage).toBe(false);
}));
});
describe('when a valid username and password are entered', () => {
it('then the home route should be displayed', inject([Router, UserService], (router: Router, userService: UserService) => {
spyOn(userService, 'login').and.returnValue(Observable.of(true));
spyOn(router, 'navigateByUrl').and.returnValue('');
let component = new LoginComponent(router, userService);
component.authenticateUser();
expect(router.navigateByUrl).toHaveBeenCalled();
}));
});
describe('when an invalid username and password are entered', () => {
it('then Login Failed should be displayed', inject([Router, UserService], (router: Router, userService: UserService) => {
spyOn(userService, 'login').and.returnValue(Observable.of(false));
spyOn(router, 'navigateByUrl').and.returnValue('');
let component = new LoginComponent(router, userService);
component.authenticateUser();
expect(router.navigateByUrl).not.toHaveBeenCalled();
expect(component.showErrorMessage).toBe(true);
}));
});
});
class RouterStub {
navigateByUrl(url: string) { return url; }
}
Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment