4

I'm using React-18.0.0 in my project and in the test file I'm getting an error something below

createRoot(...): Target container is not a DOM element.

My test file is :

import ReactDOM from 'react-dom/client';
import { render, screen } from "@testing-library/react";
import App from "./App";

const root = ReactDOM.createRoot(document.getElementById("root"));

test("renders learn react link", () => {
    root.render(<App />);
    const linkElement = screen.getByText(/Hello React/i);
    expect(linkElement).toBeInTheDocument();
});
0stone0
  • 34,288
  • 4
  • 39
  • 64
KARTHIKEYAN.A
  • 18,210
  • 6
  • 124
  • 133
  • This article helped me. I was using the ID in my App.js but its the root ID in the index.html file - https://bobbyhadz.com/blog/react-createroot-target-container-not-dom-element – Sambuxc Apr 06 '22 at 14:59

1 Answers1

2

Your test uses root.render(<App />) while React's testing-library provides there own render function to use inside a test

Retrieving the root isn't needed, and is causing the error you're showing.

So, apply the following change:

// Remove
root.render(<App />);

// Replace with
render(<App />);  // Imported from @testing-library/react

Example of working App.test.js:

import { render, screen } from '@testing-library/react';
import App from './App';

test('renders learn react link', () => {
    render(<App />);
    const linkElement = screen.getByText(/this should exist/i);
    expect(linkElement).toBeInTheDocument();
});
0stone0
  • 34,288
  • 4
  • 39
  • 64