
Features
- Generate Go applications and libraries in seconds within your Nx workspace
- Zero-config setup – Automatic task inference for projects with
go.mod - Blazing-fast tasks – Optimized caching with smart inputs and outputs
- Community friendly – Integration with recognized community projects such as Air
- Reliable – Use official Go commands in the background with no external dependency
Getting started
You need to have a stable version of Go installed on your machine. And.. you are ready!
Generate a Nx workspace with Go support
npx create-nx-workspace go-workspace --preset=@nx-go/nx-goAdd to an exisiting workspace
nx add @nx-go/nx-goMigrate to latest version
nx migrate @nx-go/nx-goDon't want to use a multi-module Go workspace?
The plugin configures a multi-module Go workspace by default, to simplify project management and improve the quality of the Nx graph. If you don't want to take advantage of this feature, you can use generator convert-to-one-mod after the plugin installation. Generators will automatically adapt to your configuration.
nx g @nx-go/nx-go:convert-to-one-modConvert to inferred tasks
You need to have a multi-module Go workspace to use inferred tasks.
Convert existing projects from executor-based to inferred task configuration:
nx g infer-targetsGenerators & executors
Generators
application: Generate a Go applicationlibrary: Generate a Go library
Executors
build: Build a Go projectgenerate: Generate code using Golint: Format and lint a Go projectserve: Run a Go applicationserve-air: Run a Go application with Air live reloadtest: Run tests of a Go projecttidy: Ensures go.mod file matches a project source code
You can use
nx list @nx-go/nx-goto see list capabilities.
Want to try out these capabilities quickly? Visit our playground!
Need more customization? A plugin configuration is also available.
Compatibility
| nx-go version | Nx version |
|---|---|
| 4.x | 20.x to 23.x |
| 3.x | 17.x to 20.x |
This plugin is only tested on stable versions of Go, older versions does not receive support. However, you can expect a fair degree of compatibility. Please note that multi-module Go workspaces require Go 1.18 or later.
Contributors
![]() Bram Borggreve Creator |
![]() Maxime Malgorn Maintainer |
Licensed under MIT

