mirror of
https://github.com/woodpecker-ci/woodpecker.git
synced 2025-01-10 17:45:36 +00:00
Use array syntax in docs (#3242)
This commit is contained in:
parent
05f24a5706
commit
188d6ed16c
24 changed files with 166 additions and 138 deletions
|
@ -13,11 +13,11 @@ If you are already using containers in your daily workflow, you'll for sure love
|
||||||
|
|
||||||
```yaml title=".woodpecker.yaml"
|
```yaml title=".woodpecker.yaml"
|
||||||
steps:
|
steps:
|
||||||
build:
|
- name: build
|
||||||
image: debian
|
image: debian
|
||||||
commands:
|
commands:
|
||||||
- echo "This is the build step"
|
- echo "This is the build step"
|
||||||
a-test-step:
|
- name: a-test-step
|
||||||
image: debian
|
image: debian
|
||||||
commands:
|
commands:
|
||||||
- echo "Testing.."
|
- echo "Testing.."
|
||||||
|
@ -32,7 +32,7 @@ steps:
|
||||||
|
|
||||||
```diff
|
```diff
|
||||||
steps:
|
steps:
|
||||||
build:
|
- name: build
|
||||||
- image: debian
|
- image: debian
|
||||||
+ image: mycompany/image-with-awscli
|
+ image: mycompany/image-with-awscli
|
||||||
commands:
|
commands:
|
||||||
|
@ -46,11 +46,11 @@ steps:
|
||||||
|
|
||||||
```yaml title=".woodpecker.yaml"
|
```yaml title=".woodpecker.yaml"
|
||||||
steps:
|
steps:
|
||||||
build:
|
- name: build
|
||||||
image: debian
|
image: debian
|
||||||
commands:
|
commands:
|
||||||
- touch myfile
|
- touch myfile
|
||||||
a-test-step:
|
- name: a-test-step
|
||||||
image: debian
|
image: debian
|
||||||
commands:
|
commands:
|
||||||
- cat myfile
|
- cat myfile
|
||||||
|
|
|
@ -30,7 +30,7 @@ Example pipeline configuration:
|
||||||
|
|
||||||
```yaml
|
```yaml
|
||||||
steps:
|
steps:
|
||||||
build:
|
- name: build
|
||||||
image: golang
|
image: golang
|
||||||
commands:
|
commands:
|
||||||
- go get
|
- go get
|
||||||
|
@ -38,7 +38,7 @@ steps:
|
||||||
- go test
|
- go test
|
||||||
|
|
||||||
services:
|
services:
|
||||||
postgres:
|
- name: postgres
|
||||||
image: postgres:9.4.5
|
image: postgres:9.4.5
|
||||||
environment:
|
environment:
|
||||||
- POSTGRES_USER=myapp
|
- POSTGRES_USER=myapp
|
||||||
|
@ -48,20 +48,20 @@ Example pipeline configuration with multiple, serial steps:
|
||||||
|
|
||||||
```yaml
|
```yaml
|
||||||
steps:
|
steps:
|
||||||
backend:
|
- name: backend
|
||||||
image: golang
|
image: golang
|
||||||
commands:
|
commands:
|
||||||
- go get
|
- go get
|
||||||
- go build
|
- go build
|
||||||
- go test
|
- go test
|
||||||
|
|
||||||
frontend:
|
- name: frontend
|
||||||
image: node:6
|
image: node:6
|
||||||
commands:
|
commands:
|
||||||
- npm install
|
- npm install
|
||||||
- npm test
|
- npm test
|
||||||
|
|
||||||
notify:
|
- name: notify
|
||||||
image: plugins/slack
|
image: plugins/slack
|
||||||
channel: developers
|
channel: developers
|
||||||
username: woodpecker
|
username: woodpecker
|
||||||
|
|
|
@ -4,25 +4,6 @@ The workflow section defines a list of steps to build, test and deploy your code
|
||||||
|
|
||||||
Example steps:
|
Example steps:
|
||||||
|
|
||||||
```yaml
|
|
||||||
steps:
|
|
||||||
backend:
|
|
||||||
image: golang
|
|
||||||
commands:
|
|
||||||
- go build
|
|
||||||
- go test
|
|
||||||
frontend:
|
|
||||||
image: node
|
|
||||||
commands:
|
|
||||||
- npm install
|
|
||||||
- npm run test
|
|
||||||
- npm run build
|
|
||||||
```
|
|
||||||
|
|
||||||
In the above example we define two steps, `frontend` and `backend`. The names of these steps are completely arbitrary.
|
|
||||||
|
|
||||||
Another way to name a step is by using the name keyword:
|
|
||||||
|
|
||||||
```yaml
|
```yaml
|
||||||
steps:
|
steps:
|
||||||
- name: backend
|
- name: backend
|
||||||
|
@ -38,7 +19,26 @@ steps:
|
||||||
- npm run build
|
- npm run build
|
||||||
```
|
```
|
||||||
|
|
||||||
Keep in mind the name is optional, if not added the steps will be numerated.
|
In the above example we define two steps, `frontend` and `backend`. The names of these steps are completely arbitrary.
|
||||||
|
|
||||||
|
The name is optional, if not added the steps will be numerated.
|
||||||
|
|
||||||
|
Another way to name a step is by using dictionaries:
|
||||||
|
|
||||||
|
```yaml
|
||||||
|
steps:
|
||||||
|
backend:
|
||||||
|
image: golang
|
||||||
|
commands:
|
||||||
|
- go build
|
||||||
|
- go test
|
||||||
|
frontend:
|
||||||
|
image: node
|
||||||
|
commands:
|
||||||
|
- npm install
|
||||||
|
- npm run test
|
||||||
|
- npm run build
|
||||||
|
```
|
||||||
|
|
||||||
## Skip Commits
|
## Skip Commits
|
||||||
|
|
||||||
|
@ -55,7 +55,7 @@ The associated commit is checked out with git to a workspace which is mounted to
|
||||||
|
|
||||||
```diff
|
```diff
|
||||||
steps:
|
steps:
|
||||||
backend:
|
- name: backend
|
||||||
image: golang
|
image: golang
|
||||||
commands:
|
commands:
|
||||||
+ - go build
|
+ - go build
|
||||||
|
@ -69,11 +69,11 @@ The associated commit is checked out with git to a workspace which is mounted to
|
||||||
|
|
||||||
```yaml title=".woodpecker.yaml"
|
```yaml title=".woodpecker.yaml"
|
||||||
steps:
|
steps:
|
||||||
build:
|
- name: build
|
||||||
image: debian
|
image: debian
|
||||||
commands:
|
commands:
|
||||||
- echo "test content" > myfile
|
- echo "test content" > myfile
|
||||||
a-test-step:
|
- name: a-test-step
|
||||||
image: debian
|
image: debian
|
||||||
commands:
|
commands:
|
||||||
- cat myfile
|
- cat myfile
|
||||||
|
@ -87,18 +87,18 @@ When using the `local` backend, the `image` entry is used to specify the shell,
|
||||||
|
|
||||||
```diff
|
```diff
|
||||||
steps:
|
steps:
|
||||||
build:
|
- name: build
|
||||||
+ image: golang:1.6
|
+ image: golang:1.6
|
||||||
commands:
|
commands:
|
||||||
- go build
|
- go build
|
||||||
- go test
|
- go test
|
||||||
|
|
||||||
publish:
|
- name: publish
|
||||||
+ image: plugins/docker
|
+ image: plugins/docker
|
||||||
repo: foo/bar
|
repo: foo/bar
|
||||||
|
|
||||||
services:
|
services:
|
||||||
database:
|
- name: database
|
||||||
+ image: mysql
|
+ image: mysql
|
||||||
```
|
```
|
||||||
|
|
||||||
|
@ -116,7 +116,7 @@ Woodpecker does not automatically upgrade container images. Example configuratio
|
||||||
|
|
||||||
```diff
|
```diff
|
||||||
steps:
|
steps:
|
||||||
build:
|
- name: build
|
||||||
image: golang:latest
|
image: golang:latest
|
||||||
+ pull: true
|
+ pull: true
|
||||||
```
|
```
|
||||||
|
@ -129,7 +129,7 @@ Commands of every step are executed serially as if you would enter them into you
|
||||||
|
|
||||||
```diff
|
```diff
|
||||||
steps:
|
steps:
|
||||||
backend:
|
- name: backend
|
||||||
image: golang
|
image: golang
|
||||||
commands:
|
commands:
|
||||||
+ - go build
|
+ - go build
|
||||||
|
@ -178,7 +178,7 @@ Some of the steps may be allowed to fail without causing the whole workflow and
|
||||||
|
|
||||||
```diff
|
```diff
|
||||||
steps:
|
steps:
|
||||||
backend:
|
- name: backend
|
||||||
image: golang
|
image: golang
|
||||||
commands:
|
commands:
|
||||||
- go build
|
- go build
|
||||||
|
@ -192,7 +192,7 @@ Woodpecker supports defining a list of conditions for a step by using a `when` b
|
||||||
|
|
||||||
```diff
|
```diff
|
||||||
steps:
|
steps:
|
||||||
slack:
|
- name: slack
|
||||||
image: plugins/slack
|
image: plugins/slack
|
||||||
settings:
|
settings:
|
||||||
channel: dev
|
channel: dev
|
||||||
|
@ -209,7 +209,7 @@ Example conditional execution by repository:
|
||||||
|
|
||||||
```diff
|
```diff
|
||||||
steps:
|
steps:
|
||||||
slack:
|
- name: slack
|
||||||
image: plugins/slack
|
image: plugins/slack
|
||||||
settings:
|
settings:
|
||||||
channel: dev
|
channel: dev
|
||||||
|
@ -227,7 +227,7 @@ Example conditional execution by branch:
|
||||||
|
|
||||||
```diff
|
```diff
|
||||||
steps:
|
steps:
|
||||||
slack:
|
- name: slack
|
||||||
image: plugins/slack
|
image: plugins/slack
|
||||||
settings:
|
settings:
|
||||||
channel: dev
|
channel: dev
|
||||||
|
@ -324,7 +324,7 @@ There are use cases for executing steps on failure, such as sending notification
|
||||||
|
|
||||||
```diff
|
```diff
|
||||||
steps:
|
steps:
|
||||||
slack:
|
- name: slack
|
||||||
image: plugins/slack
|
image: plugins/slack
|
||||||
settings:
|
settings:
|
||||||
channel: dev
|
channel: dev
|
||||||
|
@ -457,18 +457,18 @@ Normally steps of a workflow are executed serially in the order in which they ar
|
||||||
|
|
||||||
```diff
|
```diff
|
||||||
steps:
|
steps:
|
||||||
build: # build will be executed immediately
|
- name: build # build will be executed immediately
|
||||||
image: golang
|
image: golang
|
||||||
commands:
|
commands:
|
||||||
- go build
|
- go build
|
||||||
|
|
||||||
deploy:
|
- name: deploy
|
||||||
image: plugins/docker
|
image: plugins/docker
|
||||||
settings:
|
settings:
|
||||||
repo: foo/bar
|
repo: foo/bar
|
||||||
+ depends_on: [build, test] # deploy will be executed after build and test finished
|
+ depends_on: [build, test] # deploy will be executed after build and test finished
|
||||||
|
|
||||||
test: # test will be executed immediately as no dependencies are set
|
- name: test # test will be executed immediately as no dependencies are set
|
||||||
image: golang
|
image: golang
|
||||||
commands:
|
commands:
|
||||||
- go test
|
- go test
|
||||||
|
@ -508,7 +508,7 @@ The workspace can be customized using the workspace block in the YAML file:
|
||||||
+ path: src/github.com/octocat/hello-world
|
+ path: src/github.com/octocat/hello-world
|
||||||
|
|
||||||
steps:
|
steps:
|
||||||
build:
|
- name: build
|
||||||
image: golang:latest
|
image: golang:latest
|
||||||
commands:
|
commands:
|
||||||
- go get
|
- go get
|
||||||
|
@ -523,12 +523,12 @@ The base attribute defines a shared base volume available to all steps. This ens
|
||||||
path: src/github.com/octocat/hello-world
|
path: src/github.com/octocat/hello-world
|
||||||
|
|
||||||
steps:
|
steps:
|
||||||
deps:
|
- name: deps
|
||||||
image: golang:latest
|
image: golang:latest
|
||||||
commands:
|
commands:
|
||||||
- go get
|
- go get
|
||||||
- go test
|
- go test
|
||||||
build:
|
- name: build
|
||||||
image: node:latest
|
image: node:latest
|
||||||
commands:
|
commands:
|
||||||
- go build
|
- go build
|
||||||
|
@ -580,7 +580,7 @@ You can add additional labels as a key value map:
|
||||||
+ hostname: "" # this label will be ignored as it is empty
|
+ hostname: "" # this label will be ignored as it is empty
|
||||||
|
|
||||||
steps:
|
steps:
|
||||||
build:
|
- name: build
|
||||||
image: golang
|
image: golang
|
||||||
commands:
|
commands:
|
||||||
- go build
|
- go build
|
||||||
|
@ -622,7 +622,7 @@ You can manually configure the clone step in your workflow for customization:
|
||||||
+ image: woodpeckerci/plugin-git
|
+ image: woodpeckerci/plugin-git
|
||||||
|
|
||||||
steps:
|
steps:
|
||||||
build:
|
- name: build
|
||||||
image: golang
|
image: golang
|
||||||
commands:
|
commands:
|
||||||
- go build
|
- go build
|
||||||
|
@ -633,7 +633,7 @@ Example configuration to override depth:
|
||||||
|
|
||||||
```diff
|
```diff
|
||||||
clone:
|
clone:
|
||||||
git:
|
- name: git
|
||||||
image: woodpeckerci/plugin-git
|
image: woodpeckerci/plugin-git
|
||||||
+ settings:
|
+ settings:
|
||||||
+ partial: false
|
+ partial: false
|
||||||
|
@ -652,7 +652,7 @@ Example configuration to clone Mercurial repository:
|
||||||
|
|
||||||
```diff
|
```diff
|
||||||
clone:
|
clone:
|
||||||
hg:
|
- name: hg
|
||||||
+ image: plugins/hg
|
+ image: plugins/hg
|
||||||
+ settings:
|
+ settings:
|
||||||
+ path: bitbucket.org/foo/bar
|
+ path: bitbucket.org/foo/bar
|
||||||
|
@ -673,7 +673,7 @@ To use the ssh git url in `.gitmodules` for users cloning with ssh, and also use
|
||||||
|
|
||||||
```diff
|
```diff
|
||||||
clone:
|
clone:
|
||||||
git:
|
- name: git
|
||||||
image: woodpeckerci/plugin-git
|
image: woodpeckerci/plugin-git
|
||||||
settings:
|
settings:
|
||||||
recursive: true
|
recursive: true
|
||||||
|
@ -705,7 +705,7 @@ Example conditional execution by repository:
|
||||||
+ repo: test/test
|
+ repo: test/test
|
||||||
+
|
+
|
||||||
steps:
|
steps:
|
||||||
slack:
|
- name: slack
|
||||||
image: plugins/slack
|
image: plugins/slack
|
||||||
settings:
|
settings:
|
||||||
channel: dev
|
channel: dev
|
||||||
|
@ -724,7 +724,7 @@ Example conditional execution by branch:
|
||||||
+ branch: main
|
+ branch: main
|
||||||
+
|
+
|
||||||
steps:
|
steps:
|
||||||
slack:
|
- name: slack
|
||||||
image: plugins/slack
|
image: plugins/slack
|
||||||
settings:
|
settings:
|
||||||
channel: dev
|
channel: dev
|
||||||
|
@ -862,14 +862,14 @@ Privileged mode is only available to trusted repositories and for security reaso
|
||||||
|
|
||||||
```diff
|
```diff
|
||||||
steps:
|
steps:
|
||||||
build:
|
- name: build
|
||||||
image: docker
|
image: docker
|
||||||
environment:
|
environment:
|
||||||
- DOCKER_HOST=tcp://docker:2375
|
- DOCKER_HOST=tcp://docker:2375
|
||||||
commands:
|
commands:
|
||||||
- docker --tls=false ps
|
- docker --tls=false ps
|
||||||
|
|
||||||
services:
|
- name: services
|
||||||
docker:
|
docker:
|
||||||
image: docker:dind
|
image: docker:dind
|
||||||
commands: dockerd-entrypoint.sh --storage-driver=vfs --tls=false
|
commands: dockerd-entrypoint.sh --storage-driver=vfs --tls=false
|
||||||
|
|
|
@ -31,7 +31,7 @@ If you still need to pass artifacts between the workflows you need use some stor
|
||||||
|
|
||||||
```yaml title=".woodpecker/.build.yaml"
|
```yaml title=".woodpecker/.build.yaml"
|
||||||
steps:
|
steps:
|
||||||
build:
|
- name: build
|
||||||
image: debian:stable-slim
|
image: debian:stable-slim
|
||||||
commands:
|
commands:
|
||||||
- echo building
|
- echo building
|
||||||
|
@ -40,7 +40,7 @@ steps:
|
||||||
|
|
||||||
```yaml title=".woodpecker/.deploy.yaml"
|
```yaml title=".woodpecker/.deploy.yaml"
|
||||||
steps:
|
steps:
|
||||||
deploy:
|
- name: deploy
|
||||||
image: debian:stable-slim
|
image: debian:stable-slim
|
||||||
commands:
|
commands:
|
||||||
- echo deploying
|
- echo deploying
|
||||||
|
@ -53,7 +53,7 @@ depends_on:
|
||||||
|
|
||||||
```yaml title=".woodpecker/.test.yaml"
|
```yaml title=".woodpecker/.test.yaml"
|
||||||
steps:
|
steps:
|
||||||
test:
|
- name: test
|
||||||
image: debian:stable-slim
|
image: debian:stable-slim
|
||||||
commands:
|
commands:
|
||||||
- echo testing
|
- echo testing
|
||||||
|
@ -65,7 +65,7 @@ depends_on:
|
||||||
|
|
||||||
```yaml title=".woodpecker/.lint.yaml"
|
```yaml title=".woodpecker/.lint.yaml"
|
||||||
steps:
|
steps:
|
||||||
lint:
|
- name: lint
|
||||||
image: debian:stable-slim
|
image: debian:stable-slim
|
||||||
commands:
|
commands:
|
||||||
- echo linting
|
- echo linting
|
||||||
|
@ -86,7 +86,7 @@ The name for a `depends_on` entry is the filename without the path, leading dots
|
||||||
|
|
||||||
```diff
|
```diff
|
||||||
steps:
|
steps:
|
||||||
deploy:
|
- name: deploy
|
||||||
image: debian:stable-slim
|
image: debian:stable-slim
|
||||||
commands:
|
commands:
|
||||||
- echo deploying
|
- echo deploying
|
||||||
|
@ -101,7 +101,7 @@ Workflows that need to run even on failures should set the `runs_on` tag.
|
||||||
|
|
||||||
```diff
|
```diff
|
||||||
steps:
|
steps:
|
||||||
notify:
|
- name: notify
|
||||||
image: debian:stable-slim
|
image: debian:stable-slim
|
||||||
commands:
|
commands:
|
||||||
- echo notifying
|
- echo notifying
|
||||||
|
|
|
@ -43,7 +43,7 @@ matrix:
|
||||||
- mariadb:10.1
|
- mariadb:10.1
|
||||||
|
|
||||||
steps:
|
steps:
|
||||||
build:
|
- name: build
|
||||||
image: golang:${GO_VERSION}
|
image: golang:${GO_VERSION}
|
||||||
commands:
|
commands:
|
||||||
- go get
|
- go get
|
||||||
|
@ -51,7 +51,7 @@ steps:
|
||||||
- go test
|
- go test
|
||||||
|
|
||||||
services:
|
services:
|
||||||
database:
|
- name: database
|
||||||
image: ${DATABASE}
|
image: ${DATABASE}
|
||||||
```
|
```
|
||||||
|
|
||||||
|
@ -59,7 +59,7 @@ Example YAML file after injecting the matrix parameters:
|
||||||
|
|
||||||
```diff
|
```diff
|
||||||
steps:
|
steps:
|
||||||
build:
|
- name: build
|
||||||
- image: golang:${GO_VERSION}
|
- image: golang:${GO_VERSION}
|
||||||
+ image: golang:1.4
|
+ image: golang:1.4
|
||||||
commands:
|
commands:
|
||||||
|
@ -71,7 +71,7 @@ Example YAML file after injecting the matrix parameters:
|
||||||
+ - DATABASE=mysql:8
|
+ - DATABASE=mysql:8
|
||||||
|
|
||||||
services:
|
services:
|
||||||
database:
|
- name: database
|
||||||
- image: ${DATABASE}
|
- image: ${DATABASE}
|
||||||
+ image: mysql:8
|
+ image: mysql:8
|
||||||
```
|
```
|
||||||
|
@ -88,7 +88,7 @@ matrix:
|
||||||
- latest
|
- latest
|
||||||
|
|
||||||
steps:
|
steps:
|
||||||
build:
|
- name: build
|
||||||
image: golang:${TAG}
|
image: golang:${TAG}
|
||||||
commands:
|
commands:
|
||||||
- go build
|
- go build
|
||||||
|
@ -105,7 +105,7 @@ matrix:
|
||||||
- golang:latest
|
- golang:latest
|
||||||
|
|
||||||
steps:
|
steps:
|
||||||
build:
|
- name: build
|
||||||
image: ${IMAGE}
|
image: ${IMAGE}
|
||||||
commands:
|
commands:
|
||||||
- go build
|
- go build
|
||||||
|
@ -124,12 +124,12 @@ labels:
|
||||||
platform: ${platform}
|
platform: ${platform}
|
||||||
|
|
||||||
steps:
|
steps:
|
||||||
test:
|
- name: test
|
||||||
image: alpine
|
image: alpine
|
||||||
commands:
|
commands:
|
||||||
- echo "I am running on ${platform}"
|
- echo "I am running on ${platform}"
|
||||||
|
|
||||||
test-arm-only:
|
- name: test-arm-only
|
||||||
image: alpine
|
image: alpine
|
||||||
commands:
|
commands:
|
||||||
- echo "I am running on ${platform}"
|
- echo "I am running on ${platform}"
|
||||||
|
|
|
@ -18,7 +18,7 @@ once their usage is declared in the `secrets` section:
|
||||||
|
|
||||||
```diff
|
```diff
|
||||||
steps:
|
steps:
|
||||||
docker:
|
- name: docker
|
||||||
image: docker
|
image: docker
|
||||||
commands:
|
commands:
|
||||||
+ - echo $DOCKER_USERNAME
|
+ - echo $DOCKER_USERNAME
|
||||||
|
@ -35,7 +35,7 @@ In this example, the secret named `secret_token` would be passed to the setting
|
||||||
|
|
||||||
```diff
|
```diff
|
||||||
steps:
|
steps:
|
||||||
docker:
|
- name: docker
|
||||||
image: my-plugin
|
image: my-plugin
|
||||||
settings:
|
settings:
|
||||||
+ token:
|
+ token:
|
||||||
|
@ -48,7 +48,7 @@ Please note parameter expressions are subject to pre-processing. When using secr
|
||||||
|
|
||||||
```diff
|
```diff
|
||||||
steps:
|
steps:
|
||||||
docker:
|
- name: docker
|
||||||
image: docker
|
image: docker
|
||||||
commands:
|
commands:
|
||||||
- - echo ${DOCKER_USERNAME}
|
- - echo ${DOCKER_USERNAME}
|
||||||
|
@ -64,7 +64,7 @@ There may be scenarios where you are required to store secrets using alternate n
|
||||||
|
|
||||||
```diff
|
```diff
|
||||||
steps:
|
steps:
|
||||||
docker:
|
- name: docker
|
||||||
image: plugins/docker
|
image: plugins/docker
|
||||||
repo: octocat/hello-world
|
repo: octocat/hello-world
|
||||||
tags: latest
|
tags: latest
|
||||||
|
|
|
@ -12,7 +12,7 @@ Example configuration using a private image:
|
||||||
|
|
||||||
```diff
|
```diff
|
||||||
steps:
|
steps:
|
||||||
build:
|
- name: build
|
||||||
+ image: gcr.io/custom/golang
|
+ image: gcr.io/custom/golang
|
||||||
commands:
|
commands:
|
||||||
- go build
|
- go build
|
||||||
|
@ -55,14 +55,14 @@ With a `Dockerfile` at the root of the project:
|
||||||
|
|
||||||
```yaml
|
```yaml
|
||||||
steps:
|
steps:
|
||||||
build-image:
|
- name: build-image
|
||||||
image: docker
|
image: docker
|
||||||
commands:
|
commands:
|
||||||
- docker build --rm -t local/project-image .
|
- docker build --rm -t local/project-image .
|
||||||
volumes:
|
volumes:
|
||||||
- /var/run/docker.sock:/var/run/docker.sock
|
- /var/run/docker.sock:/var/run/docker.sock
|
||||||
|
|
||||||
build-project:
|
- name: build-project
|
||||||
image: local/project-image
|
image: local/project-image
|
||||||
commands:
|
commands:
|
||||||
- ./build.sh
|
- ./build.sh
|
||||||
|
|
|
@ -8,7 +8,7 @@ To configure cron jobs you need at least push access to the repository.
|
||||||
|
|
||||||
```diff
|
```diff
|
||||||
steps:
|
steps:
|
||||||
sync_locales:
|
- name: sync_locales
|
||||||
image: weblate_sync
|
image: weblate_sync
|
||||||
settings:
|
settings:
|
||||||
url: example.com
|
url: example.com
|
||||||
|
|
|
@ -4,7 +4,7 @@ Woodpecker provides the ability to pass environment variables to individual pipe
|
||||||
|
|
||||||
```diff
|
```diff
|
||||||
steps:
|
steps:
|
||||||
build:
|
- name: build
|
||||||
image: golang
|
image: golang
|
||||||
+ environment:
|
+ environment:
|
||||||
+ - CGO=0
|
+ - CGO=0
|
||||||
|
@ -19,7 +19,7 @@ Please note that the environment section is not able to expand environment varia
|
||||||
|
|
||||||
```diff
|
```diff
|
||||||
steps:
|
steps:
|
||||||
build:
|
- name: build
|
||||||
image: golang
|
image: golang
|
||||||
- environment:
|
- environment:
|
||||||
- - PATH=$PATH:/go
|
- - PATH=$PATH:/go
|
||||||
|
@ -35,7 +35,7 @@ Please note that the environment section is not able to expand environment varia
|
||||||
|
|
||||||
```diff
|
```diff
|
||||||
steps:
|
steps:
|
||||||
build:
|
- name: build
|
||||||
image: golang
|
image: golang
|
||||||
commands:
|
commands:
|
||||||
- - export PATH=${PATH}:/go
|
- - export PATH=${PATH}:/go
|
||||||
|
@ -153,7 +153,7 @@ WOODPECKER_ENVIRONMENT=GOLANG_VERSION:1.18
|
||||||
|
|
||||||
```diff
|
```diff
|
||||||
steps:
|
steps:
|
||||||
build:
|
- name: build
|
||||||
- image: golang:1.18
|
- image: golang:1.18
|
||||||
+ image: golang:${GOLANG_VERSION}
|
+ image: golang:${GOLANG_VERSION}
|
||||||
commands:
|
commands:
|
||||||
|
@ -168,7 +168,7 @@ Example commit substitution:
|
||||||
|
|
||||||
```diff
|
```diff
|
||||||
steps:
|
steps:
|
||||||
docker:
|
- name: docker
|
||||||
image: plugins/docker
|
image: plugins/docker
|
||||||
settings:
|
settings:
|
||||||
+ tags: ${CI_COMMIT_SHA}
|
+ tags: ${CI_COMMIT_SHA}
|
||||||
|
@ -178,7 +178,7 @@ Example tag substitution:
|
||||||
|
|
||||||
```diff
|
```diff
|
||||||
steps:
|
steps:
|
||||||
docker:
|
- name: docker
|
||||||
image: plugins/docker
|
image: plugins/docker
|
||||||
settings:
|
settings:
|
||||||
+ tags: ${CI_COMMIT_TAG}
|
+ tags: ${CI_COMMIT_TAG}
|
||||||
|
@ -206,7 +206,7 @@ Example variable substitution with substring:
|
||||||
|
|
||||||
```diff
|
```diff
|
||||||
steps:
|
steps:
|
||||||
docker:
|
- name: docker
|
||||||
image: plugins/docker
|
image: plugins/docker
|
||||||
settings:
|
settings:
|
||||||
+ tags: ${CI_COMMIT_SHA:0:8}
|
+ tags: ${CI_COMMIT_SHA:0:8}
|
||||||
|
@ -216,7 +216,7 @@ Example variable substitution strips `v` prefix from `v.1.0.0`:
|
||||||
|
|
||||||
```diff
|
```diff
|
||||||
steps:
|
steps:
|
||||||
docker:
|
- name: docker
|
||||||
image: plugins/docker
|
image: plugins/docker
|
||||||
settings:
|
settings:
|
||||||
+ tags: ${CI_COMMIT_TAG##v}
|
+ tags: ${CI_COMMIT_TAG##v}
|
||||||
|
|
|
@ -8,19 +8,19 @@ Example pipeline using the Docker and Slack plugins:
|
||||||
|
|
||||||
```yaml
|
```yaml
|
||||||
steps:
|
steps:
|
||||||
build:
|
- name: build
|
||||||
image: golang
|
image: golang
|
||||||
commands:
|
commands:
|
||||||
- go build
|
- go build
|
||||||
- go test
|
- go test
|
||||||
|
|
||||||
publish:
|
- name: publish
|
||||||
image: plugins/docker
|
image: plugins/docker
|
||||||
settings:
|
settings:
|
||||||
repo: foo/bar
|
repo: foo/bar
|
||||||
tags: latest
|
tags: latest
|
||||||
|
|
||||||
notify:
|
- name: notify
|
||||||
image: plugins/slack
|
image: plugins/slack
|
||||||
settings:
|
settings:
|
||||||
channel: dev
|
channel: dev
|
||||||
|
|
|
@ -28,7 +28,7 @@ It's also possible to use complex settings like this:
|
||||||
|
|
||||||
```yaml
|
```yaml
|
||||||
steps:
|
steps:
|
||||||
plugin:
|
- name: plugin
|
||||||
image: foo/plugin
|
image: foo/plugin
|
||||||
settings:
|
settings:
|
||||||
complex:
|
complex:
|
||||||
|
@ -58,7 +58,7 @@ The below example demonstrates how we might configure a webhook plugin in the YA
|
||||||
|
|
||||||
```yaml
|
```yaml
|
||||||
steps:
|
steps:
|
||||||
webhook:
|
- name: webhook
|
||||||
image: foo/webhook
|
image: foo/webhook
|
||||||
settings:
|
settings:
|
||||||
url: https://example.com
|
url: https://example.com
|
||||||
|
|
|
@ -8,17 +8,17 @@ In the example below, the MySQL service is assigned the hostname `database` and
|
||||||
|
|
||||||
```yaml
|
```yaml
|
||||||
steps:
|
steps:
|
||||||
build:
|
- name: build
|
||||||
image: golang
|
image: golang
|
||||||
commands:
|
commands:
|
||||||
- go build
|
- go build
|
||||||
- go test
|
- go test
|
||||||
|
|
||||||
services:
|
services:
|
||||||
database:
|
- name: database
|
||||||
image: mysql
|
image: mysql
|
||||||
|
|
||||||
cache:
|
- name: cache
|
||||||
image: redis
|
image: redis
|
||||||
```
|
```
|
||||||
|
|
||||||
|
@ -26,12 +26,12 @@ You can define a port and a protocol explicitly:
|
||||||
|
|
||||||
```yaml
|
```yaml
|
||||||
services:
|
services:
|
||||||
database:
|
- name: database
|
||||||
image: mysql
|
image: mysql
|
||||||
ports:
|
ports:
|
||||||
- 3306
|
- 3306
|
||||||
|
|
||||||
wireguard:
|
- name: wireguard
|
||||||
image: wg
|
image: wg
|
||||||
ports:
|
ports:
|
||||||
- 51820/udp
|
- 51820/udp
|
||||||
|
@ -43,13 +43,13 @@ Service containers generally expose environment variables to customize service s
|
||||||
|
|
||||||
```diff
|
```diff
|
||||||
services:
|
services:
|
||||||
database:
|
- name: database
|
||||||
image: mysql
|
image: mysql
|
||||||
+ environment:
|
+ environment:
|
||||||
+ - MYSQL_DATABASE=test
|
+ - MYSQL_DATABASE=test
|
||||||
+ - MYSQL_ALLOW_EMPTY_PASSWORD=yes
|
+ - MYSQL_ALLOW_EMPTY_PASSWORD=yes
|
||||||
|
|
||||||
cache:
|
- name: cache
|
||||||
image: redis
|
image: redis
|
||||||
```
|
```
|
||||||
|
|
||||||
|
@ -59,17 +59,17 @@ Service and long running containers can also be included in the pipeline section
|
||||||
|
|
||||||
```diff
|
```diff
|
||||||
steps:
|
steps:
|
||||||
build:
|
- name: build
|
||||||
image: golang
|
image: golang
|
||||||
commands:
|
commands:
|
||||||
- go build
|
- go build
|
||||||
- go test
|
- go test
|
||||||
|
|
||||||
database:
|
- name: database
|
||||||
image: redis
|
image: redis
|
||||||
+ detach: true
|
+ detach: true
|
||||||
|
|
||||||
test:
|
- name: test
|
||||||
image: golang
|
image: golang
|
||||||
commands:
|
commands:
|
||||||
- go test
|
- go test
|
||||||
|
@ -83,7 +83,7 @@ Service containers require time to initialize and begin to accept connections. I
|
||||||
|
|
||||||
```diff
|
```diff
|
||||||
steps:
|
steps:
|
||||||
test:
|
- name: test
|
||||||
image: golang
|
image: golang
|
||||||
commands:
|
commands:
|
||||||
+ - sleep 15
|
+ - sleep 15
|
||||||
|
@ -91,7 +91,7 @@ Service containers require time to initialize and begin to accept connections. I
|
||||||
- go test
|
- go test
|
||||||
|
|
||||||
services:
|
services:
|
||||||
database:
|
- name: database
|
||||||
image: mysql
|
image: mysql
|
||||||
```
|
```
|
||||||
|
|
||||||
|
@ -99,13 +99,13 @@ Service containers require time to initialize and begin to accept connections. I
|
||||||
|
|
||||||
```yaml
|
```yaml
|
||||||
services:
|
services:
|
||||||
database:
|
- name: database
|
||||||
image: mysql
|
image: mysql
|
||||||
environment:
|
environment:
|
||||||
- MYSQL_DATABASE=test
|
- MYSQL_DATABASE=test
|
||||||
- MYSQL_ROOT_PASSWORD=example
|
- MYSQL_ROOT_PASSWORD=example
|
||||||
steps:
|
steps:
|
||||||
get-version:
|
- name: get-version
|
||||||
image: ubuntu
|
image: ubuntu
|
||||||
commands:
|
commands:
|
||||||
- ( apt update && apt dist-upgrade -y && apt install -y mysql-client 2>&1 )> /dev/null
|
- ( apt update && apt dist-upgrade -y && apt install -y mysql-client 2>&1 )> /dev/null
|
||||||
|
|
|
@ -8,7 +8,7 @@ Volumes are only available to trusted repositories and for security reasons shou
|
||||||
|
|
||||||
```diff
|
```diff
|
||||||
steps:
|
steps:
|
||||||
build:
|
- name: build
|
||||||
image: docker
|
image: docker
|
||||||
commands:
|
commands:
|
||||||
- docker build --rm -t octocat/hello-world .
|
- docker build --rm -t octocat/hello-world .
|
||||||
|
|
|
@ -12,10 +12,10 @@ To convert this:
|
||||||
|
|
||||||
```yaml
|
```yaml
|
||||||
steps:
|
steps:
|
||||||
test:
|
- name: test
|
||||||
image: golang:1.18
|
image: golang:1.18
|
||||||
commands: go test ./...
|
commands: go test ./...
|
||||||
build:
|
- name: build
|
||||||
image: golang:1.18
|
image: golang:1.18
|
||||||
commands: build
|
commands: build
|
||||||
```
|
```
|
||||||
|
@ -27,11 +27,11 @@ Just add a new section called **variables** like this:
|
||||||
+ - &golang_image 'golang:1.18'
|
+ - &golang_image 'golang:1.18'
|
||||||
|
|
||||||
steps:
|
steps:
|
||||||
test:
|
- name: test
|
||||||
- image: golang:1.18
|
- image: golang:1.18
|
||||||
+ image: *golang_image
|
+ image: *golang_image
|
||||||
commands: go test ./...
|
commands: go test ./...
|
||||||
build:
|
- name: build
|
||||||
- image: golang:1.18
|
- image: golang:1.18
|
||||||
+ image: *golang_image
|
+ image: *golang_image
|
||||||
commands: build
|
commands: build
|
||||||
|
@ -50,14 +50,14 @@ variables:
|
||||||
- &some-plugin codeberg.org/6543/docker-images/print_env
|
- &some-plugin codeberg.org/6543/docker-images/print_env
|
||||||
|
|
||||||
steps:
|
steps:
|
||||||
develop:
|
- name: develop
|
||||||
image: *some-plugin
|
image: *some-plugin
|
||||||
settings:
|
settings:
|
||||||
<<: [*base-plugin-settings, *special-setting] # merge two maps into an empty map
|
<<: [*base-plugin-settings, *special-setting] # merge two maps into an empty map
|
||||||
when:
|
when:
|
||||||
branch: develop
|
branch: develop
|
||||||
|
|
||||||
main:
|
- name: main
|
||||||
image: *some-plugin
|
image: *some-plugin
|
||||||
settings:
|
settings:
|
||||||
<<: *base-plugin-settings # merge one map and ...
|
<<: *base-plugin-settings # merge one map and ...
|
||||||
|
@ -80,13 +80,13 @@ variables:
|
||||||
- echo hello
|
- echo hello
|
||||||
|
|
||||||
steps:
|
steps:
|
||||||
step1:
|
- name: step1
|
||||||
image: debian
|
image: debian
|
||||||
commands:
|
commands:
|
||||||
- <<: *pre_cmds # prepend a sequence
|
- <<: *pre_cmds # prepend a sequence
|
||||||
- echo exec step now do dedicated things
|
- echo exec step now do dedicated things
|
||||||
- <<: *post_cmds # append a sequence
|
- <<: *post_cmds # append a sequence
|
||||||
step2:
|
- name: step2
|
||||||
image: debian
|
image: debian
|
||||||
commands:
|
commands:
|
||||||
- <<: [*pre_cmds, *hello_cmd] # prepend two sequences
|
- <<: [*pre_cmds, *hello_cmd] # prepend two sequences
|
||||||
|
@ -105,13 +105,13 @@ One can create a file containing environment variables, and then source it in ea
|
||||||
|
|
||||||
```yaml
|
```yaml
|
||||||
steps:
|
steps:
|
||||||
init:
|
- name: init
|
||||||
image: bash
|
image: bash
|
||||||
commands:
|
commands:
|
||||||
- echo "FOO=hello" >> envvars
|
- echo "FOO=hello" >> envvars
|
||||||
- echo "BAR=world" >> envvars
|
- echo "BAR=world" >> envvars
|
||||||
|
|
||||||
debug:
|
- name: debug
|
||||||
image: bash
|
image: bash
|
||||||
commands:
|
commands:
|
||||||
- source envvars
|
- source envvars
|
||||||
|
|
|
@ -18,6 +18,24 @@ Woodpecker is having two different kinds of releases: **stable** and **next**.
|
||||||
|
|
||||||
To find out more about the differences between the two releases, please read the [FAQ](/faq#which-version-of-woodpecker-should-i-use).
|
To find out more about the differences between the two releases, please read the [FAQ](/faq#which-version-of-woodpecker-should-i-use).
|
||||||
|
|
||||||
|
### Stable releases
|
||||||
|
|
||||||
|
We release a new version every four weeks and will release the current state of the `main` branch.
|
||||||
|
If there are security fixes or critical bug fixes, we'll release them directly.
|
||||||
|
There are no backports or similar.
|
||||||
|
|
||||||
|
#### Versioning
|
||||||
|
|
||||||
|
We use [Semantic Versioning](https://semver.org/) to be able,
|
||||||
|
to communicate when admins have to do manual migration steps and when they can just bump versions up.
|
||||||
|
|
||||||
|
#### Breaking changes
|
||||||
|
|
||||||
|
As of semver guidelines, breaking changes will be released as a major version. We will hold back
|
||||||
|
breaking changes to not release many majors each containing just a few breaking changes.
|
||||||
|
Prior to the release of a major version, a release candidate (RC) will be published to allow easy testing,
|
||||||
|
the actual release will be about a week later.
|
||||||
|
|
||||||
## Hardware Requirements
|
## Hardware Requirements
|
||||||
|
|
||||||
Below are minimal resources requirements for Woodpecker components itself:
|
Below are minimal resources requirements for Woodpecker components itself:
|
||||||
|
|
|
@ -189,9 +189,13 @@ Disable colored debug output.
|
||||||
|
|
||||||
> Default: empty
|
> Default: empty
|
||||||
|
|
||||||
Server fully qualified URL of the user-facing hostname and path prefix.
|
Server fully qualified URL of the user-facing hostname, port (if not default for HTTP/HTTPS) and path prefix.
|
||||||
|
|
||||||
Example: `WOODPECKER_HOST=http://woodpecker.example.org` or `WOODPECKER_HOST=http://example.org/woodpecker`
|
Examples:
|
||||||
|
|
||||||
|
- `WOODPECKER_HOST=http://woodpecker.example.org`
|
||||||
|
- `WOODPECKER_HOST=http://example.org/woodpecker`
|
||||||
|
- `WOODPECKER_HOST=http://example.org:1234/woodpecker`
|
||||||
|
|
||||||
### `WOODPECKER_WEBHOOK_HOST`
|
### `WOODPECKER_WEBHOOK_HOST`
|
||||||
|
|
||||||
|
|
|
@ -84,7 +84,7 @@ WOODPECKER_CONFIG_SERVICE_ENDPOINT=https://example.com/ciconfig
|
||||||
"configs": [
|
"configs": [
|
||||||
{
|
{
|
||||||
"name": ".woodpecker.yaml",
|
"name": ".woodpecker.yaml",
|
||||||
"data": "steps:\n backend:\n image: alpine\n commands:\n - echo \"Hello there from Repo (.woodpecker.yaml)\"\n"
|
"data": "steps:\n - name: backend\n image: alpine\n commands:\n - echo \"Hello there from Repo (.woodpecker.yaml)\"\n"
|
||||||
}
|
}
|
||||||
]
|
]
|
||||||
}
|
}
|
||||||
|
@ -97,7 +97,7 @@ WOODPECKER_CONFIG_SERVICE_ENDPOINT=https://example.com/ciconfig
|
||||||
"configs": [
|
"configs": [
|
||||||
{
|
{
|
||||||
"name": "central-override",
|
"name": "central-override",
|
||||||
"data": "steps:\n backend:\n image: alpine\n commands:\n - echo \"Hello there from ConfigAPI\"\n"
|
"data": "steps:\n - name: backend\n image: alpine\n commands:\n - echo \"Hello there from ConfigAPI\"\n"
|
||||||
}
|
}
|
||||||
]
|
]
|
||||||
}
|
}
|
||||||
|
|
|
@ -1,3 +1,7 @@
|
||||||
|
---
|
||||||
|
toc_max_heading_level: 2
|
||||||
|
---
|
||||||
|
|
||||||
# GitHub
|
# GitHub
|
||||||
|
|
||||||
Woodpecker comes with built-in support for GitHub and GitHub Enterprise.
|
Woodpecker comes with built-in support for GitHub and GitHub Enterprise.
|
||||||
|
|
|
@ -1,3 +1,7 @@
|
||||||
|
---
|
||||||
|
toc_max_heading_level: 2
|
||||||
|
---
|
||||||
|
|
||||||
# Gitea / Forgejo
|
# Gitea / Forgejo
|
||||||
|
|
||||||
Woodpecker comes with built-in support for Gitea and the "soft" fork Forgejo. To enable Gitea you should configure the Woodpecker container using the following environment variables:
|
Woodpecker comes with built-in support for Gitea and the "soft" fork Forgejo. To enable Gitea you should configure the Woodpecker container using the following environment variables:
|
||||||
|
|
|
@ -1,3 +1,7 @@
|
||||||
|
---
|
||||||
|
toc_max_heading_level: 2
|
||||||
|
---
|
||||||
|
|
||||||
# GitLab
|
# GitLab
|
||||||
|
|
||||||
Woodpecker comes with built-in support for the GitLab version 8.2 and higher. To enable GitLab you should configure the Woodpecker container using the following environment variables:
|
Woodpecker comes with built-in support for the GitLab version 8.2 and higher. To enable GitLab you should configure the Woodpecker container using the following environment variables:
|
||||||
|
|
|
@ -1,3 +1,7 @@
|
||||||
|
---
|
||||||
|
toc_max_heading_level: 2
|
||||||
|
---
|
||||||
|
|
||||||
# Bitbucket
|
# Bitbucket
|
||||||
|
|
||||||
Woodpecker comes with built-in support for Bitbucket Cloud. To enable Bitbucket Cloud you should configure the Woodpecker container using the following environment variables:
|
Woodpecker comes with built-in support for Bitbucket Cloud. To enable Bitbucket Cloud you should configure the Woodpecker container using the following environment variables:
|
||||||
|
|
|
@ -44,7 +44,7 @@ used to run the commands.
|
||||||
|
|
||||||
```yaml title=".woodpecker.yaml"
|
```yaml title=".woodpecker.yaml"
|
||||||
steps:
|
steps:
|
||||||
build:
|
- name: build
|
||||||
image: bash
|
image: bash
|
||||||
commands: [...]
|
commands: [...]
|
||||||
```
|
```
|
||||||
|
@ -55,7 +55,7 @@ Plugins are just executable binaries:
|
||||||
|
|
||||||
```yaml
|
```yaml
|
||||||
steps:
|
steps:
|
||||||
build:
|
- name: build
|
||||||
image: /usr/bin/tree
|
image: /usr/bin/tree
|
||||||
```
|
```
|
||||||
|
|
||||||
|
|
|
@ -17,7 +17,7 @@ Here is an example definition with an arbitrary `resources` definition below the
|
||||||
|
|
||||||
```yaml
|
```yaml
|
||||||
steps:
|
steps:
|
||||||
'My kubernetes step':
|
- name: 'My kubernetes step'
|
||||||
image: alpine
|
image: alpine
|
||||||
commands:
|
commands:
|
||||||
- echo "Hello world"
|
- echo "Hello world"
|
||||||
|
@ -75,7 +75,7 @@ Example pipeline configuration:
|
||||||
|
|
||||||
```yaml
|
```yaml
|
||||||
steps:
|
steps:
|
||||||
build:
|
- name: build
|
||||||
image: golang
|
image: golang
|
||||||
commands:
|
commands:
|
||||||
- go get
|
- go get
|
||||||
|
@ -107,7 +107,7 @@ Assuming a PVC named "woodpecker-cache" exists, it can be referenced as follows
|
||||||
|
|
||||||
```yaml
|
```yaml
|
||||||
steps:
|
steps:
|
||||||
"Restore Cache":
|
- name: "Restore Cache"
|
||||||
image: meltwater/drone-cache
|
image: meltwater/drone-cache
|
||||||
volumes:
|
volumes:
|
||||||
- woodpecker-cache:/woodpecker/src/cache
|
- woodpecker-cache:/woodpecker/src/cache
|
||||||
|
@ -123,7 +123,7 @@ Use the following configuration to set the `securityContext` for the pod/contain
|
||||||
|
|
||||||
```yaml
|
```yaml
|
||||||
steps:
|
steps:
|
||||||
test:
|
- name: test
|
||||||
image: alpine
|
image: alpine
|
||||||
commands:
|
commands:
|
||||||
- echo Hello world
|
- echo Hello world
|
||||||
|
|
|
@ -1,10 +0,0 @@
|
||||||
# Security
|
|
||||||
|
|
||||||
We take security seriously.
|
|
||||||
If you discover a security issue, please bring it to our attention right away!
|
|
||||||
|
|
||||||
## Reporting a Vulnerability
|
|
||||||
|
|
||||||
Please **DO NOT** file a public issue, instead send your report privately to [`security @ woodpecker-ci.org`](mailto:security@woodpecker-ci.org).
|
|
||||||
|
|
||||||
Security reports are greatly appreciated, and we will publicly thank you for it. If you choose to remain anonymous, we will respect your request and keep your name confidential.
|
|
Loading…
Reference in a new issue