2016-02-18 10:25:59 +01:00
# Contributing
### Building
2016-09-19 14:05:23 -06:00
You need either [Docker ](https://github.com/docker/docker ) and `make` (Method 1), or `go` and `glide` (Method 2) in order to build traefik.
2016-02-18 10:25:59 +01:00
2016-09-19 14:05:23 -06:00
#### Method 1: Using `Docker` and `Makefile`
2016-02-18 10:25:59 +01:00
You need to run the `binary` target. This will create binaries for Linux platform in the `dist` folder.
```bash
$ make binary
docker build -t "traefik-dev:no-more-godep-ever" -f build.Dockerfile .
Sending build context to Docker daemon 295.3 MB
2016-11-15 17:53:55 +00:00
Step 0 : FROM golang:1.7
2016-02-18 10:25:59 +01:00
---> 8c6473912976
Step 1 : RUN go get github.com/Masterminds/glide
[...]
2016-02-24 16:43:39 +01:00
docker run --rm -v "/var/run/docker.sock:/var/run/docker.sock" -it -e OS_ARCH_ARG -e OS_PLATFORM_ARG -e TESTFLAGS -v "/home/emile/dev/go/src/github.com/containous/traefik/"dist":/go/src/github.com/containous/traefik/"dist"" "traefik-dev:no-more-godep-ever" ./script/make.sh generate binary
2016-02-18 10:25:59 +01:00
---> Making bundle: generate (in .)
removed 'gen.go'
---> Making bundle: binary (in .)
$ ls dist/
traefik*
```
2016-09-19 14:05:23 -06:00
#### Method 2: Using `go` and `glide`
###### Setting up your `go` environment
2016-11-15 17:53:55 +00:00
- You need `go` v1.7+
2016-09-19 14:05:23 -06:00
- It is recommended you clone Træfɪ k into a directory like `~/go/src/github.com/containous/traefik` (This is the official golang workspace hierarchy, and will allow dependencies to resolve properly)
- This will allow your `GOPATH` and `PATH` variable to be set to `~/go` via:
```
$ export GOPATH=~/go
$ export PATH=$PATH:$GOPATH/bin
```
This can be verified via `$ go env`
- You will want to add those 2 export lines to your `.bashrc` or `.bash_profile`
- You need `go-bindata` to be able to use `go generate` command (needed to build) : `$ go get github.com/jteeuwen/go-bindata/...` (Please note, the ellipses are required)
###### Setting up your `glide` environment
- Glide can be installed either via homebrew: `$ brew install glide` or via the official glide script: `$ curl https://glide.sh/get | sh`
2016-02-18 10:25:59 +01:00
The idea behind `glide` is the following :
2017-01-01 15:32:50 +01:00
- when checkout(ing) a project, run `$ glide install -v` from the cloned directory to install
2016-09-19 14:05:23 -06:00
(`go get …` ) the dependencies in your `GOPATH` .
2016-02-18 10:25:59 +01:00
- if you need another dependency, import and use it in
2016-09-19 14:05:23 -06:00
the source, and run `$ glide get github.com/Masterminds/cookoo` to save it in
2016-02-18 10:25:59 +01:00
`vendor` and add it to your `glide.yaml` .
```bash
2017-01-01 15:32:50 +01:00
$ glide install --strip-vendor
2016-09-19 14:05:23 -06:00
# generate (Only required to integrate other components such as web dashboard)
2016-02-18 10:25:59 +01:00
$ go generate
2016-09-19 14:05:23 -06:00
# Standard go build
2016-02-18 10:25:59 +01:00
$ go build
# Using gox to build multiple platform
$ gox "linux darwin" "386 amd64 arm" \
-output="dist/traefik_{{.OS}}-{{.Arch}}"
# run other commands like tests
```
### Tests
2016-09-19 14:05:23 -06:00
##### Method 1: `Docker` and `make`
2016-02-18 10:25:59 +01:00
You can run unit tests using the `test-unit` target and the
integration test using the `test-integration` target.
```bash
$ make test-unit
docker build -t "traefik-dev:your-feature-branch" -f build.Dockerfile .
# […]
2016-02-24 16:43:39 +01:00
docker run --rm -it -e OS_ARCH_ARG -e OS_PLATFORM_ARG -e TESTFLAGS -v "/home/vincent/src/github/vdemeester/traefik/dist:/go/src/github.com/containous/traefik/dist" "traefik-dev:your-feature-branch" ./script/make.sh generate test-unit
2016-02-18 10:25:59 +01:00
---> Making bundle: generate (in .)
removed 'gen.go'
---> Making bundle: test-unit (in .)
+ go test -cover -coverprofile=cover.out .
2016-02-24 16:43:39 +01:00
ok github.com/containous/traefik 0.005s coverage: 4.1% of statements
2016-02-18 10:25:59 +01:00
Test success
```
2016-05-05 21:45:57 +01:00
2016-07-18 14:55:45 +09:00
For development purposes, you can specify which tests to run by using:
2016-05-30 11:10:51 +02:00
```
# Run every tests in the MyTest suite
TESTFLAGS="-check.f MyTestSuite" make test-integration
# Run the test "MyTest" in the MyTest suite
TESTFLAGS="-check.f MyTestSuite.MyTest" make test-integration
# Run every tests starting with "My", in the MyTest suite
TESTFLAGS="-check.f MyTestSuite.My" make test-integration
# Run every tests ending with "Test", in the MyTest suite
TESTFLAGS="-check.f MyTestSuite.*Test" make test-integration
```
More: https://labix.org/gocheck
2016-09-19 14:05:23 -06:00
##### Method 2: `go` and `glide`
- Tests can be run from the cloned directory, by `$ go test ./...` which should return `ok` similar to:
```
ok _/home/vincent/src/github/vdemeester/traefik 0.004s
```
2016-10-30 15:25:52 +01:00
- Note that `$ go test ./...` will run all tests (including the ones in the vendor directory for the dependencies that glide have fetched). If you only want to run the tests for traefik use `$ go test $(glide novendor)` instead.
2016-09-19 14:05:23 -06:00
2016-05-05 21:45:57 +01:00
### Documentation
The [documentation site ](http://docs.traefik.io/ ) is built with [mkdocs ](http://mkdocs.org/ )
First make sure you have python and pip installed
```
$ python --version
Python 2.7.2
$ pip --version
pip 1.5.2
```
Then install mkdocs with pip
```
$ pip install mkdocs
```
2016-07-18 14:55:45 +09:00
To test documentation locally run `mkdocs serve` in the root directory, this should start a server locally to preview your changes.
2016-05-05 21:45:57 +01:00
```
$ mkdocs serve
2016-09-19 14:05:23 -06:00
INFO - Building documentation...
WARNING - Config value: 'theme'. Warning: The theme 'united' will be removed in an upcoming MkDocs release. See http://www.mkdocs.org/about/release-notes/ for more details
INFO - Cleaning site directory
2016-05-05 21:45:57 +01:00
[I 160505 22:31:24 server:281] Serving on http://127.0.0.1:8000
[I 160505 22:31:24 handlers:59] Start watching changes
[I 160505 22:31:24 handlers:61] Start detecting changes
```