Fix Z.DynamicLinq.SystemTextJson when property is null #1248
Workflow file for this run
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 with Tests | |
| on: | |
| push: | |
| workflow_dispatch: | |
| pull_request: | |
| types: [opened, edited] | |
| jobs: | |
| build_and_test_Windows: | |
| name: "Windows: Build and Tests" | |
| runs-on: windows-latest | |
| env: | |
| IsRunningOnGitHubActions: 'true' | |
| UseInMemory: 'true' | |
| steps: | |
| - uses: actions/checkout@v4 | |
| with: | |
| fetch-depth: 0 | |
| - uses: actions/setup-dotnet@v4 | |
| with: | |
| dotnet-version: '10.0.x' | |
| - name: Build | |
| run: | | |
| dotnet build ./src/System.Linq.Dynamic.Core/System.Linq.Dynamic.Core.csproj -c Release -p:buildType=azure-pipelines-ci | |
| - name: Run Tests EFCore net10.0 | |
| run: | | |
| dotnet test ./test/System.Linq.Dynamic.Core.Tests/System.Linq.Dynamic.Core.Tests.csproj -c Release -p:buildType=azure-pipelines-ci | |
| build_and_test_Linux: | |
| name: "Linux: Build and Tests" | |
| runs-on: ubuntu-latest | |
| env: | |
| IsRunningOnGitHubActions: 'true' | |
| BranchName: ${{ github.head_ref || github.ref_name }} | |
| steps: | |
| - uses: actions/checkout@v4 | |
| - uses: actions/setup-dotnet@v4 | |
| with: | |
| dotnet-version: '9.0.x' | |
| - uses: actions/setup-java@v4 | |
| with: | |
| distribution: 'temurin' # See 'Supported distributions' for available options | |
| java-version: '17' | |
| - name: Install dotnet tools | |
| run: | | |
| dotnet tool install --global dotnet-sonarscanner | |
| dotnet tool install --global dotnet-coverage | |
| - name: Check if analysis on SonarCloud is possible | |
| id: secret-check | |
| # perform secret check & put boolean result as an output | |
| shell: bash | |
| run: | | |
| if [ "${{ secrets.SONAR_TOKEN }}" != '' ]; then | |
| echo "run_analysis=true" >> $GITHUB_OUTPUT; | |
| else | |
| echo "run_analysis=false" >> $GITHUB_OUTPUT; | |
| fi | |
| - name: Begin analysis on SonarCloud | |
| if: ${{ steps.secret-check.outputs.run_analysis == 'true' }} | |
| run: | | |
| dotnet sonarscanner begin /k:"zzzprojects_System.Linq.Dynamic.Core" /o:"zzzprojects" /d:sonar.branch.name=$BranchName /d:sonar.host.url="https://sonarcloud.io" /d:sonar.token=${{ secrets.SONAR_TOKEN }} /d:sonar.pullrequest.provider=github /d:sonar.dotnet.excludeTestProjects=true /d:sonar.cs.vscoveragexml.reportsPaths=**/dynamic-coverage-*.xml /d:sonar.verbose=true | |
| - name: Build | |
| run: | | |
| dotnet build ./src/System.Linq.Dynamic.Core/System.Linq.Dynamic.Core.csproj -c Debug -p:buildType=azure-pipelines-ci | |
| - name: Run Tests EFCore .NET 10 (with Coverage) | |
| run: | | |
| dotnet-coverage collect 'dotnet test ./test/System.Linq.Dynamic.Core.Tests/System.Linq.Dynamic.Core.Tests.csproj --configuration Debug -p:buildType=azure-pipelines-ci' -f xml -o dynamic-coverage-efcore.xml | |
| - name: Run Tests EF .NET 10 (with Coverage) | |
| run: | | |
| dotnet-coverage collect 'dotnet test ./test/EntityFramework.DynamicLinq.Tests/EntityFramework.DynamicLinq.Tests.csproj --configuration Debug --framework net10.0 -p:buildType=azure-pipelines-ci' -f xml -o dynamic-coverage-ef.xml | |
| - name: Run Tests Newtonsoft.Json .NET 10 (with Coverage) | |
| run: | | |
| dotnet-coverage collect 'dotnet test ./test/System.Linq.Dynamic.Core.NewtonsoftJson.Tests/System.Linq.Dynamic.Core.NewtonsoftJson.Tests.csproj --configuration Debug --framework net10.0 -p:buildType=azure-pipelines-ci' -f xml -o dynamic-coverage-newtonsoftjson.xml | |
| - name: Run Tests System.Text.Json .NET 10 (with Coverage) | |
| run: | | |
| dotnet-coverage collect 'dotnet test ./test/System.Linq.Dynamic.Core.SystemTextJson.Tests/System.Linq.Dynamic.Core.SystemTextJson.Tests.csproj --configuration Debug --framework net10.0 -p:buildType=azure-pipelines-ci' -f xml -o dynamic-coverage-systemtextjson.xml | |
| - name: End analysis on SonarCloud | |
| if: ${{ steps.secret-check.outputs.run_analysis == 'true' }} | |
| run: | | |
| dotnet sonarscanner end /d:sonar.token=${{ secrets.SONAR_TOKEN }} |