-
Notifications
You must be signed in to change notification settings - Fork 0
101 lines (80 loc) · 3.85 KB
/
gradle-custom-plugin-release.yml
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
# This workflow uses actions that are not certified by GitHub.
# They are provided by a third-party and are governed by
# separate terms of service, privacy policy, and support
# documentation.
# This workflow will build a package using Gradle and then publish it to GitHub packages when a release is created
# For more information see: https://github.com/actions/setup-java/blob/main/docs/advanced-usage.md#Publishing-using-gradle
name: gradle custom plugin release
on:
push:
branches:
- gtihub-action-gradle-custom-plugin-release
jobs:
build:
runs-on: ubuntu-latest
permissions: write-all
steps:
- uses: actions/checkout@v4
with:
ref: gradle-custom-plugin-release
- name: Set up JDK 11
uses: actions/setup-java@v3
with:
java-version: '11'
distribution: 'temurin'
server-id: github # Value of the distributionManagement/repository/id field of the pom.xml
settings-path: ${{ github.workspace }} # location for the settings.xml file
- name: Grant execute permission to Gradle wrapper
run: chmod +x ./gradlew
- name: Build with Gradle
uses: gradle/gradle-build-action@67421db6bd0bf253fb4bd25b31ebb98943c375e1
with:
arguments: build
- name: read version.json
id: read_version
shell: bash
run: |
echo "${{ github.workspace }}"
cd ${{ github.workspace }}
echo "ls $(ls ${{ github.workspace }})"
# I have determined that there is no need to include metadata in the tagging information
temp_major=`node -p "const p = require('${{ github.workspace }}/app/version.json'); p.major;"`
temp_minor=`node -p "const p = require('${{ github.workspace }}/app/version.json'); p.minor;"`
temp_patch=`node -p "const p = require('${{ github.workspace }}/app/version.json'); p.patch;"`
temp_prereleaseVersion=`node -p "const p = require('${{ github.workspace }}/app/version.json'); p.prereleaseVersion;"`
# The task involves adding both '.' and '-' to the string so that dots (.) and dashes (-) can be included when combining all version information.
if [ "$temp_minor" != "" ]; then
temp_minor=".${temp_minor}"
fi
if [ "$temp_patch" != "" ]; then
temp_patch=".${temp_patch}"
fi
if [ "$temp_prereleaseVersion" != "" ]; then
temp_prereleaseVersion="-${temp_prereleaseVersion}"
fi
echo "temp_major : $temp_major"
echo "temp_minor : $temp_minor"
echo "temp_patch : $temp_patch"
echo "temp_prereleaseVersion : $temp_prereleaseVersion"
version="$temp_major$temp_minor$temp_patch$temp_prereleaseVersion"
echo "VERSION=$version" >> $GITHUB_OUTPUT
ls "${{ github.workspace }}/app/dist"
- name: create release
id: create_release
uses: actions/create-release@v1
env:
GITHUB_TOKEN: ${{ secrets.GITHUB_TOKEN }}
with:
tag_name: ${{ steps.read_version.outputs.VERSION }}
release_name: ${{ steps.read_version.outputs.VERSION }}
prerelease: true
- name: Upload Release Asset
id: upload-release-asset
uses: actions/upload-release-asset@v1
env:
GITHUB_TOKEN: ${{ secrets.GITHUB_TOKEN }}
with:
upload_url: ${{ steps.create_release.outputs.upload_url }} # This pulls from the CREATE RELEASE step above, referencing it's ID to get its outputs object, which include a `upload_url`. See this blog post for more info: https://jasonet.co/posts/new-features-of-github-actions/#passing-data-to-future-steps
asset_path: "${{ github.workspace }}/app/dist/gradle-semantic-versioning-manager-plugin-${{ steps.read_version.outputs.VERSION }}.jar"
asset_name: gradle-semantic-versioning-manager-plugin-${{ steps.read_version.outputs.VERSION }}.jar
asset_content_type: application/jar