与 cucumberjs 的反应集成

React integration with cucumberjs

我正在研究 React-Nextjs 项目并尝试集成 BDD 工具 cucumber 以进行规范和功能级别测试。虽然在使用 enzyme 浅渲染组件时将 cucumber 与 React 集成时遇到了一些麻烦:

这是我收到的错误: TypeError: Cannot read property 'contextTypes' of undefinedconst wrapper = shallow(<Referrer/>);

黄瓜步骤测试文件代码:

import React from 'react';
import { defineSupportCode } from "cucumber";
import { shallow } from "enzyme";
import {Referrer} from "./../../components/Referrer";

defineSupportCode(({ Given, When, Then }) => {
    Given("I want to do something", function (callback) {
        // Write code here that turns the phrase above into concrete actions
        callback();
    });

    When("Xyz link is clicked", function (callback) {
        const wrapper = shallow(<Referrer/>);
        ... // Write code here that turns the phrase above into concrete actions
    });

    Then("Appropriate action happens", function (callback) {
        // Write code here that turns the phrase above into concrete actions
        callback();
    });
});

该组件是一个简单的 UI 组件,非常简单,这是它的结构:

import React from "react"; // eslint-disable-line no-unused-vars

export default class Referrer extends React.Component {
    render () {
        return (
            <div className="some-class" id="some-id">
              // html tags
              <style jsx>{`
                .some-class {
                  //styling
                }

                .some-class2 {
                  //styling
                }
              `}
              </style>
            </div>
        );
    }
}

我正在使用 "cucumber": "^2.3.1""enzyme": "^2.6.0",我不确定如何解决这个问题,目前在线上没有任何帮助,过去几个小时我一直在尝试调试,但没有成功。

确切的错误片段:

Warning: React.createElement: type is invalid -- expected a string (for built-in components) or a class/function (for composite components) but got: undefined. You likely forgot to export your component from the file it's defined in.

TypeError: Cannot read property 'contextTypes' of undefinedconst wrapper = shallow(<Referrer/>);

我意识到出了什么问题,我的 Referrer 组件正在默认导出,但我没有正确导入它。我必须将其导入为 import Referrer from "./../../components/Referrer"; 而不是 import {Referrer} from "./../../components/Referrer";