mirror of https://github.com/fluxcd/flux2.git
				
				
				
			
			You cannot select more than 25 topics
			Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.
		
		
		
		
		
			
		
			
				
	
	
		
			71 lines
		
	
	
		
			2.6 KiB
		
	
	
	
		
			Go
		
	
			
		
		
	
	
			71 lines
		
	
	
		
			2.6 KiB
		
	
	
	
		
			Go
		
	
| package main
 | |
| 
 | |
| import (
 | |
| 	"fmt"
 | |
| 	"os"
 | |
| 	"testing"
 | |
| )
 | |
| 
 | |
| func TestCreateGitSecret(t *testing.T) {
 | |
| 	file, err := os.CreateTemp(t.TempDir(), "ca-crt")
 | |
| 	if err != nil {
 | |
| 		t.Fatal("could not create CA certificate file")
 | |
| 	}
 | |
| 	_, err = file.Write([]byte("ca-data"))
 | |
| 	if err != nil {
 | |
| 		t.Fatal("could not write to CA certificate file")
 | |
| 	}
 | |
| 
 | |
| 	tests := []struct {
 | |
| 		name   string
 | |
| 		args   string
 | |
| 		assert assertFunc
 | |
| 	}{
 | |
| 		{
 | |
| 			name:   "no args",
 | |
| 			args:   "create secret git",
 | |
| 			assert: assertError("name is required"),
 | |
| 		},
 | |
| 		{
 | |
| 			name:   "basic secret",
 | |
| 			args:   "create secret git podinfo-auth --url=https://github.com/stefanprodan/podinfo --username=my-username --password=my-password --namespace=my-namespace --export",
 | |
| 			assert: assertGoldenFile("./testdata/create_secret/git/secret-git-basic.yaml"),
 | |
| 		},
 | |
| 		{
 | |
| 			name:   "ssh key",
 | |
| 			args:   "create secret git podinfo-auth --url=ssh://git@github.com/stefanprodan/podinfo --private-key-file=./testdata/create_secret/git/ecdsa.private --namespace=my-namespace --export",
 | |
| 			assert: assertGoldenFile("testdata/create_secret/git/git-ssh-secret.yaml"),
 | |
| 		},
 | |
| 		{
 | |
| 			name:   "ssh key with password",
 | |
| 			args:   "create secret git podinfo-auth --url=ssh://git@github.com/stefanprodan/podinfo --private-key-file=./testdata/create_secret/git/ecdsa-password.private --password=password --namespace=my-namespace --export",
 | |
| 			assert: assertGoldenFile("testdata/create_secret/git/git-ssh-secret-password.yaml"),
 | |
| 		},
 | |
| 		{
 | |
| 			name:   "git authentication with bearer token",
 | |
| 			args:   "create secret git bearer-token-auth --url=https://github.com/stefanprodan/podinfo --bearer-token=ghp_baR2qnFF0O41WlucePL3udt2N9vVZS4R0hAS --namespace=my-namespace --export",
 | |
| 			assert: assertGoldenFile("testdata/create_secret/git/git-bearer-token.yaml"),
 | |
| 		},
 | |
| 		{
 | |
| 			name:   "git authentication with CA certificate",
 | |
| 			args:   fmt.Sprintf("create secret git ca-crt --url=https://github.com/stefanprodan/podinfo --password=my-password --username=my-username --ca-crt-file=%s --namespace=my-namespace --export", file.Name()),
 | |
| 			assert: assertGoldenFile("testdata/create_secret/git/secret-ca-crt.yaml"),
 | |
| 		},
 | |
| 		{
 | |
| 			name:   "git authentication with basic auth and bearer token",
 | |
| 			args:   "create secret git podinfo-auth --url=https://github.com/stefanprodan/podinfo --username=aaa --password=zzzz --bearer-token=aaaa --namespace=my-namespace --export",
 | |
| 			assert: assertError("user credentials and bearer token cannot be used together"),
 | |
| 		},
 | |
| 	}
 | |
| 
 | |
| 	for _, tt := range tests {
 | |
| 		t.Run(tt.name, func(t *testing.T) {
 | |
| 			cmd := cmdTestCase{
 | |
| 				args:   tt.args,
 | |
| 				assert: tt.assert,
 | |
| 			}
 | |
| 			cmd.runTestCmd(t)
 | |
| 		})
 | |
| 	}
 | |
| }
 |