enzymejs/enzyme

importing the wrong file gives `type is invalid` error from React

eshanCV opened this issue · 4 comments

All common issues

I have created a styled-components in a sperate file with the same name and .css.jsx for example Abc.jsx have Abc.css.jsx and it's imported to the Abc.jsx to use. But when I try to test Abc.jsx I get the below error from the mount,

Current behavior

gives error when trying to mount,

Warning: React.createElement: type is invalid -- expected a string (for built-in components) or a class/function (for composite components) but got: undefined. You likely forgot to export your component from the file it's defined in, or you might have mixed up default and named imports.

Expected behavior

Should be able to mount it without any issue

Your environment

React 17, Next.js 11.1, Jest 26.4.2, enzyme 3.11.0, styled-components 5.3.0, @wojtekmaj/enzyme-adapter-react-17 0.6.2

API

  • mount

Version

library version
enzyme 3.11.0
react 17.0.2
react-dom 17.0.2
react-test-renderer
adapter (below) 0.6.2

Adapter

  • enzyme-adapter-react-17 | 0.6.2

This isn't an enzyme problem. It means the "Foo" in <Foo /> is undefined, which means you have an importing problem. Perhaps it's a default export and you're using named imports, or the reverse?

Please provide the full test and component code.

@ljharb below is the code,

Is this something to do with the enzyme-adapter-react-17

Abc.jsx

import * as Styled from './Abc.css';

function Abc() {
  return (<Styled.Title>ABC</ Styled.Title>);
}

export default Abc

Abc.css.jsx

import styled from 'styled-components';

export const Title = styled.div`
`;

Abc.test.js

import Abc from '../../../components/Abc';
import { mount } from 'enzyme';

describe("My Abc tests", () => {

    let wrapper;

    beforeAll(() => {
        wrapper = mount(<Abc />);
    })

    test("check api call", async () => {
        

    })

});

There is no react 17 adapter; you must be using an unofficial one. enzyme is not currently supported with react 17.

I believe the issue is that you’re importing a file named “a.css.jsx” and omitting the extension. My guess is Babel or typescript is assuming you mean a file named literally “a.css” and thus, Title is undefined.

Yes, importing as a.css.jsx fixed the issue. Thanks