Skip to content

Commit

Permalink
added namespace to skaffold profile
Browse files Browse the repository at this point in the history
  • Loading branch information
MarlonGamez committed Aug 30, 2019
1 parent eb15156 commit 3ba27b3
Show file tree
Hide file tree
Showing 3 changed files with 59 additions and 5 deletions.
13 changes: 10 additions & 3 deletions pkg/skaffold/generate_pipeline/profile.go
Original file line number Diff line number Diff line change
Expand Up @@ -27,12 +27,13 @@ import (
"github.com/pkg/errors"

"github.com/GoogleContainerTools/skaffold/pkg/skaffold/color"
"github.com/GoogleContainerTools/skaffold/pkg/skaffold/runner/runcontext"
"github.com/GoogleContainerTools/skaffold/pkg/skaffold/schema/latest"

yamlv2 "gopkg.in/yaml.v2"
)

func CreateSkaffoldProfile(out io.Writer, configFile *ConfigFile) error {
func CreateSkaffoldProfile(out io.Writer, runCtx *runcontext.RunContext, configFile *ConfigFile) error {
reader := bufio.NewReader(os.Stdin)

// Check for existing oncluster profile, if none exists then prompt to create one
Expand Down Expand Up @@ -63,7 +64,7 @@ confirmLoop:
}

color.Default.Fprintln(out, "Creating skaffold profile \"oncluster\"...")
profile, err := generateProfile(out, configFile.Config)
profile, err := generateProfile(out, runCtx.Opts.Namespace, configFile.Config)
if err != nil {
return errors.Wrap(err, "generating profile \"oncluster\"")
}
Expand Down Expand Up @@ -106,7 +107,7 @@ confirmLoop:
return nil
}

func generateProfile(out io.Writer, config *latest.SkaffoldConfig) (*latest.Profile, error) {
func generateProfile(out io.Writer, namespace string, config *latest.SkaffoldConfig) (*latest.Profile, error) {
if len(config.Build.Artifacts) == 0 {
return nil, errors.New("No Artifacts to add to profile")
}
Expand Down Expand Up @@ -141,6 +142,12 @@ func generateProfile(out io.Writer, config *latest.SkaffoldConfig) (*latest.Prof
}
profile.Build.LocalBuild = nil
}
if namespace != "" {
if profile.Build.Cluster == nil {
profile.Build.Cluster = &latest.ClusterDetails{}
}
profile.Build.Cluster.Namespace = namespace
}

return profile, nil
}
49 changes: 48 additions & 1 deletion pkg/skaffold/generate_pipeline/profile_test.go
Original file line number Diff line number Diff line change
Expand Up @@ -30,6 +30,7 @@ func TestGenerateProfile(t *testing.T) {
skaffoldConfig *latest.SkaffoldConfig
expectedProfile *latest.Profile
responses []string
namespace string
shouldErr bool
}{
{
Expand All @@ -48,6 +49,7 @@ func TestGenerateProfile(t *testing.T) {
},
},
},
namespace: "",
expectedProfile: &latest.Profile{
Name: "oncluster",
Pipeline: latest.Pipeline{
Expand Down Expand Up @@ -94,6 +96,7 @@ func TestGenerateProfile(t *testing.T) {
},
},
},
namespace: "",
expectedProfile: &latest.Profile{
Name: "oncluster",
Pipeline: latest.Pipeline{
Expand All @@ -114,6 +117,50 @@ func TestGenerateProfile(t *testing.T) {
},
shouldErr: false,
},
{
description: "kaniko artifact with namespace",
skaffoldConfig: &latest.SkaffoldConfig{
Pipeline: latest.Pipeline{
Build: latest.BuildConfig{
Artifacts: []*latest.Artifact{
{
ImageName: "test",
ArtifactType: latest.ArtifactType{
DockerArtifact: &latest.DockerArtifact{},
},
},
},
},
},
},
namespace: "test-ns",
expectedProfile: &latest.Profile{
Name: "oncluster",
Pipeline: latest.Pipeline{
Build: latest.BuildConfig{
Artifacts: []*latest.Artifact{
{
ImageName: "test-pipeline",
ArtifactType: latest.ArtifactType{
KanikoArtifact: &latest.KanikoArtifact{
BuildContext: &latest.KanikoBuildContext{
GCSBucket: "skaffold-kaniko",
},
},
},
},
},
BuildType: latest.BuildType{
Cluster: &latest.ClusterDetails{
PullSecretName: "kaniko-secret",
Namespace: "test-ns",
},
},
},
},
},
shouldErr: false,
},
{
description: "failed profile generation",
skaffoldConfig: &latest.SkaffoldConfig{
Expand All @@ -130,7 +177,7 @@ func TestGenerateProfile(t *testing.T) {

for _, test := range tests {
testutil.Run(t, test.description, func(t *testutil.T) {
profile, err := generateProfile(ioutil.Discard, test.skaffoldConfig)
profile, err := generateProfile(ioutil.Discard, test.namespace, test.skaffoldConfig)
t.CheckErrorAndDeepEqual(test.shouldErr, err, test.expectedProfile, profile)
})
}
Expand Down
2 changes: 1 addition & 1 deletion pkg/skaffold/runner/generate_pipeline.go
Original file line number Diff line number Diff line change
Expand Up @@ -43,7 +43,7 @@ func (r *SkaffoldRunner) GeneratePipeline(ctx context.Context, out io.Writer, co
// Will run the profile setup multiple times and require user input for each specified config
color.Default.Fprintln(out, "Running profile setup...")
for _, configFile := range configFiles {
if err := pipeline.CreateSkaffoldProfile(out, configFile); err != nil {
if err := pipeline.CreateSkaffoldProfile(out, r.runCtx, configFile); err != nil {
return errors.Wrap(err, "setting up profile")
}
}
Expand Down

0 comments on commit 3ba27b3

Please sign in to comment.