release.yml 3.9 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128
  1. name: Release
  2. on:
  3. push:
  4. branches:
  5. - release/**
  6. jobs:
  7. github-release:
  8. runs-on: ubuntu-latest
  9. outputs:
  10. RELEASE_VERSION: ${{ steps.step-bump-version.RELEASE_VERSION }}
  11. steps:
  12. - uses: actions/checkout@v2
  13. - name: Init Git
  14. run: |
  15. git config --local user.name "GitHub Action"
  16. git config --local user.email "info@weseek.co.jp"
  17. git remote set-url origin "https://$GITHUB_ACTOR:${{ secrets.GITHUB_TOKEN }}@github.com/$GITHUB_REPOSITORY"
  18. - name: Bump version
  19. id: step-bump-version
  20. run: |
  21. npm --no-git-tag-version version patch
  22. export RELEASE_VERSION=`npm run version --silent`
  23. sh ./bin/github-actions/update-readme.sh
  24. echo ::set-env name=RELEASE_VERSION::$RELEASE_VERSION
  25. echo ::set-output name=RELEASE_VERSION::$RELEASE_VERSION
  26. - name: Checkout, Commit, Tag and Push
  27. run: |
  28. TMP_RELEASE_BRANCH=tmp/release-${{ env.RELEASE_VERSION }}
  29. git checkout -B $TMP_RELEASE_BRANCH
  30. git commit -am "Release v${{ env.RELEASE_VERSION }}"
  31. git tag -a v${{ env.RELEASE_VERSION }} -m "v${{ env.RELEASE_VERSION }}"
  32. git push --follow-tags origin $TMP_RELEASE_BRANCH
  33. git push --delete origin $TMP_RELEASE_BRANCH
  34. - name: Upload release notes
  35. uses: Roang-zero1/github-create-release-action@master
  36. with:
  37. created_tag: v${{ env.RELEASE_VERSION }}
  38. changelog_file: CHANGES.md
  39. env:
  40. GITHUB_TOKEN: ${{ secrets.GITHUB_TOKEN }}
  41. build-image:
  42. needs: github-release
  43. runs-on: ubuntu-latest
  44. strategy:
  45. matrix:
  46. flavor: [default, nocdn]
  47. steps:
  48. - uses: actions/checkout@v2
  49. - name: Checkout released tag
  50. run: git checkout refs/tags/v${{ needs.github-release.outputs.RELEASE_VERSION }}
  51. - name: Determine suffix
  52. run: |
  53. [[ ${{ matrix.flavor }} = "nocdn" ]] && suffix="-nocdn" || suffix=""
  54. echo ::set-env name=SUFFIX::$suffix
  55. - name: Cache/Restore yarn cache
  56. uses: actions/cache@v1
  57. with:
  58. path: /usr/local/share/.cache/yarn
  59. key: ${{ runner.os }}-yarn-${{ matrix.node-version }}-${{ hashFiles('**/yarn.lock') }}
  60. restore-keys: |
  61. ${{ runner.os }}-yarn-${{ matrix.node-version }}-
  62. - name: Set up Docker Buildx
  63. uses: crazy-max/ghaction-docker-buildx@v1.0.4
  64. - name: Login to docker.io registry
  65. run: |
  66. echo ${{ secrets. DOCKER_REGISTRY_PASSWORD }} | docker login --username wsmoogle --password-stdin
  67. - name: Build Docker Image
  68. run: |
  69. CACHE_REF=weseek/growi-cache:3${{ env.SUFFIX }}
  70. docker buildx build \
  71. --tag growi${{ env.SUFFIX }} \
  72. --build-arg flavor=${{ matrix.flavor }} \
  73. --platform linux/amd64 \
  74. --load \
  75. --cache-from=type=registry,ref=$CACHE_REF \
  76. --cache-to=type=registry,ref=$CACHE_REF,mode=max \
  77. --file ./docker/Dockerfile .
  78. - name: Docker Tags by SemVer
  79. uses: weseek/ghaction-docker-tags-by-semver@v1.0.5
  80. with:
  81. source: growi${{ env.SUFFIX }}
  82. target: weseek/growi
  83. semver: ${{ needs.github-release.outputs.RELEASE_VERSION }}
  84. suffix: ${{ env.SUFFIX }}
  85. additional-tags: 'latest'
  86. publish: true
  87. - name: Slack Notification
  88. uses: weseek/ghaction-release-slack-notification@master
  89. with:
  90. channel: '#general'
  91. url: ${{ secrets.SLACK_WEBHOOK_URL }}
  92. created_tag: 'v${{ needs.github-release.outputs.RELEASE_VERSION }}${{ env.SUFFIX }}'
  93. - name: Update Docker Hub Description
  94. uses: peter-evans/dockerhub-description@v2.1.0
  95. env:
  96. DOCKERHUB_USERNAME: wsmoogle
  97. DOCKERHUB_PASSWORD: ${{ secrets.DOCKER_REGISTRY_PASSWORD }}
  98. DOCKERHUB_REPOSITORY: weseek/growi
  99. README_FILEPATH: ./docker/README.md
  100. - name: Check whether workspace is clean
  101. run: |
  102. STATUS=`git status --porcelain`
  103. if [ -z "$STATUS" ]; then exit 0; else exit 1; fi