52bb01f007dfa1be3f1be8065f2d1fdda02fe8ba
[portal/sdk.git] /
1 /*
2  * ============LICENSE_START==========================================
3  * ONAP Portal SDK
4  * ===================================================================
5  * Copyright © 2019 AT&T Intellectual Property. All rights reserved.
6  * ===================================================================
7 *  Modification Copyright © 2020 IBM.
8  * ===================================================================
9  *
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
14  *
15  *             http://www.apache.org/licenses/LICENSE-2.0
16  *
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.
22  *
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
27  *
28  *             https://creativecommons.org/licenses/by/4.0/
29  *
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.
35  *
36  * ============LICENSE_END============================================
37  *
38  * 
39  */
40
41 import { async, ComponentFixture, TestBed } from '@angular/core/testing';
42
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';
58
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}}
65  
66   beforeEach(async(() => {
67     TestBed.configureTestingModule({
68       schemas: [CUSTOM_ELEMENTS_SCHEMA],
69       declarations: [ 
70         SelfComponent,
71         InformationModalComponent,
72         ErrorModalComponent,
73         ConfirmationModalComponent
74       ],
75       imports: [
76         ReactiveFormsModule, 
77         FormsModule,
78         MatTableModule, 
79         MatSelectModule,
80         MatSlideToggleModule,
81         BrowserAnimationsModule,
82         HttpClientTestingModule,
83         RouterTestingModule,
84         NgbModule.forRoot()
85         ]
86     })
87     TestBed.overrideModule(BrowserDynamicTestingModule,{
88       set:{
89         entryComponents:[
90           InformationModalComponent,
91           ErrorModalComponent,
92           ConfirmationModalComponent]
93       }
94     })
95     .compileComponents();
96   }));
97
98   beforeEach(() => {
99     fixture = TestBed.createComponent(SelfComponent);
100     component = fixture.componentInstance;
101     fixture.detectChanges();
102     userService=TestBed.get(UserService);
103     profileService=TestBed.get(ProfileService);
104   });
105
106   it('should create', () => {
107     expect(component).toBeTruthy();
108   });
109
110
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();
116     })
117   })
118
119   it('should test getDismissReason method',()=>{
120     component['getDismissReason'](ModalDismissReasons.ESC);
121     component['getDismissReason'](ModalDismissReasons.BACKDROP_CLICK);
122     component['getDismissReason']("");
123   })
124
125   it('should test getProfileById method',()=>{
126     let spy=spyOn(profileService,'getProfileById').and.callThrough();
127     component.getProfileById("indrijeet");
128     expect(spy).toHaveBeenCalled();
129   })
130
131   it('should test getSelfProfileDetail method',()=>{
132     let spy=spyOn(profileService,'getSelfProfile').and.callThrough();
133     component.getSelfProfileDetail();
134     expect(spy).toHaveBeenCalled();
135   })
136
137   it('should test saveProfile method first if condition',()=>{
138     component.oriProfile={"loginId":"loginId1"};
139     component.profile.loginId="loginId2";
140     component.saveProfile()
141   })
142
143   it('should test saveProfile method second if condition',()=>{
144     component.oriProfile={
145                           "loginId":"loginId",
146                           "loginPwd":"loginPwd1"
147                         };
148     component.profile.loginId="loginId";
149     component.profile.loginPwd="loginPwd2"
150     component.saveProfile()
151   })
152
153   it('should test saveProfile method',()=>{
154     component.oriProfile={
155                           "loginId":"loginId",
156                           "loginPwd":"loginPwd"
157                         };
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";
166     component.postData={
167     profile: "profile",
168     selectedCountry:"selectedCountry",
169     selectedState:"selectedState",
170     selectedTimeZone:"selectedTimeZone"
171         };
172     component.profileId="profileId";
173     let spy= spyOn(profileService,'saveProfile').and.returnValue(Observable.of('your object'));
174     component.saveProfile()
175     expect(spy).toHaveBeenCalled();
176   });
177
178   it('should test toggleRoles method',()=>{
179     component.ociavailableRoles=[{"ociavailableRoles":"ociavailableRoles"}];
180     component.finalSelectedRoles=[{"finalSelectedRoles":"finalSelectedRoles"}];
181     component.toggleRoles(_element);
182     component.addUserRole(_element);
183   })
184
185 });