/*! * @license * Copyright 2019 Alfresco Software, Ltd. * * Licensed under the Apache License, Version 2.0 (the "License"); * you may not use this file except in compliance with the License. * You may obtain a copy of the License at * * http://www.apache.org/licenses/LICENSE-2.0 * * Unless required by applicable law or agreed to in writing, software * distributed under the License is distributed on an "AS IS" BASIS, * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. * See the License for the specific language governing permissions and * limitations under the License. */ import { ComponentFixture, TestBed } from '@angular/core/testing'; import { By, DomSanitizer } from '@angular/platform-browser'; import { AuthenticationService, ContentService } from '../../services'; import { InitialUsernamePipe } from '../../pipes'; import { fakeBpmUser } from '../../mock/bpm-user.service.mock'; import { fakeEcmEditedUser, fakeEcmUser, fakeEcmUserNoImage } from '../../mock/ecm-user.service.mock'; import { BpmUserService } from '../../services/bpm-user.service'; import { EcmUserService } from '../../services/ecm-user.service'; import { IdentityUserService } from '../../services/identity-user.service'; import { BpmUserModel } from '../../models/bpm-user.model'; import { EcmUserModel } from '../../models/ecm-user.model'; import { UserInfoComponent } from './user-info.component'; import { of } from 'rxjs'; import { setupTestBed } from '../../testing/setup-test-bed'; import { CoreTestingModule } from '../../testing/core.testing.module'; import { TranslateModule } from '@ngx-translate/core'; import { MatMenuModule } from '@angular/material/menu'; class FakeSanitizer extends DomSanitizer { constructor() { super(); } sanitize(html) { return html; } bypassSecurityTrustHtml(value: string): any { return value; } bypassSecurityTrustStyle(): any { return null; } bypassSecurityTrustScript(): any { return null; } bypassSecurityTrustUrl(): any { return null; } bypassSecurityTrustResourceUrl(): any { return null; } } describe('User info component', () => { let component: UserInfoComponent; let fixture: ComponentFixture; let element: HTMLElement; let authService: AuthenticationService; let contentService: ContentService; let ecmUserService: EcmUserService; let bpmUserService: BpmUserService; let identityUserService: IdentityUserService; const identityUserMock = { firstName: 'fake-identity-first-name', lastName: 'fake-identity-last-name', email: 'fakeIdentity@email.com' }; const identityUserWithOutFirstNameMock = { firstName: null, lastName: 'fake-identity-last-name', email: 'fakeIdentity@email.com' }; const identityUserWithOutLastNameMock = { firstName: 'fake-identity-first-name', lastName: null, email: 'fakeIdentity@email.com' }; const openUserInfo = () => { fixture.detectChanges(); const imageButton = element.querySelector('#logged-user-img'); imageButton.click(); fixture.detectChanges(); }; const whenFixtureReady = async () => { fixture.detectChanges(); await fixture.whenStable(); fixture.detectChanges(); }; setupTestBed({ imports: [ TranslateModule.forRoot(), CoreTestingModule, MatMenuModule ] }); beforeEach(() => { fixture = TestBed.createComponent(UserInfoComponent); component = fixture.componentInstance; element = fixture.nativeElement; authService = TestBed.inject(AuthenticationService); ecmUserService = TestBed.inject(EcmUserService); bpmUserService = TestBed.inject(BpmUserService); contentService = TestBed.inject(ContentService); identityUserService = TestBed.inject(IdentityUserService); spyOn(window, 'requestAnimationFrame').and.returnValue(1); spyOn(bpmUserService, 'getCurrentUserProfileImage').and.returnValue('app/rest/admin/profile-picture'); spyOn(contentService, 'getContentUrl').and.returnValue('alfresco-logo.svg'); }); afterEach(() => { fixture.destroy(); }); it('should not show any image if the user is not logged in', () => { expect(element.querySelector('#userinfo_container')).toBeDefined(); expect(element.querySelector('#logged-user-img')).toBeNull(); }); it('should NOT have users immediately after ngOnInit', () => { expect(element.querySelector('#userinfo_container')).toBeDefined(); expect(element.querySelector('#ecm_username')).toBeNull(); expect(element.querySelector('#bpm_username')).toBeNull(); expect(element.querySelector('#user-profile-lists')).toBeNull(); }); describe('when user is logged on ecm', () => { let getCurrenEcmtUserInfoStub; let isOauthStub; let isEcmLoggedInStub; let isLoggedInStub; let isBpmLoggedInStub; beforeEach(() => { isOauthStub = spyOn(authService, 'isOauth').and.returnValue(false); isEcmLoggedInStub = spyOn(authService, 'isEcmLoggedIn').and.returnValue(true); isLoggedInStub = spyOn(authService, 'isLoggedIn').and.returnValue(true); isBpmLoggedInStub = spyOn(authService, 'isBpmLoggedIn').and.returnValue(false); getCurrenEcmtUserInfoStub = spyOn(ecmUserService, 'getCurrentUserInfo').and.returnValue(of(fakeEcmUser)); }); describe('ui ', () => { it('should able to fetch ecm userInfo', (done) => { component.getUserInfo(); fixture.detectChanges(); fixture.whenStable().then(() => { component.ecmUser$.subscribe((response: EcmUserModel) => { expect(response).toBeDefined(); expect(response.firstName).toBe('fake-ecm-first-name'); expect(response.lastName).toBe('fake-ecm-last-name'); expect(response.email).toBe('fakeEcm@ecmUser.com'); done(); }); }); }); it('should show ecm only last name when user first name is null ', async () => { getCurrenEcmtUserInfoStub.and.returnValue(of(fakeEcmEditedUser)); await whenFixtureReady(); openUserInfo(); expect(element.querySelector('#userinfo_container')).toBeDefined(); const ecmUsername = fixture.debugElement.query(By.css('#ecm-username')); expect(ecmUsername).toBeDefined(); expect(ecmUsername).not.toBeNull(); expect(ecmUsername.nativeElement.textContent).not.toContain('fake-ecm-first-name'); expect(ecmUsername.nativeElement.textContent).not.toContain('null'); }); it('should show the username when showName attribute is true', async () => { await whenFixtureReady(); expect(component.showName).toBeTruthy(); expect(element.querySelector('#adf-userinfo-ecm-name-display')).not.toBeNull(); }); it('should hide the username when showName attribute is false', async () => { component.showName = false; await whenFixtureReady(); expect(element.querySelector('#adf-userinfo-ecm-name-display')).toBeNull(); }); it('should have the defined class to show the name on the right side', async () => { await whenFixtureReady(); expect(element.querySelector('#userinfo_container').classList).toContain('adf-userinfo-name-right'); }); it('should not have the defined class to show the name on the left side', async () => { component.namePosition = 'left'; await whenFixtureReady(); expect(element.querySelector('#userinfo_container').classList).not.toContain('adf-userinfo-name-right'); }); describe('and has image', () => { beforeEach(async () => { isOauthStub.and.returnValue(false); isEcmLoggedInStub.and.returnValue(true); isLoggedInStub.and.returnValue(true); getCurrenEcmtUserInfoStub.and.returnValue(of(fakeEcmUser)); await whenFixtureReady(); }); it('should get the ecm current user image from the service', async () => { openUserInfo(); const loggedImage = fixture.debugElement.query(By.css('#logged-user-img')); expect(element.querySelector('#userinfo_container')).not.toBeNull(); expect(loggedImage).not.toBeNull(); expect(loggedImage.properties.src).toContain('alfresco-logo.svg'); }); it('should display the current user image if user has avatarId', (done) => { openUserInfo(); const loggedImage = fixture.debugElement.query(By.css('#logged-user-img')); component.ecmUser$.subscribe((response: EcmUserModel) => { expect(response).toBeDefined(); expect(response.avatarId).toBe('fake-avatar-id'); done(); }); expect(element.querySelector('#userinfo_container')).not.toBeNull(); expect(loggedImage).not.toBeNull(); expect(loggedImage.properties.src).toContain('alfresco-logo.svg'); }); it('should get the ecm user information from the service', async () => { openUserInfo(); const ecmImage = fixture.debugElement.query(By.css('#ecm-user-detail-image')); const ecmFullName = fixture.debugElement.query(By.css('#ecm-full-name')); const ecmJobTitle = fixture.debugElement.query(By.css('#ecm-job-title-label')); expect(element.querySelector('#userinfo_container')).not.toBeNull(); expect(fixture.debugElement.query(By.css('#ecm-username'))).not.toBeNull(); expect(ecmImage).not.toBeNull(); expect(ecmImage.properties.src).toContain('alfresco-logo.svg'); expect(ecmFullName.nativeElement.textContent).toContain('fake-ecm-first-name fake-ecm-last-name'); expect(ecmJobTitle.nativeElement.textContent).toContain('USER_PROFILE.LABELS.ECM.JOB_TITLE'); }); }); describe('and has no image', () => { beforeEach( async () => { isOauthStub.and.returnValue(false); isEcmLoggedInStub.and.returnValue(true); isLoggedInStub.and.returnValue(true); isBpmLoggedInStub.and.returnValue(false); getCurrenEcmtUserInfoStub.and.returnValue(of(fakeEcmUserNoImage)); await whenFixtureReady(); }); it('should show N/A when the job title is null', () => { const imageButton = element.querySelector('#user-initials-image'); imageButton.click(); fixture.detectChanges(); expect(element.querySelector('#userinfo_container')).not.toBeNull(); const ecmJobTitle = fixture.debugElement.query(By.css('#ecm-job-title')); expect(ecmJobTitle).not.toBeNull(); expect(ecmJobTitle).not.toBeNull(); expect(ecmJobTitle.nativeElement.textContent).toContain('N/A'); }); it('should not show the tabs', () => { const imageButton = element.querySelector('#user-initials-image'); imageButton.click(); fixture.detectChanges(); const tabHeader = fixture.debugElement.query(By.css('#tab-group-env')); expect(tabHeader.classes['adf-hide-tab']).toBeTruthy(); }); it('should display the current user Initials if the user dose not have avatarId', (done) => { fixture.detectChanges(); const pipe = new InitialUsernamePipe(new FakeSanitizer()); const expected = pipe.transform({ id: 13, firstName: 'Wilbur', lastName: 'Adams', email: 'wilbur@app.com' }); expect(expected).toBe('
WA
'); component.ecmUser$.subscribe((response: EcmUserModel) => { expect(response).toBeDefined(); expect(response.avatarId).toBeNull(); done(); }); }); }); }); describe('when user is logged on bpm', () => { let getCurrentUserInfoStub: jasmine.Spy; beforeEach(() => { isOauthStub.and.returnValue(false); isBpmLoggedInStub.and.returnValue(true); isLoggedInStub.and.returnValue(true); isEcmLoggedInStub.and.returnValue(false); getCurrentUserInfoStub = spyOn(bpmUserService, 'getCurrentUserInfo').and.returnValue(of(fakeBpmUser)); }); it('should fetch bpm userInfo', (done) => { getCurrentUserInfoStub.and.returnValue(of(fakeBpmUser)); fixture.detectChanges(); fixture.whenStable().then(() => { component.bpmUser$.subscribe((response: BpmUserModel) => { expect(response).toBeDefined(); expect(response.firstName).toBe('fake-bpm-first-name'); expect(response.lastName).toBe('fake-bpm-last-name'); expect(response.email).toBe('fakeBpm@fake.com'); done(); }); }); }); it('should show full name next the user image', async () => { await whenFixtureReady(); openUserInfo(); const bpmUserName = fixture.debugElement.query(By.css('#bpm-username')); expect(element.querySelector('#userinfo_container')).not.toBeNull(); expect(bpmUserName).toBeDefined(); expect(bpmUserName).not.toBeNull(); expect(bpmUserName.nativeElement.innerHTML).toContain('fake-bpm-first-name fake-bpm-last-name'); }); it('should get the bpm current user image from the service', async () => { await whenFixtureReady(); expect(element.querySelector('#userinfo_container')).not.toBeNull(); expect(element.querySelector('#logged-user-img')).not.toBeNull(); expect(element.querySelector('#logged-user-img').getAttribute('src')) .toContain('app/rest/admin/profile-picture'); }); it('should show last name if first name is null', async () => { const wrongBpmUser: BpmUserModel = new BpmUserModel({ firstName: null, lastName: 'fake-last-name' }); getCurrentUserInfoStub.and.returnValue(of(wrongBpmUser)); await whenFixtureReady(); const fullNameElement = (element.querySelector('#adf-userinfo-bpm-name-display')); fixture.detectChanges(); expect(element.querySelector('#userinfo_container')).toBeDefined(); expect(element.querySelector('#adf-userinfo-bpm-name-display')).not.toBeNull(); expect(fullNameElement.textContent).toContain('fake-last-name'); expect(fullNameElement.textContent).not.toContain('fake-first-name'); }); it('should not show first name if it is null string', async () => { const wrongFirstNameBpmUser: BpmUserModel = new BpmUserModel({ firstName: 'null', lastName: 'fake-last-name' }); getCurrentUserInfoStub.and.returnValue(of(wrongFirstNameBpmUser)); await whenFixtureReady(); expect(element.querySelector('#userinfo_container')).toBeDefined(); expect(element.querySelector('#adf-userinfo-bpm-name-display')).toBeDefined(); expect(element.querySelector('#adf-userinfo-bpm-name-display').textContent).toContain('fake-last-name'); expect(element.querySelector('#adf-userinfo-bpm-name-display').textContent).not.toContain('null'); }); it('should not show last name if it is null string', async () => { const wrongLastNameBpmUser: BpmUserModel = new BpmUserModel({ firstName: 'fake-first-name', lastName: 'null' }); getCurrentUserInfoStub.and.returnValue(of(wrongLastNameBpmUser)); await whenFixtureReady(); expect(element.querySelector('#userinfo_container')).toBeDefined(); expect(element.querySelector('#adf-userinfo-bpm-name-display')).toBeDefined(); expect(element.querySelector('#adf-userinfo-bpm-name-display').textContent).toContain('fake-first-name'); expect(element.querySelector('#adf-userinfo-bpm-name-display').textContent).not.toContain('null'); }); it('should not show the tabs', async () => { await whenFixtureReady(); openUserInfo(); await fixture.whenStable(); fixture.detectChanges(); expect(fixture.debugElement.query(By.css('#tab-group-env')).classes['adf-hide-tab']).toBeTruthy(); }); }); describe('when user is logged on bpm and ecm', () => { beforeEach(() => { isOauthStub.and.returnValue(false); isEcmLoggedInStub.and.returnValue(true); isBpmLoggedInStub.and.returnValue(true); isLoggedInStub.and.returnValue(true); getCurrenEcmtUserInfoStub.and.returnValue(of(fakeEcmUser)); spyOn(bpmUserService, 'getCurrentUserInfo').and.returnValue(of(fakeBpmUser)); }); it('should get the bpm user information from the service', async () => { await whenFixtureReady(); openUserInfo(); const bpmTab = fixture.debugElement.queryAll(By.css('#tab-group-env .mat-tab-labels .mat-tab-label'))[1]; bpmTab.triggerEventHandler('click', null); fixture.detectChanges(); await fixture.whenStable(); const bpmUsername = fixture.debugElement.query(By.css('#bpm-username')); const bpmImage = fixture.debugElement.query(By.css('#bpm-user-detail-image')); expect(element.querySelector('#userinfo_container')).not.toBeNull(); expect(bpmUsername).not.toBeNull(); expect(bpmImage).not.toBeNull(); expect(bpmImage.properties.src).toContain('app/rest/admin/profile-picture'); expect(bpmUsername.nativeElement.textContent).toContain('fake-bpm-first-name fake-bpm-last-name'); expect(fixture.debugElement.query(By.css('#bpm-tenant')).nativeElement.textContent).toContain('fake-tenant-name'); }); it('should get the ecm user information from the service', async () => { await whenFixtureReady(); openUserInfo(); const ecmUsername = fixture.debugElement.query(By.css('#ecm-username')); const ecmImage = fixture.debugElement.query(By.css('#ecm-user-detail-image')); fixture.detectChanges(); await fixture.whenStable(); expect(element.querySelector('#userinfo_container')).toBeDefined(); expect(ecmUsername).not.toBeNull(); expect(ecmImage).not.toBeNull(); expect(ecmImage.properties.src).toContain('alfresco-logo.svg'); expect(fixture.debugElement.query(By.css('#ecm-full-name')).nativeElement.textContent).toContain('fake-ecm-first-name fake-ecm-last-name'); expect(fixture.debugElement.query(By.css('#ecm-job-title')).nativeElement.textContent).toContain('job-ecm-test'); }); it('should show the ecm image if exists', async () => { await whenFixtureReady(); openUserInfo(); expect(element.querySelector('#userinfo_container')).toBeDefined(); expect(element.querySelector('#logged-user-img')).toBeDefined(); expect(element.querySelector('#logged-user-img').getAttribute('src')).toEqual('alfresco-logo.svg'); }); it('should show the ecm initials if the ecm user has no image', async () => { getCurrenEcmtUserInfoStub.and.returnValue(of(fakeEcmUserNoImage)); await whenFixtureReady(); expect(element.querySelector('#userinfo_container')).toBeDefined(); expect(element.querySelector('#user-initials-image').textContent).toContain('ff'); }); it('should show the tabs for the env', async () => { await whenFixtureReady(); openUserInfo(); const tabGroup = fixture.debugElement.query(By.css('#tab-group-env')); const tabs = fixture.debugElement.queryAll(By.css('#tab-group-env .mat-tab-labels .mat-tab-label')); expect(tabGroup).not.toBeNull(); expect(tabGroup.classes['adf-hide-tab']).toBeFalsy(); expect(tabs.length).toBe(2); }); it('should not close the menu when a tab is clicked', async () => { await whenFixtureReady(); openUserInfo(); const tabGroup = fixture.debugElement.query(By.css('#tab-group-env')); const tabs = fixture.debugElement.queryAll(By.css('#tab-group-env .mat-tab-labels .mat-tab-label')); expect(tabGroup).not.toBeNull(); tabs[1].triggerEventHandler('click', null); fixture.detectChanges(); expect(fixture.debugElement.query(By.css('#user-profile-lists'))).not.toBeNull(); }); }); describe('when identity user is logged in', () => { let getCurrentUserInfoStub: jasmine.Spy; beforeEach(() => { isOauthStub.and.returnValue(true); isLoggedInStub.and.returnValue(true); isEcmLoggedInStub.and.returnValue(false); getCurrentUserInfoStub = spyOn(identityUserService, 'getCurrentUserInfo').and.returnValue(identityUserMock); }); it('should show the identity user initials if is not ecm user', async () => { await whenFixtureReady(); expect(element.querySelector('#userinfo_container')).toBeDefined(); expect(element.querySelector('#user-initials-image').textContent).toContain('ff'); }); it('should able to fetch identity userInfo', (done) => { fixture.detectChanges(); fixture.whenStable().then(() => { component.identityUser$.subscribe(response => { expect(response).toBeDefined(); expect(response.firstName).toBe('fake-identity-first-name'); expect(response.lastName).toBe('fake-identity-last-name'); expect(response.email).toBe('fakeIdentity@email.com'); done(); }); }); }); it('should show full name next the user image', async () => { await whenFixtureReady(); const imageButton = element.querySelector('#identity-user-image'); imageButton.click(); fixture.detectChanges(); expect(element.querySelector('#userinfo_container')).not.toBeNull(); const bpmUserName = fixture.debugElement.query(By.css('#identity-username')); expect(bpmUserName).toBeDefined(); expect(bpmUserName).not.toBeNull(); expect(bpmUserName.nativeElement.textContent).toContain('fake-identity-first-name fake-identity-last-name'); }); it('should show last name if first name is null', async () => { getCurrentUserInfoStub.and.returnValue(identityUserWithOutFirstNameMock); await whenFixtureReady(); const fullNameElement = element.querySelector('#adf-userinfo-identity-name-display'); expect(element.querySelector('#userinfo_container')).toBeDefined(); expect(element.querySelector('#adf-userinfo-identity-name-display')).not.toBeNull(); expect(fullNameElement.textContent).toContain('fake-identity-last-name'); expect(fullNameElement.textContent).not.toContain('fake-identity-first-name'); }); it('should not show first name if it is null string', async () => { getCurrentUserInfoStub.and.returnValue(identityUserWithOutFirstNameMock); await whenFixtureReady(); const fullNameElement = element.querySelector('#adf-userinfo-identity-name-display'); fixture.detectChanges(); expect(element.querySelector('#userinfo_container')).toBeDefined(); expect(fullNameElement).toBeDefined(); expect(fullNameElement.textContent).toContain('fake-identity-last-name'); expect(fullNameElement.textContent).not.toContain('null'); }); it('should not show last name if it is null string', async () => { getCurrentUserInfoStub.and.returnValue(identityUserWithOutLastNameMock); await whenFixtureReady(); const fullNameElement = element.querySelector('#adf-userinfo-identity-name-display'); fixture.detectChanges(); expect(element.querySelector('#userinfo_container')).toBeDefined(); expect(fullNameElement).toBeDefined(); expect(fullNameElement.textContent).toContain('fake-identity-first-name'); expect(fullNameElement.textContent).not.toContain('null'); }); it('should not show initials if the user have avatar', async () => { getCurrentUserInfoStub.and.returnValue(identityUserWithOutLastNameMock); getCurrenEcmtUserInfoStub.and.returnValue(of(fakeEcmUser)); isEcmLoggedInStub.and.returnValue(true); await whenFixtureReady(); expect(element.querySelector('.adf-userinfo-pic')).toBeNull(); expect(element.querySelector('.adf-userinfo-profile-image')).toBeDefined(); expect(element.querySelector('.adf-userinfo-profile-image')).not.toBeNull(); }); }); describe('kerberos', () => { beforeEach(async () => { isOauthStub.and.returnValue(false); isEcmLoggedInStub.and.returnValue(false); isBpmLoggedInStub.and.returnValue(false); isLoggedInStub.and.returnValue(false); spyOn(authService, 'isKerberosEnabled').and.returnValue(true); spyOn(authService, 'isALLProvider').and.returnValue(true); spyOn(bpmUserService, 'getCurrentUserInfo').and.returnValue(of(fakeBpmUser)); getCurrenEcmtUserInfoStub.and.returnValue(of(fakeEcmUser)); await whenFixtureReady(); }); it('should show the bpm user information', async () => { openUserInfo(); const bpmTab = fixture.debugElement.queryAll(By.css('#tab-group-env .mat-tab-labels .mat-tab-label'))[1]; bpmTab.triggerEventHandler('click', null); fixture.detectChanges(); await fixture.whenStable(); const bpmUsername = fixture.debugElement.query(By.css('#bpm-username')); const bpmImage = fixture.debugElement.query(By.css('#bpm-user-detail-image')); expect(bpmImage.properties.src).toContain('app/rest/admin/profile-picture'); expect(bpmUsername.nativeElement.textContent).toContain('fake-bpm-first-name fake-bpm-last-name'); expect(fixture.debugElement.query(By.css('#bpm-tenant')).nativeElement.textContent).toContain('fake-tenant-name'); }); it('should show the ecm user information', async () => { openUserInfo(); const ecmTab = fixture.debugElement.queryAll(By.css('#tab-group-env .mat-tab-labels .mat-tab-label'))[0]; ecmTab.triggerEventHandler('click', null); fixture.detectChanges(); await fixture.whenStable(); expect(fixture.debugElement.query(By.css('#ecm-full-name')).nativeElement.textContent).toContain('fake-ecm-first-name fake-ecm-last-name'); expect(fixture.debugElement.query(By.css('#ecm-job-title')).nativeElement.textContent).toContain('job-ecm-test'); }); }); }); });