nx/e2e/workspace-create/src/create-nx-workspace.test.ts

361 lines
9.2 KiB
TypeScript

import {
checkFilesDoNotExist,
checkFilesExist,
cleanupProject,
e2eCwd,
expectNoAngularDevkit,
expectNoTsJestInJestConfig,
getSelectedPackageManager,
packageManagerLockFile,
readJson,
runCLI,
runCreateWorkspace,
uniq,
updateFile,
updateJson,
} from '@nrwl/e2e/utils';
import { existsSync, mkdirSync } from 'fs-extra';
describe('create-nx-workspace', () => {
const packageManager = getSelectedPackageManager() || 'pnpm';
afterEach(() => cleanupProject());
it('should create a workspace with a single react app', () => {
const wsName = uniq('react');
const appName = uniq('app');
runCreateWorkspace(wsName, {
preset: 'react-experimental',
appName,
style: 'css',
packageManager,
});
checkFilesExist('package.json');
});
it('should be able to create an empty workspace built for apps', () => {
const wsName = uniq('apps');
runCreateWorkspace(wsName, {
preset: 'empty',
packageManager,
});
checkFilesExist(
'package.json',
packageManagerLockFile[packageManager],
'apps/.gitkeep',
'libs/.gitkeep'
);
const foreignLockFiles = Object.keys(packageManagerLockFile)
.filter((pm) => pm !== packageManager)
.map((pm) => packageManagerLockFile[pm]);
checkFilesDoNotExist(...foreignLockFiles, 'workspace.json');
expectNoAngularDevkit();
});
it('should be able to create an empty workspace with npm capabilities', () => {
const wsName = uniq('npm');
runCreateWorkspace(wsName, {
preset: 'npm',
packageManager,
});
expectNoAngularDevkit();
});
it('should be able to create an empty workspace with ts/js capabilities', () => {
const wsName = uniq('ts');
runCreateWorkspace(wsName, {
preset: 'npm',
packageManager,
});
expectNoAngularDevkit();
});
it('should be able to create an angular workspace', () => {
const wsName = uniq('angular');
const appName = uniq('app');
runCreateWorkspace(wsName, {
preset: 'angular',
style: 'css',
appName,
packageManager,
});
});
it('should fail correctly when preset errors', () => {
// Using Angular Preset as the example here to test
// It will error when npmScope is of form `<char>-<num>-<char>`
// Due to a validation error Angular will throw.
const wsName = uniq('angular-1-test');
const appName = uniq('app');
try {
runCreateWorkspace(wsName, {
preset: 'angular',
style: 'css',
appName,
packageManager,
});
} catch (e) {
expect(e).toBeTruthy();
}
});
it('should be able to create an react workspace', () => {
const wsName = uniq('react');
const appName = uniq('app');
runCreateWorkspace(wsName, {
preset: 'react',
style: 'css',
appName,
packageManager,
});
expectNoAngularDevkit();
expectNoTsJestInJestConfig(appName);
});
it('should be able to create an next workspace', () => {
const wsName = uniq('next');
const appName = uniq('app');
runCreateWorkspace(wsName, {
preset: 'next',
style: 'css',
appName,
packageManager,
});
expectNoAngularDevkit();
});
it('should be able to create an web-components workspace', () => {
const wsName = uniq('web-components');
const appName = uniq('app');
runCreateWorkspace(wsName, {
preset: 'web-components',
style: 'css',
appName,
packageManager,
});
expectNoAngularDevkit();
});
it('should be able to create an angular + nest workspace', () => {
const wsName = uniq('angular-nest');
const appName = uniq('app');
runCreateWorkspace(wsName, {
preset: 'angular-nest',
style: 'css',
appName,
packageManager,
});
});
it('should be able to create an react + express workspace', () => {
const wsName = uniq('react-express');
const appName = uniq('app');
runCreateWorkspace(wsName, {
preset: 'react-express',
style: 'css',
appName,
packageManager,
});
expectNoAngularDevkit();
expectNoTsJestInJestConfig(appName);
});
it('should be able to create an express workspace', () => {
const wsName = uniq('express');
const appName = uniq('app');
runCreateWorkspace(wsName, {
preset: 'express',
style: 'css',
appName,
packageManager,
});
expectNoAngularDevkit();
});
it('should be able to create react-native workspace', () => {
const wsName = uniq('react-native');
const appName = uniq('app');
runCreateWorkspace(wsName, {
preset: 'react-native',
appName,
packageManager: 'npm',
});
expectNoAngularDevkit();
});
it('should be able to create an expo workspace', () => {
const wsName = uniq('expo');
const appName = uniq('app');
runCreateWorkspace(wsName, {
preset: 'expo',
appName,
packageManager: 'npm',
});
expectNoAngularDevkit();
});
it('should be able to create a workspace with a custom base branch and HEAD', () => {
const wsName = uniq('branch');
runCreateWorkspace(wsName, {
preset: 'empty',
base: 'main',
packageManager,
});
});
it('should be able to create a workspace with custom commit information', () => {
const wsName = uniq('branch');
runCreateWorkspace(wsName, {
preset: 'empty',
extraArgs:
'--commit.name="John Doe" --commit.email="myemail@test.com" --commit.message="Custom commit message!"',
packageManager,
});
});
it('should be able to create a nest workspace', () => {
const wsName = uniq('nest');
const appName = uniq('app');
runCreateWorkspace(wsName, {
preset: 'nest',
appName,
packageManager,
});
});
it('should respect package manager preference', () => {
const wsName = uniq('pm');
const appName = uniq('app');
process.env.YARN_REGISTRY = `http://localhost:4872`;
process.env.SELECTED_PM = 'npm';
runCreateWorkspace(wsName, {
preset: 'react',
style: 'css',
appName,
packageManager: 'npm',
});
checkFilesDoNotExist('yarn.lock');
checkFilesExist('package-lock.json');
process.env.SELECTED_PM = packageManager;
});
it('should store package manager preference for angular cli', () => {
const wsName = uniq('pm');
const appName = uniq('app');
process.env.YARN_REGISTRY = `http://localhost:4872`;
process.env.SELECTED_PM = 'npm';
runCreateWorkspace(wsName, {
preset: 'angular',
appName,
style: 'css',
packageManager: 'npm',
cli: 'angular',
});
const nxJson = readJson('nx.json');
expect(nxJson.cli.packageManager).toEqual('npm');
checkFilesDoNotExist('yarn.lock');
checkFilesExist('package-lock.json');
process.env.SELECTED_PM = packageManager;
});
it('should return error when ci workflow is selected but no cloud is set up', () => {
const wsName = uniq('github');
const create = runCreateWorkspace(wsName, {
preset: 'npm',
packageManager,
ci: 'circleci',
});
checkFilesExist('package.json');
checkFilesDoNotExist('.circleci/config.yml');
});
describe('Use detected package manager', () => {
function setupProject(envPm: 'npm' | 'yarn' | 'pnpm') {
process.env.SELECTED_PM = envPm;
runCreateWorkspace(uniq('pm'), {
preset: 'empty',
packageManager: envPm,
useDetectedPm: true,
});
}
if (packageManager === 'npm') {
it('should use npm when invoked with npx', () => {
setupProject('npm');
checkFilesExist(packageManagerLockFile['npm']);
checkFilesDoNotExist(
packageManagerLockFile['yarn'],
packageManagerLockFile['pnpm']
);
process.env.SELECTED_PM = packageManager;
}, 90000);
}
if (packageManager === 'pnpm') {
it('should use pnpm when invoked with pnpx', () => {
setupProject('pnpm');
checkFilesExist(packageManagerLockFile['pnpm']);
checkFilesDoNotExist(
packageManagerLockFile['yarn'],
packageManagerLockFile['npm']
);
process.env.SELECTED_PM = packageManager;
}, 90000);
}
// skipping due to packageManagerCommand for createWorkspace not using yarn create nx-workspace
if (packageManager === 'yarn') {
xit('should use yarn when invoked with yarn create', () => {
setupProject('yarn');
checkFilesExist(packageManagerLockFile['yarn']);
checkFilesDoNotExist(
packageManagerLockFile['pnpm'],
packageManagerLockFile['npm']
);
process.env.SELECTED_PM = packageManager;
}, 90000);
}
});
});
describe('create-nx-workspace custom parent folder', () => {
const tmpDir = `${e2eCwd}/${uniq('with space')}`;
const wsName = uniq('empty');
const packageManager = getSelectedPackageManager() || 'pnpm';
afterEach(() => cleanupProject({ cwd: `${tmpDir}/${wsName}` }));
it('should handle spaces in workspace path', () => {
mkdirSync(tmpDir, { recursive: true });
runCreateWorkspace(wsName, {
preset: 'apps',
packageManager,
cwd: tmpDir,
});
expect(existsSync(`${tmpDir}/${wsName}/package.json`)).toBeTruthy();
});
});