unit-testing - 模拟命名导出以使用 Jest 进行测试

标签 unit-testing mocking jestjs

我有一个 Helper.js具有以下几个辅助函数的文件,这些函数正在不同的组件中使用。

    export function buildOptions(elem) { 
        var oList=[];   
        for (var i=0; i < field.length; i++) {
            oList.push (
              <option value={options[i]["id"]}>
                  {options[i][elem]}
              </option>
            )
         }    
         return oList;
      }

      export function B(){
           .....
      }

这是一个使用 Helper.js 中定义的函数的组件。文件。我正在为组件编写测试,我想模拟这里调用的外部函数。

    import React from 'react';
    import ReactDOM from 'react-dom';
    import { buildOptions, A} from './Helper.js';

    class DemoComponent extends React.Component {
        constructor(props) {
            super(props);
        }

        add(e, index) {
            ....
        }


        render() {
            var o_list=buildOptions("name");

            return (
               <div>
                  ...
                  <select required className={selectClass}  >
                      {o_list}
                  </select>  
                  ...           
                  <button type="button" onClick={(e) => this.add(e, this.props.index)}>
                        Add 
                  </button>
               </div>
            );
         };
     }

我是 Jest/Enzyme 的新手,我无法弄清楚如何模拟外部函数 buildOptions。我无法弄清楚如何模拟外部 buildOptions 函数。任何人都可以帮我解决这个问题。
这是我的测试代码:

import React from 'react';
import { mount, shallow } from 'enzyme';
import { buildOptions } from '../components/Helper.js';
import DemoComponent from '../components/DemoComponent';

describe('Democomponent', () => {

  it('should render required elements', () => {

    const wrapper = shallow(
       <DemoComponent 
        index={0}/> 
    );
    //
    tests
}); 

最佳答案

既然你要模拟一个命名的导出函数 , 有一个特殊的技巧涉及 使用 * 导入所有命名导出在你的测试之前。

// your test file
import * as Helper from './Helper.js';

const originalBuildOptions = Helper.buildOptions;
Helper.buildOptions = jest.fn();

beforeEach(() => {
  jest.clearAllMocks();
  // Reset to original implementation before each test
  Helper.buildOptions.mockImplementation(originalBuildOptions);
});

test('my test', () => {
  // Mock for this test only (will be restored by next `beforeEach` call)
  Helper.buildOptions.mockImplementation(() => 'your mock');
}); 

关于unit-testing - 模拟命名导出以使用 Jest 进行测试,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/51203516/

相关文章:

node.js - 你如何在 jasmine 测试中模拟 process.platform?

reactjs - 使用 jest.fn 时,值必须是模拟或 spy 函数

database - 在 Go 中模拟数据库/sql 结构

.net - 使 NUnit 在第一次失败时不停止

unit-testing - 单元测试 mGo

c++ - 为什么 GMOCK 对象不返回依赖注入(inject)中 EXPECT_CALL 设置的值

unit-testing - Golang使用动态函数调用模拟函数

javascript - 如何在 Jest 测试中为无状态函数的输入文本元素设置值

css - Jest 在 typescript 中遇到了意外的标记

javascript - 用 Jest 在 javascript 中模拟类原型(prototype)