仅出于测试目的导出函数是否被认为是一种不好的做法?

Fai*_*med 5 javascript testing design-patterns node.js reactjs

我有这个问题,尤其是在阅读了关于测试 React 组件的官方 redux 文档后:

https://github.com/reduxjs/redux/blob/master/docs/recipes/WritingTests.md

为了能够在不处理装饰器的情况下测试 App 组件本身,我们建议您也导出未装饰的组件

即使是著名的https://www.reactboilerplate.com/ 也导出了命名为未连接的组件,只是为了能够在不模拟商店的情况下测试它们。

但是,仅仅为了使事情更容易测试而导出某些东西不是被认为是坏事吗?

在某些情况下,开发人员可能会错误地导入并引入错误,只是因为从文件中导出了两件事。

所以,问题本质上是:

我们可以对实际代码进行更改以使测试更容易吗?

虽然这个问题是针对 React 的,但如果知道其他语言或框架是否有类似的问题以及如何处理这些问题,那就太好了。

dee*_* zg 4

您始终可以根据您的环境进行有条件导出。

就像是:

export default connect(mstp, mdtp)(component1);

export let tests = {
  component1,
  component2,
  ...
};

if (process.env.NODE_ENV !==   "test") {
  tests = undefined;
}
Run Code Online (Sandbox Code Playgroud)

然后在你的测试文件中你做

import { tests} from ".";
const { component1, component2 } = tests;
//now test unconnected components
Run Code Online (Sandbox Code Playgroud)