Skip to content

alexellis/go-execute

Folders and files

NameName
Last commit message
Last commit date

Latest commit

 

History

27 Commits
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 

Repository files navigation

go-execute

A wrapper for Go's command execution packages.

go get github.com/alexellis/go-execute/v2

Docs

See docs at pkg.go.dev: github.com/alexellis/go-execute

go-execute users

Used by dozens of projects as identified by GitHub, notably:

Community examples:

Feel free to add a link to your own projects in a PR.

Main options

  • DisableStdioBuffer - Discard Stdio, rather than buffering into memory
  • StreamStdio - Stream stderr and stdout to the console, useful for debugging and testing
  • Shell - Use bash as a shell to execute the command, rather than exec a binary directly
  • StdOutWriter - an additional writer for stdout, useful for mutating or filtering the output
  • StdErrWriter - an additional writer for stderr, useful for mutating or filtering the output
  • PrintCommand - print the command to stdout before executing it

Example of exec without streaming to STDIO

This example captures the values from stdout and stderr without relaying to the console. This means the values can be inspected and used for automation.

package main

import (
	"fmt"

	execute "github.com/alexellis/go-execute/v2"
	"context"
)

func main() {
	cmd := execute.ExecTask{
		Command:     "docker",
		Args:        []string{"version"},
		StreamStdio: false,
	}

	res, err := cmd.Execute(context.Background())
	if err != nil {
		panic(err)
	}

	if res.ExitCode != 0 {
		panic("Non-zero exit code: " + res.Stderr)
	}

	fmt.Printf("stdout: %s, stderr: %s, exit-code: %d\n", res.Stdout, res.Stderr, res.ExitCode)
}

Example with "shell" and exit-code 0

package main

import (
	"fmt"

	execute "github.com/alexellis/go-execute/v2"
	"context"
)

func main() {
	ls := execute.ExecTask{
		Command: "ls",
		Args:    []string{"-l"},
		Shell:   true,
	}
	res, err := ls.Execute(context.Background())
	if err != nil {
		panic(err)
	}

	fmt.Printf("stdout: %q, stderr: %q, exit-code: %d\n", res.Stdout, res.Stderr, res.ExitCode)
}

Example with "shell" and exit-code 1

package main

import (
	"fmt"

	"context"
	execute "github.com/alexellis/go-execute/v2"
)

func main() {
	ls := execute.ExecTask{
		Command: "exit 1",
		Shell:   true,
	}
	res, err := ls.Execute(context.Background())
	if err != nil {
		panic(err)
	}

	fmt.Printf("stdout: %q, stderr: %q, exit-code: %d\n", res.Stdout, res.Stderr, res.ExitCode)
}

Contributing

Commits must be signed off with git commit -s

License: MIT