From 154a11c5dcbf96ee9eb28f6964a7ada79c9891de Mon Sep 17 00:00:00 2001 From: dosas Date: Tue, 20 Feb 2024 13:48:05 +0100 Subject: [PATCH] Use theforeman github actions for ruby testing --- .github/workflows/rubocop.yml | 19 --------- .github/workflows/ruby_tests.yml | 23 ++++++++++ .github/workflows/unit_tests.yml | 73 -------------------------------- 3 files changed, 23 insertions(+), 92 deletions(-) delete mode 100644 .github/workflows/rubocop.yml create mode 100644 .github/workflows/ruby_tests.yml delete mode 100644 .github/workflows/unit_tests.yml diff --git a/.github/workflows/rubocop.yml b/.github/workflows/rubocop.yml deleted file mode 100644 index a008eb33..00000000 --- a/.github/workflows/rubocop.yml +++ /dev/null @@ -1,19 +0,0 @@ -name: Rubocop -on: - pull_request: - push: - branches: - - master -jobs: - rubocop: - runs-on: ubuntu-latest - steps: - - uses: actions/checkout@v2 - - name: Setup Ruby - uses: ruby/setup-ruby@v1 - with: - ruby-version: 2.7 - bundler-cache: true - - name: Execute rubocop - run: | - bundle exec rake rubocop diff --git a/.github/workflows/ruby_tests.yml b/.github/workflows/ruby_tests.yml new file mode 100644 index 00000000..bd382f31 --- /dev/null +++ b/.github/workflows/ruby_tests.yml @@ -0,0 +1,23 @@ +--- +name: Ruby Tests +"on": + push: + branches: + - main + pull_request: + +concurrency: + group: ${{ github.ref_name }}-${{ github.workflow }} + cancel-in-progress: true + +jobs: + rubocop: + uses: theforeman/actions/.github/workflows/rubocop.yml@v0 + + test: + name: Ruby + needs: rubocop + uses: theforeman/actions/.github/workflows/foreman_plugin.yml@v0 + with: + plugin: foreman_acd + matrix_exclude: '[{"ruby": "3.0", "node": "14"}]' diff --git a/.github/workflows/unit_tests.yml b/.github/workflows/unit_tests.yml deleted file mode 100644 index 023d6c1a..00000000 --- a/.github/workflows/unit_tests.yml +++ /dev/null @@ -1,73 +0,0 @@ -name: Unit and functional tests -on: - pull_request: - push: - branches: - - master - -env: - RAILS_ENV: test - DATABASE_URL: postgresql://postgres:@localhost/test - DATABASE_CLEANER_ALLOW_REMOTE_DATABASE_URL: true - -jobs: - test_ruby: - runs-on: ubuntu-latest - env: - BUNDLE_WITHOUT: journald:development:console:libvirt - services: - postgres: - image: postgres:12.1 - ports: ['5432:5432'] - options: --health-cmd pg_isready --health-interval 10s --health-timeout 5s --health-retries 5 - strategy: - fail-fast: false - matrix: - foreman-repo: [theforeman/foreman] - foreman-core-branch: [3.8-stable, 3.9-stable, develop] - ruby-version: [2.7] - steps: - - run: | - sudo apt-get update - sudo apt-get install build-essential libcurl4-openssl-dev zlib1g-dev libpq-dev - - uses: actions/checkout@v2 - with: - repository: ${{ matrix.foreman-repo }} - ref: ${{ matrix.foreman-core-branch }} - - uses: actions/checkout@v2 - with: - path: foreman_acd - - name: Add ACD to foreman - run: | - echo "gem 'foreman_acd', path: './foreman_acd'" > bundler.d/foreman_acd.local.rb - - name: Limit REX and tasks version for Foreman 3.8-stable - working-directory: foreman_acd - if: ${{ matrix.foreman-core-branch == '3.8-stable' }} - run: | - sed -i '/s\.add_dependency .foreman-tasks./s/,[^,]*$/, "~> 8.3"/' foreman_acd.gemspec - sed -i '/s\.add_dependency .foreman_remote_execution./s/,[^,]*$/, "~> 11.1"/' foreman_acd.gemspec - cat foreman_acd.gemspec - - - name: Setup Ruby - uses: ruby/setup-ruby@v1 - with: - ruby-version: ${{ matrix.ruby-version }} - bundler-cache: true - - run: bundle list - - name: Prepare test env - run: | - bundle exec rake db:create - bundle exec rake db:migrate - bundle exec rake db:test:prepare - - name: Run plugin tests - run: | - bundle exec rake test:foreman_acd - - name: Run access permission test - run: | - bundle exec rake test TEST="test/unit/foreman/access_permissions_test.rb" - - name: Upload test.log - uses: actions/upload-artifact@v2 - if: failure() - with: - name: log - path: log/test.log