mirror of
https://github.com/woodpecker-ci/woodpecker.git
synced 2024-12-30 10:11:23 +02:00
Set 'HOME' during local pipeline step (#1686)
close #1685 --------- Co-authored-by: 6543 <6543@obermui.de> Co-authored-by: Lauris BH <lauris@nix.lv>
This commit is contained in:
parent
6bf72cbeaf
commit
ea95d5aa76
@ -21,6 +21,7 @@ import (
|
|||||||
"io"
|
"io"
|
||||||
"os"
|
"os"
|
||||||
"os/exec"
|
"os/exec"
|
||||||
|
"path/filepath"
|
||||||
"strings"
|
"strings"
|
||||||
|
|
||||||
"github.com/alessio/shellescape"
|
"github.com/alessio/shellescape"
|
||||||
@ -30,6 +31,11 @@ import (
|
|||||||
"github.com/woodpecker-ci/woodpecker/shared/constant"
|
"github.com/woodpecker-ci/woodpecker/shared/constant"
|
||||||
)
|
)
|
||||||
|
|
||||||
|
const (
|
||||||
|
workingSubDir = "work"
|
||||||
|
homeSubDir = "home"
|
||||||
|
)
|
||||||
|
|
||||||
// notAllowedEnvVarOverwrites are all env vars that can not be overwritten by step config
|
// notAllowedEnvVarOverwrites are all env vars that can not be overwritten by step config
|
||||||
var notAllowedEnvVarOverwrites = []string{
|
var notAllowedEnvVarOverwrites = []string{
|
||||||
"CI_NETRC_MACHINE",
|
"CI_NETRC_MACHINE",
|
||||||
@ -42,9 +48,9 @@ var notAllowedEnvVarOverwrites = []string{
|
|||||||
|
|
||||||
type local struct {
|
type local struct {
|
||||||
// TODO: make cmd a cmd list to iterate over, the hard part is to have a common ReadCloser
|
// TODO: make cmd a cmd list to iterate over, the hard part is to have a common ReadCloser
|
||||||
cmd *exec.Cmd
|
cmd *exec.Cmd
|
||||||
output io.ReadCloser
|
output io.ReadCloser
|
||||||
workingdir string
|
workflowBaseDir string
|
||||||
}
|
}
|
||||||
|
|
||||||
// New returns a new local Engine.
|
// New returns a new local Engine.
|
||||||
@ -62,7 +68,7 @@ func (e *local) IsAvailable(context.Context) bool {
|
|||||||
|
|
||||||
func (e *local) Load(context.Context) error {
|
func (e *local) Load(context.Context) error {
|
||||||
dir, err := os.MkdirTemp("", "woodpecker-local-*")
|
dir, err := os.MkdirTemp("", "woodpecker-local-*")
|
||||||
e.workingdir = dir
|
e.workflowBaseDir = dir
|
||||||
return err
|
return err
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -82,12 +88,15 @@ func (e *local) Exec(ctx context.Context, step *types.Step) error {
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
// Set HOME
|
||||||
|
env = append(env, "HOME="+filepath.Join(e.workflowBaseDir, homeSubDir))
|
||||||
|
|
||||||
var command []string
|
var command []string
|
||||||
if step.Image == constant.DefaultCloneImage {
|
if step.Image == constant.DefaultCloneImage {
|
||||||
// Default clone step
|
// Default clone step
|
||||||
// TODO: creat tmp HOME and insert netrc
|
// TODO: use tmp HOME and insert netrc and delete it after clone
|
||||||
// TODO: download plugin-git binary if not exist
|
// TODO: download plugin-git binary if not exist
|
||||||
env = append(env, "CI_WORKSPACE="+e.workingdir+"/"+step.Environment["CI_REPO"])
|
env = append(env, "CI_WORKSPACE="+filepath.Join(e.workflowBaseDir, workingSubDir, step.Environment["CI_REPO"]))
|
||||||
command = append(command, "plugin-git")
|
command = append(command, "plugin-git")
|
||||||
} else {
|
} else {
|
||||||
// Use "image name" as run command
|
// Use "image name" as run command
|
||||||
@ -111,9 +120,9 @@ func (e *local) Exec(ctx context.Context, step *types.Step) error {
|
|||||||
|
|
||||||
// Prepare working directory
|
// Prepare working directory
|
||||||
if step.Image == constant.DefaultCloneImage {
|
if step.Image == constant.DefaultCloneImage {
|
||||||
e.cmd.Dir = e.workingdir + "/" + step.Environment["CI_REPO_OWNER"]
|
e.cmd.Dir = filepath.Join(e.workflowBaseDir, workingSubDir, step.Environment["CI_REPO_OWNER"])
|
||||||
} else {
|
} else {
|
||||||
e.cmd.Dir = e.workingdir + "/" + step.Environment["CI_REPO"]
|
e.cmd.Dir = filepath.Join(e.workflowBaseDir, workingSubDir, step.Environment["CI_REPO"])
|
||||||
}
|
}
|
||||||
err := os.MkdirAll(e.cmd.Dir, 0o700)
|
err := os.MkdirAll(e.cmd.Dir, 0o700)
|
||||||
if err != nil {
|
if err != nil {
|
||||||
@ -152,5 +161,5 @@ func (e *local) Tail(context.Context, *types.Step) (io.ReadCloser, error) {
|
|||||||
|
|
||||||
// Destroy the pipeline environment.
|
// Destroy the pipeline environment.
|
||||||
func (e *local) Destroy(context.Context, *types.Config) error {
|
func (e *local) Destroy(context.Context, *types.Config) error {
|
||||||
return os.RemoveAll(e.cmd.Dir)
|
return os.RemoveAll(e.workflowBaseDir)
|
||||||
}
|
}
|
||||||
|
Loading…
Reference in New Issue
Block a user