mirror of
https://github.com/SAP/jenkins-library.git
synced 2025-01-18 05:18:24 +02:00
a1988f6808
* Add GH issue creation + SARIF * Code cleanup * Fix fmt, add debug * Code enhancements * Fix * Added debug info * Rework UA log scan * Fix code * read UA version * Fix nil reference * Extraction * Credentials * Issue creation * Error handling * Fix issue creation * query escape * Query escape 2 * Revert * Test avoid update * HTTP client * Add support for custom TLS certs * Fix code * Fix code 2 * Fix code 3 * Disable cert check * Fix auth * Remove implicit trust * Skip verification * Fix * Fix client * Fix HTTP auth * Fix trusted certs * Trim version * Code * Add token * Added token handling to client * Fix token * Cleanup * Fix token * Token rework * Fix code * Kick out oauth client * Kick out oauth client * Transport wrapping * Token * Simplification * Refactor * Variation * Check * Fix * Debug * Switch client * Variation * Debug * Switch to cert check * Add debug * Parse self * Cleanup * Update resources/metadata/whitesourceExecuteScan.yaml * Add debug * Expose subjects * Patch * Debug * Debug2 * Debug3 * Fix logging response body * Cleanup * Cleanup * Fix request body logging * Cleanup import * Fix import cycle * Cleanup * Fix fmt * Fix NopCloser reference * Regenerate * Reintroduce * Fix test * Fix tests * Correction * Fix error * Code fix * Fix tests * Add tests * Fix code climate issues * Code climate * Code climate again * Code climate again * Fix fmt * Fix fmt 2 Co-authored-by: Oliver Nocon <33484802+OliverNocon@users.noreply.github.com>
96 lines
3.2 KiB
Go
96 lines
3.2 KiB
Go
//go:build !release
|
|
// +build !release
|
|
|
|
package mock
|
|
|
|
import (
|
|
"fmt"
|
|
"io"
|
|
"os"
|
|
)
|
|
|
|
type baseRunner interface {
|
|
SetDir(d string)
|
|
SetEnv(e []string)
|
|
Stdout(out io.Writer)
|
|
Stderr(err io.Writer)
|
|
RunExecutable(e string, p ...string) error
|
|
}
|
|
|
|
// DockerExecConfig is the configuration for an individual tool that shall be executed in docker.
|
|
type DockerExecConfig struct {
|
|
// Image is the fully qualified docker image name that is passed to docker for this tool.
|
|
Image string
|
|
// Workspace is the (optional) directory to which the current working directory is mapped
|
|
// within the docker container.
|
|
Workspace string
|
|
}
|
|
|
|
// DockerExecRunner can be used "in place" of another ExecRunner in order to transparently
|
|
// execute commands within a docker container. One use-case is to test locally with tools
|
|
// that are not available on the current platform. When entering the run*() function of a
|
|
// step implementation, a DockerExecRunner can be wrapped around a command.Command{}
|
|
// an be configured to run certain executables within docker.
|
|
type DockerExecRunner struct {
|
|
// Runner is the ExecRunner to which all executions are forwarded in the end.
|
|
Runner baseRunner
|
|
executablesToWrap map[string]DockerExecConfig
|
|
}
|
|
|
|
// SetDir directly forwards to the provided BaseRunner.
|
|
func (d *DockerExecRunner) SetDir(dir string) {
|
|
d.Runner.SetDir(dir)
|
|
}
|
|
|
|
// SetEnv directly forwards to the provided BaseRunner.
|
|
func (d *DockerExecRunner) SetEnv(env []string) {
|
|
d.Runner.SetEnv(env)
|
|
}
|
|
|
|
// Stdout directly forwards to the provided BaseRunner.
|
|
func (d *DockerExecRunner) Stdout(out io.Writer) {
|
|
d.Runner.Stdout(out)
|
|
}
|
|
|
|
// Stderr directly forwards to the provided BaseRunner.
|
|
func (d *DockerExecRunner) Stderr(err io.Writer) {
|
|
d.Runner.Stderr(err)
|
|
}
|
|
|
|
// AddExecConfig needs to be called to store a configuration for a specific executable, in order
|
|
// to run this executable within docker.
|
|
func (d *DockerExecRunner) AddExecConfig(executable string, config DockerExecConfig) error {
|
|
if executable == "" {
|
|
return fmt.Errorf("'executable' needs to be provided")
|
|
}
|
|
if config.Image == "" {
|
|
return fmt.Errorf("the DockerExecConfig must specify a docker image")
|
|
}
|
|
if d.executablesToWrap == nil {
|
|
d.executablesToWrap = map[string]DockerExecConfig{}
|
|
}
|
|
d.executablesToWrap[executable] = config
|
|
return nil
|
|
}
|
|
|
|
// RunExecutable runs the provided executable within docker, if a DockerExecConfig has been previously
|
|
// associated with this executable via AddExecConfig(). Otherwise runs it directly. The BaseRunner is
|
|
// used for execution in any case.
|
|
func (d *DockerExecRunner) RunExecutable(executable string, parameters ...string) error {
|
|
if config, ok := d.executablesToWrap[executable]; ok {
|
|
wrappedParameters := []string{"run", "--entrypoint=" + executable}
|
|
if config.Workspace != "" {
|
|
currentDir, err := os.Getwd()
|
|
if err != nil {
|
|
return fmt.Errorf("failed to get current directory for mounting in docker: %w", err)
|
|
}
|
|
wrappedParameters = append(wrappedParameters, "-v", currentDir+":"+config.Workspace)
|
|
}
|
|
wrappedParameters = append(wrappedParameters, config.Image)
|
|
wrappedParameters = append(wrappedParameters, parameters...)
|
|
executable = "docker"
|
|
parameters = wrappedParameters
|
|
}
|
|
return d.Runner.RunExecutable(executable, parameters...)
|
|
}
|