Dependencies
- On OSX:
brew install sponge jq protobuf protoc-gen-go protoc-gen-go-grpc golang
- Run
pnpm install
at root
Building
- Building turbo CLI: In
cli
runmake turbo
- Using turbo to build turbo CLI:
./turbow.js
From the cli/
directory, you can
- run smoke tests with
make e2e
- run unit tests with
make test-go
To run a single test, you can run go test ./[path/to/package/]
. See more in the Go docs.
- Install
go install github.com/go-delve/delve/cmd/dlv@latest
- In VS Code's "Run and Debug" tab, select
Build Basic
to start debugging the initial launch ofturbo
against thebuild
target of the Basic Example. This task is configured in launch.json.
You might need to update packages/turbo
in order to support a new platform. When you do that you will need to link the module in order to be able to continue working. As an example, with npm link
:
cd ~/repos/vercel/turborepo/packages/turbo
npm link
# Run your build, e.g. `go build ./cmd/turbo` if you're on the platform you're adding.
cd ~/repos/vercel/turborepo/cli
go build ./cmd/turbo
# You can then run the basic example specifying the build asset path.
cd ~/repos/vercel/turborepo/examples/basic
TURBO_BINARY_PATH=~/repos/vercel/turborepo/cli/turbo.exe npm install
TURBO_BINARY_PATH=~/repos/vercel/turborepo/cli/turbo.exe npm link turbo
If you're using a different package manager replace npm accordingly.
All builds are handled by manually triggering the appropriate release
GitHub workflow.
To manually run a release:
brew install goreleaser
- Add
GORELEASER_KEY
env var with the GoReleaser Pro key (ask @turbo-oss to get access to the key) - Update
version.txt
(do not commit this change to git manually) cd cli && make publish