Skip to content

Commit

Permalink
Add build tooling to support releasing patches, i.e. 1.3.2.1 (#18)
Browse files Browse the repository at this point in the history
  • Loading branch information
jack-berg authored Sep 30, 2024
1 parent f8f2b13 commit 835072e
Show file tree
Hide file tree
Showing 3 changed files with 30 additions and 15 deletions.
6 changes: 3 additions & 3 deletions .github/workflows/release-build.yml
Original file line number Diff line number Diff line change
Expand Up @@ -4,7 +4,7 @@ on:
workflow_dispatch:
inputs:
version:
description: The version to tag the release with, e.g., 1.2.0, 1.2.1-alpha.1
description: The version to tag the release with, e.g., 1.2.0, 1.2.1-alpha, or 1.2.0.1 for a patch release of the 1.2.0 proto release
required: true

jobs:
Expand All @@ -26,14 +26,14 @@ jobs:
remote-build-cache-proxy-enabled: false
arguments: build --stacktrace
properties: |
release.version=${{ github.event.inputs.version }}
release.version.prop=${{ github.event.inputs.version }}
org.gradle.java.installations.paths=${{ steps.setup-java-17.outputs.path }}
- uses: burrunan/[email protected]
with:
remote-build-cache-proxy-enabled: false
arguments: final closeAndReleaseSonatypeStagingRepository --stacktrace
properties: |
release.version=${{ github.event.inputs.version }}
release.version.prop=${{ github.event.inputs.version }}
org.gradle.java.installations.paths=${{ steps.setup-java-17.outputs.path }}
env:
SONATYPE_USER: ${{ secrets.SONATYPE_USER }}
Expand Down
4 changes: 2 additions & 2 deletions README.md
Original file line number Diff line number Diff line change
Expand Up @@ -48,10 +48,10 @@ is [0.20.0](https://github.com/open-telemetry/opentelemetry-proto-java/tree/v0.2
downloaded from
the [v0.20.0 release](https://github.com/open-telemetry/opentelemetry-proto/releases/tag/v0.20.0).
This can be overridden for the build or other gradle tasks (e.g. `publishToMavenLocal`)
with `-Prelease.version`:
with `-Prelease.version.prop`:

```shell
./gradlew build -Prelease.version=1.0.0
./gradlew build -Prelease.version.prop=1.0.0
```

## Support
Expand Down
35 changes: 25 additions & 10 deletions build.gradle.kts
Original file line number Diff line number Diff line change
Expand Up @@ -14,7 +14,32 @@ plugins {
id("otel.publish-conventions")
}

// Resolve protoVersion and releaseVersion
// If user provides property release.version.prop match against releaseVersionRegex. protoVersion is the semconv matching group (i.e. for release.version.prop=1.3.2.1, protoVersion is 1.3.2). releaseVersion is the value of the release.version.prop.
// Else, set protoVersion and releaseVersion to the most recent git tag.
// The releaseVersion is used to set the nebular release plugin release version. Note, the release.version.prop is used because the nebula release plugin verifies release.version matches semconv.
// The protoVersion is used to download sources from opentelemetry-proto..
var protoVersion = "unknown"
var releaseVersion = "unknown"
if (properties.contains("release.version.prop")) {
val releaseVersionProperty = properties.get("release.version.prop") as String
val matchResult = "^(?<protoversion>([0-9]*)\\.([0-9]*)\\.([0-9]*)).*\$".toRegex().matchEntire(releaseVersionProperty)
if (matchResult == null) {
throw GradleException("Invalid value for release.version.prop")
}
protoVersion = matchResult.groups["protoversion"]?.value as String
releaseVersion = releaseVersionProperty
} else {
protoVersion = NearestVersionLocator(TagStrategy()).locate(release.grgit).any.toString()
releaseVersion = protoVersion
}
logger.lifecycle("proto version: " + protoVersion)
logger.lifecycle("release version: " + releaseVersion)

val protoArchive = file("$buildDir/archives/opentelemetry-proto-$protoVersion.zip")

release {
version = releaseVersion
defaultVersionStrategy = nebula.plugin.release.git.opinion.Strategies.getSNAPSHOT()
}

Expand Down Expand Up @@ -65,16 +90,6 @@ protobuf {
}
}

// Proto version is set from -Prelease.version or inferred from the latest tag
var protoVersion = if (properties.contains(
"release.version"
)) {
properties.get("release.version") as String
} else {
NearestVersionLocator(TagStrategy()).locate(release.grgit).any.toString()
}
val protoArchive = file("$buildDir/archives/opentelemetry-proto-$protoVersion.zip")

tasks {
val downloadProtoArchive by registering(Download::class) {
onlyIf { !protoArchive.exists() }
Expand Down

0 comments on commit 835072e

Please sign in to comment.