diff --git a/.github/workflows/publish_latest_server_image.yml b/.github/workflows/publish_latest_server_image.yml new file mode 100644 index 0000000..54bb55b --- /dev/null +++ b/.github/workflows/publish_latest_server_image.yml @@ -0,0 +1,94 @@ +name: "Publish server image(latest)" + +on: + schedule: + - cron: '0 23 * * *' + workflow_dispatch: + +jobs: + build_latest: + runs-on: ubuntu-latest + env: + REPOSITORY_URL: apache/hugegraph + BRANCH: master + IMAGE_URL: hugegraph/hugegraph:latest + GITHUB_TOKEN: ${{ secrets.PERSONAL_ACCESS_TOKEN }} + OWNER: hugegraph + REPO: actions + LAST_COMMIT_HASH: ${{vars.LAST_COMMIT_HASH}} + + steps: + - name: Set up Docker Buildx + uses: docker/setup-buildx-action@v2 + + - name: Login to Docker Hub + uses: docker/login-action@v2 + with: + username: ${{ secrets.DOCKERHUB_USERNAME }} + password: ${{ secrets.DOCKERHUB_PASSWORD }} + + - name: Checkout latest + uses: actions/checkout@v3 + with: + repository: ${{ env.REPOSITORY_URL }} + ref: ${{ env.BRANCH }} + fetch-depth: 2 + + - name: Get current commit-hash + run: | + current_commit_hash=$(git rev-parse HEAD) + echo "CURRENT_COMMIT_HASH=$current_commit_hash" >> $GITHUB_ENV + + - name: Check if an update is needed + run: | + need_update='false' + if [[ "$CURRENT_COMMIT_HASH" != "$LAST_COMMIT_HASH" ]]; then + need_update='true' + fi + echo "NEED_UPDATE=$need_update" >> $GITHUB_ENV + # TODO: replace `if` statements for exit if github provide support for exit gracefully, + # see https://github.com/actions/runner/issues/662 for more details + + - name: Build X86 Image + if: ${{ env.NEED_UPDATE == 'true' }} + uses: docker/build-push-action@v4 + with: + context: . + load: true + tags: ${{ env.IMAGE_URL }} + cache-from: type=gha + cache-to: type=gha,mode=max + + - name: Test X86 Image + if: ${{ env.NEED_UPDATE == 'true' }} + run: | + docker images + docker run -itd --name=graph -p 18080:8080 $IMAGE_URL + sleep 20s + curl 0.0.0.0:18080 || exit + docker ps -a + sleep 20s + curl 0.0.0.0:18080 || exit + docker ps -a + + - name: Build ARM & Push all + if: ${{ env.NEED_UPDATE == 'true' }} + uses: docker/build-push-action@v4 + with: + context: . + file: ./Dockerfile + platforms: linux/amd64,linux/arm64 + push: true + tags: ${{ env.IMAGE_URL }} + cache-from: type=gha + cache-to: type=gha,mode=max + + - name: Updata last commit-hash + if: ${{ env.NEED_UPDATE == 'true' }} + run: | + curl -L -X PATCH \ + -H "Accept: application/vnd.github+json" \ + -H "X-GitHub-Api-Version: 2022-11-28" \ + -H "Authorization: Bearer $GITHUB_TOKEN" \ + https://api.github.com/repos/$OWNER/$REPO/actions/variables/LAST_COMMIT_HASH \ + -d '{"name":"LAST_COMMIT_HASH","value":"'"$CURRENT_COMMIT_HASH"'"}' diff --git a/.github/workflows/publish_release_server_image.yml b/.github/workflows/publish_release_server_image.yml new file mode 100644 index 0000000..31d3286 --- /dev/null +++ b/.github/workflows/publish_release_server_image.yml @@ -0,0 +1,69 @@ +name: "Publish server image(release)" +on: + workflow_dispatch: + inputs: + branch: + required: true + default: '' + description: 'The branch name should be like *-x.x.x, for example release-1.0.0' + +jobs: + build_latest: + runs-on: ubuntu-latest + env: + REPOSITORY_URL: apache/hugegraph + BRANCH: ${{inputs.branch}} + + steps: + - name: Set image_url + run: | + image_url=hugegraph/hugegraph:$(echo "${{ inputs.branch }}" | grep -oP '(\d+\.\d+\.\d+)') + echo $image_url && echo "image_url=$image_url" >> $GITHUB_ENV + + - name: Set up Docker Buildx + uses: docker/setup-buildx-action@v2 + + - name: Login to Docker Hub + uses: docker/login-action@v2 + with: + username: ${{ secrets.DOCKERHUB_USERNAME }} + password: ${{ secrets.DOCKERHUB_PASSWORD }} + + - name: Checkout latest + uses: actions/checkout@v3 + with: + repository: ${{ env.REPOSITORY_URL }} + ref: ${{ env.BRANCH }} + fetch-depth: 2 + + - name: Build X86 Image + uses: docker/build-push-action@v4 + with: + context: . + load: true + tags: ${{ env.image_url }} + cache-from: type=gha + cache-to: type=gha,mode=max + + - name: Test X86 Image + run: | + echo "$image_url" + docker images + docker run -itd --name=graph -p 18080:8080 $image_url + sleep 20s + curl 0.0.0.0:18080 || exit + docker ps -a + sleep 20s + curl 0.0.0.0:18080 || exit + docker ps -a + + - name: Build ARM & Push all + uses: docker/build-push-action@v4 + with: + context: . + file: ./Dockerfile + platforms: linux/amd64,linux/arm64 + push: true + tags: ${{ env.image_url }} + cache-from: type=gha + cache-to: type=gha,mode=max