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

TypeError:React.createContext 不是 ApolloContext 和 Jest 的函数

如何解决TypeError:React.createContext 不是 ApolloContext 和 Jest 的函数

我正在尝试为我使用 apollo+graphql 的 TS+NextJS 应用程序测试一些带有玩笑的打字稿代码。 Unfornautley,我收到错误

TypeError: React.createContext is not a function

来自以下节点模块:

getApolloContext (node_modules/@apollo/client/react/context/ApolloContext.js:7:25)

当我在 Stack Overflow 上的其他问题上查看此错误时,它说 react 版本已过时,但我的 package.json 中的 react 版本是

"react": "^17.0.1",

所以我不确定是什么导致了这个问题。似乎由于某种原因,类型检查失败,或者在该节点模块中使用了旧版本的 react 而不是项目范围的,这似乎不正确。

到目前为止我尝试过的是:

更新我的 react 和 react-dom 节点模块(什么都不做)

非常执着于除此之外要做的事情。

代码在这里

test.tsx

import * as React from 'react';
import { render } from '@testing-library/react'
import DonePage from '../pages/done'

describe('Pages',() => {
  describe('Index',() => {
    it('Pages render',function testCases() {
        render(<DonePage apolloClient={{}} apolloState={{}}/>)
    })
  })
})

export {}

page.tsx

import * as React from 'react';
import { withApollo } from 'apollo'
{...}

const DonePage: NextPage<{}> = () => {
  return (
    <>
        {...}
    </>
  )
}

export default withApollo(DonePage,{ ssr: false })

其中 withApollohttps://github.com/apollographql/apollo-client/issues/5089 中的代码

我正在使用 jest --runInBand

运行测试

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