/*! * @license * Copyright 2019 Alfresco Software, Ltd. * * 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 { Component } from '@angular/core'; import { By } from '@angular/platform-browser'; import { TranslateModule } from '@ngx-translate/core'; import { TestBed, ComponentFixture } from '@angular/core/testing'; import { setupTestBed } from '../testing/setup-test-bed'; import { CoreTestingModule } from '../testing/core.testing.module'; import { VersionCompatibilityService } from '../services/version-compatibility.service'; import { VersionModel } from '../models/product-version.model'; @Component({ template: `
My hidden content 1
My hidden content 2
My hidden content 3
My visible content 1
My visible content 2
My visible content 3
` }) class TestComponent { } describe('VersionCompatibilityDirective', () => { let fixture: ComponentFixture; let versionCompatibilityService: VersionCompatibilityService; const acsResponceMock = new VersionModel({ display: '7.0.1', major: '7', minor: '0', patch: '1' }); setupTestBed({ imports: [ TranslateModule.forRoot(), CoreTestingModule ], declarations: [TestComponent] }); beforeEach(() => { fixture = TestBed.createComponent(TestComponent); versionCompatibilityService = TestBed.inject(VersionCompatibilityService); spyOn(versionCompatibilityService, 'getAcsVersion').and.returnValue(acsResponceMock); }); it('should display component when the version is supported', () => { fixture.detectChanges(); const element1 = fixture.debugElement.query(By.css('[class="visible-content-1"]')); const element2 = fixture.debugElement.query(By.css('[class="visible-content-2"]')); const element3 = fixture.debugElement.query(By.css('[class="visible-content-3"]')); expect(element1).toBeDefined(); expect(element2).toBeDefined(); expect(element3).toBeDefined(); }); it('should hide component when the version is not supported', () => { fixture.detectChanges(); const element1 = fixture.debugElement.query(By.css('[class="hidden-content-1"]')); const element2 = fixture.debugElement.query(By.css('[class="hidden-content-2"]')); const element3 = fixture.debugElement.query(By.css('[class="hidden-content-3"]')); expect(element1).toBeNull(); expect(element2).toBeNull(); expect(element3).toBeNull(); }); });