-
Notifications
You must be signed in to change notification settings - Fork 42
157 lines (144 loc) · 5.42 KB
/
publish.yml
File metadata and controls
157 lines (144 loc) · 5.42 KB
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
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
137
138
139
140
141
142
143
144
145
146
147
148
149
150
151
152
153
154
155
156
157
name: Publish Spark packages
on:
release:
types: [published]
pull_request:
paths:
- .github/workflows/publish.yml
types:
- opened
- synchronize
- ready_for_review
- reopened
workflow_dispatch:
inputs:
mode:
description: 'Release mode'
required: true
type: choice
default: dry_run
options:
- dry_run
- release
ref:
description: 'The branch, tag or SHA to checkout'
required: false
type: string
jobs:
release:
name: Release Spark
runs-on: ubuntu-24.04
timeout-minutes: 60
steps:
- name: Checkout repository
uses: actions/checkout@v4
with:
# When triggered by a release, use the release tag
# When triggered manually, use the provided ref
ref: ${{ github.event.release.tag_name || inputs.ref }}
- name: Set up Java 17
uses: actions/setup-java@v4
with:
distribution: corretto
java-version: 17
cache: "maven"
server-id: ossrh
server-username: SONATYPE_USER
server-password: SONATYPE_TOKEN
gpg-private-key: ${{ secrets.GPG_PRIVATE_KEY }}
gpg-passphrase: ${{ secrets.GPG_PASSPHRASE }}
- name: Set github
run: |
git config --global user.email "Lance Github Runner"
git config --global user.name "dev+gha@lancedb.com"
- name: Dry run
if: |
github.event_name == 'pull_request' ||
inputs.mode == 'dry_run'
run: |
mvn --batch-mode -DskipTests package
- name: Publish to Maven Central
if: |
github.event_name == 'release' ||
inputs.mode == 'release'
run: |
echo "use-agent" >> ~/.gnupg/gpg.conf
echo "pinentry-mode loopback" >> ~/.gnupg/gpg.conf
export GPG_TTY=$(tty)
mvn --batch-mode -DskipTests -DpushChanges=false -Dgpg.passphrase=${{ secrets.GPG_PASSPHRASE }} deploy -P deploy-to-ossrh
env:
SONATYPE_USER: ${{ secrets.SONATYPE_USER }}
SONATYPE_TOKEN: ${{ secrets.SONATYPE_TOKEN }}
- name: Get published version
if: |
github.event_name == 'release' ||
inputs.mode == 'release'
id: get_version
run: |
VERSION=$(mvn help:evaluate -Dexpression=project.version -q -DforceStdout)
echo "version=$VERSION" >> $GITHUB_OUTPUT
echo "Published version: $VERSION"
- name: Wait for Maven Central availability
if: |
github.event_name == 'release' ||
inputs.mode == 'release'
run: |
VERSION="${{ steps.get_version.outputs.version }}"
GROUP_ID="org.lance"
# List of artifacts to check (a representative subset)
ARTIFACTS=(
"lance-spark-base_2.12"
"lance-spark-3.5_2.12"
"lance-spark-bundle-3.5_2.12"
)
echo "Waiting for version $VERSION to be available in Maven Central..."
echo "This typically takes 10-30 minutes after publishing to OSSRH."
# Maximum wait time: 60 minutes
MAX_WAIT=3600
INTERVAL=60
ELAPSED=0
while [ $ELAPSED -lt $MAX_WAIT ]; do
ALL_AVAILABLE=true
for ARTIFACT_ID in "${ARTIFACTS[@]}"; do
URL="https://repo1.maven.org/maven2/org/lance/${ARTIFACT_ID}/${VERSION}/${ARTIFACT_ID}-${VERSION}.pom"
if curl --head --silent --fail "$URL" > /dev/null 2>&1; then
echo "✓ ${ARTIFACT_ID} is available"
else
echo "✗ ${ARTIFACT_ID} is not yet available"
ALL_AVAILABLE=false
fi
done
if [ "$ALL_AVAILABLE" = true ]; then
echo ""
echo "🎉 All artifacts are now available in Maven Central!"
echo ""
echo "Users can now add the following dependency to their projects:"
echo ""
echo "Maven:"
echo "<dependency>"
echo " <groupId>org.lance</groupId>"
echo " <artifactId>lance-spark-bundle-3.5_2.12</artifactId>"
echo " <version>${VERSION}</version>"
echo "</dependency>"
echo ""
echo "Gradle:"
echo "implementation 'org.lance:lance-spark-bundle-3.5_2.12:${VERSION}'"
echo ""
echo "SBT:"
echo "libraryDependencies += \"org.lance\" % \"lance-spark-bundle-3.5_2.12\" % \"${VERSION}\""
exit 0
fi
ELAPSED=$((ELAPSED + INTERVAL))
if [ $ELAPSED -lt $MAX_WAIT ]; then
echo ""
echo "Artifacts not yet available. Waiting ${INTERVAL} seconds... (${ELAPSED}s elapsed)"
sleep $INTERVAL
fi
done
echo ""
echo "⚠️ WARNING: Artifacts are not yet available in Maven Central after ${MAX_WAIT} seconds."
echo "This is normal - Maven Central sync can take up to 2 hours."
echo "The artifacts will appear at: https://central.sonatype.com/artifact/org.lance/lance-spark-bundle-3.5_2.12/${VERSION}"
echo ""
echo "You can check the sync status at: https://s01.oss.sonatype.org/"
exit 0