|
1 | | -import { TranslateService } from '@ngx-translate/core'; |
2 | | -import { MockComponent, MockProvider } from 'ng-mocks'; |
3 | | - |
4 | | -import { DialogService, DynamicDialogRef } from 'primeng/dynamicdialog'; |
5 | | - |
6 | | -import { Subject } from 'rxjs'; |
| 1 | +import { MockProvider } from 'ng-mocks'; |
7 | 2 |
|
8 | 3 | import { ComponentFixture, TestBed } from '@angular/core/testing'; |
| 4 | +import { Router } from '@angular/router'; |
9 | 5 |
|
10 | | -import { DeveloperAppAddEditFormComponent } from '@osf/features/settings/developer-apps/components'; |
11 | | -import { SubHeaderComponent } from '@osf/shared/components/sub-header/sub-header.component'; |
12 | | -import { ToastService } from '@osf/shared/services/toast.service'; |
| 6 | +import { CustomDialogService } from '@osf/shared/services/custom-dialog.service'; |
13 | 7 |
|
| 8 | +import { DeveloperAppAddEditFormComponent } from './components'; |
14 | 9 | import { DeveloperAppsContainerComponent } from './developer-apps-container.component'; |
15 | 10 |
|
16 | 11 | import { provideOSFCore } from '@testing/osf.testing.provider'; |
| 12 | +import { |
| 13 | + CustomDialogServiceMockBuilder, |
| 14 | + CustomDialogServiceMockType, |
| 15 | +} from '@testing/providers/custom-dialog-provider.mock'; |
| 16 | +import { RouterMockBuilder, RouterMockType } from '@testing/providers/router-provider.mock'; |
17 | 17 |
|
18 | 18 | describe('DeveloperAppsContainerComponent', () => { |
19 | 19 | let component: DeveloperAppsContainerComponent; |
20 | 20 | let fixture: ComponentFixture<DeveloperAppsContainerComponent>; |
21 | | - let translateService: TranslateService; |
22 | | - let dialogRefMock: Partial<DynamicDialogRef>; |
23 | | - let dialogService: DialogService; |
24 | | - let openSpy: jest.SpyInstance; |
25 | | - let translateSpy: jest.SpyInstance; |
26 | | - |
27 | | - beforeEach(async () => { |
28 | | - dialogRefMock = { onClose: new Subject<void>() }; |
29 | | - |
30 | | - await TestBed.configureTestingModule({ |
31 | | - imports: [DeveloperAppsContainerComponent, MockComponent(SubHeaderComponent)], |
32 | | - providers: [MockProvider(DialogService), MockProvider(ToastService), provideOSFCore()], |
33 | | - }).compileComponents(); |
| 21 | + let routerMock: RouterMockType; |
| 22 | + let customDialogServiceMock: CustomDialogServiceMockType; |
| 23 | + |
| 24 | + function setup(url = '/settings/developer-apps') { |
| 25 | + routerMock = RouterMockBuilder.create().withUrl(url).build(); |
| 26 | + customDialogServiceMock = CustomDialogServiceMockBuilder.create().withDefaultOpen().build(); |
| 27 | + |
| 28 | + TestBed.configureTestingModule({ |
| 29 | + imports: [DeveloperAppsContainerComponent], |
| 30 | + providers: [ |
| 31 | + provideOSFCore(), |
| 32 | + MockProvider(Router, routerMock), |
| 33 | + MockProvider(CustomDialogService, customDialogServiceMock), |
| 34 | + ], |
| 35 | + }); |
34 | 36 |
|
35 | 37 | fixture = TestBed.createComponent(DeveloperAppsContainerComponent); |
36 | 38 | component = fixture.componentInstance; |
| 39 | + fixture.detectChanges(); |
| 40 | + } |
37 | 41 |
|
38 | | - translateService = TestBed.inject(TranslateService); |
39 | | - dialogService = fixture.debugElement.injector.get(DialogService); |
| 42 | + it('should create', () => { |
| 43 | + setup(); |
40 | 44 |
|
41 | | - openSpy = jest.spyOn(dialogService, 'open').mockReturnValue(dialogRefMock as DynamicDialogRef); |
42 | | - translateSpy = jest.spyOn(translateService, 'instant').mockReturnValue('Create Developer App'); |
| 45 | + expect(component).toBeTruthy(); |
| 46 | + }); |
43 | 47 |
|
44 | | - fixture.detectChanges(); |
| 48 | + it('should set isBaseRoute to true when current url is base route', () => { |
| 49 | + setup('/settings/developer-apps'); |
| 50 | + |
| 51 | + expect(component.isBaseRoute()).toBe(true); |
45 | 52 | }); |
46 | 53 |
|
47 | | - it('should create', () => { |
48 | | - expect(component).toBeTruthy(); |
| 54 | + it('should set isBaseRoute to false when current url is not base route', () => { |
| 55 | + setup('/settings/developer-apps/create'); |
| 56 | + |
| 57 | + expect(component.isBaseRoute()).toBe(false); |
49 | 58 | }); |
50 | 59 |
|
51 | | - it('should open dialog with 500px width', () => { |
| 60 | + it('should open create developer app dialog with expected config', () => { |
| 61 | + setup(); |
| 62 | + |
52 | 63 | component.createDeveloperApp(); |
53 | 64 |
|
54 | | - expect(openSpy).toHaveBeenCalledWith(DeveloperAppAddEditFormComponent, { |
| 65 | + expect(customDialogServiceMock.open).toHaveBeenCalledWith(DeveloperAppAddEditFormComponent, { |
| 66 | + header: 'settings.developerApps.form.createTitle', |
55 | 67 | width: '500px', |
56 | | - focusOnShow: false, |
57 | | - header: 'Create Developer App', |
58 | | - breakpoints: { '768px': '95vw' }, |
59 | | - closeOnEscape: true, |
60 | | - modal: true, |
61 | | - closable: true, |
62 | 68 | }); |
63 | | - expect(translateSpy).toHaveBeenCalledWith('settings.developerApps.form.createTitle'); |
64 | 69 | }); |
65 | 70 | }); |
0 commit comments