UNPKG

@nx/expo

Version:

The Expo Plugin for Nx contains executors and generators for managing and developing an expo application within your workspace. For example, you can directly build for different target platforms as well as generate projects and publish your code.

88 lines (86 loc) 3.64 kB
"use strict"; Object.defineProperty(exports, "__esModule", { value: true }); exports.addJest = addJest; const devkit_1 = require("@nx/devkit"); const path_1 = require("path"); const update_tsconfig_files_1 = require("../update-tsconfig-files"); const versions_1 = require("../versions"); const version_utils_1 = require("../version-utils"); async function addJest(host, unitTestRunner, projectName, appProjectRoot, js, skipPackageJson, addPlugin) { if (unitTestRunner !== 'jest') { return () => { }; } const { configurationGenerator } = (0, devkit_1.ensurePackage)('@nx/jest', versions_1.nxVersion); const jestTask = await configurationGenerator(host, { js, project: projectName, supportTsx: true, skipSerializers: true, setupFile: 'react-native', compiler: 'babel', skipPackageJson, skipFormat: true, addPlugin, }); // Check if using Expo v54 to determine Jest configuration approach const useExpoV54 = await (0, version_utils_1.isExpoV54)(host); // Overwrite the jest.config.ts file because react native needs to have special transform property // use preset from https://github.com/expo/expo/blob/main/packages/jest-expo/jest-preset.js // Workaround issue where Jest is not picking tyope node nor jest types from tsconfig by using <reference>. const configPath = `${appProjectRoot}/jest.config.${js ? 'js' : 'cts'}`; // For Expo v54, we don't use the custom resolver - instead we mock ImportMetaRegistry in test-setup const resolverLine = useExpoV54 ? '' : "resolver: require.resolve('./jest.resolver.js'),\n "; const content = `/// <reference types="jest" /> /// <reference types="node" /> module.exports = { displayName: '${projectName}', ${resolverLine}preset: 'jest-expo', moduleFileExtensions: ['ts', 'js', 'html', 'tsx', 'jsx'], setupFilesAfterEnv: ['<rootDir>/src/test-setup.${js ? 'js' : 'ts'}'], moduleNameMapper: { '\\\\.svg$': '@nx/expo/plugins/jest/svg-mock' }, transform: { '\\\\.[jt]sx?$': [ 'babel-jest', { configFile: __dirname + '/.babelrc.js', }, ], '^.+\\\\.(bmp|gif|jpg|jpeg|mp4|png|psd|svg|webp|ttf|otf|m4v|mov|mp4|mpeg|mpg|webm|aac|aiff|caf|m4a|mp3|wav|html|pdf|obj)$': require.resolve( 'jest-expo/src/preset/assetFileTransformer.js' ), }, coverageDirectory: '${(0, devkit_1.offsetFromRoot)(appProjectRoot)}coverage/${appProjectRoot}' };`; host.write(configPath, content); if (useExpoV54) { // For Expo v54, generate test-setup with ImportMetaRegistry mock and structuredClone polyfill const testSetupPath = `${appProjectRoot}/src/test-setup.${js ? 'js' : 'ts'}`; const testSetupContent = `jest.mock('expo/src/winter/ImportMetaRegistry', () => ({ ImportMetaRegistry: { get url() { return null; }, }, })); if (typeof global.structuredClone === 'undefined') { global.structuredClone = (object) => JSON.parse(JSON.stringify(object)); } `; host.write(testSetupPath, testSetupContent); } else { // For Expo v53, generate the Jest resolver file from template (0, devkit_1.generateFiles)(host, (0, path_1.join)(__dirname, 'files'), appProjectRoot, { projectName, coverageDirectory: `${(0, devkit_1.offsetFromRoot)(appProjectRoot)}coverage/${appProjectRoot}`, js, }); // Update tsconfig files to handle jest.resolver.js properly (only for v53) (0, update_tsconfig_files_1.updateTsConfigFiles)(host, projectName, appProjectRoot); } return jestTask; }