mirror of
https://github.com/kubernetes-sigs/kustomize.git
synced 2026-06-10 08:20:59 +00:00
This PR closes a TODO in the fileLoader type to replace the string representing a git repo url with a struct called holding validated fields. New struct is called RepoSpec. It holds what we need in coming PRs for remote repo base containment checks, and will also allow the overlay cycle prevention code to take into account different host schemes or branches. The struct is in a new file called repospec.go. The new file is mostly just a code move of url parsing code that was in cloner.go. Git "blame" history preserved through the move. No change in execution (see final commit by itself).
297 lines
7.1 KiB
Go
297 lines
7.1 KiB
Go
/*
|
|
Copyright 2018 The Kubernetes Authors.
|
|
|
|
Licensed under the Apache License, Version 2.0 (the "License");
|
|
you may not use this file except in compliance with the License.
|
|
You may obtain a copy of the License at
|
|
|
|
http://www.apache.org/licenses/LICENSE-2.0
|
|
|
|
Unless required by applicable law or agreed to in writing, software
|
|
distributed under the License is distributed on an "AS IS" BASIS,
|
|
WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
|
|
See the License for the specific language governing permissions and
|
|
limitations under the License.
|
|
*/
|
|
|
|
package git
|
|
|
|
import (
|
|
"fmt"
|
|
"path/filepath"
|
|
"testing"
|
|
)
|
|
|
|
func TestIsRepoURL(t *testing.T) {
|
|
|
|
testcases := []struct {
|
|
input string
|
|
expected bool
|
|
}{
|
|
{
|
|
input: "https://github.com/org/repo",
|
|
expected: true,
|
|
},
|
|
{
|
|
input: "github.com/org/repo",
|
|
expected: true,
|
|
},
|
|
{
|
|
input: "git@github.com:org/repo",
|
|
expected: true,
|
|
},
|
|
{
|
|
input: "gh:org/repo",
|
|
expected: true,
|
|
},
|
|
{
|
|
input: "git::https://gitlab.com/org/repo",
|
|
expected: true,
|
|
},
|
|
{
|
|
input: "git@gitlab2.sqtools.ru:10022/infra/kubernetes/thanos-base.git?ref=v0.1.0",
|
|
expected: true,
|
|
},
|
|
{
|
|
input: "git@bitbucket.org:org/repo.git",
|
|
expected: true,
|
|
},
|
|
{
|
|
input: "git::http://git.example.com/org/repo.git",
|
|
expected: true,
|
|
},
|
|
{
|
|
input: "git::https://git.example.com/org/repo.git",
|
|
expected: true,
|
|
},
|
|
{
|
|
input: "ssh://git.example.com:7999/org/repo.git",
|
|
expected: true,
|
|
},
|
|
{
|
|
input: "/github.com/org/repo",
|
|
expected: false,
|
|
},
|
|
{
|
|
input: "/abs/path/to/file",
|
|
expected: false,
|
|
},
|
|
{
|
|
input: "../relative",
|
|
expected: false,
|
|
},
|
|
{
|
|
input: "foo",
|
|
expected: false,
|
|
},
|
|
{
|
|
input: ".",
|
|
expected: false,
|
|
},
|
|
{
|
|
input: "",
|
|
expected: false,
|
|
},
|
|
}
|
|
for _, tc := range testcases {
|
|
actual := IsRepoUrl(tc.input)
|
|
if actual != tc.expected {
|
|
t.Errorf("unexpected error: unexpected result %t for input %s", actual, tc.input)
|
|
}
|
|
}
|
|
}
|
|
|
|
var repoNames = []string{"someOrg/someRepo", "kubernetes/website"}
|
|
|
|
var paths = []string{"README.md", "foo/krusty.txt", ""}
|
|
|
|
var hrefArgs = []string{"someBranch", ""}
|
|
|
|
var extractFmts = map[string]string{
|
|
"gh:%s": "gh:",
|
|
"GH:%s": "gh:",
|
|
"gitHub.com/%s": "https://github.com/",
|
|
"https://github.com/%s": "https://github.com/",
|
|
"hTTps://github.com/%s": "https://github.com/",
|
|
"git::https://gitlab.com/%s": "https://gitlab.com/",
|
|
"github.com:%s": "https://github.com/",
|
|
"git::http://git.example.com/%s": "http://git.example.com/",
|
|
"git::https://git.example.com/%s": "https://git.example.com/",
|
|
"ssh://git.example.com:7999/%s": "ssh://git.example.com:7999/",
|
|
}
|
|
|
|
func TestParseGithubUrl(t *testing.T) {
|
|
for _, repoName := range repoNames {
|
|
for _, pathName := range paths {
|
|
for extractFmt, hostSpec := range extractFmts {
|
|
for _, hrefArg := range hrefArgs {
|
|
spec := repoName
|
|
if len(pathName) > 0 {
|
|
spec = filepath.Join(spec, pathName)
|
|
}
|
|
input := fmt.Sprintf(extractFmt, spec)
|
|
if hrefArg != "" {
|
|
input = input + refQuery + hrefArg
|
|
}
|
|
if !IsRepoUrl(input) {
|
|
t.Errorf("Should smell like github arg: %s\n", input)
|
|
continue
|
|
}
|
|
host, repo, path, gitRef, err := parseGithubUrl(input)
|
|
if err != nil {
|
|
t.Errorf("problem %v", err)
|
|
}
|
|
if host != hostSpec {
|
|
t.Errorf("\n"+
|
|
" from %s\n"+
|
|
" actual host %s\n"+
|
|
"expected host %s\n", input, host, hostSpec)
|
|
}
|
|
if repo != repoName {
|
|
t.Errorf("\n"+
|
|
" from %s\n"+
|
|
" actual Repo %s\n"+
|
|
"expected Repo %s\n", input, repo, repoName)
|
|
}
|
|
if path != pathName {
|
|
t.Errorf("\n"+
|
|
" from %s\n"+
|
|
" actual Path %s\n"+
|
|
"expected Path %s\n", input, path, pathName)
|
|
}
|
|
if gitRef != hrefArg {
|
|
t.Errorf("\n"+
|
|
" from %s\n"+
|
|
" actual Href %s\n"+
|
|
"expected Href %s\n", input, gitRef, hrefArg)
|
|
}
|
|
}
|
|
}
|
|
}
|
|
}
|
|
}
|
|
|
|
func TestNewRepoSpecFromUrl(t *testing.T) {
|
|
testcases := []struct {
|
|
input string
|
|
repo string
|
|
path string
|
|
ref string
|
|
}{
|
|
{
|
|
input: "https://git-codecommit.us-east-2.amazonaws.com/someorg/somerepo/somedir",
|
|
repo: "https://git-codecommit.us-east-2.amazonaws.com/someorg/somerepo",
|
|
path: "somedir",
|
|
ref: "",
|
|
},
|
|
{
|
|
input: "https://git-codecommit.us-east-2.amazonaws.com/someorg/somerepo/somedir?ref=testbranch",
|
|
repo: "https://git-codecommit.us-east-2.amazonaws.com/someorg/somerepo",
|
|
path: "somedir",
|
|
ref: "testbranch",
|
|
},
|
|
{
|
|
input: "https://fabrikops2.visualstudio.com/someorg/somerepo?ref=master",
|
|
repo: "https://fabrikops2.visualstudio.com/someorg/somerepo",
|
|
path: "",
|
|
ref: "master",
|
|
},
|
|
{
|
|
input: "http://github.com/someorg/somerepo/somedir",
|
|
repo: "https://github.com/someorg/somerepo.git",
|
|
path: "somedir",
|
|
ref: "",
|
|
},
|
|
{
|
|
input: "git@github.com:someorg/somerepo/somedir",
|
|
repo: "git@github.com:someorg/somerepo.git",
|
|
path: "somedir",
|
|
ref: "",
|
|
},
|
|
{
|
|
input: "git@gitlab2.sqtools.ru:10022/infra/kubernetes/thanos-base.git?ref=v0.1.0",
|
|
repo: "git@gitlab2.sqtools.ru:10022/infra/kubernetes/thanos-base.git",
|
|
path: "",
|
|
ref: "v0.1.0",
|
|
},
|
|
}
|
|
for _, testcase := range testcases {
|
|
rs, err := NewRepoSpecFromUrl(testcase.input)
|
|
if err != nil {
|
|
t.Errorf("Unexpected error: %v", err)
|
|
}
|
|
if rs.repo != testcase.repo {
|
|
t.Errorf("repo expected to be %v, but got %v on %s",
|
|
testcase.repo, rs.repo, testcase.input)
|
|
}
|
|
if rs.path != testcase.path {
|
|
t.Errorf("path expected to be %v, but got %v on %s",
|
|
testcase.path, rs.path, testcase.input)
|
|
}
|
|
if rs.ref != testcase.ref {
|
|
t.Errorf("ref expected to be %v, but got %v on %s",
|
|
testcase.ref, rs.ref, testcase.input)
|
|
}
|
|
}
|
|
}
|
|
|
|
func TestIsAzureHost(t *testing.T) {
|
|
testcases := []struct {
|
|
input string
|
|
expect bool
|
|
}{
|
|
{
|
|
input: "https://git-codecommit.us-east-2.amazonaws.com",
|
|
expect: false,
|
|
},
|
|
{
|
|
input: "ssh://git-codecommit.us-east-2.amazonaws.com",
|
|
expect: false,
|
|
},
|
|
{
|
|
input: "https://fabrikops2.visualstudio.com/",
|
|
expect: true,
|
|
},
|
|
{
|
|
input: "https://dev.azure.com/myorg/myproject/",
|
|
expect: true,
|
|
},
|
|
}
|
|
for _, testcase := range testcases {
|
|
actual := isAzureHost(testcase.input)
|
|
if actual != testcase.expect {
|
|
t.Errorf("IsAzureHost: expected %v, but got %v on %s", testcase.expect, actual, testcase.input)
|
|
}
|
|
}
|
|
}
|
|
|
|
func TestIsAWSHost(t *testing.T) {
|
|
testcases := []struct {
|
|
input string
|
|
expect bool
|
|
}{
|
|
{
|
|
input: "https://git-codecommit.us-east-2.amazonaws.com",
|
|
expect: true,
|
|
},
|
|
{
|
|
input: "ssh://git-codecommit.us-east-2.amazonaws.com",
|
|
expect: true,
|
|
},
|
|
{
|
|
input: "git@github.com:",
|
|
expect: false,
|
|
},
|
|
{
|
|
input: "http://github.com/",
|
|
expect: false,
|
|
},
|
|
}
|
|
for _, testcase := range testcases {
|
|
actual := isAWSHost(testcase.input)
|
|
if actual != testcase.expect {
|
|
t.Errorf("IsAWSHost: expected %v, but got %v on %s", testcase.expect, actual, testcase.input)
|
|
}
|
|
}
|
|
}
|