Chore: Ensure we run miri with the tests to detect undefined behavior… #19164
  
    
      This file contains hidden or bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
      Learn more about bidirectional Unicode characters
    
  
  
    
  | name: Build and Test | |
| on: | |
| workflow_dispatch: | |
| pull_request: | |
| branches: [ master, main-* ] | |
| merge_group: | |
| concurrency: | |
| group: ${{ github.workflow }}-${{ github.ref }} | |
| cancel-in-progress: true | |
| env: | |
| dotnet-version: 6.0.x # SDK Version for building Dafny | |
| jobs: | |
| check-deep-tests: | |
| uses: ./.github/workflows/check-deep-tests-reusable.yml | |
| singletons: | |
| needs: check-deep-tests | |
| if: always() && (( github.event_name == 'pull_request' && (needs.check-deep-tests.result == 'success' || contains(github.event.pull_request.labels.*.name, 'run-deep-tests'))) || ( github.event_name == 'push' && ( github.ref_name == 'master' || vars.TEST_ON_FORK == 'true' ))) | |
| runs-on: ubuntu-20.04 | |
| steps: | |
| - name: Setup dotnet | |
| uses: actions/setup-dotnet@v4 | |
| with: | |
| dotnet-version: ${{env.dotnet-version}} | |
| - name: Checkout Dafny | |
| uses: actions/checkout@v4 | |
| with: | |
| path: dafny | |
| submodules: recursive | |
| - name: Restore tools | |
| working-directory: dafny | |
| run: dotnet tool restore | |
| - name: Check whitespace and style | |
| working-directory: dafny | |
| run: dotnet format whitespace Source/Dafny.sln --verify-no-changes --exclude Source/DafnyCore/Scanner.cs --exclude Source/DafnyCore/Parser.cs --exclude Source/DafnyCore/GeneratedFromDafny/* --exclude Source/DafnyCore.Test/GeneratedFromDafny/* --exclude Source/DafnyRuntime/DafnyRuntimeSystemModule.cs | |
| - name: Get Boogie Version | |
| run: | | |
| sudo apt-get update | |
| sudo apt-get install -qq libxml2-utils | |
| echo "boogieVersion=`xmllint --xpath "//PackageReference[@Include='Boogie.ExecutionEngine']/@Version" dafny/Source/DafnyCore/DafnyCore.csproj | grep -Po 'Version="\K.*?(?=")'`" >> $GITHUB_ENV | |
| - name: Attempt custom Boogie patch | |
| working-directory: dafny | |
| run: git apply customBoogie.patch | |
| - name: Checkout Boogie | |
| uses: actions/checkout@v4 | |
| with: | |
| repository: boogie-org/boogie | |
| path: dafny/boogie | |
| ref: v${{ env.boogieVersion }} | |
| - name: Build Dafny with local Boogie | |
| working-directory: dafny | |
| run: dotnet build Source/Dafny.sln | |
| - name: Create NuGet package (just to make sure it works) | |
| run: dotnet pack dafny/Source/Dafny.sln | |
| - name: Check uniformity of integration tests that exercise backends | |
| run: DAFNY_INTEGRATION_TESTS_MODE=uniformity-check dotnet test dafny/Source/IntegrationTests | |
| xunit-tests: | |
| needs: check-deep-tests | |
| if: always() && (( github.event_name == 'pull_request' && (needs.check-deep-tests.result == 'success' || contains(github.event.pull_request.labels.*.name, 'run-deep-tests'))) || ( github.event_name == 'push' && ( github.ref_name == 'master' || vars.TEST_ON_FORK == 'true' ))) | |
| uses: ./.github/workflows/xunit-tests-reusable.yml | |
| integration-tests: | |
| needs: check-deep-tests | |
| if: always() && (( github.event_name == 'pull_request' && (needs.check-deep-tests.result == 'success' || contains(github.event.pull_request.labels.*.name, 'run-deep-tests') || contains(github.event.pull_request.labels.*.name, 'run-integration-tests'))) || ( github.event_name == 'push' && ( github.ref_name == 'master' || vars.TEST_ON_FORK == 'true' ))) | |
| uses: ./.github/workflows/integration-tests-reusable.yml | |
| with: | |
| ref: ${{ github.ref }} | |
| # By default run only on one platform, but run on all platforms if the PR has the "run-deep-tests" | |
| # label, and skip checking the nightly build above. | |
| # This is the best way to fix an issue in master that was only caught by the nightly build. | |
| all_platforms: ${{ contains(github.event.pull_request.labels.*.name, 'run-deep-tests') || contains(github.event.push.labels.*.name, 'run-deep-tests')}} | |
| num_shards: 5 | |
| # Omit Rust in the nightly build (or rather simulating it here) because Rust is known to have random issues | |
| compilers: ${{ (contains(github.event.pull_request.labels.*.name, 'run-deep-tests') || contains(github.event.push.labels.*.name, 'run-deep-tests')) && 'cs,java,go,js,cpp,dfy,py' || '' }} | |
| test-coverage-analysis: | |
| runs-on: ubuntu-20.04 | |
| # Don't include in run-deep-tests, because those tests run on | |
| # release builds instead of source packages. | |
| if: ${{ !contains(github.event.pull_request.labels.*.name, 'run-deep-tests') && !contains(github.event.push.labels.*.name, 'run-deep-tests')}})) | |
| needs: [xunit-tests, integration-tests] | |
| steps: | |
| # Check out Dafny so that highlighted source is possible | |
| - name: Checkout Dafny | |
| uses: actions/checkout@v4 | |
| with: | |
| path: dafny | |
| submodules: recursive | |
| - name: Setup dotnet | |
| uses: actions/setup-dotnet@v4 | |
| with: | |
| dotnet-version: ${{env.dotnet-version}} | |
| - name: Install dotnet-reportgenerator and coverage | |
| run: | | |
| dotnet tool install --global dotnet-reportgenerator-globaltool | |
| dotnet tool install --global dotnet-coverage | |
| - name: Install and run Coco | |
| run: | | |
| # Run coco to ensure that all source code is available. It's faster to do this alone than to rebuild everything. | |
| cd dafny | |
| dotnet tool restore | |
| dotnet tool run coco "Source/DafnyCore/Dafny.atg" -namespace Microsoft.Dafny -frames "Source/DafnyCore/Coco" | |
| - name: Download integration test artifacts | |
| uses: actions/download-artifact@v4 | |
| with: | |
| pattern: integration-test-results-ubuntu-20.04-* | |
| merge-multiple: true | |
| - name: Download unit test artifacts | |
| uses: actions/download-artifact@v4 | |
| with: | |
| name: unit-test-results-ubuntu-20.04 | |
| - name: Merge reports | |
| run: | | |
| # Convert the coverage data from the language server to Cobertura format | |
| dotnet coverage merge DafnyLanguageServer.Test.coverage -o DafnyLanguageServer.Test.Cobertura.xml -f cobertura | |
| # Generate a combined report, including xUnit results but not | |
| # LSP results | |
| reportgenerator \ | |
| -reports:"./**/coverage.cobertura.xml" \ | |
| -reporttypes:Cobertura -targetdir:coverage-cobertura \ | |
| -classfilters:"-Microsoft.Dafny.*PreType*;-Microsoft.Dafny.ResolverPass;-Microsoft.Dafny.*Underspecification*;-Microsoft.Dafny.DetectUnderspecificationVisitor;-Microsoft.Dafny.Microsoft.Dafny.UnderspecificationDetector;-Microsoft.Dafny.Compilers.DafnyCompiler;-DAST.*;-DCOMP.*" | |
| # Generate HTML from combined report, leaving out XUnitExtensions | |
| reportgenerator \ | |
| -reports:"coverage-cobertura/Cobertura.xml" \ | |
| -assemblyfilters:"-XUnitExtensions" \ | |
| -reporttypes:HTML -targetdir:coverage-html | |
| # Generate HTML from LSP report, including only LSP stuff | |
| reportgenerator \ | |
| -reports:"DafnyLanguageServer.Test.Cobertura.xml" \ | |
| -assemblyfilters:"+dafnylanguageserver" \ | |
| -reporttypes:HTML -targetdir:lsp-html | |
| # Generate new Cobertura from LSP report, including only LSP stuff | |
| reportgenerator \ | |
| -reports:"DafnyLanguageServer.Test.Cobertura.xml" \ | |
| -assemblyfilters:"+dafnylanguageserver" \ | |
| -reporttypes:Cobertura -targetdir:. | |
| mv Cobertura.xml coverage-cobertura/LSP-Cobertura.xml | |
| - name: Code coverage report (non-LSP) | |
| uses: irongut/[email protected] | |
| with: | |
| filename: ./coverage-cobertura/Cobertura.xml | |
| badge: true | |
| fail_below_min: true | |
| format: markdown | |
| hide_branch_rate: false | |
| hide_complexity: true | |
| indicators: true | |
| output: both | |
| # Fail if less than 86% total coverage, measured across all packages combined. | |
| # Report "yellow" status if less than 90% total coverage. | |
| thresholds: '85 90' | |
| - name: Code coverage report (LSP) | |
| uses: irongut/[email protected] | |
| with: | |
| filename: ./coverage-cobertura/LSP-Cobertura.xml | |
| badge: true | |
| fail_below_min: true | |
| format: markdown | |
| hide_branch_rate: false | |
| hide_complexity: true | |
| indicators: true | |
| output: both | |
| # Fail if less than 86% total coverage, measured across all packages combined. | |
| # Report "yellow" status if less than 90% total coverage. | |
| thresholds: '86 90' | |
| - uses: actions/upload-artifact@v4 | |
| if: always() # Upload results even if the job fails | |
| with: | |
| name: test-coverage-results | |
| path: | | |
| coverage-cobertura | |
| coverage-html | |
| lsp-html |