首页
学习
活动
专区
工具
TVP
发布
精选内容/技术社群/优惠产品,尽在小程序
立即前往

React-testing-library + Redux:在"Connect(Currency)“的上下文中找不到"store”

React-testing-library是一个用于测试React组件的工具库,它提供了一套简洁而强大的API,用于模拟用户与组件的交互并进行断言验证。Redux是一个用于管理应用状态的JavaScript库,它提供了可预测的状态容器,使得状态管理变得简单而可靠。

在React应用中使用Redux时,通常会通过react-redux库的connect函数将组件连接到Redux的状态树。在这个问题中,出现了一个错误提示:"Connect(Currency)"的上下文中找不到"store"。这个错误通常表示在测试过程中,没有正确地提供Redux的store给被连接的组件。

解决这个问题的方法是在测试代码中手动创建一个Redux的store,并将其传递给被测试组件的上下文中。可以使用redux-mock-store库来创建一个模拟的store,并使用Provider组件将被测试组件包裹起来,以便正确地提供store。

下面是一个示例代码,展示了如何在React-testing-library中测试一个使用Redux的组件:

代码语言:txt
复制
import React from 'react';
import { render } from '@testing-library/react';
import { Provider } from 'react-redux';
import configureStore from 'redux-mock-store';
import Currency from './Currency';

const mockStore = configureStore([]);

describe('Currency component', () => {
  it('should render currency value from store', () => {
    const initialState = {
      currency: 'USD',
    };
    const store = mockStore(initialState);

    const { getByText } = render(
      <Provider store={store}>
        <Currency />
      </Provider>
    );

    expect(getByText('USD')).toBeInTheDocument();
  });
});

在上面的示例中,我们首先创建了一个模拟的store,并将初始状态传递给它。然后,我们使用Provider组件将被测试的Currency组件包裹起来,并将模拟的store作为store属性传递给Provider。最后,我们使用render函数获取渲染后的组件,并通过getByText函数来断言渲染结果中是否包含了'USD'文本。

这样,我们就可以在React-testing-library中正确地测试使用了Redux的组件,并且可以通过模拟的store来提供所需的上下文环境。

推荐的腾讯云相关产品和产品介绍链接地址:

  • 腾讯云云服务器(CVM):提供灵活可扩展的云服务器实例,满足各种计算需求。产品介绍链接
  • 腾讯云云数据库MySQL版:高性能、可扩展的关系型数据库服务,适用于各种规模的应用。产品介绍链接
  • 腾讯云对象存储(COS):安全可靠的云端存储服务,适用于存储和处理各种类型的数据。产品介绍链接
  • 腾讯云人工智能:提供丰富的人工智能服务和工具,包括图像识别、语音识别、自然语言处理等。产品介绍链接
  • 腾讯云物联网(IoT):提供全面的物联网解决方案,帮助连接和管理物联网设备。产品介绍链接
  • 腾讯云区块链服务(BCS):提供简单易用的区块链服务,帮助构建和管理区块链网络。产品介绍链接
  • 腾讯云视频处理:提供强大的视频处理服务,包括转码、截图、水印、封面生成等功能。产品介绍链接
  • 腾讯云音视频通信(TRTC):提供实时音视频通信能力,支持多人音视频通话和互动直播。产品介绍链接
  • 腾讯云云原生应用引擎(TKE):帮助用户快速构建、部署和管理云原生应用的容器服务。产品介绍链接

以上是腾讯云提供的一些与云计算相关的产品,可以根据具体需求选择合适的产品来支持开发和部署云计算应用。

相关搜索:在“创建可重用的react-redux包时出错”的上下文中找不到"store“React Native + Redux Orm无法在"Connect (截图)“的上下文或道具中找到"store”在“连接(MyComponent)”的上下文中找不到“存储”?Redux-React问题在Jest/React中的“Connect(App)”的上下文或属性中找不到“store”使用提供程序但仍看到错误不变冲突:无法在"Connect“的上下文中找到"store”在“连接(AppComponent)”的上下文中找不到“存储”这个错误有没有解决方法:在"Connect(App)“的上下文中找不到"store”。要么将根组件包装在<Provider>中错误:在“连接(AppProvider)”的上下文中找不到“存储”在一个功能组件中,如何使用react-redux connect访问redux store中的props?在“连接(清除)”的上下文或属性中找不到"store“在Connect()的上下文或属性中找不到提供程序存储在android的父上下文或祖先上下文中找不到方法值(视图):onClick如何修复“在DragSource(组件)的上下文中找不到拖放管理器”在RendezvousChannel应用程序上下文中找不到已注册的Spring beanNameAndIdProvider在ASP.NET Core MVC类的上下文中找不到任何引用在视图类上定义的android:onClick属性的父级或祖先上下文中找不到方法log_out(视图java.lang.IllegalStateException:在视图类上定义的android:onClick属性的父级或祖先上下文中找不到方法计数(视图)找不到错误的实际含义。错误:"(<unknown>):此上下文中不允许在第3行第16列中使用映射值“
相关搜索:
页面内容是否对你有帮助?
有帮助
没帮助

相关·内容

  • react-redux 源码解析一: Provider做了什么,发布订阅模式实现?

    使用过react的同学都知道,redux作为react公共状态管理容器,配合react-redux可以很好的派发更新,更新视图渲染的作用,那么对于react-redux是如何做到根据state的改变,而更新组件,促使视图渲染的呢,让我们一起来探讨一下,react-redux源码的奥妙所在。在正式分析之前我们不妨来想几个问题: 1 为什么要在root跟组件上使用react-redux的provider组件包裹 2 redux是使用store.subscribe()来发布订阅 ,那么react-redux组件更新是否也是用这个模式呢 3 provide 用什么方式存放当前的redux的 store, 又是怎么传递给每一个需要管理state的组件的 带着这些疑问我们不妨先看一下Provider究竟做了什么

    03
    领券