From 5d8e60808de1a8fdb69843edb8aad744e9821f33 Mon Sep 17 00:00:00 2001 From: 6543 <6543@obermui.de> Date: Sun, 3 Oct 2021 15:07:39 +0200 Subject: [PATCH] Move cli exec flags to own file (#380) Co-authored-by: Anbraten --- cli/build/build_logs.go | 3 +- cli/exec/exec.go | 246 +-------------------------------- cli/exec/flags.go | 265 ++++++++++++++++++++++++++++++++++++ cmd/cli/main.go | 14 ++ pipeline/backend/backend.go | 2 +- 5 files changed, 283 insertions(+), 247 deletions(-) create mode 100644 cli/exec/flags.go diff --git a/cli/build/build_logs.go b/cli/build/build_logs.go index c07ee14e7..232779a02 100644 --- a/cli/build/build_logs.go +++ b/cli/build/build_logs.go @@ -14,5 +14,6 @@ var buildLogsCmd = cli.Command{ } func buildLogs(c *cli.Context) error { - return fmt.Errorf("Command temporarily disabled. See https://github.com/drone/drone/issues/2005") + // TODO: add logs command + return fmt.Errorf("Command temporarily disabled. See https://github.com/woodpecker-ci/woodpecker/issues/383") } diff --git a/cli/exec/exec.go b/cli/exec/exec.go index 9397334a6..2fade5a46 100644 --- a/cli/exec/exec.go +++ b/cli/exec/exec.go @@ -10,7 +10,6 @@ import ( "path/filepath" "runtime" "strings" - "time" "github.com/drone/envsubst" "github.com/woodpecker-ci/woodpecker/pipeline" @@ -37,250 +36,7 @@ var Command = cli.Command{ log.Fatalln(err) } }, - Flags: []cli.Flag{ - cli.BoolTFlag{ - EnvVar: "WOODPECKER_LOCAL", - Name: "local", - Usage: "build from local directory", - }, - cli.DurationFlag{ - EnvVar: "WOODPECKER_TIMEOUT", - Name: "timeout", - Usage: "build timeout", - Value: time.Hour, - }, - cli.StringSliceFlag{ - EnvVar: "WOODPECKER_VOLUMES", - Name: "volumes", - Usage: "build volumes", - }, - cli.StringSliceFlag{ - EnvVar: "WOODPECKER_NETWORKS", - Name: "network", - Usage: "external networks", - }, - cli.StringFlag{ - EnvVar: "WOODPECKER_DOCKER_PREFIX", - Name: "prefix", - Value: "woodpecker", - Usage: "prefix containers created by woodpecker", - Hidden: true, - }, - cli.StringSliceFlag{ - Name: "privileged", - Usage: "privileged plugins", - Value: &cli.StringSlice{ - "plugins/docker", - "plugins/gcr", - "plugins/ecr", - }, - }, - - // - // Please note the below flags are mirrored in the pipec and - // should be kept synchronized. Do not edit directly - // https://github.com/cncd/pipeline/pipec - // - - // - // workspace default - // - cli.StringFlag{ - EnvVar: "WOODPECKER_WORKSPACE_BASE", - Name: "workspace-base", - Value: "/woodpecker", - }, - cli.StringFlag{ - EnvVar: "WOODPECKER_WORKSPACE_PATH", - Name: "workspace-path", - Value: "src", - }, - // - // netrc parameters - // - cli.StringFlag{ - EnvVar: "WOODPECKER_NETRC_USERNAME", - Name: "netrc-username", - }, - cli.StringFlag{ - EnvVar: "WOODPECKER_NETRC_PASSWORD", - Name: "netrc-password", - }, - cli.StringFlag{ - EnvVar: "WOODPECKER_NETRC_MACHINE", - Name: "netrc-machine", - }, - // - // metadata parameters - // - cli.StringFlag{ - EnvVar: "WOODPECKER_SYSTEM_ARCH", - Name: "system-arch", - Value: "linux/amd64", - }, - cli.StringFlag{ - EnvVar: "WOODPECKER_SYSTEM_NAME", - Name: "system-name", - Value: "pipec", - }, - cli.StringFlag{ - EnvVar: "WOODPECKER_SYSTEM_LINK", - Name: "system-link", - Value: "https://github.com/cncd/pipec", - }, - cli.StringFlag{ - EnvVar: "WOODPECKER_REPO_NAME", - Name: "repo-name", - }, - cli.StringFlag{ - EnvVar: "WOODPECKER_REPO_LINK", - Name: "repo-link", - }, - cli.StringFlag{ - EnvVar: "WOODPECKER_REPO_REMOTE", - Name: "repo-remote-url", - }, - cli.StringFlag{ - EnvVar: "WOODPECKER_REPO_PRIVATE", - Name: "repo-private", - }, - cli.IntFlag{ - EnvVar: "WOODPECKER_BUILD_NUMBER", - Name: "build-number", - }, - cli.IntFlag{ - EnvVar: "WOODPECKER_PARENT_BUILD_NUMBER", - Name: "parent-build-number", - }, - cli.Int64Flag{ - EnvVar: "WOODPECKER_BUILD_CREATED", - Name: "build-created", - }, - cli.Int64Flag{ - EnvVar: "WOODPECKER_BUILD_STARTED", - Name: "build-started", - }, - cli.Int64Flag{ - EnvVar: "WOODPECKER_BUILD_FINISHED", - Name: "build-finished", - }, - cli.StringFlag{ - EnvVar: "WOODPECKER_BUILD_STATUS", - Name: "build-status", - }, - cli.StringFlag{ - EnvVar: "WOODPECKER_BUILD_EVENT", - Name: "build-event", - }, - cli.StringFlag{ - EnvVar: "WOODPECKER_BUILD_LINK", - Name: "build-link", - }, - cli.StringFlag{ - EnvVar: "WOODPECKER_BUILD_TARGET", - Name: "build-target", - }, - cli.StringFlag{ - EnvVar: "WOODPECKER_COMMIT_SHA", - Name: "commit-sha", - }, - cli.StringFlag{ - EnvVar: "WOODPECKER_COMMIT_REF", - Name: "commit-ref", - }, - cli.StringFlag{ - EnvVar: "WOODPECKER_COMMIT_REFSPEC", - Name: "commit-refspec", - }, - cli.StringFlag{ - EnvVar: "WOODPECKER_COMMIT_BRANCH", - Name: "commit-branch", - }, - cli.StringFlag{ - EnvVar: "WOODPECKER_COMMIT_MESSAGE", - Name: "commit-message", - }, - cli.StringFlag{ - EnvVar: "WOODPECKER_COMMIT_AUTHOR_NAME", - Name: "commit-author-name", - }, - cli.StringFlag{ - EnvVar: "WOODPECKER_COMMIT_AUTHOR_AVATAR", - Name: "commit-author-avatar", - }, - cli.StringFlag{ - EnvVar: "WOODPECKER_COMMIT_AUTHOR_EMAIL", - Name: "commit-author-email", - }, - cli.IntFlag{ - EnvVar: "WOODPECKER_PREV_BUILD_NUMBER", - Name: "prev-build-number", - }, - cli.Int64Flag{ - EnvVar: "WOODPECKER_PREV_BUILD_CREATED", - Name: "prev-build-created", - }, - cli.Int64Flag{ - EnvVar: "WOODPECKER_PREV_BUILD_STARTED", - Name: "prev-build-started", - }, - cli.Int64Flag{ - EnvVar: "WOODPECKER_PREV_BUILD_FINISHED", - Name: "prev-build-finished", - }, - cli.StringFlag{ - EnvVar: "WOODPECKER_PREV_BUILD_STATUS", - Name: "prev-build-status", - }, - cli.StringFlag{ - EnvVar: "WOODPECKER_PREV_BUILD_EVENT", - Name: "prev-build-event", - }, - cli.StringFlag{ - EnvVar: "WOODPECKER_PREV_BUILD_LINK", - Name: "prev-build-link", - }, - cli.StringFlag{ - EnvVar: "WOODPECKER_PREV_COMMIT_SHA", - Name: "prev-commit-sha", - }, - cli.StringFlag{ - EnvVar: "WOODPECKER_PREV_COMMIT_REF", - Name: "prev-commit-ref", - }, - cli.StringFlag{ - EnvVar: "WOODPECKER_PREV_COMMIT_REFSPEC", - Name: "prev-commit-refspec", - }, - cli.StringFlag{ - EnvVar: "WOODPECKER_PREV_COMMIT_BRANCH", - Name: "prev-commit-branch", - }, - cli.StringFlag{ - EnvVar: "WOODPECKER_PREV_COMMIT_MESSAGE", - Name: "prev-commit-message", - }, - cli.StringFlag{ - EnvVar: "WOODPECKER_PREV_COMMIT_AUTHOR_NAME", - Name: "prev-commit-author-name", - }, - cli.StringFlag{ - EnvVar: "WOODPECKER_PREV_COMMIT_AUTHOR_AVATAR", - Name: "prev-commit-author-avatar", - }, - cli.StringFlag{ - EnvVar: "WOODPECKER_PREV_COMMIT_AUTHOR_EMAIL", - Name: "prev-commit-author-email", - }, - cli.IntFlag{ - EnvVar: "WOODPECKER_JOB_NUMBER", - Name: "job-number", - }, - cli.StringSliceFlag{ - EnvVar: "WOODPECKER_ENV", - Name: "env, e", - }, - }, + Flags: flags, } func exec(c *cli.Context) error { diff --git a/cli/exec/flags.go b/cli/exec/flags.go new file mode 100644 index 000000000..b8e89fbd9 --- /dev/null +++ b/cli/exec/flags.go @@ -0,0 +1,265 @@ +// Copyright 2021 Woodpecker Authors +// +// 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 +// +// http://www.apache.org/licenses/LICENSE-2.0 +// +// 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. + +package exec + +import ( + "time" + + "github.com/urfave/cli" +) + +var flags = []cli.Flag{ + cli.BoolTFlag{ + EnvVar: "WOODPECKER_LOCAL", + Name: "local", + Usage: "build from local directory", + }, + cli.DurationFlag{ + EnvVar: "WOODPECKER_TIMEOUT", + Name: "timeout", + Usage: "build timeout", + Value: time.Hour, + }, + cli.StringSliceFlag{ + EnvVar: "WOODPECKER_VOLUMES", + Name: "volumes", + Usage: "build volumes", + }, + cli.StringSliceFlag{ + EnvVar: "WOODPECKER_NETWORKS", + Name: "network", + Usage: "external networks", + }, + cli.StringFlag{ + EnvVar: "WOODPECKER_DOCKER_PREFIX", + Name: "prefix", + Value: "woodpecker", + Usage: "prefix containers created by woodpecker", + Hidden: true, + }, + cli.StringSliceFlag{ + Name: "privileged", + Usage: "privileged plugins", + Value: &cli.StringSlice{ + "plugins/docker", + "plugins/gcr", + "plugins/ecr", + }, + }, + + // + // Please note the below flags should match the flags from + // pipeline/frontend/metadata.go and should be kept synchronized. + // + + // + // workspace default + // + cli.StringFlag{ + EnvVar: "WOODPECKER_WORKSPACE_BASE", + Name: "workspace-base", + Value: "/woodpecker", + }, + cli.StringFlag{ + EnvVar: "WOODPECKER_WORKSPACE_PATH", + Name: "workspace-path", + Value: "src", + }, + // + // netrc parameters + // + cli.StringFlag{ + EnvVar: "WOODPECKER_NETRC_USERNAME", + Name: "netrc-username", + }, + cli.StringFlag{ + EnvVar: "WOODPECKER_NETRC_PASSWORD", + Name: "netrc-password", + }, + cli.StringFlag{ + EnvVar: "WOODPECKER_NETRC_MACHINE", + Name: "netrc-machine", + }, + // + // metadata parameters + // + cli.StringFlag{ + EnvVar: "WOODPECKER_SYSTEM_ARCH", + Name: "system-arch", + Value: "linux/amd64", + }, + cli.StringFlag{ + EnvVar: "WOODPECKER_SYSTEM_NAME", + Name: "system-name", + Value: "pipec", + }, + cli.StringFlag{ + EnvVar: "WOODPECKER_SYSTEM_LINK", + Name: "system-link", + Value: "https://github.com/cncd/pipec", + }, + cli.StringFlag{ + EnvVar: "WOODPECKER_REPO_NAME", + Name: "repo-name", + }, + cli.StringFlag{ + EnvVar: "WOODPECKER_REPO_LINK", + Name: "repo-link", + }, + cli.StringFlag{ + EnvVar: "WOODPECKER_REPO_REMOTE", + Name: "repo-remote-url", + }, + cli.StringFlag{ + EnvVar: "WOODPECKER_REPO_PRIVATE", + Name: "repo-private", + }, + cli.IntFlag{ + EnvVar: "WOODPECKER_BUILD_NUMBER", + Name: "build-number", + }, + cli.IntFlag{ + EnvVar: "WOODPECKER_PARENT_BUILD_NUMBER", + Name: "parent-build-number", + }, + cli.Int64Flag{ + EnvVar: "WOODPECKER_BUILD_CREATED", + Name: "build-created", + }, + cli.Int64Flag{ + EnvVar: "WOODPECKER_BUILD_STARTED", + Name: "build-started", + }, + cli.Int64Flag{ + EnvVar: "WOODPECKER_BUILD_FINISHED", + Name: "build-finished", + }, + cli.StringFlag{ + EnvVar: "WOODPECKER_BUILD_STATUS", + Name: "build-status", + }, + cli.StringFlag{ + EnvVar: "WOODPECKER_BUILD_EVENT", + Name: "build-event", + }, + cli.StringFlag{ + EnvVar: "WOODPECKER_BUILD_LINK", + Name: "build-link", + }, + cli.StringFlag{ + EnvVar: "WOODPECKER_BUILD_TARGET", + Name: "build-target", + }, + cli.StringFlag{ + EnvVar: "WOODPECKER_COMMIT_SHA", + Name: "commit-sha", + }, + cli.StringFlag{ + EnvVar: "WOODPECKER_COMMIT_REF", + Name: "commit-ref", + }, + cli.StringFlag{ + EnvVar: "WOODPECKER_COMMIT_REFSPEC", + Name: "commit-refspec", + }, + cli.StringFlag{ + EnvVar: "WOODPECKER_COMMIT_BRANCH", + Name: "commit-branch", + }, + cli.StringFlag{ + EnvVar: "WOODPECKER_COMMIT_MESSAGE", + Name: "commit-message", + }, + cli.StringFlag{ + EnvVar: "WOODPECKER_COMMIT_AUTHOR_NAME", + Name: "commit-author-name", + }, + cli.StringFlag{ + EnvVar: "WOODPECKER_COMMIT_AUTHOR_AVATAR", + Name: "commit-author-avatar", + }, + cli.StringFlag{ + EnvVar: "WOODPECKER_COMMIT_AUTHOR_EMAIL", + Name: "commit-author-email", + }, + cli.IntFlag{ + EnvVar: "WOODPECKER_PREV_BUILD_NUMBER", + Name: "prev-build-number", + }, + cli.Int64Flag{ + EnvVar: "WOODPECKER_PREV_BUILD_CREATED", + Name: "prev-build-created", + }, + cli.Int64Flag{ + EnvVar: "WOODPECKER_PREV_BUILD_STARTED", + Name: "prev-build-started", + }, + cli.Int64Flag{ + EnvVar: "WOODPECKER_PREV_BUILD_FINISHED", + Name: "prev-build-finished", + }, + cli.StringFlag{ + EnvVar: "WOODPECKER_PREV_BUILD_STATUS", + Name: "prev-build-status", + }, + cli.StringFlag{ + EnvVar: "WOODPECKER_PREV_BUILD_EVENT", + Name: "prev-build-event", + }, + cli.StringFlag{ + EnvVar: "WOODPECKER_PREV_BUILD_LINK", + Name: "prev-build-link", + }, + cli.StringFlag{ + EnvVar: "WOODPECKER_PREV_COMMIT_SHA", + Name: "prev-commit-sha", + }, + cli.StringFlag{ + EnvVar: "WOODPECKER_PREV_COMMIT_REF", + Name: "prev-commit-ref", + }, + cli.StringFlag{ + EnvVar: "WOODPECKER_PREV_COMMIT_REFSPEC", + Name: "prev-commit-refspec", + }, + cli.StringFlag{ + EnvVar: "WOODPECKER_PREV_COMMIT_BRANCH", + Name: "prev-commit-branch", + }, + cli.StringFlag{ + EnvVar: "WOODPECKER_PREV_COMMIT_MESSAGE", + Name: "prev-commit-message", + }, + cli.StringFlag{ + EnvVar: "WOODPECKER_PREV_COMMIT_AUTHOR_NAME", + Name: "prev-commit-author-name", + }, + cli.StringFlag{ + EnvVar: "WOODPECKER_PREV_COMMIT_AUTHOR_AVATAR", + Name: "prev-commit-author-avatar", + }, + cli.StringFlag{ + EnvVar: "WOODPECKER_PREV_COMMIT_AUTHOR_EMAIL", + Name: "prev-commit-author-email", + }, + cli.IntFlag{ + EnvVar: "WOODPECKER_JOB_NUMBER", + Name: "job-number", + }, + cli.StringSliceFlag{ + EnvVar: "WOODPECKER_ENV", + Name: "env", + }, +} diff --git a/cmd/cli/main.go b/cmd/cli/main.go index b54a29a6e..d0f3adef4 100644 --- a/cmd/cli/main.go +++ b/cmd/cli/main.go @@ -1,3 +1,17 @@ +// Copyright 2021 Woodpecker Authors +// +// 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 +// +// http://www.apache.org/licenses/LICENSE-2.0 +// +// 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. + package main import ( diff --git a/pipeline/backend/backend.go b/pipeline/backend/backend.go index c70204de6..65d232800 100644 --- a/pipeline/backend/backend.go +++ b/pipeline/backend/backend.go @@ -11,7 +11,7 @@ type Engine interface { // Setup the pipeline environment. Setup(context.Context, *Config) error - // Start the pipeline step. + // Exec start the pipeline step. Exec(context.Context, *Step) error // Kill the pipeline step.