angular - 尝试从 Angular 应用程序中的服务模拟后端结果的 Karma 测试错误

标签 angular testing karma-jasmine integration

我有一个小型测试服务,我试图在我的集成测试中模拟结果。该服务被注入(inject)到页面的构造函数中,并像这样在 ngOnInit 方法中调用。

import { Component, OnInit } from '@angular/core';
import { TodoService } from './todo.service'

@Component({
  selector: 'app-todos',
  templateUrl: './todos.component.html',
  styleUrls: ['./todos.component.css']
})
export class TodosComponent implements OnInit {
  todos;
  message; 

  constructor(private service: TodoService) {}

  ngOnInit() { 
    this.service.getTodos().subscribe(t => this.todos = t);
  }

我正在尝试创建一个集成测试以确认组件中的代码编写正确。该服务返回一个对象数组类型的可观察对象,因此我创建了这样的测试。

describe('TodosComponent', () => {
  let component: TodosComponent;
  let fixture: ComponentFixture<TodosComponent>;

  beforeEach(async(() => {
    TestBed.configureTestingModule({
      imports: [ HttpClientModule],
      declarations: [ TodosComponent ],
      providers: [TodoService]
    })
    .compileComponents();
  }));

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

  it('should create', () => {
    expect(component).toBeTruthy();
  });

  it('should load todos from the server', () => {
    let svc = TestBed.get(TodoService);

    let todoData = [
      {id: 1, title: 'todo 1'},
      {id: 2, title: 'todo 2'},
      {id: 3, title: 'todo 3'}
  ];

    spyOn(svc, 'getTodos').and.returnValues(todoData);

    // This statement causes the ngOnInit method to get called
    fixture.detectChanges();

    expect(component.todos.length).toBe(3);
    expect(component.todos).toBe(todoData);
  });
});

当我运行此测试时,出现以下错误: 第一个错误出现两次 - 不知道为什么..

zone.js:3272 Access to XMLHttpRequest at 'ng:///DynamicTestModule/TodosComponent_Host.ngfactory.js' from origin 'http://localhost:9876' has been blocked by CORS policy: Cross origin requests are only supported for protocol schemes: http, data, chrome, chrome-extension, https.


TypeError: this.service.getTodos(...).subscribe is not a function
    at TodosComponent../src/app/2-todos/todos.component.ts.TodosComponent.ngOnInit (_karma_webpack_/webpack:/src/app/2-todos/todos.component.ts:16)
    at checkAndUpdateDirectiveInline (_karma_webpack_/webpack:/node_modules/@angular/core/fesm5/core.js:22099)
    at checkAndUpdateNodeInline (_karma_webpack_/webpack:/node_modules/@angular/core/fesm5/core.js:23363)
    at checkAndUpdateNode (_karma_webpack_/webpack:/node_modules/@angular/core/fesm5/core.js:23325)
    at debugCheckAndUpdateNode (_karma_webpack_/webpack:/node_modules/@angular/core/fesm5/core.js:23959)
    at debugCheckDirectivesFn (_karma_webpack_/webpack:/node_modules/@angular/core/fesm5/core.js:23919)
    at Object.eval [as updateDirectives] (VM723 TodosComponent_Host.ngfactory.js:9)
    at Object.debugUpdateDirectives [as updateDirectives] (_karma_webpack_/webpack:/node_modules/@angular/core/fesm5/core.js:23911)
    at checkAndUpdateView (_karma_webpack_/webpack:/node_modules/@angular/core/fesm5/core.js:23307)
    at callWithDebugContext (_karma_webpack_/webpack:/node_modules/@angular/core/fesm5/core.js:24177)

服务方法看起来像这样......

 getTodos() {
    let todoData = [
      {id: 1, title: 'todo 1'},
      {id: 2, title: 'todo 2'},
      {id: 3, title: 'todo 3'}
    ];
    return Observable.create(todoData);

  }

我正在学习教程,他们的测试运行正常。他们使用的是旧版本的 Angular - 我相信是 4。 My Karma、Angular 是最新的稳定版本。如果有人可以帮助解释如何解决这个问题,我将永远感激不已。

最佳答案

哇,有时看东西太久,你会忘记自己在做什么。问题出在 spyOn 调用上——它没有返回可观察对象,我认为是。将代码更改为此解决了我的问题。

    spyOn(svc, 'getTodos').and.returnValue(
      of(todoData)
    );

关于angular - 尝试从 Angular 应用程序中的服务模拟后端结果的 Karma 测试错误,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/55952827/

相关文章:

unit-testing - 有什么工具可以记录单元测试的Java对象吗?

Angular Testing 抛出错误

javascript - Karma - 我可以使用脚本标签代替 karma.config.files 吗?

angularjs - Jasmine - 任何 bool 值 (jasmine.any(Boolean))

jquery - Angular 2 从 Jquery 调用 Typescript 函数导致未捕获的 TypeError

javascript - 模型不会因模糊事件而更新

asp.net-mvc - 是否有工具可以自动执行/强调对我网站的 POST 调用以进行测试?

c# - 如果一个测试用例在通过 VSTS 运行相关测试时失败,则整个测试套件将失败

html - 当我开始在输入区输入值时,函数立即触发

angular - 如何在 Angular 4 中导入 jquery-ui