diff --git a/packages/react/src/generators/application/lib/add-e2e.ts b/packages/react/src/generators/application/lib/add-e2e.ts index b699f60384164e..2b58d966331d6b 100644 --- a/packages/react/src/generators/application/lib/add-e2e.ts +++ b/packages/react/src/generators/application/lib/add-e2e.ts @@ -4,12 +4,12 @@ import { ensurePackage, getPackageManagerCommand, joinPathFragments, - readNxJson, } from '@nx/devkit'; import { webStaticServeGenerator } from '@nx/web'; import { nxVersion } from '../../../utils/versions'; import { hasWebpackPlugin } from '../../../utils/has-webpack-plugin'; +import { hasVitePlugin } from '../../../utils/has-vite-plugin'; import { NormalizedSchema } from '../schema'; export async function addE2e( @@ -18,7 +18,10 @@ export async function addE2e( ): Promise { switch (options.e2eTestRunner) { case 'cypress': { - if (!hasWebpackPlugin(tree)) { + if ( + (options.bundler === 'webpack' && !hasWebpackPlugin(tree)) || + (options.bundler === 'vite' && !hasVitePlugin(tree)) + ) { webStaticServeGenerator(tree, { buildTarget: `${options.projectName}:build`, targetName: 'serve-static', diff --git a/packages/react/src/generators/library/__snapshots__/library.spec.ts.snap b/packages/react/src/generators/library/__snapshots__/library.spec.ts.snap index b6537f9624b706..4d4970fca14d7d 100644 --- a/packages/react/src/generators/library/__snapshots__/library.spec.ts.snap +++ b/packages/react/src/generators/library/__snapshots__/library.spec.ts.snap @@ -17,7 +17,6 @@ export default defineConfig({ // }, test: { - reportsDirectory: '../coverage/my-lib', globals: true, cache: { dir: '../node_modules/.vitest' }, environment: 'jsdom', @@ -72,7 +71,6 @@ export default defineConfig({ // External packages that should not be bundled into your library. external: ['react', 'react-dom', 'react/jsx-runtime'], }, - outDir: 'dist/my-lib', }, test: { diff --git a/packages/react/src/utils/has-vite-plugin.ts b/packages/react/src/utils/has-vite-plugin.ts new file mode 100644 index 00000000000000..9430f5030ea075 --- /dev/null +++ b/packages/react/src/utils/has-vite-plugin.ts @@ -0,0 +1,10 @@ +import { readNxJson, Tree } from '@nx/devkit'; + +export function hasVitePlugin(tree: Tree) { + const nxJson = readNxJson(tree); + return !!nxJson.plugins?.some((p) => + typeof p === 'string' + ? p === '@nx/vite/plugin' + : p.plugin === '@nx/vite/plugin' + ); +} diff --git a/packages/vite/migrations.json b/packages/vite/migrations.json index 2c4928c3d57e40..bbca74289a12ee 100644 --- a/packages/vite/migrations.json +++ b/packages/vite/migrations.json @@ -45,11 +45,6 @@ "version": "17.2.0-beta.10", "description": "Update vite config.", "implementation": "./src/migrations/update-17-2-0/update-vite-config" - }, - "add-vite-plugin": { - "version": "17.3.0-beta.0", - "description": "Add @nx/vite/plugin", - "implementation": "./src/migrations/update-17-2-0/add-vite-plugin" } }, "packageJsonUpdates": { diff --git a/packages/vite/src/generators/configuration/__snapshots__/configuration.spec.ts.snap b/packages/vite/src/generators/configuration/__snapshots__/configuration.spec.ts.snap index 14596cdabcf733..b5ffd6de1c1b45 100644 --- a/packages/vite/src/generators/configuration/__snapshots__/configuration.spec.ts.snap +++ b/packages/vite/src/generators/configuration/__snapshots__/configuration.spec.ts.snap @@ -44,7 +44,6 @@ export default defineConfig({ // External packages that should not be bundled into your library. external: ['react', 'react-dom', 'react/jsx-runtime'], }, - outDir: 'dist/react-lib-nonb-jest', }, }); " @@ -94,7 +93,6 @@ export default defineConfig({ // External packages that should not be bundled into your library. external: ['react', 'react-dom', 'react/jsx-runtime'], }, - outDir: 'dist/react-lib-nonb-jest', }, test: { @@ -170,7 +168,6 @@ export default defineConfig({ // External packages that should not be bundled into your library. external: ['react', 'react-dom', 'react/jsx-runtime'], }, - outDir: 'dist/react-lib-nonb-vitest', }, plugins: [ nxViteTsPaths(), diff --git a/packages/vite/src/generators/init/lib/utils.ts b/packages/vite/src/generators/init/lib/utils.ts index 3450adf9f197e4..428693b440f018 100644 --- a/packages/vite/src/generators/init/lib/utils.ts +++ b/packages/vite/src/generators/init/lib/utils.ts @@ -91,17 +91,6 @@ export function createVitestConfig(tree: Tree) { nxJson.namedInputs.production = Array.from(new Set(productionFileSet)); } - nxJson.targetDefaults ??= {}; - nxJson.targetDefaults['@nx/vite:test'] ??= {}; - nxJson.targetDefaults['@nx/vite:test'].cache ??= true; - nxJson.targetDefaults['@nx/vite:test'].inputs ??= [ - 'default', - productionFileSet ? '^production' : '^default', - ]; - nxJson.targetDefaults['@nx/vite:test'].options ??= { - passWithNoTests: true, - }; - updateNxJson(tree, nxJson); } diff --git a/packages/vite/src/generators/vitest/vitest.spec.ts b/packages/vite/src/generators/vitest/vitest.spec.ts index 36b9eb9a42b985..80336aa433bf28 100644 --- a/packages/vite/src/generators/vitest/vitest.spec.ts +++ b/packages/vite/src/generators/vitest/vitest.spec.ts @@ -54,6 +54,9 @@ describe('vitest generator', () => { expect(config.targets['test']).toMatchInlineSnapshot(` { "executor": "@nx/vite:test", + "options": { + "reportsDirectory": "../../coverage/apps/my-test-react-app", + }, "outputs": [ "{options.reportsDirectory}", ], diff --git a/packages/vite/src/migrations/update-17-2-0/add-vite-plugin.spec.ts b/packages/vite/src/migrations/update-17-2-0/add-vite-plugin.spec.ts deleted file mode 100644 index 594340403d9f48..00000000000000 --- a/packages/vite/src/migrations/update-17-2-0/add-vite-plugin.spec.ts +++ /dev/null @@ -1,223 +0,0 @@ -import { createTreeWithEmptyWorkspace } from '@nx/devkit/testing'; -import { - readProjectConfiguration, - Tree, - updateProjectConfiguration, -} from '@nx/devkit'; -import update from './add-vite-plugin'; -import { TempFs } from 'nx/src/internal-testing-utils/temp-fs'; - -jest.mock('vite', () => ({ - loadConfigFromFile: jest.fn().mockImplementation(() => { - return Promise.resolve({ - path: 'vite.config.ts', - config: {}, - dependencies: [], - }); - }), -})); -describe('add-vite-plugin migration', () => { - let tree: Tree; - let tempFs: TempFs; - - describe('not root project', () => { - beforeEach(async () => { - tempFs = new TempFs('test'); - tree = createTreeWithEmptyWorkspace(); - tree.root = tempFs.tempDir; - await tempFs.createFiles({ - 'apps/my-app/vite.config.ts': '', - 'apps/my-app/project.json': '{ "name": "my-app" }', - }); - tree.write('apps/my-app/vite.config.ts', `console.log('hi');`); - }); - - afterEach(() => { - jest.resetModules(); - tempFs.cleanup(); - }); - - it('should remove the serve target', async () => { - updateProjectConfiguration(tree, 'my-app', { - root: 'apps/my-app', - targets: { - serve: { - executor: '@nx/vite:dev-server', - defaultConfiguration: 'development', - options: { - buildTarget: 'build', - }, - configurations: { - development: { - buildTarget: 'build:development', - hmr: true, - }, - production: { - buildTarget: 'build:production', - hmr: false, - }, - }, - }, - }, - }); - - await update(tree); - - expect( - readProjectConfiguration(tree, 'my-app').targets.serve - ).toBeUndefined(); - }); - - it('should remove the serve, serve-static and build target, but keep other targets', async () => { - updateProjectConfiguration(tree, 'my-app', { - root: 'apps/my-app', - targets: { - build: { - executor: '@nx/vite:build', - outputs: ['{options.outputPath}'], - defaultConfiguration: 'production', - options: { - outputPath: 'dist/apps/my-app', - }, - configurations: { - development: { - mode: 'development', - }, - production: { - mode: 'production', - }, - }, - }, - serve: { - executor: '@nx/vite:dev-server', - defaultConfiguration: 'development', - options: { - buildTarget: 'build', - }, - configurations: { - development: { - buildTarget: 'build:development', - hmr: true, - }, - production: { - buildTarget: 'build:production', - hmr: false, - }, - }, - }, - 'preview-custom': { - executor: '@nx/vite:preview-server', - defaultConfiguration: 'development', - options: { - buildTarget: 'build', - }, - configurations: { - development: { - buildTarget: 'build:development', - }, - production: { - buildTarget: 'build:production', - }, - }, - }, - 'test-custom': { - executor: '@nx/vite:test', - outputs: ['{options.reportsDirectory}'], - options: { - passWithNoTests: true, - reportsDirectory: '../../coverage/apps/my-app', - }, - }, - lint: { - executor: '@nx/eslint:lint', - outputs: ['{options.outputFile}'], - options: { - lintFilePatterns: ['apps/my-app/**/*.{ts,tsx,js,jsx}'], - }, - }, - 'serve-static': { - executor: '@nx/web:file-server', - options: { - buildTarget: 'my-app:build', - }, - }, - }, - }); - - await update(tree); - - expect( - readProjectConfiguration(tree, 'my-app').targets.serve - ).toBeUndefined(); - - expect( - readProjectConfiguration(tree, 'my-app').targets.build - ).toBeUndefined(); - - expect( - readProjectConfiguration(tree, 'my-app').targets['preview-custom'] - ).toBeDefined(); - - expect( - readProjectConfiguration(tree, 'my-app').targets['lint'] - ).toBeDefined(); - - expect( - readProjectConfiguration(tree, 'my-app').targets['test-custom'] - ).toBeDefined(); - - expect( - readProjectConfiguration(tree, 'my-app').targets['serve-static'] - ).toBeUndefined(); - }); - }); - - describe('root project', () => { - beforeEach(async () => { - tempFs = new TempFs('test'); - tree = createTreeWithEmptyWorkspace(); - tree.root = tempFs.tempDir; - await tempFs.createFiles({ - 'vite.config.ts': '', - 'project.json': '{ "name": "my-app" }', - }); - tree.write('vite.config.ts', `console.log('hi');`); - }); - - afterEach(() => { - jest.resetModules(); - tempFs.cleanup(); - }); - - it('should remove the serve target', async () => { - updateProjectConfiguration(tree, 'my-app', { - root: '.', - targets: { - serve: { - executor: '@nx/vite:dev-server', - defaultConfiguration: 'development', - options: { - buildTarget: 'build', - }, - configurations: { - development: { - buildTarget: 'build:development', - hmr: true, - }, - production: { - buildTarget: 'build:production', - hmr: false, - }, - }, - }, - }, - }); - - await update(tree); - - expect( - readProjectConfiguration(tree, 'my-app').targets.serve - ).toBeUndefined(); - }); - }); -}); diff --git a/packages/vite/src/migrations/update-17-2-0/add-vite-plugin.ts b/packages/vite/src/migrations/update-17-2-0/add-vite-plugin.ts deleted file mode 100644 index 3bb9b1916cba7f..00000000000000 --- a/packages/vite/src/migrations/update-17-2-0/add-vite-plugin.ts +++ /dev/null @@ -1,31 +0,0 @@ -import { formatFiles, getProjects, Tree } from '@nx/devkit'; -import { createNodes } from '../../plugins/plugin'; - -import { createProjectRootMappingsFromProjectConfigurations } from 'nx/src/project-graph/utils/find-project-for-path'; -import { replaceProjectConfigurationsWithPlugin } from '@nx/devkit/src/utils/replace-project-configuration-with-plugin'; - -export default async function update(tree: Tree) { - const proj = Object.fromEntries(getProjects(tree).entries()); - - const rootMappings = createProjectRootMappingsFromProjectConfigurations(proj); - - // add function here to remove - // passWithNoTests: true, - // reportsDirectory: '../../coverage/apps/my-app', - - await replaceProjectConfigurationsWithPlugin( - tree, - rootMappings, - '@nx/vite/plugin', - createNodes, - { - buildTargetName: 'build', - serveTargetName: 'serve', - previewTargetName: 'preview', - testTargetName: 'test', - serveStaticTargetName: 'serve-static', - } - ); - - await formatFiles(tree); -} diff --git a/packages/vite/src/plugins/__snapshots__/plugin.spec.ts.snap b/packages/vite/src/plugins/__snapshots__/plugin.spec.ts.snap index da0769cf83861b..d35229bffcd73d 100644 --- a/packages/vite/src/plugins/__snapshots__/plugin.spec.ts.snap +++ b/packages/vite/src/plugins/__snapshots__/plugin.spec.ts.snap @@ -8,10 +8,15 @@ exports[`@nx/vite/plugin not root project should create nodes 1`] = ` "targets": { "build-something": { "cache": true, - "command": "pnpm exec vite build", + "command": "vite build", "inputs": [ "production", "^production", + { + "externalDependencies": [ + "vite", + ], + }, ], "options": { "cwd": "my-app", @@ -21,13 +26,13 @@ exports[`@nx/vite/plugin not root project should create nodes 1`] = ` ], }, "my-serve": { - "command": "pnpm exec vite serve", + "command": "vite serve", "options": { "cwd": "my-app", }, }, "preview-site": { - "command": "pnpm exec vite preview", + "command": "vite preview", "options": { "cwd": "my-app", }, @@ -40,10 +45,15 @@ exports[`@nx/vite/plugin not root project should create nodes 1`] = ` }, "vitest": { "cache": true, - "command": "pnpm exec vitest run", + "command": "vitest run", "inputs": [ - "default", + "production", "^production", + { + "externalDependencies": [ + "vitest", + ], + }, ], "options": { "cwd": "my-app", @@ -66,10 +76,15 @@ exports[`@nx/vite/plugin root project should create nodes 1`] = ` "targets": { "build": { "cache": true, - "command": "pnpm exec vite build", + "command": "vite build", "inputs": [ "production", "^production", + { + "externalDependencies": [ + "vite", + ], + }, ], "options": { "cwd": ".", @@ -79,13 +94,13 @@ exports[`@nx/vite/plugin root project should create nodes 1`] = ` ], }, "preview": { - "command": "pnpm exec vite preview", + "command": "vite preview", "options": { "cwd": ".", }, }, "serve": { - "command": "pnpm exec vite serve", + "command": "vite serve", "options": { "cwd": ".", }, @@ -98,10 +113,15 @@ exports[`@nx/vite/plugin root project should create nodes 1`] = ` }, "test": { "cache": true, - "command": "pnpm exec vitest run", + "command": "vitest run", "inputs": [ - "default", + "production", "^production", + { + "externalDependencies": [ + "vitest", + ], + }, ], "options": { "cwd": ".", diff --git a/packages/vite/src/plugins/plugin.ts b/packages/vite/src/plugins/plugin.ts index b6589421867e6f..e07ea161d96fce 100644 --- a/packages/vite/src/plugins/plugin.ts +++ b/packages/vite/src/plugins/plugin.ts @@ -4,7 +4,6 @@ import { CreateNodesContext, TargetConfiguration, detectPackageManager, - getPackageManagerCommand, joinPathFragments, readJsonFile, writeJsonFile, @@ -17,6 +16,7 @@ import { UserConfig, loadConfigFromFile } from 'vite'; import { existsSync, readdirSync } from 'fs'; import { calculateHashForCreateNodes } from '@nx/devkit/src/utils/calculate-hash-for-create-nodes'; import { projectGraphCacheDirectory } from 'nx/src/utils/cache-directory'; +import { getLockFileName } from '@nx/js'; export interface VitePluginOptions { buildTargetName?: string; testTargetName?: string; @@ -66,7 +66,9 @@ export const createNodes: CreateNodes = [ options = normalizeOptions(options); - const hash = calculateHashForCreateNodes(projectRoot, options, context); + const hash = calculateHashForCreateNodes(projectRoot, options, context, [ + getLockFileName(detectPackageManager(context.workspaceRoot)), + ]); const targets = targetsCache[hash] ? targetsCache[hash] : await buildViteTargets(configFilePath, projectRoot, options, context); @@ -143,14 +145,11 @@ async function buildTarget( ) { const targetDefaults = readTargetDefaultsForTarget( options.buildTargetName, - context.nxJsonConfiguration.targetDefaults, - '@nx/vite:build' + context.nxJsonConfiguration.targetDefaults ); const targetConfig: TargetConfiguration = { - command: `${ - getPackageManagerCommand(detectPackageManager()).exec - } vite build`, + command: `vite build`, options: { cwd: joinPathFragments(projectRoot), }, @@ -165,10 +164,14 @@ async function buildTarget( } if (targetDefaults?.inputs === undefined) { - targetConfig.inputs = - 'production' in namedInputs + targetConfig.inputs = [ + ...('production' in namedInputs ? ['production', '^production'] - : ['default', '^default']; + : ['default', '^default']), + { + externalDependencies: ['vite'], + }, + ]; } return targetConfig; @@ -176,9 +179,7 @@ async function buildTarget( function serveTarget(projectRoot: string) { const targetConfig: TargetConfiguration = { - command: `${ - getPackageManagerCommand(detectPackageManager()).exec - } vite serve`, + command: `vite serve`, options: { cwd: joinPathFragments(projectRoot), }, @@ -189,9 +190,7 @@ function serveTarget(projectRoot: string) { function previewTarget(projectRoot: string) { const targetConfig: TargetConfiguration = { - command: `${ - getPackageManagerCommand(detectPackageManager()).exec - } vite preview`, + command: `vite preview`, options: { cwd: joinPathFragments(projectRoot), }, @@ -211,14 +210,11 @@ async function testTarget( ) { const targetDefaults = readTargetDefaultsForTarget( options.testTargetName, - context.nxJsonConfiguration.targetDefaults, - '@nx/vite:test' + context.nxJsonConfiguration.targetDefaults ); const targetConfig: TargetConfiguration = { - command: `${ - getPackageManagerCommand(detectPackageManager()).exec - } vitest run`, + command: `vitest run`, options: { cwd: joinPathFragments(projectRoot), }, @@ -233,10 +229,14 @@ async function testTarget( } if (targetDefaults?.inputs === undefined) { - targetConfig.inputs = - 'production' in namedInputs - ? ['default', '^production'] - : ['default', '^default']; + targetConfig.inputs = [ + ...('production' in namedInputs + ? ['production', '^production'] + : ['default', '^default']), + { + externalDependencies: ['vitest'], + }, + ]; } return targetConfig; } diff --git a/packages/vue/src/generators/library/__snapshots__/library.spec.ts.snap b/packages/vue/src/generators/library/__snapshots__/library.spec.ts.snap index b477b8007ed937..dc9843b800d76a 100644 --- a/packages/vue/src/generators/library/__snapshots__/library.spec.ts.snap +++ b/packages/vue/src/generators/library/__snapshots__/library.spec.ts.snap @@ -71,7 +71,6 @@ export default defineConfig({ // External packages that should not be bundled into your library. external: [], }, - outDir: 'dist/my-lib', }, test: {