SystemJs和jasmine spyOn错误"模块导出无法在外部更改"

时间:2017-03-13 14:01:08

标签: javascript webpack jasmine aurelia jspm

我正在使用webpack + aurelia进行项目,最近切换到JSPM版本0.16.52。我将jasmine的spyOn用于导入到我的类中的实用程序或工厂函数。但是,spyOn(object, 'method')的测试会出现此错误:

"Module Exports Cannot Be Changed Externally"

当jasmine在模块obj[methodName] = spiedMethod'

上设置spied方法时会发生这种情况

这是一个非常简单的例子:

test.js

import * as env from '../../src/env';

describe('stackoverflow example', () => {

  it('runs the test', () => {
    // this gets thrown and swallowed. jasmine does not report an error, but does not increase the test count.
    let envSpy = spyOn(env, 'getBaseUrl');
  });

});

env.js

export function getBaseUrl(location) {
  return location.port ? `http://${location.hostname}:9001/api/`: '/api/';
}

karam.conf.js

'use strict'
const path = require('path')

module.exports = function(config) {
  config.set({

    // base path that will be used to resolve all patterns
    basePath: __dirname,

    // frameworks to use
    frameworks: ['jspm', 'jasmine'],

    // list of files / patterns to load in the browser
    files: [],

    // list of files to exclude
    exclude: [],

    jspm: {
      // Edit this to your needs
      loadFiles: [
        'test/unit/setup.js',
        'test/unit/**/*.js'
      ],
      serveFiles: [
        'src/**/*.*',
        'jspm_packages/system-polyfills.js'
      ],
      paths: {
        '*': 'src/*',
        'test/*': 'test/*',
        'github:*': 'jspm_packages/github/*',
        'npm:*': 'jspm_packages/npm/*'
      }
    },

    // preprocess matching files before serving them to the browser
    preprocessors: {
      'test/**/*.js': ['babel'],
      'src/**/*.js': ['babel']
    },
    'babelPreprocessor': {
      options: {
        sourceMap: 'inline',
        presets: [ ['es2015', { loose: true }], 'stage-1'],
        plugins: [
          'syntax-flow',
          'transform-decorators-legacy',
          'transform-flow-strip-types',
          [ 'istanbul', { 'ignore': 'test/' } ]
        ]
      }
    },

    // test results reporter to use
    reporters: ['mocha'],

    // web server port
    port: 9876,

    // enable / disable colors in the output (reporters and logs)
    colors: true,

    // possible values: config.LOG_DISABLE || config.LOG_ERROR || config.LOG_WARN || config.LOG_INFO || config.LOG_DEBUG
    logLevel: config.LOG_INFO,

    // enable / disable watching file and executing tests whenever any file changes
    autoWatch: true,

    // start these browsers
    browsers: ['Chromium'],

    // Continuous Integration mode
    // if true, Karma captures browsers, runs the tests and exits
    singleRun: false
  });
};

设置,JS

import 'babel-polyfill'; // for async/await
import 'aurelia-polyfills';
import {initialize} from 'aurelia-pal-browser';
initialize();

更新

当我拿下Aurelia-esnext的新副本时,我没有收到错误。所以在我的生产应用程序和第一个spyOn工作中注释掉了我的所有测试,但随着我添加了更多测试,我开始再次收到错误,这似乎是systemjs加载模块的方式。下面是导入的模块对象在加载到测试中时的外观

新鲜副本不会抛出

{
  __esModule: true,
  getBaseUrl: (),
  __proto__: Object
}

投掷的原件

{
  __esModule: (...)
  get __esModule: ()
  set __esModule: ()
  getBaseUrl: (...)
  get getBaseUrl: ()
  set getBsaeUrl: ()
  _proto__: Object
}

更新 我在system.js中找到了代码片段,其中导入的差异发生了。在我较大的原始项目loader.defined[name];中返回undefined并定义了aurelia loader.defined[name];的新副本...仍然没有找到解决方法

system.src.js

function getModule(name, loader) {
    var exports;
    var entry = loader.defined[name];

    if (!entry) {
      exports = loader.get(name);
      if (!exports)
        throw new Error('Unable to load dependency ' + name + '.');
    }

    else {
      if (entry.declarative)
        ensureEvaluated(name, entry, [], loader);

      else if (!entry.evaluated)
        linkDynamicModule(entry, loader);

      exports = entry.module.exports;
    }

    if ((!entry || entry.declarative) && exports && exports.__useDefault)
      return exports['default'];

    return exports;
  }

0 个答案:

没有答案