Skip to content

Commit

Permalink
feat(core): enable project crystal by default
Browse files Browse the repository at this point in the history
  • Loading branch information
FrozenPandaz committed Jan 29, 2024
1 parent d31b951 commit d29a2a6
Show file tree
Hide file tree
Showing 44 changed files with 166 additions and 268 deletions.
2 changes: 1 addition & 1 deletion docs/generated/cli/add.md
Original file line number Diff line number Diff line change
Expand Up @@ -53,7 +53,7 @@ The package name and optional version (e.g. `@nx/react` or `@nx/react@latest`) t

Type: `boolean`

Update `package.json` scripts with inferred targets. Defaults to `true` when `NX_PCV3=true` and the package is a core Nx plugin
Update `package.json` scripts with inferred targets. Defaults to `true` when the package is a core Nx plugin

### verbose

Expand Down
34 changes: 1 addition & 33 deletions docs/generated/cli/init.md
Original file line number Diff line number Diff line change
Expand Up @@ -17,36 +17,12 @@ Install `nx` globally to invoke the command directly using `nx`, or use `npx nx`

## Options

### addE2e

Type: `boolean`

Default: `false`

Set up Cypress E2E tests in integrated workspaces. Only for CRA projects.

### force

Type: `boolean`

Default: `false`

Force the migration to continue and ignore custom webpack setup or uncommitted changes. Only for CRA projects.

### help

Type: `boolean`

Show help

### integrated

Type: `boolean`

Default: `false`

Migrate to an Nx integrated layout workspace. Only for Angular CLI workspaces and CRA projects.

### interactive

Type: `boolean`
Expand All @@ -59,7 +35,7 @@ When false disables interactive input prompts for options.

Type: `boolean`

Set up remote caching with Nx Cloud.
Set up distributed caching with Nx Cloud.

### useDotNxInstallation

Expand All @@ -74,11 +50,3 @@ Initialize an Nx workspace setup in the .nx directory of the current repository.
Type: `boolean`

Show version number

### vite

Type: `boolean`

Default: `true`

Use Vite as the bundler. Only for CRA projects.
2 changes: 1 addition & 1 deletion docs/generated/packages/nx/documents/add.md
Original file line number Diff line number Diff line change
Expand Up @@ -53,7 +53,7 @@ The package name and optional version (e.g. `@nx/react` or `@nx/react@latest`) t

Type: `boolean`

Update `package.json` scripts with inferred targets. Defaults to `true` when `NX_PCV3=true` and the package is a core Nx plugin
Update `package.json` scripts with inferred targets. Defaults to `true` when the package is a core Nx plugin

### verbose

Expand Down
34 changes: 1 addition & 33 deletions docs/generated/packages/nx/documents/init.md
Original file line number Diff line number Diff line change
Expand Up @@ -17,36 +17,12 @@ Install `nx` globally to invoke the command directly using `nx`, or use `npx nx`

## Options

### addE2e

Type: `boolean`

Default: `false`

Set up Cypress E2E tests in integrated workspaces. Only for CRA projects.

### force

Type: `boolean`

Default: `false`

Force the migration to continue and ignore custom webpack setup or uncommitted changes. Only for CRA projects.

### help

Type: `boolean`

Show help

### integrated

Type: `boolean`

Default: `false`

Migrate to an Nx integrated layout workspace. Only for Angular CLI workspaces and CRA projects.

### interactive

Type: `boolean`
Expand All @@ -59,7 +35,7 @@ When false disables interactive input prompts for options.

Type: `boolean`

Set up remote caching with Nx Cloud.
Set up distributed caching with Nx Cloud.

### useDotNxInstallation

Expand All @@ -74,11 +50,3 @@ Initialize an Nx workspace setup in the .nx directory of the current repository.
Type: `boolean`

Show version number

### vite

Type: `boolean`

Default: `true`

Use Vite as the bundler. Only for CRA projects.
Original file line number Diff line number Diff line change
Expand Up @@ -7,7 +7,7 @@ import {
updateJson,
} from 'e2e/utils';

describe('@nx/detox/plugin', () => {
describe('@nx/detox (legacy)', () => {
let project: string;
let appName: string;

Expand All @@ -16,7 +16,7 @@ describe('@nx/detox/plugin', () => {
appName = uniq('app');
runCLI(
`generate @nx/react-native:app ${appName} --e2eTestRunner=detox --install=false --project-name-and-root-format=as-provided --interactive=false`,
{ env: { NX_PCV3: 'true' } }
{ env: { NX_ADD_PLUGINS: 'false' } }
);
updateJson(`${appName}-e2e/.detoxrc.json`, (json) => {
json.apps['e2e.debug'] = {
Expand Down
4 changes: 2 additions & 2 deletions e2e/eslint/src/linter.test.ts
Original file line number Diff line number Diff line change
Expand Up @@ -790,10 +790,10 @@ describe('Linter', () => {
});
});

it('should lint example app', () => {
it('should lint example app (legacy)', () => {
runCLI(
`generate @nx/react:app ${myapp} --directory apps/${myapp} --unitTestRunner=none --bundler=vite --e2eTestRunner=cypress --style=css --no-interactive --projectNameAndRootFormat=as-provided`,
{ env: { NX_PCV3: 'true' } }
{ env: { NX_ADD_PLUGINS: 'false' } }
);

let lintResults = runCLI(`lint ${myapp}`);
Expand Down
4 changes: 2 additions & 2 deletions e2e/expo/src/expo-pcv3.test.ts
Original file line number Diff line number Diff line change
Expand Up @@ -13,7 +13,7 @@ import {
} from 'e2e/utils';
import { join } from 'path';

describe('@nx/expo/plugin', () => {
describe('@nx/expo (legacy)', () => {
let project: string;
let appName: string;

Expand All @@ -22,7 +22,7 @@ describe('@nx/expo/plugin', () => {
appName = uniq('app');
runCLI(
`generate @nx/expo:app ${appName} --project-name-and-root-format=as-provided --no-interactive`,
{ env: { NX_PCV3: 'true' } }
{ env: { NX_ADD_PLUGINS: 'false' } }
);
});

Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -12,7 +12,7 @@ import {
createFile,
} from 'e2e/utils';

describe('@nx/next/plugin', () => {
describe('@nx/next (legacy)', () => {
let project: string;
let appName: string;

Expand All @@ -23,7 +23,7 @@ describe('@nx/next/plugin', () => {
appName = uniq('app');
runCLI(
`generate @nx/next:app ${appName} --project-name-and-root-format=as-provided --no-interactive`,
{ env: { NX_PCV3: 'true' } }
{ env: { NX_ADD_PLUGINS: 'false' } }
);

// update package.json to add next as a script
Expand All @@ -50,7 +50,7 @@ describe('@nx/next/plugin', () => {

it('should build the app', async () => {
const result = runCLI(`build ${appName}`);
// check build output for PCV3 artifacts (e.g. .next directory) are inside the project directory
// check build output for cached artifacts (e.g. .next directory) are inside the project directory
directoryExists(`${appName}/.next`);

expect(result).toContain(
Expand Down
10 changes: 5 additions & 5 deletions e2e/playwright/src/playwright.test.ts
Original file line number Diff line number Diff line change
Expand Up @@ -69,23 +69,23 @@ describe('Playwright E2E Test runner', () => {
);
});

describe('Playwright E2E Test Runner - PCV3', () => {
describe('Playwright E2E Test Runner - legacy', () => {
let env: string | undefined;

beforeAll(() => {
env = process.env.NX_PCV3;
env = process.env.NX_ADD_PLUGINS;
newProject({
name: uniq('playwright'),
unsetProjectNameAndRootFormat: false,
});
process.env.NX_PCV3 = 'true';
process.env.NX_ADD_PLUGINS = 'false';
});

afterAll(() => {
if (env) {
process.env.NX_PCV3 = env;
process.env.NX_ADD_PLUGINS = env;
} else {
delete process.env.NX_PCV3;
delete process.env.NX_ADD_PLUGINS;
}
});

Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -10,31 +10,20 @@ import {
fileExists,
} from 'e2e/utils';

describe('@nx/react-native/plugin', () => {
describe('@nx/react-native (legacy)', () => {
let appName: string;

beforeAll(() => {
newProject();
appName = uniq('app');
runCLI(
`generate @nx/react-native:app ${appName} --project-name-and-root-format=as-provided --install=false --no-interactive`,
{ env: { NX_PCV3: 'true' } }
{ env: { NX_ADD_PLUGINS: 'false' } }
);
});

afterAll(() => cleanupProject());

it('nx.json should contain plugin configuration', () => {
const nxJson = readJson('nx.json');
const reactNativePlugin = nxJson.plugins.find(
(plugin) => plugin.plugin === '@nx/react-native/plugin'
);
expect(reactNativePlugin).toBeDefined();
expect(reactNativePlugin.options).toBeDefined();
expect(reactNativePlugin.options.bundleTargetName).toEqual('bundle');
expect(reactNativePlugin.options.startTargetName).toEqual('start');
});

it('should bundle the app', async () => {
const result = runCLI(
`bundle ${appName} --platform=ios --bundle-output=dist.js --entry-file=src/main.tsx`
Expand Down
2 changes: 1 addition & 1 deletion e2e/utils/get-env-info.ts
Original file line number Diff line number Diff line change
Expand Up @@ -157,7 +157,7 @@ export function getStrippedEnvironmentVariables() {
return true;
}

const allowedKeys = ['NX_PCV3'];
const allowedKeys = ['NX_ADD_PLUGINS'];

if (key.startsWith('NX_') && !allowedKeys.includes(key)) {
return false;
Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -18,8 +18,8 @@ describe('@nx/vite/plugin', () => {

describe('with react', () => {
beforeAll(() => {
originalEnv = process.env.NX_PCV3;
process.env.NX_PCV3 = 'true';
originalEnv = process.env.NX_ADD_PLUGINS;
process.env.NX_ADD_PLUGINS = 'false';
proj = newProject({
packages: ['@nx/react', '@nx/vue'],
});
Expand Down Expand Up @@ -83,8 +83,8 @@ describe('@nx/vite/plugin', () => {
const reactVitest = uniq('reactVitest');

beforeAll(() => {
originalEnv = process.env.NX_PCV3;
process.env.NX_PCV3 = 'true';
originalEnv = process.env.NX_ADD_PLUGINS;
process.env.NX_ADD_PLUGINS = 'false';
proj = newProject({
packages: ['@nx/vite', '@nx/react'],
});
Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -8,14 +8,14 @@ import {
} from '@nx/e2e/utils';
import { ChildProcess } from 'child_process';

describe('Webpack Plugin (PCv3)', () => {
let originalPcv3: string | undefined;
describe('Webpack Plugin (legacy)', () => {
let originalAddPluginsEnv: string | undefined;
const appName = uniq('app');
const libName = uniq('lib');

beforeAll(() => {
originalPcv3 = process.env.NX_PCV3;
process.env.NX_PCV3 = 'true';
originalAddPluginsEnv = process.env.NX_ADD_PLUGINS;
process.env.NX_ADD_PLUGINS = 'false';
newProject({
packages: ['@nx/react'],
unsetProjectNameAndRootFormat: false,
Expand All @@ -29,7 +29,7 @@ describe('Webpack Plugin (PCv3)', () => {
});

afterAll(() => {
process.env.NX_PCV3 = originalPcv3;
process.env.NX_ADD_PLUGINS = originalAddPluginsEnv;
cleanupProject();
});

Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -99,7 +99,6 @@ describe('Cypress Component Configuration', () => {
});

it('should not add the target when @nx/cypress/plugin is registered', async () => {
process.env.NX_PCV3 = 'true';
await cypressInitGenerator(tree, {});
const nxJson = readNxJson(tree);
nxJson.namedInputs = {
Expand All @@ -125,8 +124,6 @@ describe('Cypress Component Configuration', () => {
"!{projectRoot}/cypress.config.[jt]s",
]
`);

delete process.env.NX_PCV3;
});

it('should add base cypress component testing config', async () => {
Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -35,7 +35,6 @@ describe('Cypress e2e configuration', () => {
});

it('should add web server commands to the cypress config when the @nx/cypress/plugin is present', async () => {
process.env.NX_PCV3 = 'true';
await cypressInitGenerator(tree, {});

addProject(tree, { name: 'my-app', type: 'apps' });
Expand Down Expand Up @@ -99,7 +98,6 @@ describe('Cypress e2e configuration', () => {
}
`);
assertCypressFiles(tree, 'apps/my-app/src');
delete process.env.NX_PCV3;
});

it('should add e2e target to existing app', async () => {
Expand Down
3 changes: 0 additions & 3 deletions packages/cypress/src/generators/init/init.spec.ts
Original file line number Diff line number Diff line change
Expand Up @@ -49,7 +49,6 @@ describe('init', () => {
});

it('should setup @nx/cypress/plugin', async () => {
process.env.NX_PCV3 = 'true';
updateJson<NxJsonConfiguration>(tree, 'nx.json', (json) => {
json.namedInputs ??= {};
json.namedInputs.production = ['default'];
Expand Down Expand Up @@ -91,7 +90,5 @@ describe('init', () => {
},
}
`);

delete process.env.NX_PCV3;
});
});
2 changes: 1 addition & 1 deletion packages/cypress/src/generators/init/init.ts
Original file line number Diff line number Diff line change
Expand Up @@ -99,7 +99,7 @@ function updateProductionFileset(tree: Tree) {
export async function cypressInitGenerator(tree: Tree, options: Schema) {
updateProductionFileset(tree);

if (process.env.NX_PCV3 === 'true') {
if (process.env.NX_ADD_PLUGINS !== 'false') {
addPlugin(tree);
} else {
setupE2ETargetDefaults(tree);
Expand Down
2 changes: 1 addition & 1 deletion packages/detox/src/generators/init/init.ts
Original file line number Diff line number Diff line change
Expand Up @@ -21,7 +21,7 @@ export async function detoxInitGenerator(host: Tree, schema: Schema) {
tasks.push(updateDependencies(host, schema));
}

if (process.env.NX_PCV3 === 'true') {
if (process.env.NX_ADD_PLUGINS !== 'false') {
addPlugin(host);
}

Expand Down
Loading

0 comments on commit d29a2a6

Please sign in to comment.