2020-01-05 18:42:07 +01:00
|
|
|
package hooks
|
|
|
|
|
|
|
|
|
|
import (
|
|
|
|
|
"bufio"
|
2020-08-18 17:33:53 +02:00
|
|
|
"io"
|
|
|
|
|
"os"
|
2020-01-05 18:42:07 +01:00
|
|
|
"os/exec"
|
2020-01-06 17:41:10 +01:00
|
|
|
"runtime"
|
2020-01-05 18:42:07 +01:00
|
|
|
"strings"
|
|
|
|
|
|
2020-08-18 17:33:53 +02:00
|
|
|
log "github.com/sirupsen/logrus"
|
|
|
|
|
|
2020-01-05 18:42:07 +01:00
|
|
|
"github.com/Nightapes/go-semantic-release/internal/shared"
|
|
|
|
|
"github.com/Nightapes/go-semantic-release/pkg/config"
|
|
|
|
|
)
|
|
|
|
|
|
|
|
|
|
//Hooks struct
|
|
|
|
|
type Hooks struct {
|
|
|
|
|
version *shared.ReleaseVersion
|
|
|
|
|
config *config.ReleaseConfig
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
// New hooks struct
|
|
|
|
|
func New(config *config.ReleaseConfig, version *shared.ReleaseVersion) *Hooks {
|
|
|
|
|
return &Hooks{
|
|
|
|
|
config: config,
|
|
|
|
|
version: version,
|
|
|
|
|
}
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
// PreRelease runs before creating release
|
|
|
|
|
func (h *Hooks) PreRelease() error {
|
|
|
|
|
log.Infof("Run pre release hooks")
|
|
|
|
|
for _, cmd := range h.config.Hooks.PreRelease {
|
|
|
|
|
log.Debugf("Run %s", cmd)
|
|
|
|
|
err := h.runCommand(cmd)
|
|
|
|
|
if err != nil {
|
|
|
|
|
return err
|
|
|
|
|
}
|
|
|
|
|
}
|
|
|
|
|
return nil
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
// PostRelease runs after creating release
|
|
|
|
|
func (h *Hooks) PostRelease() error {
|
|
|
|
|
log.Infof("Run post release hooks")
|
|
|
|
|
for _, cmd := range h.config.Hooks.PostRelease {
|
|
|
|
|
err := h.runCommand(cmd)
|
|
|
|
|
if err != nil {
|
|
|
|
|
return err
|
|
|
|
|
}
|
|
|
|
|
}
|
|
|
|
|
return nil
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
func (h *Hooks) runCommand(command string) error {
|
|
|
|
|
|
2020-01-06 17:41:10 +01:00
|
|
|
cmdReplaced := strings.ReplaceAll(command, "$RELEASE_VERSION", h.version.Next.Version.String())
|
2020-01-05 18:42:07 +01:00
|
|
|
|
2020-01-06 17:41:10 +01:00
|
|
|
var cmd *exec.Cmd
|
|
|
|
|
if runtime.GOOS == "windows" {
|
|
|
|
|
cmd = exec.Command("cmd.exe", "/C", cmdReplaced)
|
|
|
|
|
} else {
|
|
|
|
|
cmd = exec.Command("sh", "-c", cmdReplaced)
|
|
|
|
|
}
|
2020-01-05 18:42:07 +01:00
|
|
|
|
2020-08-18 17:33:53 +02:00
|
|
|
cmd.Env = os.Environ()
|
2021-01-21 21:41:14 +01:00
|
|
|
cmd.Env = append(cmd.Env, "RELEASE_VERSION="+h.version.Next.Version.String())
|
2020-01-05 18:42:07 +01:00
|
|
|
cmdReader, err := cmd.StdoutPipe()
|
|
|
|
|
if err != nil {
|
|
|
|
|
return err
|
|
|
|
|
}
|
2020-08-18 17:33:53 +02:00
|
|
|
h.printOutput(cmdReader, strings.Fields(cmdReplaced)[0])
|
|
|
|
|
|
|
|
|
|
cmdErrReader, err := cmd.StderrPipe()
|
|
|
|
|
if err != nil {
|
|
|
|
|
return err
|
|
|
|
|
}
|
|
|
|
|
h.printOutput(cmdErrReader, strings.Fields(cmdReplaced)[0])
|
2020-01-05 18:42:07 +01:00
|
|
|
|
2020-08-18 17:33:53 +02:00
|
|
|
return cmd.Run()
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
func (h *Hooks) printOutput(read io.ReadCloser, cmd string) {
|
|
|
|
|
scanner := bufio.NewScanner(read)
|
2020-01-05 18:42:07 +01:00
|
|
|
go func() {
|
|
|
|
|
for scanner.Scan() {
|
2020-08-18 17:33:53 +02:00
|
|
|
log.WithField("cmd", cmd).Infof("%s\n", scanner.Text())
|
2020-01-05 18:42:07 +01:00
|
|
|
}
|
|
|
|
|
}()
|
|
|
|
|
}
|