- html - 出于某种原因,IE8 对我的 Sass 文件中继承的 html5 CSS 不友好?
- JMeter 在响应断言中使用 span 标签的问题
- html - 在 :hover and :active? 上具有不同效果的 CSS 动画
- html - 相对于居中的 html 内容固定的 CSS 重复背景?
问题
为了更好地说明,我创建了一个非常基本的代码示例。这是我要测试的代码(包含简单的 react Hook ):
const TodoHeader = ({ handleSubmit }) => {
const [value, setValue] = useState("");
return (
<form onSubmit={handleSubmit} data-testid="form">
<input
type="text"
placeholder="Your Todo.."
onChange={e => setValue(e.target.value)}
value={value}
data-testid="input"
/>
</form>
);
};
我想测试传入的 handleSubmit
属性是否会被执行。所以我设置了这个测试:
it("should call the passed in onSubmit function", () => {
const mockFn = jest.fn();
const { getByTestId } = render(
<TodoHeader handleSubmit={mockFn} />
);
const form = getByTestId("form");
fireEvent.submit(form);
// This will fail (did not get executed)
expect(mockFn).toHaveBeenCalled();
});
和react hooks有关系吗?我也尝试重新渲染它,但结果相同。我不知道为什么这不会通过。错误信息是:
Expected mock function to have been called, but it was not called.
这里有一个代码框,如果你想玩的话:
https://codesandbox.io/s/ypok50n709(TodoHeader.js
和 TodoHeader.test.js
)
最佳答案
看起来这是一个简单的问题,cleanup
实际上并没有在 afterEach
中被调用。这意味着在第二次测试期间在 document
中呈现了两个 form
元素,并且 getByTestId
返回第一个。
改变
afterEach(() => cleanup)
要么
afterEach(() => cleanup())
或者只是
afterEach(cleanup)
关于reactjs - 为什么 jest mock 函数没有在我的 react 测试库测试中执行?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/54579077/
我正在使用 Gunicorn 为 Django 应用程序提供服务,它工作正常,直到我将其超时时间从 30 秒更改为 900000 秒,我不得不这样做,因为我有一个用例需要上传和处理一个巨大的文件(过程
我有一个带有非常基本的管道的Jenkinsfile,它可以旋转docker容器: pipeline { agent { dockerfile { args '-u root' } } stag
在学习 MEAN 堆栈的过程中,我遇到了一个问题。每当我尝试使用 Passport 验证方法时,它都不会返回任何响应。我总是收到“localhost没有发送任何数据。ERR_EMPTY_RESPONS
在当今的大多数企业堆栈中,数据库是我们存储所有秘密的地方。它是安全屋,是待命室,也是用于存储可能非常私密或极具价值的物品的集散地。对于依赖它的数据库管理员、程序员和DevOps团队来说,保护它免受所
是否可以创建像图片上那样的边框?只需使用 css 边框属性。最终结果将是没 Angular 盒子。我不想添加额外的 html 元素。我只想为每个 li 元素添加 css 边框信息。 假设这是一个 ul
我是一名优秀的程序员,十分优秀!