123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227 |
- name: Acceptance
- # Optional, enabling concurrency limits: https://docs.github.com/en/actions/using-jobs/using-concurrency
- #concurrency:
- # group: ${{ github.ref }}-${{ github.workflow }}
- # cancel-in-progress: ${{ github.ref != 'refs/heads/main' }}
- # https://docs.github.com/en/actions/using-workflows/workflow-syntax-for-github-actions#permissions
- permissions:
- actions: none
- checks: none
- contents: none
- deployments: none
- id-token: none
- issues: none
- discussions: none
- packages: none
- pages: none
- pull-requests: none
- repository-projects: none
- security-events: none
- statuses: none
- on:
- push:
- branches-ignore:
- - gh-pages
- - metakitty
- pull_request:
- branches:
- - '*'
- paths:
- - 'metsploit-framework.gemspec'
- - 'Gemfile.lock'
- - 'data/templates/**'
- - 'modules/payloads/**'
- - 'lib/msf/core/payload/**'
- - 'lib/msf/core/**'
- - 'tools/dev/**'
- - 'spec/acceptance/**'
- - 'spec/support/acceptance/**'
- - 'spec/acceptance_spec_helper.rb'
- - '.github/**'
- # Example of running as a cron, to weed out flaky tests
- # schedule:
- # - cron: '*/15 * * * *'
- jobs:
- # Run all test individually, note there is a separate final job for aggregating the test results
- test:
- strategy:
- fail-fast: false
- matrix:
- os:
- - macos-11
- - windows-2019
- - ubuntu-20.04
- ruby:
- - 3.0.2
- meterpreter:
- # Python
- - { name: python, runtime_version: 3.6 }
- - { name: python, runtime_version: 3.11 }
- # Java - newer versions of Java are not supported currently: https://github.com/rapid7/metasploit-payloads/issues/647
- - { name: java, runtime_version: 8 }
- # PHP - Temporarily removed as tests are timing out on Github actions
- # - { name: php, runtime_version: 5.3 }
- # - { name: php, runtime_version: 7.4 }
- # - { name: php, runtime_version: 8.2 }
- include:
- # Windows Meterpreter
- - { meterpreter: { name: windows_meterpreter }, os: windows-2019 }
- # Temporarily required for failing pcaprub compilation:
- # - { meterpreter: { name: windows_meterpreter }, os: windows-2022 }
- # Mettle
- - { meterpreter: { name: mettle }, os: macos-11 }
- - { meterpreter: { name: mettle }, os: ubuntu-20.04 }
- runs-on: ${{ matrix.os }}
- timeout-minutes: 25
- env:
- RAILS_ENV: test
- HOST_RUNNER_IMAGE: ${{ matrix.os }}
- METERPRETER: ${{ matrix.meterpreter.name }}
- METERPRETER_RUNTIME_VERSION: ${{ matrix.meterpreter.runtime_version }}
- name: ${{ matrix.meterpreter.name }} ${{ matrix.meterpreter.runtime_version }} ${{ matrix.os }}
- steps:
- - name: Install system dependencies (Linux)
- if: runner.os == 'Linux'
- run: sudo apt-get -y --no-install-recommends install libpcap-dev graphviz
- - uses: shivammathur/setup-php@6d7209f44a25a59e904b1ee9f3b0c33ab2cd888d
- if: ${{ matrix.meterpreter.name == 'php' }}
- with:
- php-version: ${{ matrix.meterpreter.runtime_version }}
- tools: none
- - name: Set up Python
- if: ${{ matrix.meterpreter.name == 'python' }}
- uses: actions/setup-python@v5
- with:
- python-version: ${{ matrix.meterpreter.runtime_version }}
- - uses: actions/setup-java@v4
- if: ${{ matrix.meterpreter.name == 'java' }}
- with:
- distribution: temurin
- java-version: ${{ matrix.meterpreter.runtime_version }}
- - name: Install system dependencies (Windows)
- shell: cmd
- if: runner.os == 'Windows'
- run: |
- REM pcap dependencies
- powershell -Command "[System.Net.ServicePointManager]::ServerCertificateValidationCallback = {$true} ; [Net.ServicePointManager]::SecurityProtocol = [Net.SecurityProtocolType]::Tls12; (New-Object System.Net.WebClient).DownloadFile('https://www.winpcap.org/install/bin/WpdPack_4_1_2.zip', 'C:\Windows\Temp\WpdPack_4_1_2.zip')"
- choco install 7zip.installServerCertificateValidationCallback
- 7z x "C:\Windows\Temp\WpdPack_4_1_2.zip" -o"C:\"
- dir C:\\
- dir %WINDIR%
- type %WINDIR%\\system32\\drivers\\etc\\hosts
- - name: Checkout code
- uses: actions/checkout@v4
- - name: Setup Ruby
- env:
- BUNDLE_WITHOUT: "coverage development"
- BUNDLE_FORCE_RUBY_PLATFORM: true
- uses: ruby/setup-ruby@v1
- with:
- ruby-version: ${{ matrix.ruby }}
- bundler-cache: true
- cache-version: 4
- # Github actions with Ruby requires Bundler 2.2.18+
- # https://github.com/ruby/setup-ruby/tree/d2b39ad0b52eca07d23f3aa14fdf2a3fcc1f411c#windows
- bundler: 2.2.33
- - name: acceptance
- env:
- SPEC_HELPER_LOAD_METASPLOIT: false
- SPEC_OPTS: "--tag acceptance --require acceptance_spec_helper.rb --color --format documentation --format AllureRspec::RSpecFormatter"
- # Unix run command:
- # SPEC_HELPER_LOAD_METASPLOIT=false bundle exec ./spec/acceptance
- # Windows cmd command:
- # set SPEC_HELPER_LOAD_METASPLOIT=false
- # bundle exec rspec .\spec\acceptance
- # Note: rspec retry is intentionally not used, as it can cause issues with allure's reporting
- # Additionally - flakey tests should be fixed or marked as flakey instead of silently retried
- run: |
- bundle exec rspec spec/acceptance/meterpreter_spec.rb
- - name: Archive results
- if: always()
- uses: actions/upload-artifact@v4
- with:
- # Provide a unique artifact for each matrix os, otherwise race conditions can lead to corrupt zips
- name: raw-data-${{ matrix.meterpreter.name }}-${{ matrix.meterpreter.runtime_version }}-${{ matrix.os }}
- path: tmp/allure-raw-data
- # Generate a final report from the previous test results
- report:
- name: Generate report
- needs: test
- runs-on: ubuntu-latest
- if: always()
- steps:
- - name: Checkout code
- uses: actions/checkout@v4
- if: always()
- - name: Install system dependencies (Linux)
- if: always()
- run: sudo apt-get -y --no-install-recommends install libpcap-dev graphviz
- - name: Setup Ruby
- if: always()
- env:
- BUNDLE_WITHOUT: "coverage development"
- BUNDLE_FORCE_RUBY_PLATFORM: true
- uses: ruby/setup-ruby@v1
- with:
- ruby-version: '${{ matrix.ruby }}'
- bundler-cache: true
- cache-version: 4
- # Github actions with Ruby requires Bundler 2.2.18+
- # https://github.com/ruby/setup-ruby/tree/d2b39ad0b52eca07d23f3aa14fdf2a3fcc1f411c#windows
- bundler: 2.2.33
- - uses: actions/download-artifact@v4
- id: download
- if: always()
- with:
- # Note: Not specifying a name will download all artifacts from the previous workflow jobs
- path: raw-data
- - name: allure generate
- if: always()
- run: |
- export VERSION=2.22.1
- curl -o allure-$VERSION.tgz -Ls https://github.com/allure-framework/allure2/releases/download/$VERSION/allure-$VERSION.tgz
- tar -zxvf allure-$VERSION.tgz -C .
- ls -la ${{steps.download.outputs.download-path}}
- ./allure-$VERSION/bin/allure generate ${{steps.download.outputs.download-path}}/* -o ./allure-report
- find ${{steps.download.outputs.download-path}}
- bundle exec ruby tools/dev/report_generation/support_matrix/generate.rb --allure-data ${{steps.download.outputs.download-path}} > ./allure-report/support_matrix.html
- - name: archive results
- if: always()
- uses: actions/upload-artifact@v4
- with:
- name: final-report-${{ github.run_id }}
- path: |
- ./allure-report
|