-
Notifications
You must be signed in to change notification settings - Fork 2.4k
Commit
This commit does not belong to any branch on this repository, and may belong to a fork outside of the repository.
feat(core): migrate existing workspaces to slimmer tasks runner optio…
…ns config
- Loading branch information
1 parent
bdbfd35
commit b679dde
Showing
3 changed files
with
238 additions
and
0 deletions.
There are no files selected for viewing
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
171 changes: 171 additions & 0 deletions
171
packages/nx/src/migrations/update-17-0-0/use-minimal-config-for-tasks-runner-options.spec.ts
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,171 @@ | ||
import { NxJsonConfiguration } from '../../config/nx-json'; | ||
import { createTreeWithEmptyWorkspace } from '../../generators/testing-utils/create-tree-with-empty-workspace'; | ||
import { readJson, writeJson } from '../../generators/utils/json'; | ||
import { Tree } from '../../generators/tree'; | ||
import migrate from './use-minimal-config-for-tasks-runner-options'; | ||
|
||
describe('use-minimal-config-for-tasks-runner-options migration', () => { | ||
let tree: Tree; | ||
|
||
beforeEach(() => { | ||
tree = createTreeWithEmptyWorkspace(); | ||
}); | ||
|
||
it('should update nx.json with minimal config', async () => { | ||
writeJson<NxJsonConfiguration>(tree, 'nx.json', { | ||
tasksRunnerOptions: { | ||
default: { | ||
runner: 'default', | ||
options: {}, | ||
}, | ||
}, | ||
}); | ||
|
||
await migrate(tree); | ||
|
||
const nxJson = readJson<NxJsonConfiguration>(tree, 'nx.json'); | ||
expect(nxJson.tasksRunnerOptions).toEqual(undefined); | ||
}); | ||
|
||
it('should not update nx.json if there are multiple tasks runners', async () => { | ||
writeJson<NxJsonConfiguration>(tree, 'nx.json', { | ||
tasksRunnerOptions: { | ||
default: { | ||
runner: 'default', | ||
options: {}, | ||
}, | ||
custom: { | ||
runner: 'custom', | ||
options: {}, | ||
}, | ||
}, | ||
}); | ||
|
||
await migrate(tree); | ||
|
||
const nxJson = readJson<NxJsonConfiguration>(tree, 'nx.json'); | ||
expect(nxJson.tasksRunnerOptions).toEqual({ | ||
default: { | ||
runner: 'default', | ||
options: {}, | ||
}, | ||
custom: { | ||
runner: 'custom', | ||
options: {}, | ||
}, | ||
}); | ||
}); | ||
|
||
it('should move nxCloudAccessToken and nxCloudUrl for nx-cloud', async () => { | ||
writeJson<NxJsonConfiguration>(tree, 'nx.json', { | ||
tasksRunnerOptions: { | ||
default: { | ||
runner: 'nx-cloud', | ||
options: { | ||
accessToken: 'abc123', | ||
url: 'https://nx.app', | ||
encryptionKey: 'secret', | ||
}, | ||
}, | ||
}, | ||
}); | ||
|
||
await migrate(tree); | ||
|
||
const nxJson = readJson<NxJsonConfiguration>(tree, 'nx.json'); | ||
expect(nxJson.nxCloudAccessToken).toEqual('abc123'); | ||
expect(nxJson.nxCloudUrl).toEqual('https://nx.app'); | ||
expect(nxJson.nxCloudEncryptionKey).toEqual('secret'); | ||
expect(nxJson.tasksRunnerOptions).not.toBeDefined(); | ||
}); | ||
|
||
it('should move nxCloudAccessToken and nxCloudUrl for @nrwl/nx-cloud', async () => { | ||
writeJson<NxJsonConfiguration>(tree, 'nx.json', { | ||
tasksRunnerOptions: { | ||
default: { | ||
runner: '@nrwl/nx-cloud', | ||
options: { | ||
accessToken: 'abc123', | ||
url: 'https://nx.app', | ||
maskedProperties: 'secret', | ||
}, | ||
}, | ||
}, | ||
}); | ||
|
||
await migrate(tree); | ||
|
||
const nxJson = readJson<NxJsonConfiguration>(tree, 'nx.json'); | ||
expect(nxJson.nxCloudAccessToken).toEqual('abc123'); | ||
expect(nxJson.nxCloudUrl).toEqual('https://nx.app'); | ||
expect(nxJson.tasksRunnerOptions.default.options).toMatchInlineSnapshot(` | ||
{ | ||
"maskedProperties": "secret", | ||
} | ||
`); | ||
}); | ||
|
||
it('should not update accessToken if runner is not nx-cloud', async () => { | ||
writeJson<NxJsonConfiguration>(tree, 'nx.json', { | ||
tasksRunnerOptions: { | ||
default: { | ||
runner: 'custom', | ||
options: { | ||
cacheDirectory: '.nx/cache', | ||
useDaemonProcess: false, | ||
accessToken: 'xxxx-xxx-xxxx', | ||
}, | ||
}, | ||
}, | ||
}); | ||
await migrate(tree); | ||
expect(readJson<NxJsonConfiguration>(tree, 'nx.json')) | ||
.toMatchInlineSnapshot(` | ||
{ | ||
"cacheDirectory": ".nx/cache", | ||
"tasksRunnerOptions": { | ||
"default": { | ||
"options": { | ||
"accessToken": "xxxx-xxx-xxxx", | ||
}, | ||
"runner": "custom", | ||
}, | ||
}, | ||
"useDaemonProcess": false, | ||
} | ||
`); | ||
}); | ||
|
||
it('should work if nx.json does not exist', async () => { | ||
tree.delete('nx.json'); | ||
await migrate(tree); | ||
expect(tree.exists('nx.json')).toEqual(false); | ||
}); | ||
|
||
it('should not throw is cacheableOperations is an unexpected type', async () => { | ||
writeJson<NxJsonConfiguration>(tree, 'nx.json', { | ||
tasksRunnerOptions: { | ||
default: { | ||
runner: 'default', | ||
options: { | ||
cacheableOperations: 'invalid', | ||
}, | ||
}, | ||
}, | ||
}); | ||
|
||
await migrate(tree); | ||
|
||
const nxJson = readJson<NxJsonConfiguration>(tree, 'nx.json'); | ||
expect(nxJson.tasksRunnerOptions).toMatchInlineSnapshot(` | ||
{ | ||
"default": { | ||
"options": { | ||
"cacheableOperations": "invalid", | ||
}, | ||
"runner": "default", | ||
}, | ||
} | ||
`); | ||
}); | ||
}); |
61 changes: 61 additions & 0 deletions
61
packages/nx/src/migrations/update-17-0-0/use-minimal-config-for-tasks-runner-options.ts
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,61 @@ | ||
import { updateJson } from '../../generators/utils/json'; | ||
import { Tree } from '../../generators/tree'; | ||
import { NxJsonConfiguration } from '../../config/nx-json'; | ||
|
||
export default async function migrate(tree: Tree) { | ||
if (!tree.exists('nx.json')) { | ||
return; | ||
} | ||
updateJson<NxJsonConfiguration>(tree, 'nx.json', (nxJson) => { | ||
if ( | ||
Object.keys(nxJson.tasksRunnerOptions ?? {}).length > 1 || | ||
!nxJson.tasksRunnerOptions?.default | ||
) { | ||
// Minimal config only really makes sense if there is only one tasks runner | ||
return nxJson; | ||
} | ||
|
||
const { runner, options } = nxJson.tasksRunnerOptions.default; | ||
|
||
// These options can only be moved for nx-cloud. | ||
if (runner === 'nx-cloud' || runner === '@nrwl/nx-cloud') { | ||
nxJson.nxCloudAccessToken = options.accessToken; | ||
delete options.accessToken; | ||
|
||
if (options.url) { | ||
nxJson.nxCloudUrl = options.url; | ||
delete options.url; | ||
} | ||
if (options.encryptionKey) { | ||
nxJson.nxCloudEncryptionKey = options.encryptionKey; | ||
delete options.encryptionKey; | ||
} | ||
} | ||
|
||
// These options should be safe to move for all tasks runners: | ||
if (options.parallel !== undefined) { | ||
nxJson.parallel = options.parallel; | ||
delete options.parallel; | ||
} | ||
if (options.cacheDirectory !== undefined) { | ||
nxJson.cacheDirectory = options.cacheDirectory; | ||
delete options.cacheDirectory; | ||
} | ||
if (options.useDaemonProcess !== undefined) { | ||
nxJson.useDaemonProcess = options.useDaemonProcess; | ||
delete options.useDaemonProcess; | ||
} | ||
if (Array.isArray(options.cacheableOperations)) { | ||
nxJson.targetDefaults ??= {}; | ||
for (const target of options.cacheableOperations) { | ||
nxJson.targetDefaults[target] ??= {}; | ||
nxJson.targetDefaults[target].cache ??= true; | ||
} | ||
delete options.cacheableOperations; | ||
} | ||
if (Object.values(options).length === 0) { | ||
delete nxJson.tasksRunnerOptions; | ||
} | ||
return nxJson; | ||
}); | ||
} |