Skip to content

Commit

Permalink
Group build, test and asses in one workflow
Browse files Browse the repository at this point in the history
  • Loading branch information
MichaelKora committed Sep 22, 2023
1 parent 180e9d3 commit 777df37
Show file tree
Hide file tree
Showing 5 changed files with 204 additions and 112 deletions.
87 changes: 80 additions & 7 deletions .github/workflows/README.md
Original file line number Diff line number Diff line change
Expand Up @@ -11,6 +11,7 @@ The following workflows can be found here:
- [Python Poetry Release](#python-poetry-release)
- [Python Poetry Publish PyPI](#python-poetry-publish-pypi)
- [Python Poetry Publish Snapshot](#python-poetry-publish-snapshot)
- [Java Gradle Base](#java-gradle-base)
- [Java Gradle Docker](#java-gradle-docker)
- [Java Gradle Library](#java-gradle-library)
- [Java Gradle Plugin](#java-gradle-plugin)
Expand Down Expand Up @@ -679,6 +680,8 @@ These secrets define the TestPyPI token that allow the GitHub action to release
| ---------- | :------: | ---------------------------------------------- |
| pypi-token | ✅ | The TestPyPI API token for publishing packages |

<!-- -->ƒ

### Calling the workflow

```yaml
Expand All @@ -698,7 +701,7 @@ jobs:
pypi-token: ${{ secrets.TEST_PYPI_TOKEN }}
```

## Java Gradle Docker
## Java Gradle Base

This workflow will build, test and publish a Java Gradle project including a tarball image. Additionally,
the workflow creates a GitHub Release when running on a tag branch.
Expand All @@ -714,6 +717,78 @@ This workflow is built from multiple composite actions listed below:

- [java-gradle-build](https://github.com/bakdata/ci-templates/tree/main/actions/java-gradle-build)
- [java-gradle-test](https://github.com/bakdata/ci-templates/tree/main/actions/java-gradle-test)
- [java-gradle-assess-code-quality](https://github.com/bakdata/ci-templates/tree/main/actions/java-gradle-assess-code-quality)

### Input Parameters

| Name | Required | Default Value | Type | Description |
| ------------------ | :------: | :-----------: | :-----: | ------------------------------------------------------------------------------------------------------------- |
| java-distribution | ❌ | microsoft | string | [Java distribution](https://github.com/actions/setup-java#supported-distributions) to be installed |
| java-version | ❌ | 11 | string | Java version to be installed |
| gradle-version | ❌ | wrapper | string | [Gradle version](https://github.com/gradle/gradle-build-action#use-a-specific-gradle-version) to be installed |
| gradle-cache | ❌ | true | boolean | Whether Gradle caching is enabled or not |
| working-directory | ❌ | . | string | Working directory of your Gradle artifacts |
| download-lfs-files | ❌ | "false" | string | Whether the Git checkout action should resolve LFS files or not |

### Secret Parameters

For Sonarcloud you need to provide a `sonar-token` and a `sonar-organization` to publish code quality results. In case of Sonatype, the action
requires you to have a `signing-secret-key-ring` (base64 encoded), a `signing-key-id` and a `signing-password` to sign
your build artifacts and additionally an `ossrh-username` and an `ossrh-password` to publish the signed artifacts to
Nexus.

| Name | Required | Description |
| ----------------------- | :------: | -------------------------------------------------------------- |
| sonar-token | ✅ | Token for Sonarcloud |
| sonar-organization | ✅ | Organization for Sonarcloud |
| signing-secret-key-ring | ✅ | Key ring (base64 encoded) for signing the Sonatype publication |
| signing-key-id | ✅ | Key id for signing the Sonatype publication |
| signing-password | ✅ | Password for signing the Sonatype publication |
| ossrh-username | ✅ | Username for signing into Sonatype repository |
| ossrh-password | ✅ | Password for signing into Sonatype repository |

### Calling the workflow

```yaml
name: Call this reusable workflow
on:
push:
branches: [main]
jobs:
call-workflow-passing-data:
name: Java Gradle Docker
uses: bakdata/ci-templates/.github/workflows/java-gradle-base.yaml@main
with:
java-distribution: "microsoft" # (Optional) Default is microsoft
java-version: "11" # (Optional) Default is 11
gradle-version: "wrapper" # (Optional) Default is wrapper
gradle-cache: false # (Optional) Default is true
working-directory: "." # (Optional) Default is .
secrets:
sonar-token: ${{ secrets.SONARCLOUD_TOKEN }}
sonar-organization: ${{ secrets.SONARCLOUD_ORGANIZATION }}
signing-secret-key-ring: ${{ secrets.SIGNING_SECRET_KEY_RING }}
signing-key-id: ${{ secrets.SIGNING_KEY_ID }}
signing-password: ${{ secrets.SIGNING_PASSWORD }}
```

## Java Gradle Docker

This workflow will build, test and publish a Java Gradle project including a tarball image. Additionally,
the workflow creates a GitHub Release when running on a tag branch.

### Prerequisites

Your Java project needs to be set up with Gradle and either needs to contain a `build.gradle` or a `build.gradle.kts`
file that uses the [Sonar](https://github.com/bakdata/gradle-plugins/tree/master/sonar), [Sonatype](https://github.com/bakdata/gradle-plugins/tree/master/sonatype) and [Jib](https://github.com/GoogleContainerTools/jib/tree/master/jib-gradle-plugin) plugins. Moreover, prepare credentials for Sonarcloud, Sonatype, GitHub and Docker.

### Dependencies

This workflow is built from multiple composite actions and workflows listed below:

- [java-gradle-base](https://github.com/bakdata/ci-templates/tree/main/.github/workflows/java-gradle-base.yaml)
- [java-gradle-build-jib](https://github.com/bakdata/ci-templates/tree/main/actions/java-gradle-build-jib)
- [java-gradle-publish](https://github.com/bakdata/ci-templates/tree/main/actions/java-gradle-publish)
- [docker-publish](https://github.com/bakdata/ci-templates/tree/main/actions/docker-publish)
Expand Down Expand Up @@ -799,10 +874,9 @@ file that uses the [Sonar](https://github.com/bakdata/gradle-plugins/tree/master

### Dependencies

This workflow is built from multiple composite actions listed below:
This workflow is built from multiple composite actions and workflows listed below:

- [java-gradle-build](https://github.com/bakdata/ci-templates/tree/main/actions/java-gradle-build)
- [java-gradle-test](https://github.com/bakdata/ci-templates/tree/main/actions/java-gradle-test)
- [java-gradle-base](https://github.com/bakdata/ci-templates/tree/main/.github/workflows/java-gradle-base.yaml)
- [java-gradle-publish](https://github.com/bakdata/ci-templates/tree/main/actions/java-gradle-publish)
- [java-gradle-release-github](https://github.com/bakdata/ci-templates/tree/main/actions/java-gradle-release-github)

Expand Down Expand Up @@ -880,10 +954,9 @@ and Gradle Plugin Portal.

### Dependencies

This workflow is built from multiple composite actions listed below:
This workflow is built from multiple composite actions and workflows listed below:

- [java-gradle-build](https://github.com/bakdata/ci-templates/tree/main/actions/java-gradle-build)
- [java-gradle-test](https://github.com/bakdata/ci-templates/tree/main/actions/java-gradle-test)
- [java-gradle-base](https://github.com/bakdata/ci-templates/tree/main/.github/workflows/java-gradle-base.yaml)
- [java-gradle-publish](https://github.com/bakdata/ci-templates/tree/main/actions/java-gradle-publish)
- [java-gradle-publish-plugin](https://github.com/bakdata/ci-templates/tree/main/actions/java-gradle-publish-plugin)
- [java-gradle-release-github](https://github.com/bakdata/ci-templates/tree/main/actions/java-gradle-release-github)
Expand Down
103 changes: 103 additions & 0 deletions .github/workflows/java-gradle-base.yaml
Original file line number Diff line number Diff line change
@@ -0,0 +1,103 @@
name: Java Gradle Base
# Reusable workflow for building testing and assessing code quality

on:
workflow_call:
inputs:
java-distribution:
description: "Java distribution to be installed. (Default is microsoft)"
required: false
type: string
default: "microsoft"
java-version:
description: "Java version to be installed. (Default is 11)"
required: false
type: string
default: "11"
gradle-version:
description: "Gradle version to be installed. (Default is wrapper)"
required: false
type: string
default: "wrapper"
gradle-cache:
description: "Whether Gradle caching is enabled or not. (Default is true)"
required: false
type: boolean
default: true
working-directory:
description: "Working directory of your Gradle artifacts. (Default is .)"
required: false
type: string
default: "."
download-lfs-files:
description: "Whether the Git checkout action should resolve LFS files or not. (Default is false)"
required: false
type: string
default: false
secrets:
sonar-token:
description: "Token for Sonarcloud."
required: true
sonar-organization:
description: "Organization for Sonarcloud"
required: true
signing-secret-key-ring:
description: "Key ring (base64 encoded) for signing the Sonatype publication."
required: true
signing-key-id:
description: "Key id for signing the Sonatype publication."
required: true
signing-password:
description: "Password for signing the Sonatype publication."
required: true

jobs:
build:
name: Build
runs-on: ubuntu-22.04

steps:
- name: Build
uses: bakdata/ci-templates/actions/[email protected]
with:
java-distribution: ${{ inputs.java-distribution }}
java-version: ${{ inputs.java-version }}
gradle-version: ${{ inputs.gradle-version }}
gradle-cache: ${{ inputs.gradle-cache }}
working-directory: ${{ inputs.working-directory }}

test:
name: Test
runs-on: ubuntu-22.04
needs: build
steps:
- name: Run unit tests
uses: bakdata/ci-templates/actions/java-gradle-test@feat/split-test
# uses: bakdata/ci-templates/actions/[email protected]
with:
gradle-cache: ${{ inputs.gradle-cache }}
gradle-version: ${{ inputs.gradle-version }}
java-distribution: ${{ inputs.java-distribution }}
java-version: ${{ inputs.java-version }}
working-directory: ${{ inputs.working-directory }}

assess-code:
name: Asses code quality
runs-on: ubuntu-22.04
needs: test
steps:
- name: Assess code quality
uses: bakdata/ci-templates/actions/java-gradle-assess-code-quality@feat/split-test
# uses: bakdata/ci-templates/actions/[email protected]
with:
gradle-cache: ${{ inputs.gradle-cache }}
gradle-version: ${{ inputs.gradle-version }}
java-distribution: ${{ inputs.java-distribution }}
java-version: ${{ inputs.java-version }}
signing-key-id: ${{ secrets.signing-key-id }}
signing-password: ${{ secrets.signing-password }}
signing-secret-key-ring: ${{ secrets.signing-secret-key-ring }}
sonar-organization: ${{ secrets.sonar-organization }}
sonar-token: ${{ secrets.sonar-token }}
working-directory: ${{ inputs.working-directory }}
download-lfs-files: ${{ inputs.download-lfs-files }}
42 changes: 7 additions & 35 deletions .github/workflows/java-gradle-docker.yaml
Original file line number Diff line number Diff line change
Expand Up @@ -69,59 +69,31 @@ on:
required: true

jobs:
build:
name: Build
java-gradle-base:
name: Build, Test and Assess code quality
runs-on: ubuntu-22.04

steps:
- name: Build
uses: bakdata/ci-templates/actions/[email protected]
- name: Build, Test & Assess
uses: bakdata/ci-templates/actions/java-gradle-base@feat/split-test
# uses: bakdata/ci-templates/actions/[email protected]

with:
java-distribution: ${{ inputs.java-distribution }}
java-version: ${{ inputs.java-version }}
gradle-version: ${{ inputs.gradle-version }}
gradle-cache: ${{ inputs.gradle-cache }}
working-directory: ${{ inputs.working-directory }}

test:
name: Test
runs-on: ubuntu-22.04
needs: build
steps:
- name: Run unit tests
uses: bakdata/ci-templates/actions/java-gradle-test@feat/split-test
# uses: bakdata/ci-templates/actions/[email protected]
with:
gradle-cache: ${{ inputs.gradle-cache }}
gradle-version: ${{ inputs.gradle-version }}
java-distribution: ${{ inputs.java-distribution }}
java-version: ${{ inputs.java-version }}
working-directory: ${{ inputs.working-directory }}

assess-code:
name: Asses code quality
runs-on: ubuntu-22.04
needs: test
steps:
- name: Assess code quality
uses: bakdata/ci-templates/actions/java-gradle-assess-code-quality@feat/split-test
# uses: bakdata/ci-templates/actions/[email protected]
with:
gradle-cache: ${{ inputs.gradle-cache }}
gradle-version: ${{ inputs.gradle-version }}
java-distribution: ${{ inputs.java-distribution }}
java-version: ${{ inputs.java-version }}
signing-key-id: ${{ secrets.signing-key-id }}
signing-password: ${{ secrets.signing-password }}
signing-secret-key-ring: ${{ secrets.signing-secret-key-ring }}
sonar-organization: ${{ secrets.sonar-organization }}
sonar-token: ${{ secrets.sonar-token }}
working-directory: ${{ inputs.working-directory }}

build-jib:
name: Build tarball image
runs-on: ubuntu-22.04
needs: assess-code
needs: java-gradle-base

steps:
- name: Build tarball image
Expand Down
42 changes: 7 additions & 35 deletions .github/workflows/java-gradle-library.yaml
Original file line number Diff line number Diff line change
Expand Up @@ -59,59 +59,31 @@ on:
required: true

jobs:
build:
name: Build
java-gradle-base:
name: Build, Test and Assess code quality
runs-on: ubuntu-22.04

steps:
- name: Build
uses: bakdata/ci-templates/actions/[email protected]
- name: Build, Test & Assess
uses: bakdata/ci-templates/actions/java-gradle-base@feat/split-test
# uses: bakdata/ci-templates/actions/[email protected]

with:
java-distribution: ${{ inputs.java-distribution }}
java-version: ${{ inputs.java-version }}
gradle-version: ${{ inputs.gradle-version }}
gradle-cache: ${{ inputs.gradle-cache }}
working-directory: ${{ inputs.working-directory }}

test:
name: Test
runs-on: ubuntu-22.04
needs: build
steps:
- name: Run unit tests
uses: bakdata/ci-templates/actions/java-gradle-test@feat/split-test
# uses: bakdata/ci-templates/actions/[email protected]
with:
gradle-cache: ${{ inputs.gradle-cache }}
gradle-version: ${{ inputs.gradle-version }}
java-distribution: ${{ inputs.java-distribution }}
java-version: ${{ inputs.java-version }}
working-directory: ${{ inputs.working-directory }}

assess-code:
name: Asses code quality
runs-on: ubuntu-22.04
needs: test
steps:
- name: Assess code quality
uses: bakdata/ci-templates/actions/java-gradle-assess-code-quality@feat/split-test
# uses: bakdata/ci-templates/actions/[email protected]
with:
gradle-cache: ${{ inputs.gradle-cache }}
gradle-version: ${{ inputs.gradle-version }}
java-distribution: ${{ inputs.java-distribution }}
java-version: ${{ inputs.java-version }}
signing-key-id: ${{ secrets.signing-key-id }}
signing-password: ${{ secrets.signing-password }}
signing-secret-key-ring: ${{ secrets.signing-secret-key-ring }}
sonar-organization: ${{ secrets.sonar-organization }}
sonar-token: ${{ secrets.sonar-token }}
working-directory: ${{ inputs.working-directory }}

publish:
name: Publish
runs-on: ubuntu-22.04
needs: assess-code
needs: java-gradle-base

steps:
- name: Publish
Expand Down
Loading

0 comments on commit 777df37

Please sign in to comment.