Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

Unify jibMaven and jibGradle blocks into jib with auto detection #2808

Merged
merged 16 commits into from
Sep 11, 2019
Merged
Show file tree
Hide file tree
Changes from 6 commits
Commits
File filter

Filter by extension

Filter by extension

Conversations
Failed to load comments.
Loading
Jump to
Jump to file
Failed to load files.
Loading
Diff view
Diff view
3 changes: 1 addition & 2 deletions deprecation-policy.md
Original file line number Diff line number Diff line change
Expand Up @@ -54,8 +54,7 @@ However the **behavior** of individual component might suffer breaking changes d
- Artifact types:
- Dockerfile: beta
- Bazel: beta
- jibMaven: alpha
- jibGradle: alpha
- Jib: alpha
briandealwis marked this conversation as resolved.
Show resolved Hide resolved
- Filesync: alpha
- Port-forwarding: alpha
- Taggers: beta
Expand Down
20 changes: 8 additions & 12 deletions docs/content/en/docs/how-tos/builders/_index.md
Original file line number Diff line number Diff line change
Expand Up @@ -161,21 +161,17 @@ Skaffold requires using Jib v1.4.0 or later.

### Configuration

To use Jib, add a `jibMaven` or `jibGradle` field to each artifact you specify in the
To use Jib, add a `jib` field to each artifact you specify in the
`artifacts` part of the `build` section. `context` should be a path to
your Maven or Gradle project.

{{< alert title="Note" >}}
Your project must be configured to use Jib already.
{{< /alert >}}

The `jibMaven` type offers the following options:
The `jib` type offers the following options:

{{< schema root="JibMavenArtifact" >}}

The `jibGradle` type offers the following options:

{{< schema root="JibGradleArtifact" >}}
{{< schema root="JibArtifact" >}}

### Example

Expand All @@ -190,13 +186,13 @@ each produce a separate container image.

#### Maven

Copy link
Contributor

@balopat balopat Sep 10, 2019

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

I would love to see the maven/gradle detection logic documented here for our users.

To build a Maven multi-module project, first identify the modules that should
produce a container image. Then for each such module:
To build a Maven multi-module project, first identify the sub-projects (also called _modules_
in Maven) that should produce a container image. Then for each such sub-project:

- Create a Skaffold `artifact` in the `skaffold.yaml`:
- Set the `artifact`'s `context` field to the root project location.
- Add a `jibMaven` element and set its `module` field to the module's
`:artifactId`, `groupId:artifactId`, or the relative path to the module
- Add a `jib` element and set its `project` field to the sub-project's
`:artifactId`, `groupId:artifactId`, or the relative path to the sub-project
_within the project_.

{{% alert title="Updating from earlier versions" %}}
Expand All @@ -208,7 +204,7 @@ no longer required with Jib 1.4.0 and should be removed.
#### Gradle

To build a multi-module project with Gradle, specify each sub-project as a separate
briandealwis marked this conversation as resolved.
Show resolved Hide resolved
Skaffold artifact. For each artifact, add a `jibGradle` field with a `project` field
Skaffold artifact. For each artifact, add a `jib` field with a `project` field
containing the sub-project's name (the directory, by default). Each artifact's `context` field
should point to the root project location.

Expand Down
97 changes: 17 additions & 80 deletions docs/content/en/schemas/v1beta14.json
Original file line number Diff line number Diff line change
Expand Up @@ -163,10 +163,10 @@
"gcr.io/k8s-skaffold/example"
]
},
"jibMaven": {
"$ref": "#/definitions/JibMavenArtifact",
"description": "*alpha* builds images using the [Jib plugin for Maven](https://github.com/GoogleContainerTools/jib/tree/master/jib-maven-plugin).",
"x-intellij-html-description": "<em>alpha</em> builds images using the <a href=\"https://github.com/GoogleContainerTools/jib/tree/master/jib-maven-plugin\">Jib plugin for Maven</a>."
"jib": {
"$ref": "#/definitions/JibArtifact",
"description": "*alpha* builds images using the [Jib plugins for Maven or Gradle](https://github.com/GoogleContainerTools/jib/).",
"x-intellij-html-description": "<em>alpha</em> builds images using the <a href=\"https://github.com/GoogleContainerTools/jib/\">Jib plugins for Maven or Gradle</a>."
},
"sync": {
"$ref": "#/definitions/Sync",
Expand All @@ -178,42 +178,7 @@
"image",
"context",
"sync",
"jibMaven"
],
"additionalProperties": false
},
{
"properties": {
"context": {
"type": "string",
"description": "directory containing the artifact's sources.",
"x-intellij-html-description": "directory containing the artifact's sources.",
"default": "."
},
"image": {
"type": "string",
"description": "name of the image to be built.",
"x-intellij-html-description": "name of the image to be built.",
"examples": [
"gcr.io/k8s-skaffold/example"
]
},
"jibGradle": {
"$ref": "#/definitions/JibGradleArtifact",
"description": "*alpha* builds images using the [Jib plugin for Gradle](https://github.com/GoogleContainerTools/jib/tree/master/jib-gradle-plugin).",
"x-intellij-html-description": "<em>alpha</em> builds images using the <a href=\"https://github.com/GoogleContainerTools/jib/tree/master/jib-gradle-plugin\">Jib plugin for Gradle</a>."
},
"sync": {
"$ref": "#/definitions/Sync",
"description": "*alpha* local files synced to pods instead of triggering an image build when modified.",
"x-intellij-html-description": "<em>alpha</em> local files synced to pods instead of triggering an image build when modified."
}
},
"preferredOrder": [
"image",
"context",
"sync",
"jibGradle"
"jib"
],
"additionalProperties": false
},
Expand Down Expand Up @@ -1229,67 +1194,39 @@
"description": "patch to be applied by a profile.",
"x-intellij-html-description": "patch to be applied by a profile."
},
"JibGradleArtifact": {
"JibArtifact": {
"properties": {
"args": {
"items": {
"type": "string"
},
"type": "array",
"description": "additional build flags passed to Gradle.",
"x-intellij-html-description": "additional build flags passed to Gradle.",
"description": "additional build flags passed to the builder.",
"x-intellij-html-description": "additional build flags passed to the builder.",
"default": "[]",
"examples": [
"[\"--no-build-cache\"]"
]
},
"project": {
"type": "string",
"description": "selects which Gradle project to build.",
"x-intellij-html-description": "selects which Gradle project to build."
}
},
"preferredOrder": [
"project",
"args"
],
"additionalProperties": false,
"description": "*alpha* builds images using the [Jib plugin for Gradle](https://github.com/GoogleContainerTools/jib/tree/master/jib-gradle-plugin).",
"x-intellij-html-description": "<em>alpha</em> builds images using the <a href=\"https://github.com/GoogleContainerTools/jib/tree/master/jib-gradle-plugin\">Jib plugin for Gradle</a>."
},
"JibMavenArtifact": {
"properties": {
"args": {
"items": {
"type": "string"
},
"type": "array",
"description": "additional build flags passed to Maven.",
"x-intellij-html-description": "additional build flags passed to Maven.",
"default": "[]",
"examples": [
"[\"-x\", \"-DskipTests\"]"
]
},
"module": {
"profile": {
briandealwis marked this conversation as resolved.
Show resolved Hide resolved
"type": "string",
"description": "selects which Maven module to build, for a multi module project.",
"x-intellij-html-description": "selects which Maven module to build, for a multi module project."
"description": "selects which Maven profile to activate *(Maven-only)*.",
"x-intellij-html-description": "selects which Maven profile to activate <em>(Maven-only)</em>."
},
"profile": {
"project": {
"type": "string",
"description": "selects which Maven profile to activate.",
"x-intellij-html-description": "selects which Maven profile to activate."
"description": "selects which sub-project to build for multi-module builds.",
"x-intellij-html-description": "selects which sub-project to build for multi-module builds."
}
},
"preferredOrder": [
"module",
"project",
"profile",
"args"
],
"additionalProperties": false,
"description": "*alpha* builds images using the [Jib plugin for Maven](https://github.com/GoogleContainerTools/jib/tree/master/jib-maven-plugin).",
"x-intellij-html-description": "<em>alpha</em> builds images using the <a href=\"https://github.com/GoogleContainerTools/jib/tree/master/jib-maven-plugin\">Jib plugin for Maven</a>."
"description": "*alpha* builds images using the [Jib plugins for Maven and Gradle](https://github.com/GoogleContainerTools/jib/).",
"x-intellij-html-description": "<em>alpha</em> builds images using the <a href=\"https://github.com/GoogleContainerTools/jib/\">Jib plugins for Maven and Gradle</a>."
},
"KanikoArtifact": {
"properties": {
Expand Down
2 changes: 1 addition & 1 deletion integration/examples/jib-gradle/skaffold.yaml
Original file line number Diff line number Diff line change
Expand Up @@ -3,7 +3,7 @@ kind: Config
build:
artifacts:
- image: gcr.io/k8s-skaffold/skaffold-jib-gradle
jibGradle: {}
jib: {}

# optional profile to run the jib build on Google Cloud Build
profiles:
Expand Down
10 changes: 5 additions & 5 deletions integration/examples/jib-multimodule/README.adoc
Original file line number Diff line number Diff line change
Expand Up @@ -18,14 +18,14 @@ build:
- image: gcr.io/k8s-skaffold/skaffold-jib-1
# context is the root of the multi-module project
context: .
jibMaven:
# module is either the relative location within the project (i.e.,
jib:
# project is either the relative location within the project (i.e.,
# relative to `context`) or :artifactId or groupId:artifactId
briandealwis marked this conversation as resolved.
Show resolved Hide resolved
module: moduleLocation
project: moduleLocation
- image: gcr.io/k8s-skaffold/skaffold-jib-2
context: .
jibMaven:
module: :artifactId
jib:
project: :artifactId
----

There are a few caveats:
Expand Down
12 changes: 6 additions & 6 deletions integration/examples/jib-multimodule/skaffold.yaml
Original file line number Diff line number Diff line change
Expand Up @@ -3,13 +3,13 @@ kind: Config
build:
artifacts:
- image: gcr.io/k8s-skaffold/skaffold-jib-1
jibMaven:
# module can be the relative directory
module: project1
jib:
# project can be the relative directory
project: project1
- image: gcr.io/k8s-skaffold/skaffold-jib-2
jibMaven:
# module can be [groupId]:artifactId
module: :skaffold-project-2
jib:
# project can be [groupId]:artifactId
project: :skaffold-project-2

# optional profile to run the jib build on Google Cloud Build
profiles:
Expand Down
2 changes: 1 addition & 1 deletion integration/examples/jib/README.adoc
Original file line number Diff line number Diff line change
Expand Up @@ -13,7 +13,7 @@ build:
artifacts:
- image: gcr.io/k8s-skaffold/skaffold-example
context: .
jibMaven: {}
jib: {}
----

Please note that this example is for a standalone Maven project, where
Expand Down
2 changes: 1 addition & 1 deletion integration/examples/jib/skaffold.yaml
Original file line number Diff line number Diff line change
Expand Up @@ -3,7 +3,7 @@ kind: Config
build:
artifacts:
- image: gcr.io/k8s-skaffold/skaffold-jib
jibMaven: {}
jib: {}

# optional profile to run the jib build on Google Cloud Build
profiles:
Expand Down
2 changes: 1 addition & 1 deletion integration/testdata/debug/skaffold.yaml
Original file line number Diff line number Diff line change
Expand Up @@ -4,7 +4,7 @@ build:
artifacts:
- image: gcr.io/k8s-skaffold/skaffold-debug-jib
context: jib
jibMaven:
jib:
args:
- --no-transfer-progress
- image: gcr.io/k8s-skaffold/skaffold-debug-npm
Expand Down
2 changes: 1 addition & 1 deletion integration/testdata/jib-gradle/skaffold.yaml
Original file line number Diff line number Diff line change
Expand Up @@ -3,7 +3,7 @@ kind: Config
build:
artifacts:
- image: gcr.io/k8s-skaffold/skaffold-jib
jibGradle: {}
jib: {}

profiles:
- name: gcb
Expand Down
2 changes: 1 addition & 1 deletion integration/testdata/jib/skaffold.yaml
Original file line number Diff line number Diff line change
Expand Up @@ -3,7 +3,7 @@ kind: Config
build:
artifacts:
- image: gcr.io/k8s-skaffold/skaffold-jib
jibMaven:
jib:
args:
- --no-transfer-progress

Expand Down
39 changes: 24 additions & 15 deletions pkg/skaffold/build/gcb/jib.go
Original file line number Diff line number Diff line change
Expand Up @@ -21,26 +21,35 @@ import (

"github.com/GoogleContainerTools/skaffold/pkg/skaffold/jib"
"github.com/GoogleContainerTools/skaffold/pkg/skaffold/schema/latest"
"github.com/pkg/errors"
cloudbuild "google.golang.org/api/cloudbuild/v1"
)

func (b *Builder) jibMavenBuildSpec(artifact *latest.JibMavenArtifact, tag string) cloudbuild.Build {
return cloudbuild.Build{
Steps: []*cloudbuild.BuildStep{{
Name: b.MavenImage,
Entrypoint: "sh",
Args: fixHome("mvn", jib.GenerateMavenArgs("build", tag, artifact, b.skipTests, b.insecureRegistries)),
}},
func (b *Builder) jibBuildSpec(artifact *latest.Artifact, tag string) (cloudbuild.Build, error) {
t, err := jib.DeterminePluginType(artifact.Workspace, artifact.JibArtifact)
if err != nil {
return cloudbuild.Build{}, err
briandealwis marked this conversation as resolved.
Show resolved Hide resolved
}
}

func (b *Builder) jibGradleBuildSpec(artifact *latest.JibGradleArtifact, tag string) cloudbuild.Build {
return cloudbuild.Build{
Steps: []*cloudbuild.BuildStep{{
Name: b.GradleImage,
Entrypoint: "sh",
Args: fixHome("gradle", jib.GenerateGradleArgs("jib", tag, artifact, b.skipTests, b.insecureRegistries)),
}},
switch t {
case jib.JibMaven:
return cloudbuild.Build{
Steps: []*cloudbuild.BuildStep{{
Name: b.MavenImage,
Entrypoint: "sh",
Args: fixHome("mvn", jib.GenerateMavenArgs("build", tag, artifact.JibArtifact, b.skipTests, b.insecureRegistries)),
}},
}, nil
case jib.JibGradle:
return cloudbuild.Build{
Steps: []*cloudbuild.BuildStep{{
Name: b.GradleImage,
Entrypoint: "sh",
Args: fixHome("gradle", jib.GenerateGradleArgs("jib", tag, artifact.JibArtifact, b.skipTests, b.insecureRegistries)),
}},
}, nil
default:
return cloudbuild.Build{}, errors.New("skaffold can't determine Jib artifact type for Google Cloud Build")
}
}

Expand Down
4 changes: 2 additions & 2 deletions pkg/skaffold/build/gcb/jib_test.go
Original file line number Diff line number Diff line change
Expand Up @@ -46,7 +46,7 @@ func TestJibMavenBuildSpec(t *testing.T) {
testutil.Run(t, test.description, func(t *testutil.T) {
artifact := &latest.Artifact{
ArtifactType: latest.ArtifactType{
JibMavenArtifact: &latest.JibMavenArtifact{},
JibArtifact: &latest.JibArtifact{Type: int(jib.JibMaven)},
},
}

Expand Down Expand Up @@ -91,7 +91,7 @@ func TestJibGradleBuildSpec(t *testing.T) {
testutil.Run(t, test.description, func(t *testutil.T) {
artifact := &latest.Artifact{
ArtifactType: latest.ArtifactType{
JibGradleArtifact: &latest.JibGradleArtifact{},
JibArtifact: &latest.JibArtifact{Type: int(jib.JibGradle)},
},
}

Expand Down
7 changes: 2 additions & 5 deletions pkg/skaffold/build/gcb/spec.go
Original file line number Diff line number Diff line change
Expand Up @@ -53,11 +53,8 @@ func (b *Builder) buildSpecForArtifact(artifact *latest.Artifact, tag string) (c
case artifact.DockerArtifact != nil:
return b.dockerBuildSpec(artifact.DockerArtifact, tag)

case artifact.JibMavenArtifact != nil:
return b.jibMavenBuildSpec(artifact.JibMavenArtifact, tag), nil

case artifact.JibGradleArtifact != nil:
return b.jibGradleBuildSpec(artifact.JibGradleArtifact, tag), nil
case artifact.JibArtifact != nil:
return b.jibBuildSpec(artifact, tag)

case artifact.BazelArtifact != nil:
return cloudbuild.Build{}, errors.New("skaffold can't build a bazel artifact with Google Cloud Build")
Expand Down
10 changes: 2 additions & 8 deletions pkg/skaffold/build/gcb/types.go
Original file line number Diff line number Diff line change
Expand Up @@ -112,14 +112,8 @@ func (b *Builder) DependenciesForArtifact(ctx context.Context, a *latest.Artifac
return nil, errors.Wrapf(err, "getting dependencies for %s", a.ImageName)
}
}
if a.JibMavenArtifact != nil {
paths, err = jib.GetDependenciesMaven(ctx, a.Workspace, a.JibMavenArtifact)
if err != nil {
return nil, errors.Wrapf(err, "getting dependencies for %s", a.ImageName)
}
}
if a.JibGradleArtifact != nil {
paths, err = jib.GetDependenciesGradle(ctx, a.Workspace, a.JibGradleArtifact)
if a.JibArtifact != nil {
paths, err = jib.GetDependencies(ctx, a.Workspace, a.JibArtifact)
if err != nil {
return nil, errors.Wrapf(err, "getting dependencies for %s", a.ImageName)
}
Expand Down
Loading