forked from victor-paltz/JFaiss-CPU
-
Notifications
You must be signed in to change notification settings - Fork 1
127 lines (109 loc) · 3.94 KB
/
build.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
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
name: Build and Release
on:
workflow_dispatch:
pull_request:
push:
branches:
- master
jobs:
build_faiss:
runs-on: ubuntu-latest
name: Build faiss native
steps:
- uses: actions/checkout@master
with:
submodules: true
- uses: whoan/docker-build-with-cache-action@v5
with:
username: ${{ github.actor }}
password: "${{ secrets.GITHUB_TOKEN }}"
registry: docker.pkg.github.com
image_name: jfaiss-cpu
dockerfile: Dockerfile
- run: docker run -v "/home/runner/work/jfaiss-cpu/jfaiss-cpu":"/github/workspace" docker.pkg.github.com/criteo/jfaiss-cpu/jfaiss-cpu
- uses: actions/upload-artifact@v4
with:
name: faiss_JNI_and_SO
path: build
build_jfaiss:
needs: build_faiss
runs-on: ubuntu-latest
name: Build jfaiss-cpu
steps:
- name: Checkout
uses: actions/checkout@v2
- name: Read GPG private key
run: echo -ne "$GPG_PRIVATE_KEY" | base64 --decode > $RUNNER_TEMP/key.asc
env:
GPG_PRIVATE_KEY: ${{ secrets.MAVEN_SECRING_GPG_BASE64 }}
- name: Download build artifacts
uses: actions/download-artifact@v4
with:
name: faiss_JNI_and_SO
path: build_copy
- name: Move build artifacts
run: |
rm -rf src/main/java/com/vectorsearch/faiss/swig
cp -r build_copy/java/com/vectorsearch/faiss/swig src/main/java/com/vectorsearch/faiss/swig
rm -rf src/main/resources
cp -r build_copy/resources src/main/resources
- name: Extract FAISS version
id: faiss_version
run: |
FAISS_VERSION="$(mvn help:evaluate -Dexpression=project.version -q -DforceStdout)"
echo "::set-output name=version::$FAISS_VERSION"
- name: Set version
id: version
run: |
VERSION="${FAISS_VERSION}-$(git rev-parse --short HEAD)"
mvn -B versions:set -DnewVersion=$VERSION
echo "::set-output name=version::$VERSION"
env:
FAISS_VERSION: ${{ steps.faiss_version.outputs.version }}
- name: Set up Maven Central Repository
uses: warrenseine/setup-java@v1
env:
ACTIONS_ALLOW_UNSECURE_COMMANDS: true
with:
java-version: "1.8.0"
java-package: jdk
architecture: x64
server-id: ossrh
server-username: MAVEN_USERNAME
server-password: MAVEN_PASSWORD
gpg-private-key-path: ${{ runner.temp }}/key.asc
gpg-passphrase: MAVEN_GPG_PASSPHRASE
- name: Clean GPG private key
if: ${{ always() }}
run: rm -f $RUNNER_TEMP/key.asc
- name: Publish to the Maven Central Repository
run: mvn -B -DskipTests -P deploy deploy
env:
MAVEN_USERNAME: ${{ secrets.SONATYPE_USERNAME }}
MAVEN_PASSWORD: ${{ secrets.SONATYPE_PASSWORD }}
MAVEN_GPG_PASSPHRASE: ${{ secrets.MAVEN_SECRING_PASSWORD }}
- name: Upload artifact
uses: actions/upload-artifact@v4
with:
name: jfaiss-cpu
path: ./target/jfaiss-cpu-${{ steps.version.outputs.version }}.jar
- name: Create release
id: release
uses: actions/create-release@v1
env:
GITHUB_TOKEN: ${{ secrets.GITHUB_TOKEN }}
with:
tag_name: ${{ steps.faiss_version.outputs.version }}
release_name: Release ${{ steps.version.outputs.version }}
draft: false
prerelease: false
- name: Upload release asset
uses: actions/upload-release-asset@v1
env:
ACTIONS_ALLOW_UNSECURE_COMMANDS: true
GITHUB_TOKEN: ${{ secrets.GITHUB_TOKEN }}
with:
upload_url: ${{ steps.release.outputs.upload_url }}
asset_path: ./target/jfaiss-cpu-${{ steps.version.outputs.version }}.jar
asset_name: jfaiss-cpu-${{ steps.version.outputs.version }}.jar
asset_content_type: application/java-archive