getByTestID 不适用于自定义组件

getByTestID not working for custom component

正在为大型组件编写单元测试。我之前为一个较小的组件编写过一个,但是其中嵌套了其他几个自定义组件。我正在尝试 select 它以便我可以弄清楚如何处理它,但我现在甚至无法做到这一点。

MainComponent.tsx

这是组件呈现的内容的一部分。 PriceOverrideDateRange 是另一个自定义组件,我正在尝试使用 testID 来定位它
       <Counter
        />
              <MainComponentRange testID='range' />
        <Counter
        />

MainComponent.test.tsx

这是我正在进行的测试的一部分
  it('should be able to change the ranfe', () =>{



    //Mock out dependent function with jest
    //Nothing here right now...

    //Render with the props you want
    const { getByTestId } = render(        
          <MainComponent />

);

    //Locate screen components for test
    const range = getByTestId('range');


    //Perform user actions
    fireEvent.changeText(range, "01/22/2022");


    //Measure against expect cases
    expect(dateRange).toBe("1/22/2022");

  });

这是我收到的错误消息:

  ● Main Component Test › should be able to change the range

    Unable to find an element with testID: dateRange

      143 |
      144 |     //Locate screen components for test
    > 145 |     const dateRange = getByTestId('range');
          |                       ^
      146 |
      147 |

您需要将 testID 作为 props 传递给组件,然后将其添加到您正在使用的视图中我将添加一个简单的示例。

const App = () => {
  return <PriceOverrideDateRange testID="dateRange" />
}
const PriceOverrideDateRange = ({testID}) => {
  return <View testID="dateRange" ><Text>Hello</Text></View>
}