Improve build/publish

This commit is contained in:
tibs 2022-08-18 22:34:23 -04:00
parent a230808ca7
commit 25527412e5
Signed by untrusted user who does not match committer: tibs
GPG key ID: 047833989F50F88F
4 changed files with 112 additions and 28 deletions

View file

@ -5,20 +5,34 @@ on: [ push, pull_request ]
jobs:
build:
runs-on: ubuntu-latest
steps:
- uses: actions/checkout@v2
- name: Checkout latest commit
uses: actions/checkout@v3
- name: Set up JDK 17
uses: actions/setup-java@v2
uses: actions/setup-java@v3
with:
distribution: 'temurin'
distribution: temurin
java-version: 17
- name: Restore Gradle cache
uses: actions/cache@v3
with:
path: |
~/.gradle/caches
~/.gradle/wrapper
key: ${{ runner.os }}-gradle-${{ hashFiles('**/*.gradle*', '**/gradle-wrapper.properties') }}
restore-keys: ${{ runner.os }}-gradle
- name: Validate Gradle wrapper
uses: gradle/wrapper-validation-action@v1
- name: Build with Gradle
run: ./gradlew build
- name: Upload build artifacts
uses: actions/upload-artifact@v2
uses: actions/upload-artifact@v3
with:
name: build-artifacts
path: ./build/libs

View file

@ -8,20 +8,40 @@ on:
jobs:
build:
runs-on: ubuntu-latest
steps:
- uses: actions/checkout@v2
- name: Checkout latest commit
uses: actions/checkout@v3
- name: Set up JDK 17
uses: actions/setup-java@v2
uses: actions/setup-java@v3
with:
distribution: 'temurin'
distribution: temurin
java-version: 17
- name: Build with Gradle
run: ./gradlew build
- name: Restore Gradle cache
uses: actions/cache@v3
with:
path: |
~/.gradle/caches
~/.gradle/wrapper
key: ${{ runner.os }}-gradle-${{ hashFiles('**/*.gradle*', '**/gradle-wrapper.properties') }}
restore-keys: ${{ runner.os }}-gradle
- name: Validate Gradle wrapper
uses: gradle/wrapper-validation-action@v1
- name: Build and publish with Gradle
run: ./gradlew build publish modrinth curseforge
env:
MAVEN_URL: ${{ secrets.MAVEN_URL }}
MAVEN_USERNAME: ${{ secrets.MAVEN_USERNAME }}
MAVEN_PASSWORD: ${{ secrets.MAVEN_PASSWORD }}
CURSEFORGE_TOKEN: ${{ secrets.CURSEFORGE_TOKEN }}
MODRINTH_TOKEN: ${{ secrets.MODRINTH_TOKEN }}
- name: Upload build artifacts
uses: AButler/upload-release-assets@v2.0
with:
files: 'build/libs/!(*-@(dev|sources)).jar'
files: 'build/libs/!(*-sources).jar'
repo-token: ${{ secrets.GITHUB_TOKEN }}

View file

@ -3,6 +3,9 @@ plugins {
alias(libs.plugins.loom.quiltflower)
alias(libs.plugins.qmol)
alias(libs.plugins.grgit)
alias(libs.plugins.minotaur)
alias(libs.plugins.cursegradle)
id "maven-publish"
}
archivesBaseName = project.archives_base_name
@ -11,10 +14,10 @@ group = project.maven_group
repositories {
maven {
name = 'Modrinth'
url = 'https://api.modrinth.com/maven'
name = "Modrinth"
url = "https://api.modrinth.com/maven"
content {
includeGroup 'maven.modrinth'
includeGroup "maven.modrinth"
}
}
}
@ -35,16 +38,16 @@ loom {
}
processResources {
inputs.property 'version', project.version
filteringCharset 'UTF-8'
inputs.property "version", project.version
filteringCharset "UTF-8"
filesMatching('fabric.mod.json') {
expand 'version': project.version
filesMatching("fabric.mod.json") {
expand "version": project.version
}
}
tasks.withType(JavaCompile) {
it.options.encoding = 'UTF-8'
it.options.encoding = "UTF-8"
// Minecraft 1.18 (1.18-pre2) upwards uses Java 17.
it.options.release = 17
}
@ -58,34 +61,79 @@ java {
}
jar {
from('LICENSE') {
from("LICENSE") {
rename { "${it}_${project.archivesBaseName}"}
}
}
def getMetadata() {
def build_id = System.getenv('GITHUB_RUN_NUMBER')
def workflow_id = System.getenv('GITHUB_WORKFLOW')
modrinth {
projectId = "5AgJnN8I"
uploadFile = remapJar
}
tasks.modrinth.dependsOn remapJar
def metadata = libs.versions.minecraft.get()
def ENV = System.getenv()
curseforge {
if (ENV.CURSEFORGE_TOKEN) {
apiKey = ENV.CURSEFORGE_TOKEN
}
project {
id = "564870"
changelog = "No changelog provided"
releaseType = "release"
addGameVersion libs.versions.minecraft.get()
addGameVersion "Fabric"
addGameVersion "Quilt"
mainArtifact(jar) {
displayName = "Cauldron Dyeing ${project.mod_version}"
}
}
}
tasks.curseforge.dependsOn remapJar
publishing {
publications {
mavenJava(MavenPublication) {
from components.java
}
}
repositories {
maven {
url = ENV.MAVEN_URL
credentials {
username = ENV.MAVEN_USERNAME
password = ENV.MAVEN_PASSWORD
}
}
}
}
def getMetadata() {
def build_id = System.getenv("GITHUB_RUN_NUMBER")
def workflow_id = System.getenv("GITHUB_WORKFLOW")
def metadata = ""
// Release builds only
if (workflow_id == 'build-release') {
if (workflow_id == "build-release") {
return metadata
}
if (build_id != null) {
metadata += "-build.${build_id}"
metadata += "build.${build_id}"
} else if (grgit != null) {
def head = grgit.head()
def id = head.abbreviatedId
// Flag the build if the build tree is not clean
if (!grgit.status().clean) {
id += '-dirty'
id += "-dirty"
}
metadata += "-${id}"
metadata += "${id}"
}
return metadata

View file

@ -18,4 +18,6 @@ sodium = { module = "maven.modrinth:sodium", version.ref = "sodium" }
fabric_loom = { id = "fabric-loom", version = "0.12.+" }
loom_quiltflower = { id = "io.github.juuxel.loom-quiltflower", version = "1.7.+" }
qmol = { id = "org.quiltmc.quilt-mappings-on-loom", version = "4.2.0" }
grgit = { id = "org.ajoberstar.grgit", version = "5.0.0" }
grgit = { id = "org.ajoberstar.grgit", version = "5.+" }
minotaur = { id = "com.modrinth.minotaur", version = "2.+" }
cursegradle = { id = "com.matthewprenger.cursegradle", version = "1.+" }