Sync Generators

In Nx 19.8, you can use sync generators to ensure that your repository is maintained in a correct state. One specific application is to use the project graph to update files. These can be global configuration files or scripts, or at the task level to ensure that files are in sync before a task is run.

Sync Generator Examples:

  • Update a custom CI script with binning strategies based on the current project graph
  • Update TypeScript config files with project references based on the current project graph
  • Ensure code is formatted in a specific way before CI is run

Task Sync Generators

Sync generators can be associated with a particular task. Nx will use the sync generator to ensure that code is correctly configured before running the task. Nx does this in different ways, depending on whether the task is being run on a developer machine or in CI.

On a developer machine, the sync generator is run in --dry-run mode and if files would be changed by the generator, the user is prompted to run the generator or skip it. This prompt can be disabled by setting the sync.applyChanges property to true or false in the nx.json file.

nx.json
1{ 2 "$schema": "packages/nx/schemas/nx-schema.json", 3 ... 4 "sync": { 5 "applyChanges": true 6 } 7} 8
Opting out of automatic sync

If you set sync.applyChanges to false, then developers must run nx sync manually before pushing changes. Otherwise, CI may fail due to the workspace being out of sync.

In CI, the sync generator is run in --dry-run mode and if files would be changed by the generator, the task fails with an error provided by the sync generator. The sync generator can be skipped in CI by passing the --skip-sync flag when executing the task, or you can skip an individual sync generator by adding that generator to the sync.disabledTaskSyncGenerators in nx.json.

nx.json
1{ 2 "$schema": "packages/nx/schemas/nx-schema.json", 3 ... 4 "sync": { 5 "disabledTaskSyncGenerators": ["@nx/js:typescript-sync"] 6 } 7} 8 9

Use the project details view to find registered sync generators for a given task.

โฏ

nx show project <name>

The above command opens up the project details view, and the registered sync generators are under the Sync Generators for each target. Most sync generators are inferred when using an inference plugin. For example, the @nx/js/typescript plugin registers the @nx/js:typescript-sync generator on build and typecheck targets.

Project Details View

foo

Root: packages/foo

Type:library

Targets

  • build

    Cacheable
    Created by @nx/js/typescript from packages/foo/tsconfig.ts
    nx run foo:build

    Command

    tsc --build tsconfig.lib.json --pretty --verbose Set by @nx/js/typescript from packages/foo/tsconfig.ts

    Inputs

    • {workspaceRoot}/tsconfig.base.jsonSet by @nx/js/typescript from packages/foo/tsconfig.ts
    • {projectRoot}/tsconfig.lib.jsonSet by @nx/js/typescript from packages/foo/tsconfig.ts
    • {projectRoot}/src/**/*.tsSet by @nx/js/typescript from packages/foo/tsconfig.ts

    Outputs

    • {workspaceRoot}/packages/foo/distSet by @nx/js/typescript from packages/foo/tsconfig.ts

    Depends On

    • ^buildSet by @nx/js/typescript from packages/foo/tsconfig.ts

    Sync Generators

    • @nx/js:typescript-syncSet by @nx/js/typescript from packages/foo/tsconfig.ts

Task sync generators can be thought of like the dependsOn property, but for generators instead of task dependencies.

To register a generator as a sync generator for a particular task, add the generator to the syncGenerators property of the task configuration.

Global Sync Generators

Global sync generators are not associated with a particular task and are executed only when the nx sync or nx sync:check command is explicitly run. They are registered in the nx.json file with the sync.globalGenerators property.

Sync the Project Graph and the File System

Nx processes the file system in order to create the project graph which is used to run tasks in the correct order and determine project dependencies. Sync generators allow you to also go the other direction and use the project graph to update the file system.

File System
1โ””โ”€ myorg 2 โ”œโ”€ apps 3 โ”‚ โ”œโ”€ app1 4 โ”‚ โ””โ”€ app1 5 โ”œโ”€ libs 6 โ”‚ โ””โ”€ lib 7 โ”œโ”€ nx.json 8 โ””โ”€ package.json 9
Loading...

The ability to update the file system from the project graph makes it possible to use the Nx project graph to change the behavior of other tools that are not part of the Nx ecosystem.

Run nx sync:check in CI

Task sync generators are executed whenever their task is run, but global sync generators need to be triggered manually with nx sync. In order to effectively use sync generators, make sure to add nx sync:check to the beginning of your CI scripts so that CI can fail quickly if the code is out of sync. It is also helpful to run nx sync in a pre-commit or pre-push Git hook to encourage developers to commit code that is already in sync.