9 Commits

5 changed files with 81 additions and 21 deletions

View File

@ -1,4 +1,4 @@
name: Auto approve
name: Auto Approve
on:
pull_request_target
@ -8,18 +8,27 @@ jobs:
runs-on: ubuntu-latest
steps:
- uses: alexwilson/enable-github-automerge-action@1.0.0
if: >
github.actor == 'dependabot[bot]'
|| github.actor == 'dependabot-preview[bot]'
- name: Dependabot metadata
if: github.actor == 'dependabot[bot]'
id: dependabot-metadata
uses: dependabot/fetch-metadata@v1.1.1
with:
merge-method: "REBASE"
github-token: "${{ secrets.TECH_TOKEN }}"
- uses: hmarr/auto-approve-action@v2.1.0
- name: Enable auto-merge for Dependabot PRs
if: >
github.actor == 'dependabot[bot]'
&& steps.dependabot-metadata.outputs.update-type != 'version-update:semver-major'
run: gh pr merge --auto --rebase "$PR_URL"
env:
PR_URL: ${{github.event.pull_request.html_url}}
GITHUB_TOKEN: ${{ secrets.TECH_TOKEN }}
- name: Approve a PR
if: >
github.actor == 'dependabot[bot]'
|| github.actor == 'dependabot-preview[bot]'
|| github.actor == 'slawekjaranowski'
with:
github-token: "${{ secrets.TECH_TOKEN }}"
run: gh pr review --approve "$PR_URL"
env:
PR_URL: ${{github.event.pull_request.html_url}}
GITHUB_TOKEN: ${{ secrets.TECH_TOKEN }}

View File

@ -4,6 +4,7 @@ on:
push:
branches:
- 'master'
- 'main'
jobs:
update_release_draft:

View File

@ -2,13 +2,19 @@ name: Test
on:
pull_request:
branches:
- 'main'
push:
branches-ignore:
- 'dependabot/**'
branches:
- 'main'
schedule:
- cron: '22 23 * * 5'
concurrency:
group: test-action
cancel-in-progress: true
jobs:
test:
name: Test
@ -28,8 +34,8 @@ jobs:
- uses: ./
with:
java-version: ${{ matrix.java }}
java-cache: maven
maven-version: ${{ matrix.maven }}
cache-prefix: 'test-prefix-'
- run: mvn -V validate -Drequire.java=${{ matrix.java }} -Drequire.maven=${{ matrix.maven }}
shell: bash

View File

@ -4,6 +4,7 @@
This is composite action which help to prepare GitHub Actions environment for Maven build by calling:
- [actions/setup-java](https://github.com/marketplace/actions/setup-java-jdk)
- [actions/cache](https://github.com/marketplace/actions/cache)
- [stCarolas/setup-maven](https://github.com/marketplace/actions/setup-maven)
- [s4u/maven-settings-action](https://github.com/marketplace/actions/maven-settings-action)
@ -27,7 +28,29 @@ or use automatic tools like [Dependabot](https://docs.github.com/en/code-securit
| ----------------- |------------- |-------- |
| java-version | java-version | |
| java-distribution | distribution | temurin |
| java-cache | cache | |
## cache
A cache action is configured as:
```yaml
- uses: actions/cache
with:
path: |
${{ inputs.cache-path }}
${{ inputs.cache-path-add }}
key: ${{ inputs.cache-prefix }}${{ runner.os }}-jdk${{ inputs.java-version }}-${{ inputs.java-distribution }}-maven${{ inputs.maven-version }}-${{ hashFiles('**/pom.xml') }}
restore-keys: ${{ inputs.cache-prefix }}${{ runner.os }}-jdk${{ inputs.java-version }}-${{ inputs.java-distribution }}-maven${{ inputs.maven-version }}-
```
So we can use for action:
| params | description |
| ----------------- |--------------------------------------------------------- |
| cache-path | default cache path for Maven with value ~/.m2/repository |
| cache-path-add | additional value for cache path |
| cache-prefix | prefix value for `key` and `restore-keys` cache params |
## setup-maven
@ -61,8 +84,8 @@ jobs:
steps:
- uses: actions/checkout@v2
- name: Setup Maven
uses: setup-maven@v1.0.0
- name: Setup Maven with settings.xml
uses: s4u/setup-maven-action@v1.0.0
with:
java-version: 8
maven-version: ${{ matrix.maven }}

View File

@ -18,14 +18,24 @@ inputs:
default: 'temurin'
required: false
java-cache:
description: 'Name of the build platform to cache dependencies. It should be "maven" or empty.'
required: true
# cache
cache-prefix:
description: 'Cache key prefix'
required: false
cache-path:
description: 'Cache path'
default: '~/.m2/repository'
required: false
cache-path-add:
description: 'Additional item for cache path'
required: false
# maven version
maven-version:
description: 'The Maven version to set up'
default: 3.8.1
default: '3.8.1'
required: false
# maven settings.xml
@ -57,7 +67,18 @@ runs:
overwrite-settings: false
java-version: '${{ inputs.java-version }}'
distribution: '${{ inputs.java-distribution }}'
cache: '${{ inputs.java-cache }}'
- run: echo "::endgroup::"
shell: bash
- run: echo "::group::Setup Cache"
shell: bash
- uses: actions/cache@v2.1.6
with:
path: |
${{ inputs.cache-path }}
${{ inputs.cache-path-add }}
key: ${{ inputs.cache-prefix }}${{ runner.os }}-jdk${{ inputs.java-version }}-${{ inputs.java-distribution }}-maven${{ inputs.maven-version }}-${{ hashFiles('**/pom.xml') }}
restore-keys: ${{ inputs.cache-prefix }}${{ runner.os }}-jdk${{ inputs.java-version }}-${{ inputs.java-distribution }}-maven${{ inputs.maven-version }}-
- run: echo "::endgroup::"
shell: bash