This doc is for contributors to Temporal Server (hopefully that's you!)
Note: All contributors also need to fill out the Temporal Contributor License Agreement before we can merge in any of your changes.
- Go Lang (minimum version required listed in
go.mod
file):- Install on macOS with
brew install go
. - Install on Ubuntu with
sudo apt install golang
.
- Install on macOS with
- Protocol buffers compiler (only if you are going to change
proto
files):- Install on macOS with
brew install protobuf
. - Download all other versions from protoc release page.
- Install on macOS with
- Temporal CLI
- Homebrew
brew install temporal
- Or download it from here https://github.com/temporalio/cli
- Homebrew
Note: it is possible to run Temporal server without a
docker
. If for some reason (for example, performance on macOS) you want to run dependencies on the host OS, please follow the doc.
For developing on Windows, install Windows Subsystem for Linux 2 (WSL2) and Ubuntu. After that, follow the guidance for installing prerequisites, building, and testing on Ubuntu.
Temporal uses go modules, there is no dependency on $GOPATH
variable. Clone the repo into the preferred location:
git clone https://github.com/temporalio/temporal.git
For the very first time build temporal-server
and helper tools with simple make
command:
make
It will install all other build dependencies and build the binaries.
Further you can build binaries without running tests with:
make bins
Please check the top of our Makefile for other useful build targets.
We defined three categories of tests.
- Unit test: Those tests should not have dependencies other than the test target and go mock. We should have unit test coverage as much as possible.
- Integration test: Those tests cover the integration between the server and the dependencies (Cassandra, SQL, ES etc.).
- Functional test: Those tests cover the E2E functionality of Temporal server. They are all under ./tests directory.
Integration and functional tests require runtime dependencies. They can be run with start-dependencies
target (uses docker compose
internally). Open new terminal window and run:
make start-dependencies
Before testing on macOS, make sure you increase the file handle limit:
ulimit -n 8192
Run unit tests:
make unit-test
Run all integration tests:
make integration-test
Run all functional tests:
make functional-test
Or run all the tests at once:
make test
You can also run a single test:
go test -v <path> -run <TestSuite> -testify.m <TestSpecificTaskName>
for example:
go test -v github.com/temporalio/temporal/common/persistence -run TestCassandraPersistenceSuite -testify.m TestPersistenceStartWorkflow
When you are done, don't forget to stop docker compose
(with Ctrl+C
) and clean up all dependencies:
make stop-dependencies
First start runtime dependencies. They can be run with start-dependencies
target (uses docker compose
internally). Open new terminal window and run:
make start-dependencies
then run the server:
make start
This will start the server using SQLite as database. If you want to run with Cassandra and Elasticsearch, then run these commands:
make install-schema-cass-es
make start-cass-es
Now you can create default namespace with Temporal CLI:
temporal operator namespace create default
and run samples from Go and Java samples repos. Also, you can access web UI at localhost:8080
.
When you are done, press Ctrl+C
to stop the server. Don't forget to stop dependencies (with Ctrl+C
) and clean up resources:
make stop-dependencies
See the developer documentation on testing to learn more about writing tests.
gRPC / protobuf changes merged to the api repo automatically trigger a commit in api-go.
To bring such changes into your feature branch, use make update-go-api
.
If you need to make changes to the gRPC / protobuf definitions while also working on code in this repo, do the following:
- Checkout api, api-go, and sdk-go
- Make your changes to
api
, commit to a branch. - In your copy of
api-go
:- Initialize submodules:
git submodule update --init --recursive
- Point api submodule at your branch. If you make more commits to the api repo, run the last command again.
git submodule set-url proto/api ../api git submodule set-branch --branch mystuff proto/api git submodule update --remote proto/api
- Compile protos:
make proto
- Initialize submodules:
- (Optional, if SDK changes are required:) In your copy of
sdk-go
:- Point
go.mod
at localapi-go
:replace ( go.temporal.io/api => ../api-go )
- Compile & fix errors:
make bins
- Point
- In this repo:
- Point
go.mod
at localapi-go
andsdk-go
:replace ( go.temporal.io/api => ../api-go go.temporal.io/sdk => ../sdk-go )
- Build & fix errors:
make proto && make bins
- Point
This project is Open Source Software, and requires a header at the beginning of all source files. To verify that all files contain the header execute:
make copyright
Overcommit adds some requirements to your commit messages. At Temporal, we follow the Chris Beams guide to writing git commit messages. Read it, follow it, learn it, love it.
All commit messages are from the titles of your pull requests. So make sure follow the rules when titling them. Please don't use very generic titles like "bug fixes".
All PR titles should start with Upper case and have no dot at the end.
Prior to Server version v1.23.0 our protobuf code generator allowed invalid UTF-8 data to be stored as proto strings. This isn't actually allowed by the proto3 spec, so we need to specify -tags protolegacy
when building against the server. Our Makefile does this, but if you're using temporal as a library you'll need to enable that yourself.
Example:
$ go build -tags protolegacy ./cmd/server
If you see an error like grpc: error unmarshalling request: string field contains invalid UTF-8
then you've forgotten to specify this flag.
- In this repository, update
go
ingo.mod
. - In docker-builds, update the base images: base-ci-builder and base-builder
MIT License, please see LICENSE for details.