Ошибка углового 5 модульного тестирования для теста "компоненты должны создать" - PullRequest
0 голосов
/ 04 декабря 2018

Я впервые пробую Angular 5.Пока я уже создал приложение, решил запустить в нем тестирование.Но я получаю эти ошибки:

AppComponent should create the app
AppComponent should have as title 'app'
AppComponent should render title in a h1 tag
GalleryComponent should create
UploadComponent should create

и подробности ошибки, такие как:

Failed: Template parse errors:
'app-upload' is not a known element:
1. If 'app-upload' is an Angular component, then verify that it is part of this module.
2. If 'app-upload' is a Web Component then add 'CUSTOM_ELEMENTS_SCHEMA' to the '@NgModule.schemas' of this component to suppress this message. (" class="row">
        <div class="col-md-3" style="padding:5%; box-sizing: border-box">
            [ERROR ->]<app-upload></app-upload>
        </div>
        <div class="col-md-9">
"): ng:///DynamicTestModule/AppComponent.html@3:12

Мои зависимости package.json dev:

devDependencies": {
    "@angular/compiler-cli": "^6.0.2",
    "@angular-devkit/build-angular": "~0.6.3",
    "typescript": "~2.7.2",
    "@angular/cli": "~6.0.3",
    "@angular/language-service": "^6.0.2",
    "@types/jasmine": "2.8.6",
    "@types/jasminewd2": "~2.0.3",
    "@types/node": "~8.9.4",
    "codelyzer": "~4.2.1",
    "jasmine-core": "~2.99.1",
    "jasmine-spec-reporter": "~4.2.1",
    "karma": "~1.7.1",
    "karma-chrome-launcher": "~2.2.0",
    "karma-coverage-istanbul-reporter": "~1.4.2",
    "karma-jasmine": "~1.1.1",
    "karma-jasmine-html-reporter": "^0.2.2",
    "protractor": "~5.3.0",
    "ts-node": "~5.0.1",
    "tslint": "~5.9.1"
  } 

Тестовый файл приложения.component.spec.ts

import { TestBed, async } from '@angular/core/testing';
import { AppComponent } from './app.component';
describe('AppComponent', () => {
  beforeEach(async(() => {
    TestBed.configureTestingModule({
      declarations: [
        AppComponent
      ],
    }).compileComponents();
  }));
  it('should create the app', async(() => {
    const fixture = TestBed.createComponent(AppComponent);
    const app = fixture.debugElement.componentInstance;
    expect(app).toBeTruthy();
  }));
  it(`should have as title 'app'`, async(() => {
    const fixture = TestBed.createComponent(AppComponent);
    const app = fixture.debugElement.componentInstance;
    expect(app.title).toEqual('app');
  }));
  it('should render title in a h1 tag', async(() => {
    const fixture = TestBed.createComponent(AppComponent);
    fixture.detectChanges();
    const compiled = fixture.debugElement.nativeElement;
    expect(compiled.querySelector('h1').textContent).toContain('Welcome to Typito-photo-app!');
  }));
});

Я не мог понять, как их решить.Я не вносил никаких изменений в файлы спецификаций и не писал тестовых случаев.Разве все они не должны работать так, как ожидалось, в соответствии с тем, что описано в угловой документации?

Ответы [ 2 ]

0 голосов
/ 04 декабря 2018

Компонент, который вы хотите протестировать, имеет один или несколько child components.Хорошей практикой является игнорирование этих компонентов и их тестирование отдельно.

Способ архивации заключается в том, чтобы сообщить вашему угловому Testbed, что нужно пропустить их во время сборки компонента, используя NO_ERRORS_SCHEMA внутри вашего Testbed.

, на котором должен выглядеть ваш испытательный стенд.как это:

TestBed.configureTestingModule({
            declarations: [
                AppComponent
            ],
            schemas: [
                NO_ERRORS_SCHEMA
            ]
        }).compileComponents();

И он должен игнорировать все пользовательские элементы (теги), которые появляются в вашем component.html.

Другой способ - это издеваться над вашими дочерними компонентами.например, как это

0 голосов
/ 04 декабря 2018

Вы должны убедиться, что компонент доступен:

 beforeEach(() => {
    fixture = TestBed.createComponent(AppComponent);
    component = fixture.componentInstance;
});

it('should be created', () => {
    fixture.detectChanges();
    expect(component)
        .toBeTruthy();
});

Также вы должны внедрить любые зависимости в тестовый модуль при написании тестов.

Добро пожаловать на сайт PullRequest, где вы можете задавать вопросы и получать ответы от других членов сообщества.
...