Adds a new command `gh auth setup-git [<hostname>]` that sets up git to use the GitHub CLI as a credential helper. The gist is that it runs these two git commands for each hostname the user is authenticated with. ``` git config --global --replace-all 'credential.https://github.com.helper' '' git config --global --add 'credential.https://github.com.helper' '!gh auth git-credential' ``` If a hostname flag is given, it'll setup GH CLI as a credential helper for only that hostname. If the user is not authenticated with any git hostnames, or the user is not authenticated with the hostname given as a flag, it'll print an error. Co-authored-by: Mislav Marohnić <mislav@github.com>
94 lines
2.1 KiB
Go
94 lines
2.1 KiB
Go
package shared
|
|
|
|
import (
|
|
"testing"
|
|
|
|
"github.com/cli/cli/v2/internal/run"
|
|
)
|
|
|
|
func TestGitCredentialSetup_configureExisting(t *testing.T) {
|
|
cs, restoreRun := run.Stub()
|
|
defer restoreRun(t)
|
|
cs.Register(`git credential reject`, 0, "")
|
|
cs.Register(`git credential approve`, 0, "")
|
|
|
|
f := GitCredentialFlow{
|
|
Executable: "gh",
|
|
helper: "osxkeychain",
|
|
}
|
|
|
|
if err := f.gitCredentialSetup("example.com", "monalisa", "PASSWD"); err != nil {
|
|
t.Errorf("GitCredentialSetup() error = %v", err)
|
|
}
|
|
}
|
|
|
|
func TestGitCredentialSetup_setOurs(t *testing.T) {
|
|
cs, restoreRun := run.Stub()
|
|
defer restoreRun(t)
|
|
cs.Register(`git config --global --replace-all credential\.`, 0, "", func(args []string) {
|
|
if key := args[len(args)-2]; key != "credential.https://example.com.helper" {
|
|
t.Errorf("git config key was %q", key)
|
|
}
|
|
if val := args[len(args)-1]; val != "" {
|
|
t.Errorf("global credential helper configured to %q", val)
|
|
}
|
|
})
|
|
cs.Register(`git config --global --add credential\.`, 0, "", func(args []string) {
|
|
if key := args[len(args)-2]; key != "credential.https://example.com.helper" {
|
|
t.Errorf("git config key was %q", key)
|
|
}
|
|
if val := args[len(args)-1]; val != "!/path/to/gh auth git-credential" {
|
|
t.Errorf("global credential helper configured to %q", val)
|
|
}
|
|
})
|
|
|
|
f := GitCredentialFlow{
|
|
Executable: "/path/to/gh",
|
|
helper: "",
|
|
}
|
|
|
|
if err := f.gitCredentialSetup("example.com", "monalisa", "PASSWD"); err != nil {
|
|
t.Errorf("GitCredentialSetup() error = %v", err)
|
|
}
|
|
}
|
|
|
|
func Test_isOurCredentialHelper(t *testing.T) {
|
|
tests := []struct {
|
|
name string
|
|
arg string
|
|
want bool
|
|
}{
|
|
{
|
|
name: "blank",
|
|
arg: "",
|
|
want: false,
|
|
},
|
|
{
|
|
name: "invalid",
|
|
arg: "!",
|
|
want: false,
|
|
},
|
|
{
|
|
name: "osxkeychain",
|
|
arg: "osxkeychain",
|
|
want: false,
|
|
},
|
|
{
|
|
name: "looks like gh but isn't",
|
|
arg: "gh auth",
|
|
want: false,
|
|
},
|
|
{
|
|
name: "ours",
|
|
arg: "!/path/to/gh auth",
|
|
want: true,
|
|
},
|
|
}
|
|
for _, tt := range tests {
|
|
t.Run(tt.name, func(t *testing.T) {
|
|
if got := isOurCredentialHelper(tt.arg); got != tt.want {
|
|
t.Errorf("isOurCredentialHelper() = %v, want %v", got, tt.want)
|
|
}
|
|
})
|
|
}
|
|
}
|