Karma + JSPM + Typescript - 找不到' .ts.js'

时间:2016-08-18 22:49:15

标签: javascript typescript karma-runner jspm karma-coverage

主要是试图让Karma + JSPM在加载.ts文件时发挥出色,但绝对没有运气。

我看到一个discussion repo,其中包含一个精简的示例。

基本上,Karma中的JSPM在Karma中运行时似乎忽略了defaultJSExtensions: true和包级别"defaultExtension": "ts"配置,在尝试加载文件时出现以下错误:

$ npm test

> karma-jspm-typescript-coverage@1.0.0 test C:\examples\karma-jspm-typescript-coverage
> karma start

18 08 2016 17:29:31.937:INFO [karma]: Karma v1.2.0 server started at http://localhost:1337/
18 08 2016 17:29:31.943:INFO [launcher]: Launching browser Chrome with unlimited concurrency
18 08 2016 17:29:31.974:INFO [launcher]: Starting browser Chrome
18 08 2016 17:29:33.075:INFO [Chrome 52.0.2743 (Windows 7 0.0.0)]: Connected on socket /#jTR10wm0CWNIfrdhAAAA with id 75197348
18 08 2016 17:29:33.317:WARN [web-server]: 404: /src/app/app.spec.ts.js
Chrome 52.0.2743 (Windows 7 0.0.0) ERROR
  Error: (SystemJS) XHR error (404 Not Found) loading http://localhost:1337/src/app/app.spec.ts.js
        Error: XHR error (404 Not Found) loading http://localhost:1337/src/app/app.spec.ts.js
        Error loading http://localhost:1337/src/app/app.spec.ts.js

npm ERR! Test failed.  See above for more details.

请注意 .ts.js 扩展程序。尝试从karma-typescript-proprocessor到通过不同的JSPM配置进行加载,而不是使用live进行加载。

尝试保留它,以便不需要管理.js已编译的文件,只能使用.ts文件。开发服务器和捆绑/构建功能齐全 - 这个测试和覆盖范围是我的最后一个障碍。

如果有任何方向可以给我,请告诉我!

1 个答案:

答案 0 :(得分:1)

包级别"defaultExtension": "ts"不适用,因为karma正在顶级目录中运行,高于src目录的一级,其中包含带有

的config.js
baseURL: '.'

如果我复制app软件包配置,其前面加src,就像这样:

  packages: {
    "src/app": {
      "main": "app",
      "defaultExtension": "ts",
      "meta": {
        "*.ts": {
          "loader": "ts"
        }
      }
    },
    "app": {
      "main": "app",
      "defaultExtension": "ts",
      "meta": {
        "*.ts": {
          "loader": "ts"
        }
      }
    }
  },

我能够更进一步。我现在正在

Error: (SystemJS) XHR error (404 Not Found) loading http://localhost:9876/jspm_packages/github/frankwallis/plugin-typescript@5.0.9.js

向我表明karma-jspm插件无法在SystemJS期望它们的URL处提供源文件