summaryrefslogtreecommitdiff
path: root/.github/workflows/doxygen.yml
blob: 04599682f561363097e186a60ea7688f36fd0b7a (plain)
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
name: doxygen
on:
  schedule:
    - cron: '0 * * * *'
  pull_request:
    branches:
      - '*'
jobs:
  latest:
    runs-on: ubuntu-latest
    strategy:
      matrix:
        test_task: [ "check" ]
      fail-fast: false
    steps:
      - name: Install libraries
        run: |
          set -x
          sudo sed /etc/apt/sources.list -e "s/^# deb-src/deb-src/g" -i
          sudo apt-get update
          sudo apt-get install ruby2.5 doxygen graphviz
          sudo apt-get build-dep ruby2.5

      # Not using official actions/checkout because it's unstable and sometimes doesn't work for a fork.
      - name: Checkout ruby/ruby
        run: git clone --depth=1 https://github.com/ruby/ruby . && git reset --hard "$GITHUB_SHA"
        env:
          GITHUB_SHA: ${{ github.sha }}
        if: github.event_name == 'schedule'
      - name: Checkout a pull request
        run: git clone --depth=1 "--branch=$GITHUB_BRANCH" "https://github.com/${GITHUB_REPO}" . && git reset --hard "$GITHUB_REV"
        env:
          GITHUB_REV: ${{ github.event.pull_request.head.sha }}
          GITHUB_BRANCH: ${{ github.event.pull_request.head.ref }}
          GITHUB_REPO: ${{ github.event.pull_request.head.repo.full_name }}
        if: github.event_name == 'pull_request'

      - name: Fixed world writable dirs
        run: |
          chmod go-w $HOME
          sudo chmod -R go-w /usr/share
      - run: autoconf
      - name: Configure
        run: ./configure
      - name: Generate Doxyfile
        run: make Doxyfile
      - name: Run Doxygen
        run: doxygen
      - name: Upload results
        run: |
          aws s3 sync doc/capi/html/ s3://rubyci/doxygen-latest-html
        env:
          GITHUB_SHA: ${{ github.sha }}
          AWS_ACCESS_KEY_ID: ${{ secrets.AWS_ACCESS_KEY_ID }}
          AWS_SECRET_ACCESS_KEY: ${{ secrets.AWS_SECRET_ACCESS_KEY }}
        if: github.event_name == 'schedule'

      - name: Debug GitHub context
        run: echo "$GITHUB_CONTEXT"
        env:
          GITHUB_CONTEXT: ${{ toJson(github) }}
        if: failure() && github.event_name == 'schedule'