Polling mechanism to get jobs
[portal/nonrtric-controlpanel.git] / webapp-frontend / src / app / ei-coordinator / ei-coordinator.component.spec.ts
index 59b09e9..38e3fa5 100644 (file)
  * limitations under the License.
  * ========================LICENSE_END===================================
  */
-import { async, ComponentFixture, TestBed } from '@angular/core/testing';
+import { ComponentFixture, TestBed } from '@angular/core/testing';
+import { BrowserAnimationsModule } from '@angular/platform-browser/animations'
+import { CUSTOM_ELEMENTS_SCHEMA } from '@angular/core';
+import { HarnessLoader } from '@angular/cdk/testing';
+import { MatButtonModule } from '@angular/material/button';
+import { MatButtonHarness } from '@angular/material/button/testing';
+import { MatIconModule } from '@angular/material/icon';
+import { MatTableModule } from '@angular/material/table';
+import { TestbedHarnessEnvironment } from '@angular/cdk/testing/testbed';
 
 import { EICoordinatorComponent } from './ei-coordinator.component';
+import { UiService } from '@services/ui/ui.service';
+import { ProducersListComponent } from '@ei-coordinator/producers-list/producers-list.component';
+import { JobsListComponent } from '@ei-coordinator/jobs-list/jobs-list.component';
+import { MockComponent } from 'ng-mocks';
+import { By } from '@angular/platform-browser';
 
 describe('EICoordinatorComponent', () => {
   let component: EICoordinatorComponent;
   let fixture: ComponentFixture<EICoordinatorComponent>;
+  let loader: HarnessLoader;
 
-  beforeEach(async(() => {
-    TestBed.configureTestingModule({
-      declarations: [ EICoordinatorComponent ]
+  beforeEach(async () => {
+
+    await TestBed.configureTestingModule({
+      imports: [
+        MatButtonModule,
+        MatIconModule,
+        MatTableModule,
+        BrowserAnimationsModule
+      ],
+      schemas: [
+        CUSTOM_ELEMENTS_SCHEMA
+      ],
+      declarations: [
+        EICoordinatorComponent,
+        MockComponent(JobsListComponent),
+        MockComponent(ProducersListComponent),
+      ],
+      providers: [
+        UiService
+      ]
     })
-    .compileComponents();
-  }));
+      .compileComponents();
 
-  beforeEach(() => {
     fixture = TestBed.createComponent(EICoordinatorComponent);
     component = fixture.componentInstance;
+
     fixture.detectChanges();
+    loader = TestbedHarnessEnvironment.loader(fixture);
+  });
+
+  it('should create', () => {
+    expect(component).toBeTruthy();
+  });
+
+  describe('#content', () => {
+    it('should contain refresh button with correct icon', async () => {
+      let refreshButton = await loader.getHarness(MatButtonHarness.with({ selector: '#refreshButton' }));
+      expect(refreshButton).toBeTruthy();
+      expect(await refreshButton.getText()).toEqual('refresh');
+    });
+
+    it('should contain producers table', async () => {
+      const producersTableComponent = fixture.debugElement.nativeElement.querySelector('nrcp-producers-list');
+      expect(producersTableComponent).toBeTruthy();
+    });
+
+    it('should contain jobs table', async () => {
+      const jobsComponent = fixture.debugElement.nativeElement.querySelector('nrcp-jobs-list');
+      expect(jobsComponent).toBeTruthy();
+    });
+
+    it('should set correct dark mode from UIService', () => {
+      const uiService: UiService = TestBed.inject(UiService);
+      expect(component.darkMode).toBeTruthy();
+
+      uiService.darkModeState.next(false);
+      fixture.detectChanges();
+      expect(component.darkMode).toBeFalsy();
+
+    });
+
+    it('should refresh tables', async () => {
+      let refreshButton = await loader.getHarness(MatButtonHarness.with({ selector: '#refreshButton' }));
+
+      const jobsComponent: JobsListComponent = fixture.debugElement.query(By.directive(JobsListComponent)).componentInstance;
+      spyOn(jobsComponent, 'refreshDataClick');
+      spyOn(jobsComponent, 'clearFilter');
+
+      const prodsComponent: ProducersListComponent = fixture.debugElement.query(By.directive(ProducersListComponent)).componentInstance;
+      spyOn(prodsComponent, 'loadProducers');
+      spyOn(prodsComponent, 'clearFilter');
+
+      await refreshButton.click();
+
+      expect(jobsComponent.refreshDataClick).toHaveBeenCalled();
+      expect(jobsComponent.clearFilter).toHaveBeenCalled();
+      expect(prodsComponent.loadProducers).toHaveBeenCalled();
+      expect(prodsComponent.clearFilter).toHaveBeenCalled();
+
+    });
   });
 });