Fix broken login test

This commit is contained in:
mauriziovitale84 2016-06-23 16:48:12 +01:00
parent 3e9d50bdca
commit d0d0ad0bc4
2 changed files with 461 additions and 307 deletions

View File

@ -39,21 +39,21 @@
</span> </span>
</div> </div>
<br> <br>
<button type="submit" <button type="submit" id="login-button"
class="center mdl-button mdl-js-button mdl-button--raised mdl-js-ripple-effect mdl-button--colored" class="center mdl-button mdl-js-button mdl-button--raised mdl-js-ripple-effect mdl-button--colored"
data-automation-id="login-button" [disabled]="!form.valid">{{'LOGIN.BUTTON.LOGIN' | translate }}</button> data-automation-id="login-button" [disabled]="!form.valid">{{'LOGIN.BUTTON.LOGIN' | translate }}</button>
<br> <br>
<div class="center"> <div class="center">
<label class=" mdl-checkbox mdl-js-checkbox mdl-js-ripple-effect" for="remember"> <label class=" mdl-checkbox mdl-js-checkbox mdl-js-ripple-effect" for="remember">
<input type="checkbox" id="remember" class="center mdl-checkbox__input"> <input type="checkbox" id="remember" class="center mdl-checkbox__input">
<span class="mdl-checkbox__label">{{'LOGIN.LABEL.REMEMBER' | translate }}</span> <span id="login-remember" class="mdl-checkbox__label">{{'LOGIN.LABEL.REMEMBER' | translate }}</span>
</label> </label>
</div> </div>
</div> </div>
<div class="mdl-card__actions mdl-card--border mdl-card__link"> <div class="mdl-card__actions mdl-card--border mdl-card__link">
<div class="login-action"> <div class="login-action">
<div class="login-action-left"> <a href="">{{'LOGIN.ACTION.HELP' | translate }}</a> </div> <div id="login-action-help" class="login-action-left"> <a href="">{{'LOGIN.ACTION.HELP' | translate }}</a> </div>
<div class="login-action-right"> <a href="">{{'LOGIN.ACTION.REGISTER' | translate }}</a> <div id="login-action-register" class="login-action-right"> <a href="">{{'LOGIN.ACTION.REGISTER' | translate }}</a>
</div> </div>
</div> </div>
</div> </div>

View File

@ -49,7 +49,7 @@ describe('AlfrescoLogin', () => {
]; ];
}); });
it('should render `Login` form with all the keys to be translated', it('should render Login form with all the keys to be translated',
inject([TestComponentBuilder], (tcb: TestComponentBuilder) => { inject([TestComponentBuilder], (tcb: TestComponentBuilder) => {
return tcb return tcb
.createAsync(AlfrescoLoginComponent) .createAsync(AlfrescoLoginComponent)
@ -65,11 +65,21 @@ describe('AlfrescoLogin', () => {
expect(element.querySelector('[for="username"]')).toBeDefined(); expect(element.querySelector('[for="username"]')).toBeDefined();
expect(element.querySelector('[for="username"]').innerText).toEqual('LOGIN.LABEL.USERNAME'); expect(element.querySelector('[for="username"]').innerText).toEqual('LOGIN.LABEL.USERNAME');
expect(element.querySelector('#username-error').innerText).toEqual('LOGIN.MESSAGES.USERNAME-REQUIRED');
expect(element.querySelector('[for="password"]')).toBeDefined(); expect(element.querySelector('[for="password"]')).toBeDefined();
expect(element.querySelector('[for="password"]').innerText).toEqual('LOGIN.LABEL.PASSWORD'); expect(element.querySelector('[for="password"]').innerText).toEqual('LOGIN.LABEL.PASSWORD');
expect(element.querySelector('#password-required').innerText).toEqual('LOGIN.MESSAGES.PASSWORD-REQUIRED');
expect(element.querySelector('#login-button')).toBeDefined();
expect(element.querySelector('#login-button').innerText).toEqual('LOGIN.BUTTON.LOGIN');
expect(element.querySelector('#login-remember')).toBeDefined();
expect(element.querySelector('#login-remember').innerText).toEqual('LOGIN.LABEL.REMEMBER');
expect(element.querySelector('#login-action-help')).toBeDefined();
expect(element.querySelector('#login-action-help').innerText).toEqual('LOGIN.ACTION.HELP');
expect(element.querySelector('#login-action-register')).toBeDefined();
expect(element.querySelector('#login-action-register').innerText).toEqual('LOGIN.ACTION.REGISTER');
}); });
})); }));
@ -88,7 +98,7 @@ describe('AlfrescoLogin', () => {
}); });
})); }));
it('should render min-length error when the username is lower than 4 characters', it('should render validation min-length error when the username is lower than 4 characters',
inject([TestComponentBuilder], (tcb: TestComponentBuilder) => { inject([TestComponentBuilder], (tcb: TestComponentBuilder) => {
return tcb return tcb
.createAsync(AlfrescoLoginComponent) .createAsync(AlfrescoLoginComponent)
@ -99,23 +109,28 @@ describe('AlfrescoLogin', () => {
}; };
let compiled = fixture.debugElement.nativeElement; let compiled = fixture.debugElement.nativeElement;
let usernameInput = compiled.querySelector('#username');
component.form.controls.username._value = 'us';
fixture.detectChanges(); fixture.detectChanges();
component.onValueChanged(); usernameInput.value = '123';
usernameInput.dispatchEvent(new Event('input'));
fixture.detectChanges(); fixture.detectChanges();
expect(component.formError).toBeDefined(true); component.onValueChanged(null);
expect(component.formError.username).toBeDefined(true);
fixture.detectChanges();
expect(component.formError).toBeDefined();
expect(component.formError.username).toBeDefined();
expect(component.formError.username).toEqual('LOGIN.MESSAGES.USERNAME-MIN'); expect(component.formError.username).toEqual('LOGIN.MESSAGES.USERNAME-MIN');
expect(compiled.querySelector('#username-error')).toBeDefined();
expect(compiled.querySelector('#username-error').innerText).toEqual('LOGIN.MESSAGES.USERNAME-MIN'); expect(compiled.querySelector('#username-error').innerText).toEqual('LOGIN.MESSAGES.USERNAME-MIN');
}); });
})); }));
it('should render no errors when the username and password are correct', it('should render validation required error when the username is empty',
inject([TestComponentBuilder], (tcb: TestComponentBuilder) => { inject([TestComponentBuilder], (tcb: TestComponentBuilder) => {
return tcb return tcb
.createAsync(AlfrescoLoginComponent) .createAsync(AlfrescoLoginComponent)
@ -126,20 +141,91 @@ describe('AlfrescoLogin', () => {
}; };
let compiled = fixture.debugElement.nativeElement; let compiled = fixture.debugElement.nativeElement;
let usernameInput = compiled.querySelector('#username');
component.form.controls.username._value = 'fake-user';
component.form.controls.password._value = 'fake-password';
fixture.detectChanges(); fixture.detectChanges();
component.onValueChanged(); usernameInput.value = '';
usernameInput.dispatchEvent(new Event('input'));
fixture.detectChanges(); fixture.detectChanges();
expect(component.formError).toBeDefined(true); component.onValueChanged(null);
fixture.detectChanges();
expect(component.formError).toBeDefined();
expect(component.formError.username).toBeDefined();
expect(component.formError.username).toEqual('LOGIN.MESSAGES.USERNAME-REQUIRED');
expect(compiled.querySelector('#username-error')).toBeDefined();
expect(compiled.querySelector('#username-error').innerText).toEqual('LOGIN.MESSAGES.USERNAME-REQUIRED');
});
}));
it('should render validation required error when the password is empty',
inject([TestComponentBuilder], (tcb: TestComponentBuilder) => {
return tcb
.createAsync(AlfrescoLoginComponent)
.then((fixture) => {
let component = fixture.componentInstance;
component.isErrorStyle = function () {
console.log('mock');
};
let compiled = fixture.debugElement.nativeElement;
let passwordInput = compiled.querySelector('#password');
fixture.detectChanges();
passwordInput.value = '';
passwordInput.dispatchEvent(new Event('input'));
fixture.detectChanges();
component.onValueChanged(null);
fixture.detectChanges();
expect(component.formError).toBeDefined();
expect(component.formError.password).toBeDefined();
expect(component.formError.password).toEqual('LOGIN.MESSAGES.PASSWORD-REQUIRED');
expect(compiled.querySelector('#password-required')).toBeDefined();
expect(compiled.querySelector('#password-required').innerText).toEqual('LOGIN.MESSAGES.PASSWORD-REQUIRED');
});
}));
it('should render no validation errors when the username and password are filled',
inject([TestComponentBuilder], (tcb: TestComponentBuilder) => {
return tcb
.createAsync(AlfrescoLoginComponent)
.then((fixture) => {
let component = fixture.componentInstance;
component.isErrorStyle = function () {
console.log('mock');
};
let compiled = fixture.debugElement.nativeElement;
let usernameInput = compiled.querySelector('#username');
let passwordInput = compiled.querySelector('#password');
fixture.detectChanges();
usernameInput.value = 'fake-username';
passwordInput.value = 'fake-password';
usernameInput.dispatchEvent(new Event('input'));
passwordInput.dispatchEvent(new Event('input'));
fixture.detectChanges();
component.onValueChanged(null);
fixture.detectChanges();
expect(component.formError).toBeDefined();
expect(component.formError.username).toEqual(''); expect(component.formError.username).toEqual('');
expect(component.formError.password).toEqual(''); expect(component.formError.password).toEqual('');
expect(compiled.querySelector('#login-error')).toBeNull(); expect(compiled.querySelector('#username-error')).toBeNull();
expect(compiled.querySelector('#password-required')).toBeNull();
}); });
})); }));
@ -154,14 +240,24 @@ describe('AlfrescoLogin', () => {
}; };
let compiled = fixture.debugElement.nativeElement; let compiled = fixture.debugElement.nativeElement;
component.form.controls.username._value = 'my username'; let usernameInput = compiled.querySelector('#username');
component.form.controls.password._value = 'my password'; let passwordInput = compiled.querySelector('#password');
fixture.detectChanges(); fixture.detectChanges();
component.onValueChanged();
expect(compiled.querySelector('input[type="password"]').value).toEqual('my password'); usernameInput.value = 'fake-change-username';
expect(compiled.querySelector('input[type="text"]').value).toEqual('my username'); passwordInput.value = 'fake-change-password';
usernameInput.dispatchEvent(new Event('input'));
passwordInput.dispatchEvent(new Event('input'));
fixture.detectChanges();
component.onValueChanged(null);
fixture.detectChanges();
expect(compiled.querySelector('input[type="text"]').value).toEqual('fake-change-username');
expect(compiled.querySelector('input[type="password"]').value).toEqual('fake-change-password');
}); });
})); }));
@ -175,14 +271,23 @@ describe('AlfrescoLogin', () => {
console.log('mock'); console.log('mock');
}; };
let compiled = fixture.debugElement.nativeElement; expect(component.error).toBe(false);
expect(component.success).toBe(false);
component.form.controls.username._value = 'fake-username'; let compiled = fixture.debugElement.nativeElement;
component.form.controls.password._value = 'fake-password'; let usernameInput = compiled.querySelector('#username');
let passwordInput = compiled.querySelector('#password');
fixture.detectChanges(); fixture.detectChanges();
component.onValueChanged();
usernameInput.value = 'fake-username';
passwordInput.value = 'fake-password';
usernameInput.dispatchEvent(new Event('input'));
passwordInput.dispatchEvent(new Event('input'));
fixture.detectChanges();
component.onValueChanged(null);
compiled.querySelector('button').click(); compiled.querySelector('button').click();
fixture.detectChanges(); fixture.detectChanges();
@ -202,19 +307,30 @@ describe('AlfrescoLogin', () => {
console.log('mock'); console.log('mock');
}; };
let compiled = fixture.debugElement.nativeElement; expect(component.error).toBe(false);
expect(component.success).toBe(false);
component.form.controls.username._value = 'fake-wrong-username'; let compiled = fixture.debugElement.nativeElement;
component.form.controls.password._value = 'fake-password'; let usernameInput = compiled.querySelector('#username');
let passwordInput = compiled.querySelector('#password');
fixture.detectChanges(); fixture.detectChanges();
component.onValueChanged();
usernameInput.value = 'fake-wrong-username';
passwordInput.value = 'fake-password';
usernameInput.dispatchEvent(new Event('input'));
passwordInput.dispatchEvent(new Event('input'));
fixture.detectChanges();
component.onValueChanged(null);
compiled.querySelector('button').click(); compiled.querySelector('button').click();
fixture.detectChanges(); fixture.detectChanges();
expect(fixture.componentInstance.error).toBe(true); expect(component.error).toBe(true);
expect(component.success).toBe(false);
expect(compiled.querySelector('#login-error')).toBeDefined();
expect(compiled.querySelector('#login-error').innerText).toEqual('LOGIN.MESSAGES.LOGIN-ERROR'); expect(compiled.querySelector('#login-error').innerText).toEqual('LOGIN.MESSAGES.LOGIN-ERROR');
}); });
})); }));
@ -229,19 +345,30 @@ describe('AlfrescoLogin', () => {
console.log('mock'); console.log('mock');
}; };
let compiled = fixture.debugElement.nativeElement; expect(component.success).toBe(false);
expect(component.error).toBe(false);
component.form.controls.username._value = 'fake-username'; let compiled = fixture.debugElement.nativeElement;
component.form.controls.password._value = 'fake-wrong-password'; let usernameInput = compiled.querySelector('#username');
let passwordInput = compiled.querySelector('#password');
fixture.detectChanges(); fixture.detectChanges();
component.onValueChanged();
usernameInput.value = 'fake-username';
passwordInput.value = 'fake-wrong-password';
usernameInput.dispatchEvent(new Event('input'));
passwordInput.dispatchEvent(new Event('input'));
fixture.detectChanges();
component.onValueChanged(null);
compiled.querySelector('button').click(); compiled.querySelector('button').click();
fixture.detectChanges(); fixture.detectChanges();
expect(fixture.componentInstance.error).toBe(true); expect(component.error).toBe(true);
expect(component.success).toBe(false);
expect(compiled.querySelector('#login-error')).toBeDefined();
expect(compiled.querySelector('#login-error').innerText).toEqual('LOGIN.MESSAGES.LOGIN-ERROR'); expect(compiled.querySelector('#login-error').innerText).toEqual('LOGIN.MESSAGES.LOGIN-ERROR');
}); });
})); }));
@ -256,19 +383,30 @@ describe('AlfrescoLogin', () => {
console.log('mock'); console.log('mock');
}; };
let compiled = fixture.debugElement.nativeElement; expect(component.success).toBe(false);
expect(component.error).toBe(false);
component.form.controls.username._value = 'fake-wrong-username'; let compiled = fixture.debugElement.nativeElement;
component.form.controls.password._value = 'fake-wrong-password'; let usernameInput = compiled.querySelector('#username');
let passwordInput = compiled.querySelector('#password');
fixture.detectChanges(); fixture.detectChanges();
component.onValueChanged();
usernameInput.value = 'fake-wrong-username';
passwordInput.value = 'fake-wrong-password';
usernameInput.dispatchEvent(new Event('input'));
passwordInput.dispatchEvent(new Event('input'));
fixture.detectChanges();
component.onValueChanged(null);
compiled.querySelector('button').click(); compiled.querySelector('button').click();
fixture.detectChanges(); fixture.detectChanges();
expect(fixture.componentInstance.error).toBe(true); expect(component.error).toBe(true);
expect(component.success).toBe(false);
expect(compiled.querySelector('#login-error')).toBeDefined();
expect(compiled.querySelector('#login-error').innerText).toEqual('LOGIN.MESSAGES.LOGIN-ERROR'); expect(compiled.querySelector('#login-error').innerText).toEqual('LOGIN.MESSAGES.LOGIN-ERROR');
}); });
})); }));
@ -286,21 +424,30 @@ describe('AlfrescoLogin', () => {
spyOn(component.onSuccess, 'emit'); spyOn(component.onSuccess, 'emit');
expect(component.error).toBe(false);
expect(component.success).toBe(false);
let compiled = fixture.debugElement.nativeElement; let compiled = fixture.debugElement.nativeElement;
let usernameInput = compiled.querySelector('#username');
component.form.controls.username._value = 'fake-username'; let passwordInput = compiled.querySelector('#password');
component.form.controls.password._value = 'fake-password';
fixture.detectChanges();
component.onValueChanged();
let nativeElement = fixture.nativeElement;
let button = nativeElement.querySelector('button');
button.dispatchEvent(new Event('click'));
fixture.detectChanges(); fixture.detectChanges();
expect(fixture.componentInstance.error).toBe(false); usernameInput.value = 'fake-username';
passwordInput.value = 'fake-password';
usernameInput.dispatchEvent(new Event('input'));
passwordInput.dispatchEvent(new Event('input'));
fixture.detectChanges();
component.onValueChanged(null);
compiled.querySelector('button').click();
fixture.detectChanges();
expect(component.error).toBe(false);
expect(component.success).toBe(true);
expect(compiled.querySelector('#login-success')).toBeDefined();
expect(compiled.querySelector('#login-success').innerHTML).toEqual('LOGIN.MESSAGES.LOGIN-SUCCESS'); expect(compiled.querySelector('#login-success').innerHTML).toEqual('LOGIN.MESSAGES.LOGIN-SUCCESS');
expect(component.onSuccess.emit).toHaveBeenCalledWith({value: 'Login OK'}); expect(component.onSuccess.emit).toHaveBeenCalledWith({value: 'Login OK'});
}); });
@ -318,22 +465,30 @@ describe('AlfrescoLogin', () => {
spyOn(component.onError, 'emit'); spyOn(component.onError, 'emit');
expect(component.success).toBe(false);
expect(component.error).toBe(false);
let compiled = fixture.debugElement.nativeElement; let compiled = fixture.debugElement.nativeElement;
let usernameInput = compiled.querySelector('#username');
component.form.controls.username._value = 'fake-wrong-username'; let passwordInput = compiled.querySelector('#password');
component.form.controls.password._value = 'fake-password';
fixture.detectChanges();
component.onValueChanged();
// trigger the click
let nativeElement = fixture.nativeElement;
let button = nativeElement.querySelector('button');
button.dispatchEvent(new Event('click'));
fixture.detectChanges(); fixture.detectChanges();
expect(fixture.componentInstance.error).toBe(true); usernameInput.value = 'fake-username';
passwordInput.value = 'fake-wrong-password';
usernameInput.dispatchEvent(new Event('input'));
passwordInput.dispatchEvent(new Event('input'));
fixture.detectChanges();
component.onValueChanged(null);
compiled.querySelector('button').click();
fixture.detectChanges();
expect(component.error).toBe(true);
expect(component.success).toBe(false);
expect(compiled.querySelector('#login-error')).toBeDefined();
expect(compiled.querySelector('#login-error').innerText).toEqual('LOGIN.MESSAGES.LOGIN-ERROR'); expect(compiled.querySelector('#login-error').innerText).toEqual('LOGIN.MESSAGES.LOGIN-ERROR');
expect(component.onError.emit).toHaveBeenCalledWith({value: 'Login KO'}); expect(component.onError.emit).toHaveBeenCalledWith({value: 'Login KO'});
}); });
@ -380,6 +535,5 @@ describe('AlfrescoLogin', () => {
expect(compiled.querySelector('#password').type).toEqual('password'); expect(compiled.querySelector('#password').type).toEqual('password');
}); });
})); }));
}); });