微信公众号搜"智元新知"关注
微信扫一扫可直接关注哦!

当 TypeScript 阻止我时,如何为测试库的 React Native 组件添加 testId 属性?

如何解决当 TypeScript 阻止我时,如何为测试库的 React Native 组件添加 testId 属性?

我正在使用 TypeScript 编写 React Native 组件并使用 React Native Testing Library 对其进行测试。

我想在 React Native 组件上放置一个 testId 属性,如下所示:

<TextInput testId="foo" />

然后像这样在测试中引用它:

it('receives a search string',() => {
  const { getByTestId } = render(<FooComponent />);;
  const textBox = getByTestId("foo");
  fireEvent.changeText(textBox,"some fake text");
  expect(textBox.value).toEqual("some fake text");
});

但是 TypeScript 不允许我在组件上放置 testId 属性,因为当然,TypeScript 会向 React Native 询问有效属性,而 React Native 对 testId 一无所知; testId 是@testing-library/react-native 的一部分。

如何让 TypeScript 识别来自 @testing-library/react-native 的添加属性,例如 testId

解决方法

发现问题。 testId 应该是 testID。我的错别字很简单。

如果有人发现了这一点,问题不在于 TypeScript 根本不知道 testID 属性。你不需要npm install @types/whatever。它们已被视为安装 RNTL 的一部分。

版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 dio@foxmail.com 举报,一经查实,本站将立刻删除。

相关推荐


Selenium Web驱动程序和Java。元素在(x,y)点处不可单击。其他元素将获得点击?
Python-如何使用点“。” 访问字典成员?
Java 字符串是不可变的。到底是什么意思?
Java中的“ final”关键字如何工作?(我仍然可以修改对象。)
“loop:”在Java代码中。这是什么,为什么要编译?
java.lang.ClassNotFoundException:sun.jdbc.odbc.JdbcOdbcDriver发生异常。为什么?
这是用Java进行XML解析的最佳库。
Java的PriorityQueue的内置迭代器不会以任何特定顺序遍历数据结构。为什么?
如何在Java中聆听按键时移动图像。
Java“Program to an interface”。这是什么意思?