diff --git a/pkg/commands/git.go b/pkg/commands/git.go index fd7d9e9b1af..3599f7b39a4 100644 --- a/pkg/commands/git.go +++ b/pkg/commands/git.go @@ -453,7 +453,7 @@ func (c *GitCommand) usingGpg() bool { func (c *GitCommand) Commit(message string, flags string) (*exec.Cmd, error) { command := fmt.Sprintf("git commit %s -m %s", flags, c.OSCommand.Quote(message)) if c.usingGpg() { - return c.OSCommand.ExecutableFromString(fmt.Sprintf("%s %s %s", c.OSCommand.Platform.shell, c.OSCommand.Platform.shellArg, command)), nil + return c.OSCommand.ShellCommandFromString(command), nil } return nil, c.OSCommand.RunCommand(command) @@ -470,7 +470,7 @@ func (c *GitCommand) GetHeadCommitMessage() (string, error) { func (c *GitCommand) AmendHead() (*exec.Cmd, error) { command := "git commit --amend --no-edit --allow-empty" if c.usingGpg() { - return c.OSCommand.ExecutableFromString(fmt.Sprintf("%s %s %s", c.OSCommand.Platform.shell, c.OSCommand.Platform.shellArg, command)), nil + return c.OSCommand.ShellCommandFromString(command), nil } return nil, c.OSCommand.RunCommand(command) diff --git a/pkg/commands/git_test.go b/pkg/commands/git_test.go index ed1fed013f9..d74f8b68281 100644 --- a/pkg/commands/git_test.go +++ b/pkg/commands/git_test.go @@ -815,7 +815,7 @@ func TestGitCommandCommit(t *testing.T) { "Commit using gpg", func(cmd string, args ...string) *exec.Cmd { assert.EqualValues(t, "bash", cmd) - assert.EqualValues(t, []string{"-c", "git", "commit", "-m", "test"}, args) + assert.EqualValues(t, []string{"-c", "git commit -m 'test'"}, args) return exec.Command("echo") }, @@ -905,7 +905,7 @@ func TestGitCommandAmendHead(t *testing.T) { "Amend commit using gpg", func(cmd string, args ...string) *exec.Cmd { assert.EqualValues(t, "bash", cmd) - assert.EqualValues(t, []string{"-c", "git", "commit", "--amend", "--no-edit", "--allow-empty"}, args) + assert.EqualValues(t, []string{"-c", "git commit --amend --no-edit --allow-empty"}, args) return exec.Command("echo") }, diff --git a/pkg/commands/os.go b/pkg/commands/os.go index a27196f34ed..b3358b170be 100644 --- a/pkg/commands/os.go +++ b/pkg/commands/os.go @@ -118,6 +118,19 @@ func (c *OSCommand) ExecutableFromString(commandStr string) *exec.Cmd { return cmd } +// ShellCommandFromString takes a string like `git commit` and returns an executable shell command for it +func (c *OSCommand) ShellCommandFromString(commandStr string) *exec.Cmd { + quotedCommand := "" + // Windows does not seem to like quotes around the command + if c.Platform.os == "windows" { + quotedCommand = commandStr + } else { + quotedCommand = c.Quote(commandStr) + } + + return c.ExecutableFromString(fmt.Sprintf("%s %s %s", c.Platform.shell, c.Platform.shellArg, quotedCommand)) +} + // RunCommandWithOutputLive runs RunCommandWithOutputLiveWrapper func (c *OSCommand) RunCommandWithOutputLive(command string, output func(string) string) error { return RunCommandWithOutputLiveWrapper(c, command, output)