blob: 0ef9c5b594f235bb637c57a041adabe5269b1839 [file] [log] [blame]
/*
* Copyright 2019-present Open Networking 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.
*/
import { async, ComponentFixture, TestBed } from '@angular/core/testing';
import { ActivatedRoute, Params } from '@angular/router';
import { of } from 'rxjs';
import { HttpClient } from '@angular/common/http';
import { BrowserAnimationsModule } from '@angular/platform-browser/animations';
import * as d3 from 'd3';
import { TopologyComponent } from './topology.component';
import {
Instance,
InstanceComponent
} from '../panel/instance/instance.component';
import { SummaryComponent } from '../panel/summary/summary.component';
import { ToolbarComponent } from '../panel/toolbar/toolbar.component';
import { DetailsComponent } from '../panel/details/details.component';
import {Intent, TopologyService} from '../topology.service';
import {
FlashComponent,
QuickhelpComponent,
FnService,
LogService,
IconService, IconComponent, PrefsService, KeysService, LionService, ZoomableDirective
} from '../../../gui2-fw-lib/public_api';
import {RouterTestingModule} from '@angular/router/testing';
import {TrafficService} from '../traffic.service';
import {ForceSvgComponent} from '../layer/forcesvg/forcesvg.component';
import {DraggableDirective} from '../layer/forcesvg/draggable/draggable.directive';
import {MapSelectorComponent} from '../panel/mapselector/mapselector.component';
import {BackgroundSvgComponent} from '../layer/backgroundsvg/backgroundsvg.component';
import {FormsModule, ReactiveFormsModule} from '@angular/forms';
import {MapSvgComponent} from '../layer/mapsvg/mapsvg.component';
import {GridsvgComponent} from '../layer/gridsvg/gridsvg.component';
import {LinkSvgComponent} from '../layer/forcesvg/visuals/linksvg/linksvg.component';
import {DeviceNodeSvgComponent} from '../layer/forcesvg/visuals/devicenodesvg/devicenodesvg.component';
import {SubRegionNodeSvgComponent} from '../layer/forcesvg/visuals/subregionnodesvg/subregionnodesvg.component';
import {HostNodeSvgComponent} from '../layer/forcesvg/visuals/hostnodesvg/hostnodesvg.component';
import {LayoutService} from '../layout.service';
import {BadgeSvgComponent} from '../layer/forcesvg/visuals/badgesvg/badgesvg.component';
class MockActivatedRoute extends ActivatedRoute {
constructor(params: Params) {
super();
this.queryParams = of(params);
}
}
class MockHttpClient {}
class MockTopologyService {
init(instance: InstanceComponent) {
instance.onosInstances = [
<Instance>{
'id': 'inst1',
'ip': '127.0.0.1',
'reachable': true,
'online': true,
'ready': true,
'switches': 4,
'uiAttached': true
},
<Instance>{
'id': 'inst1',
'ip': '127.0.0.2',
'reachable': true,
'online': true,
'ready': true,
'switches': 3,
'uiAttached': false
}
];
}
destroy() {}
setSelectedIntent(selectedIntent: Intent): void {}
selectRelatedIntent(ids: string[]): void {}
cancelHighlights(): void {}
}
class MockIconService {
loadIconDef() { }
}
class MockKeysService {
quickHelpShown: boolean = true;
keyHandler: {
viewKeys: any[],
globalKeys: any[]
};
mockViewKeys: Object[];
constructor() {
this.mockViewKeys = [];
this.keyHandler = {
viewKeys: this.mockViewKeys,
globalKeys: this.mockViewKeys
};
}
keyBindings(x) {
return {};
}
gestureNotes() {
return {};
}
}
class MockTrafficService {
init(force: ForceSvgComponent) {}
destroy() {}
}
class MockLayoutService {}
class MockPrefsService {
listeners: ((data) => void)[] = [];
getPrefs() {
return { 'topo2_prefs': ''};
}
addListener(listener: (data) => void): void {
this.listeners.push(listener);
}
removeListener(listener: (data) => void) {
this.listeners = this.listeners.filter((obj) => obj !== listener);
}
setPrefs(name: string, obj: Object) {
}
}
/**
* ONOS GUI -- Topology View -- Unit Tests
*/
// Skipping temporarily
describe('TopologyComponent', () => {
let fs: FnService;
let ar: MockActivatedRoute;
let windowMock: Window;
let logServiceSpy: jasmine.SpyObj<LogService>;
let component: TopologyComponent;
let fixture: ComponentFixture<TopologyComponent>;
const bundleObj = {
'core.fw.QuickHelp': {
test: 'test1',
tt_help: 'Help!'
}
};
const mockLion = (key) => {
return bundleObj[key] || '%' + key + '%';
};
beforeEach(() => {
const logSpy = jasmine.createSpyObj('LogService', ['info', 'debug', 'warn', 'error']);
ar = new MockActivatedRoute({ 'debug': 'txrx' });
windowMock = <any>{
location: <any>{
hostname: 'foo',
host: 'foo',
port: '80',
protocol: 'http',
search: { debug: 'true' },
href: 'ws://foo:123/onos/ui/websock/path',
absUrl: 'ws://foo:123/onos/ui/websock/path'
}
};
fs = new FnService(ar, logSpy, windowMock);
TestBed.configureTestingModule({
imports: [
BrowserAnimationsModule,
RouterTestingModule,
FormsModule,
ReactiveFormsModule
],
declarations: [
TopologyComponent,
InstanceComponent,
SummaryComponent,
ToolbarComponent,
DetailsComponent,
FlashComponent,
IconComponent,
QuickhelpComponent,
ForceSvgComponent,
LinkSvgComponent,
DeviceNodeSvgComponent,
HostNodeSvgComponent,
DraggableDirective,
ZoomableDirective,
SubRegionNodeSvgComponent,
MapSelectorComponent,
BackgroundSvgComponent,
MapSvgComponent,
GridsvgComponent,
BadgeSvgComponent
],
providers: [
{ provide: FnService, useValue: fs },
{ provide: LogService, useValue: logSpy },
{ provide: 'Window', useValue: windowMock },
{ provide: HttpClient, useClass: MockHttpClient },
{ provide: TopologyService, useClass: MockTopologyService },
{ provide: TrafficService, useClass: MockTrafficService },
{ provide: LayoutService, useClass: MockLayoutService },
{ provide: IconService, useClass: MockIconService },
{ provide: PrefsService, useClass: MockPrefsService },
{ provide: KeysService, useClass: MockKeysService },
{ provide: LionService, useFactory: (() => {
return {
bundle: ((bundleId) => mockLion),
ubercache: new Array(),
loadCbs: new Map<string, () => void>([])
};
})
},
]
}).compileComponents();
logServiceSpy = TestBed.get(LogService);
});
beforeEach(() => {
fixture = TestBed.createComponent(TopologyComponent);
component = fixture.componentInstance;
fixture.detectChanges();
});
it('should create', () => {
expect(component).toBeTruthy();
});
});