2018-02-19 22:24:10 +00:00
|
|
|
// Copyright 2018 Drone.IO Inc.
|
2018-03-21 13:02:17 +00:00
|
|
|
//
|
2018-02-19 22:24:10 +00:00
|
|
|
// Licensed under the Apache License, Version 2.0 (the "License");
|
|
|
|
// you may not use this file except in compliance with the License.
|
|
|
|
// You may obtain a copy of the License at
|
2018-03-21 13:02:17 +00:00
|
|
|
//
|
2018-02-19 22:24:10 +00:00
|
|
|
// http://www.apache.org/licenses/LICENSE-2.0
|
2018-03-21 13:02:17 +00:00
|
|
|
//
|
2018-02-19 22:24:10 +00:00
|
|
|
// Unless required by applicable law or agreed to in writing, software
|
|
|
|
// distributed under the License is distributed on an "AS IS" BASIS,
|
|
|
|
// WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
|
|
|
|
// See the License for the specific language governing permissions and
|
|
|
|
// limitations under the License.
|
|
|
|
|
2017-07-19 10:16:09 +00:00
|
|
|
package server
|
|
|
|
|
|
|
|
import (
|
2019-06-01 08:56:12 +00:00
|
|
|
"fmt"
|
2017-07-19 10:16:09 +00:00
|
|
|
"testing"
|
|
|
|
|
2021-05-25 12:08:27 +00:00
|
|
|
"github.com/woodpecker-ci/woodpecker/model"
|
|
|
|
"github.com/woodpecker-ci/woodpecker/remote"
|
2017-07-19 10:16:09 +00:00
|
|
|
)
|
|
|
|
|
|
|
|
func TestMultilineEnvsubst(t *testing.T) {
|
2019-10-06 18:30:06 +00:00
|
|
|
t.Parallel()
|
|
|
|
|
2019-06-01 11:01:50 +00:00
|
|
|
b := procBuilder{
|
2017-07-19 10:16:09 +00:00
|
|
|
Repo: &model.Repo{},
|
|
|
|
Curr: &model.Build{
|
|
|
|
Message: `aaa
|
|
|
|
bbb`,
|
|
|
|
},
|
2018-03-21 13:02:17 +00:00
|
|
|
Last: &model.Build{},
|
2017-07-19 10:16:09 +00:00
|
|
|
Netrc: &model.Netrc{},
|
2018-03-21 13:02:17 +00:00
|
|
|
Secs: []*model.Secret{},
|
|
|
|
Regs: []*model.Registry{},
|
|
|
|
Link: "",
|
2019-06-13 15:38:19 +00:00
|
|
|
Yamls: []*remote.FileMeta{
|
|
|
|
&remote.FileMeta{Data: []byte(`
|
|
|
|
pipeline:
|
2017-07-19 10:16:09 +00:00
|
|
|
xxx:
|
|
|
|
image: scratch
|
|
|
|
yyy: ${DRONE_COMMIT_MESSAGE}
|
2019-06-13 15:38:19 +00:00
|
|
|
`)},
|
|
|
|
&remote.FileMeta{Data: []byte(`
|
|
|
|
pipeline:
|
2019-06-01 08:56:12 +00:00
|
|
|
build:
|
|
|
|
image: scratch
|
|
|
|
yyy: ${DRONE_COMMIT_MESSAGE}
|
2019-06-13 15:38:19 +00:00
|
|
|
`)},
|
|
|
|
}}
|
2017-07-19 10:16:09 +00:00
|
|
|
|
2019-06-01 08:56:12 +00:00
|
|
|
if buildItems, err := b.Build(); err != nil {
|
2017-07-19 10:16:09 +00:00
|
|
|
t.Fatal(err)
|
2019-06-01 08:56:12 +00:00
|
|
|
} else {
|
|
|
|
fmt.Println(buildItems)
|
2017-07-19 10:16:09 +00:00
|
|
|
}
|
|
|
|
}
|
2019-06-01 08:56:12 +00:00
|
|
|
|
|
|
|
func TestMultiPipeline(t *testing.T) {
|
2019-10-06 18:30:06 +00:00
|
|
|
t.Parallel()
|
|
|
|
|
2019-06-01 08:56:12 +00:00
|
|
|
b := procBuilder{
|
|
|
|
Repo: &model.Repo{},
|
|
|
|
Curr: &model.Build{},
|
|
|
|
Last: &model.Build{},
|
|
|
|
Netrc: &model.Netrc{},
|
|
|
|
Secs: []*model.Secret{},
|
|
|
|
Regs: []*model.Registry{},
|
|
|
|
Link: "",
|
2019-06-13 15:38:19 +00:00
|
|
|
Yamls: []*remote.FileMeta{
|
|
|
|
&remote.FileMeta{Data: []byte(`
|
|
|
|
pipeline:
|
|
|
|
xxx:
|
2019-06-01 08:56:12 +00:00
|
|
|
image: scratch
|
2019-06-13 15:38:19 +00:00
|
|
|
`)},
|
|
|
|
&remote.FileMeta{Data: []byte(`
|
|
|
|
pipeline:
|
|
|
|
build:
|
2019-06-01 08:56:12 +00:00
|
|
|
image: scratch
|
2019-06-13 15:38:19 +00:00
|
|
|
`)},
|
2019-06-01 08:56:12 +00:00
|
|
|
},
|
|
|
|
}
|
|
|
|
|
|
|
|
buildItems, err := b.Build()
|
|
|
|
if err != nil {
|
|
|
|
t.Fatal(err)
|
|
|
|
}
|
|
|
|
if len(buildItems) != 2 {
|
|
|
|
t.Fatal("Should have generated 2 buildItems")
|
|
|
|
}
|
|
|
|
}
|
2019-06-13 15:38:19 +00:00
|
|
|
|
|
|
|
func TestDependsOn(t *testing.T) {
|
2019-10-06 18:30:06 +00:00
|
|
|
t.Parallel()
|
|
|
|
|
2019-06-13 15:38:19 +00:00
|
|
|
b := procBuilder{
|
|
|
|
Repo: &model.Repo{},
|
|
|
|
Curr: &model.Build{},
|
|
|
|
Last: &model.Build{},
|
|
|
|
Netrc: &model.Netrc{},
|
|
|
|
Secs: []*model.Secret{},
|
|
|
|
Regs: []*model.Registry{},
|
|
|
|
Link: "",
|
|
|
|
Yamls: []*remote.FileMeta{
|
2019-07-22 12:13:46 +00:00
|
|
|
&remote.FileMeta{Name: "lint", Data: []byte(`
|
|
|
|
pipeline:
|
|
|
|
build:
|
|
|
|
image: scratch
|
|
|
|
`)},
|
|
|
|
&remote.FileMeta{Name: "test", Data: []byte(`
|
|
|
|
pipeline:
|
|
|
|
build:
|
|
|
|
image: scratch
|
|
|
|
`)},
|
2019-06-13 15:38:19 +00:00
|
|
|
&remote.FileMeta{Data: []byte(`
|
|
|
|
pipeline:
|
|
|
|
deploy:
|
|
|
|
image: scratch
|
|
|
|
|
|
|
|
depends_on:
|
|
|
|
- lint
|
|
|
|
- test
|
|
|
|
`)},
|
|
|
|
},
|
|
|
|
}
|
|
|
|
|
|
|
|
buildItems, err := b.Build()
|
|
|
|
if err != nil {
|
|
|
|
t.Fatal(err)
|
|
|
|
}
|
2019-07-22 12:13:46 +00:00
|
|
|
if len(buildItems[0].DependsOn) != 2 {
|
2019-06-13 15:38:19 +00:00
|
|
|
t.Fatal("Should have 3 dependencies")
|
|
|
|
}
|
|
|
|
if buildItems[0].DependsOn[1] != "test" {
|
|
|
|
t.Fatal("Should depend on test")
|
|
|
|
}
|
|
|
|
}
|
2019-06-17 07:06:36 +00:00
|
|
|
|
|
|
|
func TestRunsOn(t *testing.T) {
|
2019-10-06 18:30:06 +00:00
|
|
|
t.Parallel()
|
|
|
|
|
2019-06-17 07:06:36 +00:00
|
|
|
b := procBuilder{
|
|
|
|
Repo: &model.Repo{},
|
|
|
|
Curr: &model.Build{},
|
|
|
|
Last: &model.Build{},
|
|
|
|
Netrc: &model.Netrc{},
|
|
|
|
Secs: []*model.Secret{},
|
|
|
|
Regs: []*model.Registry{},
|
|
|
|
Link: "",
|
|
|
|
Yamls: []*remote.FileMeta{
|
|
|
|
&remote.FileMeta{Data: []byte(`
|
|
|
|
pipeline:
|
|
|
|
deploy:
|
|
|
|
image: scratch
|
|
|
|
|
|
|
|
runs_on:
|
|
|
|
- success
|
|
|
|
- failure
|
|
|
|
`)},
|
|
|
|
},
|
|
|
|
}
|
|
|
|
|
|
|
|
buildItems, err := b.Build()
|
|
|
|
if err != nil {
|
|
|
|
t.Fatal(err)
|
|
|
|
}
|
|
|
|
if len(buildItems[0].RunsOn) != 2 {
|
|
|
|
t.Fatal("Should run on success and failure")
|
|
|
|
}
|
|
|
|
if buildItems[0].RunsOn[1] != "failure" {
|
|
|
|
t.Fatal("Should run on failure")
|
|
|
|
}
|
|
|
|
}
|
2019-06-19 07:36:54 +00:00
|
|
|
|
|
|
|
func TestBranchFilter(t *testing.T) {
|
2019-10-06 18:30:06 +00:00
|
|
|
t.Parallel()
|
|
|
|
|
2019-06-19 07:36:54 +00:00
|
|
|
b := procBuilder{
|
|
|
|
Repo: &model.Repo{},
|
|
|
|
Curr: &model.Build{Branch: "dev"},
|
|
|
|
Last: &model.Build{},
|
|
|
|
Netrc: &model.Netrc{},
|
|
|
|
Secs: []*model.Secret{},
|
|
|
|
Regs: []*model.Registry{},
|
|
|
|
Link: "",
|
|
|
|
Yamls: []*remote.FileMeta{
|
|
|
|
&remote.FileMeta{Data: []byte(`
|
|
|
|
pipeline:
|
|
|
|
xxx:
|
|
|
|
image: scratch
|
|
|
|
branches: master
|
|
|
|
`)},
|
|
|
|
&remote.FileMeta{Data: []byte(`
|
|
|
|
pipeline:
|
|
|
|
build:
|
|
|
|
image: scratch
|
|
|
|
`)},
|
|
|
|
},
|
|
|
|
}
|
|
|
|
|
|
|
|
buildItems, err := b.Build()
|
|
|
|
if err != nil {
|
|
|
|
t.Fatal(err)
|
|
|
|
}
|
|
|
|
if len(buildItems) != 2 {
|
|
|
|
t.Fatal("Should have generated 2 buildItems")
|
|
|
|
}
|
|
|
|
if buildItems[0].Proc.State != model.StatusSkipped {
|
|
|
|
t.Fatal("Should not run on dev branch")
|
|
|
|
}
|
|
|
|
for _, child := range buildItems[0].Proc.Children {
|
|
|
|
if child.State != model.StatusSkipped {
|
|
|
|
t.Fatal("Children should skipped status too")
|
|
|
|
}
|
|
|
|
}
|
|
|
|
if buildItems[1].Proc.State != model.StatusPending {
|
2019-07-19 07:17:47 +00:00
|
|
|
t.Fatal("Should run on dev branch")
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
2019-07-19 07:18:40 +00:00
|
|
|
func TestZeroSteps(t *testing.T) {
|
2019-10-06 18:30:06 +00:00
|
|
|
t.Parallel()
|
|
|
|
|
2019-07-19 07:18:40 +00:00
|
|
|
build := &model.Build{Branch: "dev"}
|
|
|
|
|
|
|
|
b := procBuilder{
|
|
|
|
Repo: &model.Repo{},
|
|
|
|
Curr: build,
|
|
|
|
Last: &model.Build{},
|
|
|
|
Netrc: &model.Netrc{},
|
|
|
|
Secs: []*model.Secret{},
|
|
|
|
Regs: []*model.Registry{},
|
|
|
|
Link: "",
|
|
|
|
Yamls: []*remote.FileMeta{
|
|
|
|
&remote.FileMeta{Data: []byte(`
|
|
|
|
skip_clone: true
|
|
|
|
pipeline:
|
|
|
|
build:
|
|
|
|
when:
|
|
|
|
branch: notdev
|
|
|
|
image: scratch
|
|
|
|
`)},
|
|
|
|
},
|
|
|
|
}
|
|
|
|
|
|
|
|
buildItems, err := b.Build()
|
|
|
|
if err != nil {
|
|
|
|
t.Fatal(err)
|
|
|
|
}
|
|
|
|
if len(buildItems) != 0 {
|
|
|
|
t.Fatal("Should not generate a build item if there are no steps")
|
|
|
|
}
|
2019-07-22 12:13:46 +00:00
|
|
|
}
|
|
|
|
|
|
|
|
func TestZeroStepsAsMultiPipelineDeps(t *testing.T) {
|
2019-10-06 18:30:06 +00:00
|
|
|
t.Parallel()
|
|
|
|
|
2019-07-22 12:13:46 +00:00
|
|
|
build := &model.Build{Branch: "dev"}
|
|
|
|
|
|
|
|
b := procBuilder{
|
|
|
|
Repo: &model.Repo{},
|
|
|
|
Curr: build,
|
|
|
|
Last: &model.Build{},
|
|
|
|
Netrc: &model.Netrc{},
|
|
|
|
Secs: []*model.Secret{},
|
|
|
|
Regs: []*model.Registry{},
|
|
|
|
Link: "",
|
|
|
|
Yamls: []*remote.FileMeta{
|
|
|
|
&remote.FileMeta{Name: "zerostep", Data: []byte(`
|
|
|
|
skip_clone: true
|
|
|
|
pipeline:
|
|
|
|
build:
|
|
|
|
when:
|
|
|
|
branch: notdev
|
|
|
|
image: scratch
|
|
|
|
`)},
|
|
|
|
&remote.FileMeta{Name: "justastep", Data: []byte(`
|
|
|
|
pipeline:
|
|
|
|
build:
|
|
|
|
image: scratch
|
|
|
|
`)},
|
|
|
|
&remote.FileMeta{Name: "shouldbefiltered", Data: []byte(`
|
|
|
|
pipeline:
|
|
|
|
build:
|
|
|
|
image: scratch
|
|
|
|
depends_on: [ zerostep ]
|
|
|
|
`)},
|
|
|
|
},
|
|
|
|
}
|
|
|
|
|
|
|
|
buildItems, err := b.Build()
|
|
|
|
if err != nil {
|
|
|
|
t.Fatal(err)
|
|
|
|
}
|
|
|
|
if len(buildItems) != 1 {
|
|
|
|
t.Fatal("Zerostep and the step that depends on it should not generate a build item")
|
|
|
|
}
|
|
|
|
if "justastep" != buildItems[0].Proc.Name {
|
|
|
|
t.Fatal("justastep should have been generated")
|
2019-07-19 07:18:40 +00:00
|
|
|
}
|
|
|
|
}
|
|
|
|
|
2019-07-22 12:29:15 +00:00
|
|
|
func TestZeroStepsAsMultiPipelineTransitiveDeps(t *testing.T) {
|
2019-10-06 18:30:06 +00:00
|
|
|
t.Parallel()
|
|
|
|
|
2019-07-22 12:29:15 +00:00
|
|
|
build := &model.Build{Branch: "dev"}
|
|
|
|
|
|
|
|
b := procBuilder{
|
|
|
|
Repo: &model.Repo{},
|
|
|
|
Curr: build,
|
|
|
|
Last: &model.Build{},
|
|
|
|
Netrc: &model.Netrc{},
|
|
|
|
Secs: []*model.Secret{},
|
|
|
|
Regs: []*model.Registry{},
|
|
|
|
Link: "",
|
|
|
|
Yamls: []*remote.FileMeta{
|
|
|
|
&remote.FileMeta{Name: "zerostep", Data: []byte(`
|
|
|
|
skip_clone: true
|
|
|
|
pipeline:
|
|
|
|
build:
|
|
|
|
when:
|
|
|
|
branch: notdev
|
|
|
|
image: scratch
|
|
|
|
`)},
|
|
|
|
&remote.FileMeta{Name: "justastep", Data: []byte(`
|
|
|
|
pipeline:
|
|
|
|
build:
|
|
|
|
image: scratch
|
|
|
|
`)},
|
|
|
|
&remote.FileMeta{Name: "shouldbefiltered", Data: []byte(`
|
|
|
|
pipeline:
|
|
|
|
build:
|
|
|
|
image: scratch
|
|
|
|
depends_on: [ zerostep ]
|
|
|
|
`)},
|
|
|
|
&remote.FileMeta{Name: "shouldbefilteredtoo", Data: []byte(`
|
|
|
|
pipeline:
|
|
|
|
build:
|
|
|
|
image: scratch
|
|
|
|
depends_on: [ shouldbefiltered ]
|
|
|
|
`)},
|
|
|
|
},
|
|
|
|
}
|
|
|
|
|
|
|
|
buildItems, err := b.Build()
|
|
|
|
if err != nil {
|
|
|
|
t.Fatal(err)
|
|
|
|
}
|
|
|
|
if len(buildItems) != 1 {
|
|
|
|
t.Fatal("Zerostep and the step that depends on it, and the one depending on it should not generate a build item")
|
|
|
|
}
|
|
|
|
if "justastep" != buildItems[0].Proc.Name {
|
|
|
|
t.Fatal("justastep should have been generated")
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
2019-07-19 07:17:47 +00:00
|
|
|
func TestTree(t *testing.T) {
|
2019-10-06 18:30:06 +00:00
|
|
|
t.Parallel()
|
|
|
|
|
2019-07-19 07:17:47 +00:00
|
|
|
build := &model.Build{}
|
|
|
|
|
|
|
|
b := procBuilder{
|
|
|
|
Repo: &model.Repo{},
|
|
|
|
Curr: build,
|
|
|
|
Last: &model.Build{},
|
|
|
|
Netrc: &model.Netrc{},
|
|
|
|
Secs: []*model.Secret{},
|
|
|
|
Regs: []*model.Registry{},
|
|
|
|
Link: "",
|
|
|
|
Yamls: []*remote.FileMeta{
|
|
|
|
&remote.FileMeta{Data: []byte(`
|
|
|
|
pipeline:
|
|
|
|
build:
|
|
|
|
image: scratch
|
|
|
|
`)},
|
|
|
|
},
|
|
|
|
}
|
|
|
|
|
2019-07-22 11:43:18 +00:00
|
|
|
buildItems, err := b.Build()
|
|
|
|
build = setBuildStepsOnBuild(build, buildItems)
|
2019-07-19 07:17:47 +00:00
|
|
|
if err != nil {
|
|
|
|
t.Fatal(err)
|
|
|
|
}
|
|
|
|
if len(build.Procs) != 3 {
|
|
|
|
t.Fatal("Should generate three in total")
|
|
|
|
}
|
|
|
|
if build.Procs[1].PPID != 1 {
|
|
|
|
t.Fatal("Clone step should be a children of the stage")
|
|
|
|
}
|
|
|
|
if build.Procs[2].PPID != 1 {
|
|
|
|
t.Fatal("Build step should be a children of the stage")
|
2019-06-19 07:36:54 +00:00
|
|
|
}
|
|
|
|
}
|