React Native,不变违规:本机模块不能为空。(指向OneSignal模块)

3

我正在使用Jest+Enzyme为一个使用OneSignal的React Native应用编写测试。

这里可能有一个类似的问题(我想):https://github.com/facebook/jest/issues/2208,但这个问题很旧了,我已经按照那里的解决方案做了,但是都没有起作用。

起初,我在运行jest时遇到了这个错误:

home/nrion/Desktop/mobile-ui/PriceInsight_app/node_modules/react-native-onesignal/index.js:4
    import { NativeModules, NativeEventEmitter, NetInfo, Platform } from 'react-native';
    ^^^^^^

    SyntaxError: Unexpected token import

    > 1 | import OneSignal from 'react-native-onesignal';
      2 | 
      3 | export const STORE_TIMEFRAME = 'STORE_TIMEFRAME';
      4 | export const STORE_TIMEFRAMES = 'STORE_TIMEFRAMES';

      at ScriptTransformer._transformAndBuildScript (../../../../../usr/lib/node_modules/jest-cli/node_modules/jest-runtime/build/script_transformer.js:316:17)
      at Object.<anonymous> (src/actions/subscription.js:1:387)
      at Object.<anonymous> (src/reducers/subscription.js:1:402)

所以我已经将react-native-onesignal添加到package.json中:

"transformIgnorePatterns": [
      "node_modules/(?!(react-native-onesignal|react-native-login|react-native-elements)/)"
    ]

那解决了我的问题。但是又来了一个问题:
 Invariant Violation: Native module cannot be null.

    > 1 | import OneSignal from 'react-native-onesignal';
      2 | 
      3 | export const STORE_TIMEFRAME = 'STORE_TIMEFRAME';
      4 | export const STORE_TIMEFRAMES = 'STORE_TIMEFRAMES';

      at invariant (node_modules/fbjs/lib/invariant.js:42:15)
      at new NativeEventEmitter (node_modules/react-native/Libraries/EventEmitter/NativeEventEmitter.js:37:31)
      at Object.<anonymous> (node_modules/react-native-onesignal/index.js:9:33)

我尝试模拟OneSignal,但是当我这样做时会发生以下情况:

 Cannot find module 'OneSignal' from 'Main.test.js'

    > 1 | import React from 'react'
      2 | import { shallow } from '../../jest-setup'
      3 | import configureStore from 'redux-mock-store'
      4 | import OneSignal from 'react-native-onesignal'

      at Resolver.resolveModule (../../../../../usr/lib/node_modules/jest-cli/node_modules/jest-resolve/build/index.js:169:17)
      at Object.<anonymous> (src/__tests__/Main.test.js:1:108)

这个问题困扰了我好几个小时!希望能得到一些指导。

2个回答

3
所以事实证明我的模型是错误的。正确的应该是:
jest.mock('react-native-onesignal', () => ({
  addEventListener: jest.fn(),
  removeEventListener: jest.fn(),
  inFocusDisplaying: jest.fn()
}))

正如这个帖子所指出的:https://github.com/facebook/jest/issues/6382#issuecomment-394104956

该帖子讨论了一个关于IT技术方面的问题。

0

我认为你缺少了 babel-jest 作为依赖项。Jest 默认不使用 babel,因此无法理解 ES6 的导入语法。

编辑: 我还认为存在另一个问题,你还需要模拟 react-native 中的 NativeEventEmitter。如果你能提供你正在尝试测试的代码,那会很有帮助。


网页内容由stack overflow 提供, 点击上面的
可以查看英文原文,
原文链接