Note
This README refers to v3 of the plugin, currently in beta. We look forward to your feedback in #107. If you use Nx < 17, look here.
- Generate Go applications and libraries in seconds within your Nx workspace
- Execute, build, format and test projects with a customizable configuration
- Efficient caching and dependency graph tools for Go projects
- Use official Go commands in the background
You need to have a stable version of Go installed on your machine. And.. you are ready!
As the plugin is still in beta, it is impossible to use the quick commands for workspace creation or addition via Nx. You need to install the plugin manually and initialize it in your workspace. If you don't have one, follow the official documentation to create one.
npm install -D @nx-go/nx-go@beta
nx g @nx-go/nx-go:init
nx migrate @nx-go/nx-go@beta
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-mod
application
: Generate a Go applicationlibrary
: Generate a Go library
build
: Build a Go projectlint
: Format and lint a Go projectserve
: Run a Go applicationtest
: Run tests of a Go project
Tip
You can use nx list @nx-go/nx-go
to see list capabilities.
Want to try out these capabilities quickly? Visit our playground!
nx-go version | Nx version |
---|---|
3.x | 17.x, 18.x |
2.x | 13.x to 16.x |
1.x | < 13.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.
Bram Borggreve Creator |
Maxime Malgorn Maintainer |
Licensed under MIT