1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
|
/*
* -
* ============LICENSE_START=======================================================
* Copyright (C) 2022 Nordix Foundation.
* ================================================================================
* 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.
*
* SPDX-License-Identifier: Apache-2.0
* ============LICENSE_END=========================================================
*/
import {async, ComponentFixture, TestBed} from '@angular/core/testing';
import {WorkspaceMenuComponent} from './workspace-menu.component';
import {CacheService} from "../../../services/cache.service";
import {States} from "../../../../utils/constants";
import {IAppMenu} from "../../../../models/app-config";
import {SdcMenuToken} from "../../../config/sdc-menu.config";
import {IScope} from "../../../../../typings/angularjs/angular";
import {IWorkspaceViewModelScope} from "../../../../view-models/workspace/workspace-view-model";
describe('WorkspaceMenuComponent', () => {
let component: WorkspaceMenuComponent;
let fixture: ComponentFixture<WorkspaceMenuComponent>;
let cacheService: Partial<CacheService> = {
'get': jest.fn(param => {
if (param === 'version') {
return 'version';
}
if (param === 'user') {
return {};
}
})
};
let sdcMenuMock: Partial<IAppMenu> = {
'component_workspace_menu_option': {
"DataType": [
{"text": "General", "action": "onMenuItemPressed", "state": "general"}
]
}
};
let stateMock: Partial<ng.ui.IStateService> = {
'current': {
'name': States.TYPE_WORKSPACE
}
};
let injectorMock: Partial<ng.auto.IInjectorService> = {
'get': jest.fn(param => {
if (param === '$state') {
return stateMock;
}
})
};
let importedFileMock: File = null;
let stateParamsMock: Partial<ng.ui.IStateParamsService> = {
'importedFile': importedFileMock
};
let resolveMock = {"$stateParams": stateParamsMock};
let parentScopeMock: Partial<IScope> = {
'$resolve': resolveMock
};
let scopeMock_: Partial<IWorkspaceViewModelScope> = {
'$parent': parentScopeMock,
'current': {
'name': States.TYPE_WORKSPACE
}
}
beforeEach(async(() => {
TestBed.configureTestingModule({
declarations: [ WorkspaceMenuComponent ],
providers: [
{provide: CacheService, useValue: cacheService},
{provide: '$injector', useValue: injectorMock},
{provide: "$scope", useValue: scopeMock_ },
{provide: SdcMenuToken, useValue: sdcMenuMock}
]
})
.compileComponents();
}));
beforeEach(() => {
fixture = TestBed.createComponent(WorkspaceMenuComponent);
component = fixture.componentInstance;
fixture.detectChanges();
});
it('should create', () => {
expect(component).toBeTruthy();
});
});
|