茉莉花单元测试抽象类

vbp*_*p13 8 unit-testing jasmine angular

有没有办法为抽象组件创建茉莉花单元测试?

const fixture = TestBed.createComponent(MyAbstractComponent);
Run Code Online (Sandbox Code Playgroud)

说,"不能将抽象构造函数类型赋给非抽象构造函数类型"

我尝试了一些搜索但没有出现.

sho*_*ukh 12

您可以在测试文件中创建一个简单的类,它从抽象类扩展(不要忘记模拟抽象方法),而不仅仅是测试它的非抽象方法.假设我们有MyAbstractClass:

export abstract class MyAbstractClass {
  sum(a: number, b: number): number {
    return a + b;
  }

  abstract calc1(): void;
  abstract calc2(): void;
}
Run Code Online (Sandbox Code Playgroud)

然后在spec文件中我们可以创建一个新的派生类:

class MyClass extends MyAbstractClass {
  // just mock any abstract method
  calc1(): void {
    return;
  }
  calc2(): void {
    return;
  }
}
Run Code Online (Sandbox Code Playgroud)

所以现在我们可以为非抽象方法编写测试:

describe('MyAbstractClass', () => {
  let myClass: MyClass;
  beforeEach(() => {
    myClass = new MyClass();
  });

  it('sum two args', () => {
    const a = 1, b = 2;

    const sum = myClass.sum(a, b);

    expect(sum).toBe(3);
  });
});
Run Code Online (Sandbox Code Playgroud)

还创建了此测试示例的stackblitz示例.