X-Git-Url: https://git.openstreetmap.org./chef.git/blobdiff_plain/cf9a140af0e762d9e31d1ee77679618dab9d9cd4..c12e8fd9cc2fbc958dd533fd7f5dc0be957e3675:/.github/workflows/test-kitchen.yml diff --git a/.github/workflows/test-kitchen.yml b/.github/workflows/test-kitchen.yml index e320a4566..3152db471 100644 --- a/.github/workflows/test-kitchen.yml +++ b/.github/workflows/test-kitchen.yml @@ -1,23 +1,35 @@ name: Test Kitchen + on: - push - pull_request + - workflow_dispatch + +concurrency: + group: ${{ github.workflow }}-${{ github.head_ref || github.ref }} + cancel-in-progress: true + jobs: kitchen: name: Test Kitchen - runs-on: ubuntu-latest + runs-on: ubuntu-22.04 + permissions: + packages: read strategy: matrix: suite: - accounts - apache - apt + - apt-repository - backup - bind - blog - blogs + - chef - civicrm - clamav + - community - db-backup - db-base - db-master @@ -27,11 +39,16 @@ jobs: - dmca - dns - docker - - donate - elasticsearch - exim - fail2ban - - forum + - foundation-board + - foundation-dwg + - foundation-mastodon + - foundation-mwg + - foundation-owg + - foundation-welcome + - foundation-wiki - ftp - geodns - geoipupdate @@ -41,7 +58,7 @@ jobs: - gps-tile - hardware - hot - - incron + - ideditor - irc - kibana - letsencrypt @@ -49,10 +66,8 @@ jobs: - logstash-forwarder - mail - mailman + - matomo - memcached - - munin - - munin-plugins - - munin-server - mysql - networking - nginx @@ -63,12 +78,13 @@ jobs: - osmosis - osqa - otrs + - overpass - passenger - php - php-apache - php-fpm - - piwik - planet + - planet-aws - planet-current - planet-dump - planet-notes @@ -82,7 +98,8 @@ jobs: - snmpd - spamassassin - ssl - - stateofthemap + - stateofthemap-container + - stateofthemap-wordpress - subversion - supybot - switch2osm @@ -93,35 +110,95 @@ jobs: - tilelog - tools - trac - - web-backend - web-cgimap - web-frontend - web-rails - wordpress - wiki os: - - ubuntu-2004 + - ubuntu-2204 + include: + - os: ubuntu-2004 + suite: mailman + - os: ubuntu-2004 + suite: osqa + - os: debian-12 + suite: apt-repository + - os: debian-12 + suite: dns + - os: debian-12 + suite: git-server + - os: debian-12 + suite: git-web + - os: debian-12 + suite: imagery-tiler + - os: debian-12 + suite: letsencrypt + - os: debian-12 + suite: otrs + - os: debian-12 + suite: serverinfo + - os: debian-12 + suite: supybot + - os: debian-12 + suite: web-cgimap + - os: debian-12 + suite: web-frontend + - os: debian-12 + suite: web-rails + exclude: + - suite: apt-repository + os: ubuntu-2204 + - suite: dns + os: ubuntu-2204 + - suite: git-server + os: ubuntu-2204 + - suite: git-web + os: ubuntu-2204 + - suite: mailman + os: ubuntu-2204 + - suite: letsencrypt + os: ubuntu-2204 + - suite: osqa + os: ubuntu-2204 + - suite: otrs + os: ubuntu-2204 + - suite: serverinfo + os: ubuntu-2204 + - suite: supybot + os: ubuntu-2204 + - suite: web-cgimap + os: ubuntu-2204 + - suite: web-frontend + os: ubuntu-2204 + - suite: web-rails + os: ubuntu-2204 fail-fast: false steps: + - name: Login to GitHub Container Registry + uses: docker/login-action@v3 + with: + registry: ghcr.io + username: ${{ github.actor }} + password: ${{ secrets.GITHUB_TOKEN }} + - name: Login to Docker Hub + uses: docker/login-action@v3 + with: + username: ${{ secrets.DOCKERHUB_USERNAME }} + password: ${{ secrets.DOCKERHUB_TOKEN }} + if: github.repository == 'openstreetmap/chef' && github.event_name != 'pull_request' - name: Check out code - uses: actions/checkout@v2.4.0 + uses: actions/checkout@v4 - name: Setup ruby - uses: actions/setup-ruby@v1.1.3 - - name: Cache gems - uses: actions/cache@v2.1.7 + uses: ruby/setup-ruby@v1 with: - path: vendor/bundle - key: bundle-${{ runner.OS }}-${{ hashFiles('Gemfile.lock') }} - restore-keys: | - bundle-${{ runner.OS }}- - - name: Disable apparmor for mysqld - run: | - sudo apt-get install apparmor-utils - sudo aa-disable /usr/sbin/mysqld - - name: Install gems - run: | - gem install bundler - bundle config set deployment true - bundle install --jobs 4 --retry 3 + ruby-version: 3.1 + bundler-cache: true - name: Run kitchen test ${{ matrix.suite }}-${{ matrix.os }} run: bundle exec kitchen test ${{ matrix.suite }}-${{ matrix.os }} + - name: Gather journal output + run: | + bundle exec kitchen exec ${{ matrix.suite }}-${{ matrix.os }} -c "journalctl --since=yesterday" + bundle exec kitchen exec ${{ matrix.suite }}-${{ matrix.os }} -c "networkctl status --all" + bundle exec kitchen exec ${{ matrix.suite }}-${{ matrix.os }} -c "resolvectl status" || true + if: ${{ failure() }}