2 * ============LICENSE_START==========================================
4 * ===================================================================
5 * Copyright © 2019 AT&T Intellectual Property. All rights reserved.
6 * ===================================================================
7 * Modification Copyright © 2020 IBM.
8 * ===================================================================
10 * Unless otherwise specified, all software contained herein is licensed
11 * under the Apache License, Version 2.0 (the "License");
12 * you may not use this software except in compliance with the License.
13 * You may obtain a copy of the License at
15 * http://www.apache.org/licenses/LICENSE-2.0
17 * Unless required by applicable law or agreed to in writing, software
18 * distributed under the License is distributed on an "AS IS" BASIS,
19 * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
20 * See the License for the specific language governing permissions and
21 * limitations under the License.
23 * Unless otherwise specified, all documentation contained herein is licensed
24 * under the Creative Commons License, Attribution 4.0 Intl. (the "License");
25 * you may not use this documentation except in compliance with the License.
26 * You may obtain a copy of the License at
28 * https://creativecommons.org/licenses/by/4.0/
30 * Unless required by applicable law or agreed to in writing, documentation
31 * distributed under the License is distributed on an "AS IS" BASIS,
32 * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
33 * See the License for the specific language governing permissions and
34 * limitations under the License.
36 * ============LICENSE_END============================================
41 import { async, ComponentFixture, TestBed } from '@angular/core/testing';
43 import { SelfComponent } from './self.component';
44 import { FormsModule, ReactiveFormsModule } from '@angular/forms';
45 import { CUSTOM_ELEMENTS_SCHEMA } from '@angular/core';
46 import { MatTableModule, MatSelectModule, MatSlideToggleModule } from '@angular/material';
47 import { HttpClientTestingModule } from '@angular/common/http/testing';
48 import { BrowserAnimationsModule } from '@angular/platform-browser/animations';
49 import { UserService } from 'src/app/shared/services/user/user.service';
50 import { Observable } from 'rxjs';
51 import { RouterTestingModule } from '@angular/router/testing';
52 import { ModalDismissReasons, NgbModule } from '@ng-bootstrap/ng-bootstrap';
53 import { ProfileService } from '../profile.service';
54 import { InformationModalComponent } from 'src/app/modals/information-modal/information-modal.component';
55 import { BrowserDynamicTestingModule } from '@angular/platform-browser-dynamic/testing';
56 import { ErrorModalComponent } from 'src/app/modals/error-modal/error-modal.component';
57 import { ConfirmationModalComponent } from 'src/app/modals/confirmation-modal/confirmation-modal.component';
59 describe('SelfComponent', () => {
60 let component: SelfComponent;
61 let fixture: ComponentFixture<SelfComponent>;
62 let userService:UserService;
63 let profileService:ProfileService;
64 var _element={"_element":{"selected":true}}
66 beforeEach(async(() => {
67 TestBed.configureTestingModule({
68 schemas: [CUSTOM_ELEMENTS_SCHEMA],
71 InformationModalComponent,
73 ConfirmationModalComponent
81 BrowserAnimationsModule,
82 HttpClientTestingModule,
87 TestBed.overrideModule(BrowserDynamicTestingModule,{
90 InformationModalComponent,
92 ConfirmationModalComponent]
99 fixture = TestBed.createComponent(SelfComponent);
100 component = fixture.componentInstance;
101 fixture.detectChanges();
102 userService=TestBed.get(UserService);
103 profileService=TestBed.get(ProfileService);
106 it('should create', () => {
107 expect(component).toBeTruthy();
111 describe('should test ngOnInit method',()=>{
112 it('should test subscribe',()=>{
113 let spy=spyOn(userService,'getFunctionalMenuStaticDetailSession').and.returnValue(Observable.of('you object'));
114 component.ngOnInit();
115 expect(spy).toHaveBeenCalled();
119 it('should test getDismissReason method',()=>{
120 component['getDismissReason'](ModalDismissReasons.ESC);
121 component['getDismissReason'](ModalDismissReasons.BACKDROP_CLICK);
122 component['getDismissReason']("");
125 it('should test getProfileById method',()=>{
126 let spy=spyOn(profileService,'getProfileById').and.callThrough();
127 component.getProfileById("indrijeet");
128 expect(spy).toHaveBeenCalled();
131 it('should test getSelfProfileDetail method',()=>{
132 let spy=spyOn(profileService,'getSelfProfile').and.callThrough();
133 component.getSelfProfileDetail();
134 expect(spy).toHaveBeenCalled();
137 it('should test saveProfile method first if condition',()=>{
138 component.oriProfile={"loginId":"loginId1"};
139 component.profile.loginId="loginId2";
140 component.saveProfile()
143 it('should test saveProfile method second if condition',()=>{
144 component.oriProfile={
146 "loginPwd":"loginPwd1"
148 component.profile.loginId="loginId";
149 component.profile.loginPwd="loginPwd2"
150 component.saveProfile()
153 it('should test saveProfile method',()=>{
154 component.oriProfile={
156 "loginPwd":"loginPwd"
158 component.profile.loginId="loginId";
159 component.profile.loginPwd="loginPwd";
160 component.stateList=[{"value":"value"}];
161 component.profile.state="value";
162 component.ociCountries=[{"value":"India"}];
163 component.profile.country="India";
164 component.ociTimeZones=[{"value":"Indian"}];
165 component.profile.timeZoneId="Indian";
168 selectedCountry:"selectedCountry",
169 selectedState:"selectedState",
170 selectedTimeZone:"selectedTimeZone"
172 component.profileId="profileId";
173 let spy= spyOn(profileService,'saveProfile').and.returnValue(Observable.of('your object'));
174 component.saveProfile()
175 expect(spy).toHaveBeenCalled();
178 it('should test toggleRoles method',()=>{
179 component.ociavailableRoles=[{"ociavailableRoles":"ociavailableRoles"}];
180 component.finalSelectedRoles=[{"finalSelectedRoles":"finalSelectedRoles"}];
181 component.toggleRoles(_element);
182 component.addUserRole(_element);