React testing library: The given element does not have a value setter when fireEvent change on input form

前端 未结 3 1426
盖世英雄少女心
盖世英雄少女心 2021-02-12 09:27

I want to change the value of material UI TextField in react testing library. I already set up the data-testid. Then using getByTestId i picked up the

相关标签:
3条回答
  • 2021-02-12 10:16

    the issue here is when we use Material UI, it renders the TextField component having one of the elements inside it as an input field. And only "input" has getter and setter on it. So after you got the TextField, you have to get the "input" element of your TextField using querySelector() of your DOM object.

    const field = getByTestId('input-email').querySelector('input');
    // now fire your event
    fireEvent.change(field, { target: { value: 'abcd@xyz.com' } });
    
    0 讨论(0)
  • 2021-02-12 10:25

    You can use fireEvent.change on an element that supports that event like <input>. In your case, I'm not sure what you're selecting. You can try to debug(userInput) to see what it returns.

    0 讨论(0)
  • 2021-02-12 10:32

    Problem here is TextField is an abstraction in MaterialUI. It consists of FormControl, Label and Input. Clean way of solving this problem is:

    • First, add InputProps on your TextField, with data-testid attribute.
    // YourComponent.js
    
    <TextField
      onChange={event => setContent(event.target.value)}
      id="content"
      inputProps={{ "data-testid": "content-input" }}
      value={content}
      label="Content"
    />
    
    • Then simply query using this ID.
    // YourComponent.test.js
    
    const contentInput = getByTestId("content-input");
    fireEvent.change(contentInput, {
      target: { value: "new content" }
    });
    
    // and then assert stuff in here
    
    0 讨论(0)
提交回复
热议问题