Another fix for settings field in pipeline config (#579)

close #578

- adjust to new settings field own pipeline config
- more test coverage
- Fix environment parse of settings
- Fix pipeline schema
This commit is contained in:
6543
2021-12-08 18:17:52 +01:00
committed by GitHub
parent fe2f269bce
commit e7cfa902a6
5 changed files with 151 additions and 50 deletions

View File

@@ -34,25 +34,27 @@ pipeline:
branch: ${CI_REPO_DEFAULT_BRANCH} branch: ${CI_REPO_DEFAULT_BRANCH}
publish-server: publish-server:
group: bundle
image: plugins/docker image: plugins/docker
repo: woodpeckerci/woodpecker-server group: bundle
dockerfile: docker/Dockerfile.server
secrets: [docker_username, docker_password] secrets: [docker_username, docker_password]
# TODO: only release as next after 0.15.0 got released settings:
tag: [next, latest] repo: woodpeckerci/woodpecker-server
dockerfile: docker/Dockerfile.server
# TODO: only release as next after 0.15.0 got released
tag: [next, latest]
when: when:
branch: ${CI_REPO_DEFAULT_BRANCH} branch: ${CI_REPO_DEFAULT_BRANCH}
event: push event: push
publish-server-alpine: publish-server-alpine:
group: bundle
image: plugins/docker image: plugins/docker
repo: woodpeckerci/woodpecker-server group: bundle
dockerfile: docker/Dockerfile.server.alpine
secrets: [ docker_username, docker_password ] secrets: [ docker_username, docker_password ]
# TODO: only release as next-alpine after 0.15.0 got released settings:
tag: [next-alpine, latest-alpine] repo: woodpeckerci/woodpecker-server
dockerfile: docker/Dockerfile.server.alpine
# TODO: only release as next-alpine after 0.15.0 got released
tag: [next-alpine, latest-alpine]
when: when:
branch: ${CI_REPO_DEFAULT_BRANCH} branch: ${CI_REPO_DEFAULT_BRANCH}
event: push event: push
@@ -60,11 +62,12 @@ pipeline:
publish-agent: publish-agent:
group: bundle group: bundle
image: plugins/docker image: plugins/docker
repo: woodpeckerci/woodpecker-agent
dockerfile: docker/Dockerfile.agent
secrets: [docker_username, docker_password] secrets: [docker_username, docker_password]
# TODO: only release as next after 0.15.0 got released settings:
tag: [next, latest] repo: woodpeckerci/woodpecker-agent
dockerfile: docker/Dockerfile.agent
# TODO: only release as next after 0.15.0 got released
tag: [next, latest]
when: when:
branch: ${CI_REPO_DEFAULT_BRANCH} branch: ${CI_REPO_DEFAULT_BRANCH}
event: push event: push
@@ -72,11 +75,12 @@ pipeline:
publish-agent-alpine: publish-agent-alpine:
group: bundle group: bundle
image: plugins/docker image: plugins/docker
repo: woodpeckerci/woodpecker-agent
dockerfile: docker/Dockerfile.agent.alpine
secrets: [ docker_username, docker_password ] secrets: [ docker_username, docker_password ]
# TODO: only release as next-alpine after 0.15.0 got released settings:
tag: [next-alpine, latest-alpine] repo: woodpeckerci/woodpecker-agent
dockerfile: docker/Dockerfile.agent.alpine
# TODO: only release as next-alpine after 0.15.0 got released
tag: [next-alpine, latest-alpine]
when: when:
branch: ${CI_REPO_DEFAULT_BRANCH} branch: ${CI_REPO_DEFAULT_BRANCH}
event: push event: push
@@ -84,10 +88,11 @@ pipeline:
publish-cli: publish-cli:
group: docker group: docker
image: plugins/docker image: plugins/docker
repo: woodpeckerci/woodpecker-cli
dockerfile: docker/Dockerfile.cli
secrets: [docker_username, docker_password] secrets: [docker_username, docker_password]
tag: [next] settings:
repo: woodpeckerci/woodpecker-cli
dockerfile: docker/Dockerfile.cli
tag: next
when: when:
branch: ${CI_REPO_DEFAULT_BRANCH} branch: ${CI_REPO_DEFAULT_BRANCH}
event: push event: push
@@ -95,10 +100,11 @@ pipeline:
publish-cli-alpine: publish-cli-alpine:
group: docker group: docker
image: plugins/docker image: plugins/docker
repo: woodpeckerci/woodpecker-cli
dockerfile: docker/Dockerfile.cli.alpine
secrets: [ docker_username, docker_password ] secrets: [ docker_username, docker_password ]
tag: [next-alpine] settings:
repo: woodpeckerci/woodpecker-cli
dockerfile: docker/Dockerfile.cli.alpine
tag: next-alpine
when: when:
branch: ${CI_REPO_DEFAULT_BRANCH} branch: ${CI_REPO_DEFAULT_BRANCH}
event: push event: push
@@ -106,60 +112,66 @@ pipeline:
release-server: release-server:
group: bundle group: bundle
image: plugins/docker image: plugins/docker
repo: woodpeckerci/woodpecker-server
dockerfile: docker/Dockerfile.server
secrets: [docker_username, docker_password] secrets: [docker_username, docker_password]
tag: [latest, "${CI_COMMIT_TAG}"] settings:
repo: woodpeckerci/woodpecker-server
dockerfile: docker/Dockerfile.server
tag: [latest, "${CI_COMMIT_TAG}"]
when: when:
event: tag event: tag
release-server-alpine: release-server-alpine:
group: bundle group: bundle
image: plugins/docker image: plugins/docker
repo: woodpeckerci/woodpecker-server
dockerfile: docker/Dockerfile.server.alpine
secrets: [ docker_username, docker_password ] secrets: [ docker_username, docker_password ]
tag: [latest-alpine, "${CI_COMMIT_TAG}-alpine"] settings:
repo: woodpeckerci/woodpecker-server
dockerfile: docker/Dockerfile.server.alpine
tag: [latest-alpine, "${CI_COMMIT_TAG}-alpine"]
when: when:
event: tag event: tag
release-agent: release-agent:
group: bundle group: bundle
image: plugins/docker image: plugins/docker
repo: woodpeckerci/woodpecker-agent
dockerfile: docker/Dockerfile.agent
secrets: [docker_username, docker_password] secrets: [docker_username, docker_password]
tag: [latest, "${CI_COMMIT_TAG}"] settings:
repo: woodpeckerci/woodpecker-agent
dockerfile: docker/Dockerfile.agent
tag: [latest, "${CI_COMMIT_TAG}"]
when: when:
event: tag event: tag
release-agent-alpine: release-agent-alpine:
group: bundle group: bundle
image: plugins/docker image: plugins/docker
repo: woodpeckerci/woodpecker-agent
dockerfile: docker/Dockerfile.agent.alpine
secrets: [ docker_username, docker_password ] secrets: [ docker_username, docker_password ]
tag: [latest-alpine, "${CI_COMMIT_TAG}-alpine"] settings:
repo: woodpeckerci/woodpecker-agent
dockerfile: docker/Dockerfile.agent.alpine
tag: [latest-alpine, "${CI_COMMIT_TAG}-alpine"]
when: when:
event: tag event: tag
release-cli: release-cli:
group: docker group: docker
image: plugins/docker image: plugins/docker
repo: woodpeckerci/woodpecker-cli
dockerfile: docker/Dockerfile.cli
secrets: [docker_username, docker_password] secrets: [docker_username, docker_password]
tag: [latest, "${CI_COMMIT_TAG}"] settings:
repo: woodpeckerci/woodpecker-cli
dockerfile: docker/Dockerfile.cli
tag: [latest, "${CI_COMMIT_TAG}"]
when: when:
event: tag event: tag
release-cli-alpine: release-cli-alpine:
group: docker group: docker
image: plugins/docker image: plugins/docker
repo: woodpeckerci/woodpecker-cli
dockerfile: docker/Dockerfile.cli.alpine
secrets: [ docker_username, docker_password ] secrets: [ docker_username, docker_password ]
tag: [latest-alpine, "${CI_COMMIT_TAG}-alpine"] settings:
repo: woodpeckerci/woodpecker-cli
dockerfile: docker/Dockerfile.cli.alpine
tag: [latest-alpine, "${CI_COMMIT_TAG}-alpine"]
when: when:
event: tag event: tag
@@ -174,15 +186,16 @@ pipeline:
release: release:
image: plugins/github-release image: plugins/github-release
files:
- dist/*.tar.gz
- dist/*.deb
- dist/*.rpm
- dist/checksums.txt
title: ${CI_COMMIT_TAG##v}
secrets: secrets:
- source: github_token - source: github_token
target: github_release_api_key target: github_release_api_key
settings:
files:
- dist/*.tar.gz
- dist/*.deb
- dist/*.rpm
- dist/checksums.txt
title: ${CI_COMMIT_TAG##v}
when: when:
event: tag event: tag

View File

@@ -71,7 +71,10 @@ func sanitizeParamValue(v interface{}) (string, error) {
return string(out), nil return string(out), nil
case reflect.Slice, reflect.Array: case reflect.Slice, reflect.Array:
if !isComplex(t.Elem().Kind()) { if vv.Len() == 0 {
return "", nil
}
if !isComplex(t.Elem().Kind()) || t.Elem().Kind() == reflect.Interface {
in := make([]string, vv.Len()) in := make([]string, vv.Len())
for i := 0; i < vv.Len(); i++ { for i := 0; i < vv.Len(); i++ {
var err error var err error

View File

@@ -18,6 +18,8 @@ func TestParamsToEnv(t *testing.T) {
"complex": []struct{ Name string }{{"Jack"}, {"Jill"}}, "complex": []struct{ Name string }{{"Jack"}, {"Jill"}},
"complex2": struct{ Name string }{"Jack"}, "complex2": struct{ Name string }{"Jack"},
"from.address": "noreply@example.com", "from.address": "noreply@example.com",
"tags": stringsToInterface("next", "latest"),
"tag": stringsToInterface("next"),
} }
want := map[string]string{ want := map[string]string{
"PLUGIN_STRING": "stringz", "PLUGIN_STRING": "stringz",
@@ -29,8 +31,18 @@ func TestParamsToEnv(t *testing.T) {
"PLUGIN_COMPLEX": `[{"name":"Jack"},{"name":"Jill"}]`, "PLUGIN_COMPLEX": `[{"name":"Jack"},{"name":"Jill"}]`,
"PLUGIN_COMPLEX2": `{"name":"Jack"}`, "PLUGIN_COMPLEX2": `{"name":"Jack"}`,
"PLUGIN_FROM_ADDRESS": "noreply@example.com", "PLUGIN_FROM_ADDRESS": "noreply@example.com",
"PLUGIN_TAG": "next",
"PLUGIN_TAGS": "next,latest",
} }
got := map[string]string{} got := map[string]string{}
assert.NoError(t, paramsToEnv(from, got)) assert.NoError(t, paramsToEnv(from, got))
assert.EqualValues(t, want, got, "Problem converting plugin parameters to environment variables") assert.EqualValues(t, want, got, "Problem converting plugin parameters to environment variables")
} }
func stringsToInterface(val ...string) []interface{} {
res := make([]interface{}, len(val))
for i := range val {
res[i] = val[i]
}
return res
}

View File

@@ -158,6 +158,71 @@ func TestUnmarshalContainers(t *testing.T) {
}, },
}, },
}, },
{
from: `publish-agent:
group: bundle
image: print/env
repo: woodpeckerci/woodpecker-agent
dockerfile: docker/Dockerfile.agent
secrets: [docker_username, docker_password]
tag: [next, latest]
dry_run: true
when:
branch: ${CI_REPO_DEFAULT_BRANCH}
event: push`,
want: []*Container{
{
Name: "publish-agent",
Image: "print/env",
Group: "bundle",
Secrets: Secrets{Secrets: []*Secret{{
Source: "docker_username",
Target: "docker_username",
}, {
Source: "docker_password",
Target: "docker_password",
}}},
Settings: map[string]interface{}{
"repo": "woodpeckerci/woodpecker-agent",
"dockerfile": "docker/Dockerfile.agent",
"tag": stringsToInterface("next", "latest"),
"dry_run": true,
},
Constraints: Constraints{
Event: Constraint{Include: []string{"push"}},
Branch: Constraint{Include: []string{"${CI_REPO_DEFAULT_BRANCH}"}},
},
},
},
},
{
from: `publish-cli:
group: docker
image: print/env
settings:
repo: woodpeckerci/woodpecker-cli
dockerfile: docker/Dockerfile.cli
tag: [next]
when:
branch: ${CI_REPO_DEFAULT_BRANCH}
event: push`,
want: []*Container{
{
Name: "publish-cli",
Image: "print/env",
Group: "docker",
Settings: map[string]interface{}{
"repo": "woodpeckerci/woodpecker-cli",
"dockerfile": "docker/Dockerfile.cli",
"tag": stringsToInterface("next"),
},
Constraints: Constraints{
Event: Constraint{Include: []string{"push"}},
Branch: Constraint{Include: []string{"${CI_REPO_DEFAULT_BRANCH}"}},
},
},
},
},
} }
for _, test := range testdata { for _, test := range testdata {
in := []byte(test.from) in := []byte(test.from)
@@ -182,3 +247,11 @@ func TestUnmarshalContainersErr(t *testing.T) {
assert.Error(t, err, "wanted error for containers %q", test) assert.Error(t, err, "wanted error for containers %q", test)
} }
} }
func stringsToInterface(val ...string) []interface{} {
res := make([]interface{}, len(val))
for i := range val {
res[i] = val[i]
}
return res
}

View File

@@ -175,7 +175,7 @@
"description": "Change the settings of your plugin. Read more: https://woodpecker-ci.org/docs/usage/plugins/plugins", "description": "Change the settings of your plugin. Read more: https://woodpecker-ci.org/docs/usage/plugins/plugins",
"type": "object", "type": "object",
"additionalProperties": { "additionalProperties": {
"type": ["boolean", "string", "number"] "type": ["boolean", "string", "number", "array", "object"]
} }
} }
} }