【发布时间】:2021-10-23 20:16:17
【问题描述】:
我有一个来自 JS 类的实例“客户端”,如下所示:
class Client {
async fetchRandomUser() {
let response = await fetch("https://randomuser.me/api/?gender=male")
if (response.status >= 400) {
throw new Error("Error fetching random user");
}
return (await response.json()).results[0];
}
}
然后我有一个这样的 React 组件:
import React from 'react';
import client from "./service/Client";
class Person extends React.Component {
constructor(props) {
super(props);
this.state = {image: ''}
}
async componentDidMount() {
const user = await client.fetchRandomUser();
this.setState({image: user.picture.large});
}
setError(error) {
return this.setState({errorStatus: error});
}
render() {
return (
<img src={this.state.image} width="128" height="128"/>
);
}
}
export default Person;
还有一个测试:
import React from "react";
import { render, screen, waitFor } from '@testing-library/react';
import Person from './Person';
test('fetches image from random user API', async () => {
const mockFetchRandomUser = jest.fn().mockImplementation(async () => Promise.resolve({picture:{large: 'personImage'}}));
jest.mock("./service/Client", () => {
return {
fetchRandomUser: mockFetchRandomUser
};
});
const {container} = render(<Person data-testid="person"/>);
const image = screen.getByRole('img');
await waitFor(() => expect(image.src !== "").toBeTruthy())
.then(() => {
screen.debug(image);
expect(mockFetchRandomUser).toHaveBeenCalledTimes(1);
});
});
在这个测试中,我无法让 waitFor 或 findByRole 或任何与此相关的东西等到标签获得它的 src 属性集。我该怎么做?
【问题讨论】:
-
您是否尝试过使用
await waitFor(() => expect(image).toHaveAttribute('src', 'personImage'))?
标签: javascript reactjs jestjs react-testing-library