首页
学习
活动
专区
圈层
工具
发布
社区首页 >问答首页 >导入*如(茉莉spyOn)不可写

导入*如(茉莉spyOn)不可写
EN

Stack Overflow用户
提问于 2018-11-14 09:27:31
回答 3查看 8.3K关注 0票数 17

升级到babel 7.1.5之后,当我使用import * as时,我的测试失败了。

test.spec.js

代码语言:javascript
复制
import * as Helper from "../../../../src/renderer/modules/Helper";

describe('Testing', () => {
    it('Should import correctly', () => {
        console.log(Helper.test()) // a
        spyOn(Helper, 'test').and.returnValue('b');
    });
});

Helper.js

代码语言:javascript
复制
function test() {
    return 'a'
}

export {test}

错误

代码语言:javascript
复制
'Upgrade.spec.js (7:8)', 'a'

Error: <spyOn> : test is not declared writable or has no setter
Usage: spyOn(<object>, <methodName>)
    at <Jasmine>
    at UserContext.it (webpack:///./test/unit/specs/renderer/Upgrade.spec.js?:7:5)
    at <Jasmine>
EN

回答 3

Stack Overflow用户

回答已采纳

发布于 2019-02-21 12:25:46

来源:webpack 4模块可以配置成允许茉莉花监视其成员吗?

还有spyOnProperty,它允许通过将accessType参数设置为'get‘来将属性视为只读。

你的设置看起来就像

代码语言:javascript
复制
import * as mod from 'my/module';
//...
const funcSpy = jasmine.createSpy('myFunc').and.returnValue('myMockReturnValue');
spyOnProperty(mod, 'myFunc', 'get').and.returnValue(funcSpy);
票数 14
EN

Stack Overflow用户

发布于 2020-02-18 00:34:04

我也遇到过同样的问题,唯一的解决办法就是使用巴贝尔插件-重新布线

我已经创建了一个非常基本的回购这里,如果可以的话。

以下是主要文件:

  • src/index.js
代码语言:javascript
复制
function bar() {
  return 42;
}

export function foo() {
  const result = bar();
  return result;
}
  • test/index_test.js
代码语言:javascript
复制
import { foo, __RewireAPI__ as RewireAPI } from '../src/index';

describe('test foo', () => {
  it('should call bar', () => {
    const barSpy = jasmine.createSpy('bar');
    RewireAPI.__Rewire__('bar', barSpy);
    foo();
    expect(barSpy).toHaveBeenCalledWith();
  });
});
  • karma.conf.js
代码语言:javascript
复制
module.exports = function (config) {
  config.set({

    // base path that will be used to resolve all patterns (eg. files, exclude)
    basePath: '',

    // frameworks to use
    // available frameworks: https://npmjs.org/browse/keyword/karma-adapter
    frameworks: ['jasmine'],

    // list of files / patterns to load in the browser
    files: ['test/index_test.js'],

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

    // preprocess matching files before serving them to the browser
    // available preprocessors: https://npmjs.org/browse/keyword/karma-preprocessor
    preprocessors: {
      'test/**/*.js': ['webpack', 'sourcemap'],
    },

    webpack: {
      mode: 'development',
      devtool: 'inline-source-map',
      module: {
        rules: [
          {
            test: /src\/.+\.js$/,
            use: {
              loader: 'babel-loader',
              options: {
                presets: ['@babel/preset-env'],
                plugins: ['rewire'],
              },
            },
          },
        ],
      },
    },

    // test results reporter to use
    // possible values: 'dots', 'progress'
    // available reporters: https://npmjs.org/browse/keyword/karma-reporter
    reporters: ['progress'],

    // web server port
    port: 9876,

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

    // level of logging
    // 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
    // available browser launchers: https://npmjs.org/browse/keyword/karma-launcher
    // browsers: ['Chrome'],
    browsers: ['MyHeadlessChrome'],

    customLaunchers: {
      MyHeadlessChrome: {
        base: 'ChromeHeadless',
        flags: ['--remote-debugging-port=9333'],
      },
    },

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

    // Concurrency level
    // how many browser should be started simultaneous
    concurrency: Infinity,
  });
};
  • package.json
代码语言:javascript
复制
{
  "name": "webpack-karma-spy",
  "version": "1.0.0",
  "description": "",
  "main": "index.js",
  "scripts": {
    "test": "./node_modules/karma/bin/karma start"
  },
  "keywords": [],
  "author": "",
  "license": "ISC",
  "devDependencies": {
    "@babel/core": "^7.8.4",
    "@babel/preset-env": "^7.8.4",
    "babel-loader": "^8.0.6",
    "babel-plugin-rewire": "^1.2.0",
    "eslint": "^6.8.0",
    "eslint-config-airbnb-base": "^14.0.0",
    "eslint-plugin-import": "^2.20.1",
    "jasmine": "^3.5.0",
    "karma": "^4.4.1",
    "karma-chrome-launcher": "^3.1.0",
    "karma-jasmine": "^3.1.1",
    "karma-sourcemap-loader": "^0.3.7",
    "karma-webpack": "^4.0.2",
    "webpack": "^4.41.6"
  }
}
票数 1
EN

Stack Overflow用户

发布于 2021-06-11 20:35:32

解决这个问题的最简单方法是在要导入的模块周围创建一个包装器。茉莉花的导入系统似乎有一个bug,当被监视时,它会导致导出的函数失败。下面是一个可以工作的nanoid包的示例。

创建一个包装器。

代码语言:javascript
复制
import {nanoid} from "nanoid";

export const idGenerator = {
  create: () => {
    return nanoid();
  },
}

然后在你的测试间谍和正常情况下。

代码语言:javascript
复制
import {idGenerator} from "path-to-id-generator";

// Calling this will override the implementation
spyOn(idGenerator, 'create').and.returnValue('custom-id');
票数 0
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/53296840

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档