mirror of
https://github.com/GNS3/gns3-web-ui.git
synced 2025-06-06 09:11:36 +00:00
145 lines
3.9 KiB
TypeScript
145 lines
3.9 KiB
TypeScript
import { async, ComponentFixture, TestBed } from '@angular/core/testing';
|
|
import { AddBlankProjectDialogComponent } from './add-blank-project-dialog.component';
|
|
import { Server } from '../../../models/server';
|
|
import { ReactiveFormsModule, FormsModule } from '@angular/forms';
|
|
import {
|
|
MatDialogModule,
|
|
MatInputModule,
|
|
MatFormFieldModule,
|
|
MatDialogRef,
|
|
MAT_DIALOG_DATA,
|
|
MatSnackBarModule
|
|
} from '@angular/material';
|
|
import { NoopAnimationsModule } from '@angular/platform-browser/animations';
|
|
import { ProjectService } from '../../../services/project.service';
|
|
import { ToasterService } from '../../../services/toaster.service';
|
|
import { of } from 'rxjs/internal/observable/of';
|
|
import { Project } from '../../../models/project';
|
|
import { Router } from '@angular/router';
|
|
|
|
export class MockedProjectService {
|
|
public projects: Project[] = [
|
|
{
|
|
auto_close: false,
|
|
auto_open: false,
|
|
auto_start: false,
|
|
filename: 'blank',
|
|
name: 'blank',
|
|
path: '',
|
|
project_id: '',
|
|
scene_height: 100,
|
|
scene_width: 100,
|
|
status: 'opened',
|
|
readonly: false,
|
|
show_interface_labels: false,
|
|
show_layers: false,
|
|
show_grid: false,
|
|
snap_to_grid: false
|
|
}
|
|
];
|
|
|
|
list() {
|
|
return of(this.projects);
|
|
}
|
|
|
|
add() {
|
|
return of(this.projects.pop);
|
|
}
|
|
|
|
isReadOnly(project: Project){
|
|
return false;
|
|
}
|
|
}
|
|
|
|
describe('AddBlankProjectDialogComponent', () => {
|
|
let component: AddBlankProjectDialogComponent;
|
|
let fixture: ComponentFixture<AddBlankProjectDialogComponent>;
|
|
let server: Server;
|
|
let router = {
|
|
navigate: jasmine.createSpy('navigate')
|
|
};
|
|
let toaster = {
|
|
success: jasmine.createSpy('success')
|
|
};
|
|
let dialogRef = {
|
|
close: jasmine.createSpy('close')
|
|
};
|
|
|
|
beforeEach(async(() => {
|
|
TestBed.configureTestingModule({
|
|
imports: [
|
|
MatDialogModule,
|
|
MatFormFieldModule,
|
|
MatInputModule,
|
|
NoopAnimationsModule,
|
|
FormsModule,
|
|
ReactiveFormsModule,
|
|
MatSnackBarModule
|
|
],
|
|
providers: [
|
|
{ provide: MatDialogRef, useValue: dialogRef },
|
|
{ provide: MAT_DIALOG_DATA },
|
|
{ provide: ProjectService, useClass: MockedProjectService },
|
|
{ provide: ToasterService, useValue: toaster },
|
|
{ provide: Router, useValue: router }
|
|
],
|
|
declarations: [AddBlankProjectDialogComponent]
|
|
}).compileComponents();
|
|
|
|
server = new Server();
|
|
server.host = 'localhost';
|
|
server.port = 80;
|
|
}));
|
|
|
|
beforeEach(() => {
|
|
fixture = TestBed.createComponent(AddBlankProjectDialogComponent);
|
|
component = fixture.componentInstance;
|
|
component.server = server;
|
|
component.projectNameForm.controls['projectName'].setValue('ValidName');
|
|
fixture.detectChanges();
|
|
});
|
|
|
|
it('should be created', () => {
|
|
expect(fixture).toBeDefined();
|
|
expect(component).toBeTruthy();
|
|
});
|
|
|
|
it('should call adding project when name is valid', () => {
|
|
spyOn(component, 'addProject');
|
|
|
|
component.onAddClick();
|
|
|
|
expect(component.addProject).toHaveBeenCalled();
|
|
});
|
|
|
|
it('should sanitize file name input', () => {
|
|
component.projectNameForm.controls['projectName'].setValue('[][]');
|
|
fixture.detectChanges();
|
|
spyOn(component, 'addProject');
|
|
|
|
component.onAddClick();
|
|
|
|
expect(component.addProject).not.toHaveBeenCalled();
|
|
expect(component.projectNameForm.valid).toBeFalsy();
|
|
});
|
|
|
|
it('should open confirmation dialog if project with the same exists', () => {
|
|
component.projectNameForm.controls['projectName'].setValue('blank');
|
|
spyOn(component, 'openConfirmationDialog');
|
|
|
|
component.onAddClick();
|
|
|
|
expect(component.openConfirmationDialog).toHaveBeenCalled();
|
|
});
|
|
|
|
it('should redirect to newly created project', () => {
|
|
component.projectNameForm.controls['projectName'].setValue('validName');
|
|
|
|
component.addProject();
|
|
|
|
expect(dialogRef.close).toHaveBeenCalled();
|
|
expect(toaster.success).toHaveBeenCalled();
|
|
expect(router.navigate).toHaveBeenCalled();
|
|
});
|
|
});
|