桶进口似乎打破了装载顺序

awi*_*man 2 jasmine typescript systemjs angular

我有一个要进行单元测试的组件,但我不断收到这些错误,具体取决于我的导入语句:

Error: Cannot resolve all parameters for 'MyComponent'(undefined, FormBuilder).

TypeError: Cannot read property 'toString' of undefined
Run Code Online (Sandbox Code Playgroud)

我的组件需要 2 个参数,一个是 FormBuilder,一个是自定义服务,必须注入:

import {MyService} from '../';

@Component({
    ...,
    providers: [MyService]
})
class MyComponent {
    constructor(service: MyService, fb: FormBuilder) { ... }
    ...
}
Run Code Online (Sandbox Code Playgroud)

我的单元测试设置如下:

import {MyComponent} from './';
import {MyService} from '../';

describe('Component: MyComponent', () => {

    let builder: TestComponentBuilder;

    beforeEachProviders(() => [
        MyService,
        MyComponent
    ]);

    beforeEach(inject([TestComponentBuilder], function (tcb: TestComponentBuilder) {
        builder = tcb;
    }));

    it('should inject the component', inject([MyComponent],      
        (component: MyComponent) => {
            expect(component).toBeTruthy();
        })
    );

}
Run Code Online (Sandbox Code Playgroud)

进口似乎是问题所在,因为我正在尝试使用桶:

|
|- my-component
|  |- index.ts
|  |- my.component.ts
|  |- my.component.spec.ts
|
|- my-service
|  |- index.ts
|  |- my.service.ts
|
|- index.ts
Run Code Online (Sandbox Code Playgroud)

在我的 index.ts 文件中,我正在做:

export * from '<filename>';
export * from '<directory>';
Run Code Online (Sandbox Code Playgroud)

作为适当的。

但是,当我更改单元测试和组件中的导入以直接引用服务文件时,单元测试有效。

import {MyService} from '../my-service/my.service';
Run Code Online (Sandbox Code Playgroud)

我在这个项目中使用 angular-cli 并且 SystemJS 正在使用生成的配置文件进行配置:

...
const barrels: string[] = [
  ...,

  // App specific barrels.
  'app',
  'app/my-service',
  'app/my-component'
  /** @cli-barrel */
];

const cliSystemConfigPackages: any = {};
barrels.forEach((barrelName: string) => {
  cliSystemConfigPackages[barrelName] = { main: 'index' };
});

/** Type declaration for ambient System. */
declare var System: any;

// Apply the CLI SystemJS configuration.
System.config({
  map: {
    '@angular': 'vendor/@angular',
    'rxjs': 'vendor/rxjs',
    'main': 'main.js'
  },
  packages: cliSystemConfigPackages
});
...
Run Code Online (Sandbox Code Playgroud)

似乎当我从桶中导入时,组件和服务定义没有在单元测试代码之前加载。无论哪种方式,应用程序本身都会进行编译和运行。

对不起,如果这是一个广泛的问题,但我对桶和 SystemJS 仍然很陌生,我不知道如何进一步缩小范围:

这是 SystemJS/Jasmine/TypeScript/Angular2 的错误还是我在设置中做错了什么?

Mic*_*ael 6

我必须查看您要从中进口的桶的内容才能确定,但​​听起来您需要更改桶内出口的顺序。

angular2 存储库中存在一个问题:https : //github.com/angular/angular/issues/9334

如果组件 (A) 从包含 A 和 B 的出口的桶中进口和使用服务/组件 (B),并且桶中 A 出现在 B 之前,则 B 的进口值是不确定的。

因此,在您的情况下,如果您将根 index.ts 修改为以下内容,您应该能够从您的桶中导入。

export * from my-service;
export * from my-component;
Run Code Online (Sandbox Code Playgroud)