首页
学习
活动
专区
圈层
工具
发布
社区首页 >问答首页 >用jest和react测试连接的组件.测试.库

用jest和react测试连接的组件.测试.库
EN

Stack Overflow用户
提问于 2020-10-08 12:05:41
回答 1查看 1.4K关注 0票数 1

我要测试连接的反应元件。我正在使用Jest,React测试库和redux-模拟商店。当我试图获得一些元素时,我会得到一个错误:

TestingLibraryElementError:无法找到文本: Test的元素。这可能是因为文本被多个元素分解。在这种情况下,您可以为文本匹配器提供一个函数,以使匹配器更加灵活。

package.json

代码语言:javascript
复制
"redux-mock-store": "^1.5.4",
"typescript": "^3.9.7",
"@testing-library/jest-dom": "^5.11.4",
"@testing-library/react": "^11.0.4",
"@types/jest": "^26.0.13",
"@types/redux-mock-store": "^1.0.2",
"jest": "^26.4.2",
"ts-jest": "^26.3.0",
"react-redux": "5.0.7",
"react-router-dom": "^5.1.2",
"redux": "3.7.2",

Header.tsx

代码语言:javascript
复制
import React, { FunctionComponent, useEffect } from "react";
import { Box, Grid, Link } from "@material-ui/core";
import { AppState } from "../../redux/reducers/IndexReducer";
import { AppDispatch } from "../../redux/actions/Actions";
import { connect } from "react-redux";
import { getSettingsUi } from "../../redux/actions/SidebarActions";
import { SettingsUi } from "../../redux/reducers/SidebarMenuReducer";

interface Props {
    settingsUi: SettingsUi;
}

export interface Events {
    initUiSettings(): void;
}

const Header: FunctionComponent<Props & Events> = props => {
    const { settingsUi } = props as Props;
    const { initUiSettings } = props as Events;

    useEffect(() => {
        initUiSettings();
    }, []);

    return (
        <Grid item className="header">
            <Grid container alignItems="center" justify="space-between">
                <Grid item>
                    <Link href="#">
                        <Box fontWeight={700} fontSize={18}>
                            {settingsUi && settingsUi.title}
                        </Box>
                    </Link>
                    <Box>{settingsUi && settingsUi.subtitle}</Box>
                </Grid>
            </Grid>
        </Grid>
    );
};

const mapStateToProps = (state: AppState): Props => ({
    settingsUi: state.sidebar.settingsUi!,
});

const mapDispatchToProps = (dispatch: AppDispatch): Events => ({
    initUiSettings: () => dispatch(getSettingsUi()),
});

export default React.memo(connect(mapStateToProps, mapDispatchToProps)(Header));

Header.test.tsx

代码语言:javascript
复制
import React from "react";
import { render } from "@testing-library/react";
import { Provider } from "react-redux";
import Header from "../../components/header/Header";
import configureMockStore from "redux-mock-store";
import thunk from "redux-thunk";

const middlewares = [thunk];
const mockStore = configureMockStore(middlewares);
const store = mockStore({
    sidebar: { toggle: false },
    settingsUi: { title: "Test" },
});

describe("<Header/>", () => {
    it("test title", () => {
        const { getByText } = render(
            <Provider store={store}>
                <Header />
            </Provider>,
        );
        expect(getByText("Test")).toBeInTheDocument();
    });
});
EN

回答 1

Stack Overflow用户

回答已采纳

发布于 2020-10-08 12:12:57

mapStateToProps函数中,settingsUisidebar属性的属性。

代码语言:javascript
复制
const mapStateToProps = (state: AppState): Props => ({
    settingsUi: state.sidebar.settingsUi!,
});

要么是mapStateToProps使用了错误的选择器,要么是您的模拟存储错误。

代码语言:javascript
复制
const mapStateToProps = (state: AppState): Props => ({
    settingsUi: state.settingsUi!,
});

代码语言:javascript
复制
const store = mockStore({
    sidebar: { toggle: false, settingsUi: { title: "Test" } }
});
票数 0
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/64262162

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档