Fix e2e test and actually check login works
This commit is contained in:
parent
89e3d48a07
commit
971cf43c38
7 changed files with 101 additions and 21 deletions
|
@ -1,34 +1,59 @@
|
|||
import { HttpClientTestingModule, HttpTestingController } from '@angular/common/http/testing';
|
||||
import { TestBed, ComponentFixture, async } from '@angular/core/testing';
|
||||
import { HttpClient, HttpErrorResponse } from '@angular/common/http';
|
||||
import { LoginPageObject } from './login.po';
|
||||
import { ApiService } from '../src/app/providers/api-service';
|
||||
import { browser } from "protractor";
|
||||
|
||||
describe('Login Page', () => {
|
||||
let page: LoginPageObject;
|
||||
let api: ApiService;
|
||||
let apiSpy: jasmine.SpyObj<ApiService>;
|
||||
|
||||
beforeEach(() => {
|
||||
page = new LoginPageObject();
|
||||
const spy = jasmine.createSpyObj
|
||||
TestBed.configureTestingModule({ providers: [ApiService] });
|
||||
page.navigateTo();
|
||||
});
|
||||
|
||||
api = TestBed.inject(ApiService);
|
||||
apiSpy = TestBed.inject(ApiService);
|
||||
|
||||
it('should have a header saying login', () => {
|
||||
expect(page.getLoginHeaderText()).toEqual('Login');
|
||||
});
|
||||
|
||||
it('should have a username box of type email', () => {
|
||||
expect(page.isUsernameFieldPresent()).toBeTruthy();
|
||||
expect(page.getUsernameFieldType()).toEqual('email');
|
||||
expect(page.isEmailFieldPresent()).toBeTruthy();
|
||||
expect(page.getEmailFieldType()).toEqual('email');
|
||||
});
|
||||
|
||||
it('should have a password box of type password', () => {
|
||||
expect(page.isPasswordFieldPresent()).toBeTruthy();
|
||||
expect(page.getPasswordFieldType()).toBe('password');
|
||||
});
|
||||
|
||||
it('should have a login button of type submit', () => {
|
||||
expect(page.isLoginButtonPresent()).toBeTruthy();
|
||||
expect(page.getLoginButtonType()).toBe('submit');
|
||||
});
|
||||
|
||||
it('should have a disabled login button when empty', () => {
|
||||
expect(page.isLoginButtonEnabled()).toBeFalsy();
|
||||
});
|
||||
|
||||
it('should have a disabled login button when only email', () => {
|
||||
page.fillEmailFieldWith('test@example.com');
|
||||
expect(page.isLoginButtonEnabled()).toBeFalsy();
|
||||
});
|
||||
|
||||
it('should have a disabled login button when only password', () => {
|
||||
page.fillPasswordFieldWith('abc123');
|
||||
expect(page.isLoginButtonEnabled()).toBeFalsy();
|
||||
});
|
||||
|
||||
it('should have an enabled login button when both inputs filled', () => {
|
||||
page.fillEmailFieldWith('test@example.com');
|
||||
page.fillPasswordFieldWith('abc123');
|
||||
expect(page.isLoginButtonEnabled()).toBeTruthy();
|
||||
});
|
||||
|
||||
it('should submit the filled data when login pressed', () => {
|
||||
page.fillEmailFieldWith('test@example.com');
|
||||
page.fillPasswordFieldWith('abc123');
|
||||
expect(page.isLoginButtonEnabled()).toBeTruthy();
|
||||
page.getLoginButton().click();
|
||||
browser.waitForAngular();
|
||||
expect(browser.getCurrentUrl()).toContain('dashboard');
|
||||
});
|
||||
});
|
||||
|
|
Reference in a new issue