# yaml-language-server: $schema=https://raw.githubusercontent.com/SchemaStore/schemastore/master/src/schemas/json/github-workflow.json name: .NET on: push: branches: [ main ] pull_request: branches: [ main ] env: DOTNET_NOLOGO: true DOTNET_CLI_TELEMETRY_OPTOUT: true DOTNET_SKIP_FIRST_TIME_EXPERIENCE: true NUGET_XMLDOC_MODE: '' DOTNET_MULTILEVEL_LOOKUP: 0 jobs: build: strategy: matrix: config: - Release - Debug runs-on: ubuntu-latest steps: - uses: actions/checkout@v4 with: fetch-depth: 0 # so that NerdBank.GitVersioning has access to history - name: Install Nix uses: cachix/install-nix-action@V27 with: extra_nix_config: | access-tokens = github.com=${{ secrets.GITHUB_TOKEN }} - name: Restore dependencies run: nix develop --command dotnet restore - name: Build run: 'nix develop --command dotnet build --no-restore --configuration ${{matrix.config}}' - name: Test run: 'nix develop --command dotnet test --no-build --verbosity normal --configuration ${{matrix.config}}' selftest: strategy: matrix: config: - Release - Debug runs-on: ubuntu-latest steps: - uses: actions/checkout@v4 with: fetch-depth: 0 # so that NerdBank.GitVersioning has access to history - name: Install Nix uses: cachix/install-nix-action@V27 with: extra_nix_config: | access-tokens = github.com=${{ secrets.GITHUB_TOKEN }} - name: Restore dependencies run: nix develop --command dotnet restore - name: Build run: 'nix develop --command dotnet build --no-restore --configuration ${{matrix.config}}' - name: Test using self run: 'nix develop --command dotnet exec ./TestRunner/bin/${{matrix.config}}/net8.0/TestRunner.dll ./Consumer/bin/${{matrix.config}}/net8.0/Consumer.dll' analyzers: runs-on: ubuntu-latest permissions: security-events: write steps: - name: Checkout uses: actions/checkout@v4 with: fetch-depth: 0 # so that NerdBank.GitVersioning has access to history - name: Install Nix uses: cachix/install-nix-action@V27 with: extra_nix_config: | access-tokens = github.com=${{ secrets.GITHUB_TOKEN }} - name: Prepare analyzers run: nix develop --command dotnet restore analyzers/analyzers.fsproj - name: Build project run: nix develop --command dotnet build ./TestRunner/TestRunner.fsproj - name: Run analyzers run: nix run .#fsharp-analyzers -- --project ./TestRunner/TestRunner.fsproj --analyzers-path ./.analyzerpackages/g-research.fsharp.analyzers/*/ --verbosity detailed --report ./analysis.sarif --treat-as-error GRA-STRING-001 GRA-STRING-002 GRA-STRING-003 GRA-UNIONCASE-001 GRA-INTERPOLATED-001 GRA-TYPE-ANNOTATE-001 GRA-VIRTUALCALL-001 GRA-IMMUTABLECOLLECTIONEQUALITY-001 GRA-JSONOPTS-001 GRA-LOGARGFUNCFULLAPP-001 GRA-DISPBEFOREASYNC-001 --exclude-analyzers PartialAppAnalyzer build-nix: runs-on: ubuntu-latest steps: - name: Checkout uses: actions/checkout@v4 - name: Install Nix uses: cachix/install-nix-action@V27 with: extra_nix_config: | access-tokens = github.com=${{ secrets.GITHUB_TOKEN }} - name: Build run: nix build check-dotnet-format: runs-on: ubuntu-latest steps: - name: Checkout uses: actions/checkout@v4 - name: Install Nix uses: cachix/install-nix-action@V27 with: extra_nix_config: | access-tokens = github.com=${{ secrets.GITHUB_TOKEN }} - name: Run Fantomas run: nix run .#fantomas -- --check . check-nix-format: runs-on: ubuntu-latest steps: - name: Checkout uses: actions/checkout@v4 - name: Install Nix uses: cachix/install-nix-action@V27 with: extra_nix_config: | access-tokens = github.com=${{ secrets.GITHUB_TOKEN }} - name: Run Alejandra run: nix develop --command alejandra --check . linkcheck: name: Check links runs-on: ubuntu-latest steps: - uses: actions/checkout@master - name: Install Nix uses: cachix/install-nix-action@V27 with: extra_nix_config: | access-tokens = github.com=${{ secrets.GITHUB_TOKEN }} - name: Run link checker run: nix develop --command markdown-link-check README.md flake-check: name: Check flake runs-on: ubuntu-latest steps: - uses: actions/checkout@master - name: Install Nix uses: cachix/install-nix-action@V27 with: extra_nix_config: | access-tokens = github.com=${{ secrets.GITHUB_TOKEN }} - name: Flake check run: nix flake check all-required-checks-complete: needs: [check-dotnet-format, check-nix-format, build, build-nix, linkcheck, flake-check, analyzers] runs-on: ubuntu-latest steps: - run: echo "All required checks complete."