PQSoft.JsonComparer.AwesomeAssertions
                              
                            
                                1.0.0-alpha3
                            
                        
                    See the version list below for details.
dotnet add package PQSoft.JsonComparer.AwesomeAssertions --version 1.0.0-alpha3
NuGet\Install-Package PQSoft.JsonComparer.AwesomeAssertions -Version 1.0.0-alpha3
<PackageReference Include="PQSoft.JsonComparer.AwesomeAssertions" Version="1.0.0-alpha3" />
<PackageVersion Include="PQSoft.JsonComparer.AwesomeAssertions" Version="1.0.0-alpha3" />
<PackageReference Include="PQSoft.JsonComparer.AwesomeAssertions" />
paket add PQSoft.JsonComparer.AwesomeAssertions --version 1.0.0-alpha3
#r "nuget: PQSoft.JsonComparer.AwesomeAssertions, 1.0.0-alpha3"
#:package PQSoft.JsonComparer.AwesomeAssertions@1.0.0-alpha3
#addin nuget:?package=PQSoft.JsonComparer.AwesomeAssertions&version=1.0.0-alpha3&prerelease
#tool nuget:?package=PQSoft.JsonComparer.AwesomeAssertions&version=1.0.0-alpha3&prerelease
PQSoft Open Source
A repository for Open Source packages for API Test Engineering
Packages
PQSoft.HttpFile
A library for parsing HTTP request and response files, similar to Microsoft's VS Code .http files. It provides functionality to:
- Parse HTTP requests with method, URL, headers, and body
- Parse HTTP responses with status code, headers, and body
- Handle HTTP headers with parameters
- Semantically compare parsed headers for testing purposes
This package is particularly useful for API testing scenarios where you need to parse and validate HTTP traffic.
PQSoft.JsonComparer
A powerful library for comparing JSON documents with advanced features:
- Exact Match: Validates that two JSON documents are identical (except for tokens)
- Subset Match: Verifies that all elements in the expected JSON exist within the actual JSON
- Token Support: Extract values from actual JSON using tokens like [[TOKEN_NAME]]
- Function Execution: Execute functions like {{GUID()}},{{NOW()}}, and{{UTCNOW()}}during comparison
- Variable Substitution: Substitute variables from provided context during preprocessing
- Detailed Mismatch Reporting: Provides structured information on any differences found
- Custom Function Registration: Extend functionality with custom functions
Example:
string expectedJson = """{ "id": "[[JOBID]]", "createdAt": "{{NOW()}}", "status": "complete" }""";
string actualJson = """{ "id": "12345", "createdAt": "2024-01-01T10:00:00.000+00:00", "status": "complete" }""";
bool isMatch = JsonComparer.ExactMatch(expectedJson, actualJson, out var extractedValues, out var mismatches);
// isMatch = true
// extractedValues["JOBID"] = "12345"
PQSoft.JsonComparer.AwesomeAssertions
FluentAssertions extensions for JSON comparison that integrate seamlessly with the JsonComparer functionality:
- Provides a fluent API for JSON assertions
- Works with the token extraction features of JsonComparer
- Supports both exact match and subset match assertions
- Integrates with FluentAssertions failure reporting
Example:
string actualJson = """{ "id": "12345", "createdAt": "2024-01-01T10:00:00.000+00:00", "status": "complete" }""";
string expectedJson = """{ "id": "[[JOBID]]", "createdAt": "{{NOW()}}", "status": "complete" }""";
actualJson.AsJsonString().Should().FullyMatch(expectedJson);
// Extracted values are available in the assertion result
Installation
Install packages from NuGet:
# HTTP file parsing
dotnet add package PQSoft.HttpFile
# JSON comparison
dotnet add package PQSoft.JsonComparer
# JSON comparison with FluentAssertions
dotnet add package PQSoft.JsonComparer.AwesomeAssertions
Building and Publishing
Prerequisites
- NuGet API Key: Create an API key at nuget.org/account/apikeys
- Environment Variable: Set your API key as an environment variable:
export NUGET_API_KEY="your-api-key-here"
Version Management
All packages use centralized versioning in Directory.Build.props. To update the version:
- Edit Directory.Build.props: - <Version>1.0.1</Version>
- Or override during build: - ./build-nuget.sh 1.0.1
Building and Publishing
Use the automated build script:
# Build and publish all packages with version 1.0.1
./build-nuget.sh 1.0.1
The script will:
- Validate version parameter and API key
- Clean and build the solution
- Pack all packages with the specified version
- Upload packages to NuGet.org in dependency order
Manual Building
For development or testing:
# Build solution
dotnet build --configuration Release
# Pack individual packages
dotnet pack src/PQSoft.HttpFile/PQSoft.HttpFile.csproj --configuration Release -p:Version=1.0.1
dotnet pack src/PQSoft.JsonComparer/PQSoft.JsonComparer.csproj --configuration Release -p:Version=1.0.1
dotnet pack src/PQSoft.JsonComparer.AwesomeAssertions/PQSoft.JsonComparer.AwesomeAssertions.csproj --configuration Release -p:Version=1.0.1
# Push to NuGet (in dependency order)
dotnet nuget push "src/PQSoft.HttpFile/bin/Release/PQSoft.HttpFile.1.0.1.nupkg" --api-key $NUGET_API_KEY --source https://api.nuget.org/v3/index.json
dotnet nuget push "src/PQSoft.JsonComparer/bin/Release/PQSoft.JsonComparer.1.0.1.nupkg" --api-key $NUGET_API_KEY --source https://api.nuget.org/v3/index.json
dotnet nuget push "src/PQSoft.JsonComparer.AwesomeAssertions/bin/Release/PQSoft.JsonComparer.AwesomeAssertions.1.0.1.nupkg" --api-key $NUGET_API_KEY --source https://api.nuget.org/v3/index.json
Package Dependencies
- PQSoft.HttpFile: No external dependencies
- PQSoft.JsonComparer: Depends on System.Text.Json
- PQSoft.JsonComparer.AwesomeAssertions: Depends on PQSoft.JsonComparer and AwesomeAssertions
Packages must be uploaded in dependency order to ensure successful publication.
Support Projects
PQSoft.HttpFile.UnitTests PQSoft.JsonComparer.UnitTests PQSoft.JsonComparer.AwesomeAssertions.UnitTests
| Product | Versions Compatible and additional computed target framework versions. | 
|---|---|
| .NET | net8.0 is compatible. net8.0-android was computed. net8.0-browser was computed. net8.0-ios was computed. net8.0-maccatalyst was computed. net8.0-macos was computed. net8.0-tvos was computed. net8.0-windows was computed. net9.0 was computed. net9.0-android was computed. net9.0-browser was computed. net9.0-ios was computed. net9.0-maccatalyst was computed. net9.0-macos was computed. net9.0-tvos was computed. net9.0-windows was computed. net10.0 was computed. net10.0-android was computed. net10.0-browser was computed. net10.0-ios was computed. net10.0-maccatalyst was computed. net10.0-macos was computed. net10.0-tvos was computed. net10.0-windows was computed. | 
- 
                                                    net8.0- AwesomeAssertions (>= 9.0.0)
- PQSoft.JsonComparer (>= 1.0.0-alpha3)
 
NuGet packages (1)
Showing the top 1 NuGet packages that depend on PQSoft.JsonComparer.AwesomeAssertions:
| Package | Downloads | 
|---|---|
| PQSoft.ReqNRoll Reqnroll step definitions for API testing with PQSoft.HttpFile and PQSoft.JsonComparer | 
GitHub repositories
This package is not used by any popular GitHub repositories.
| Version | Downloads | Last Updated | 
|---|---|---|
| 1.2.0-beta.4 | 98 | 10/22/2025 | 
| 1.2.0-beta.3 | 98 | 10/22/2025 | 
| 1.2.0-beta.2 | 96 | 10/22/2025 | 
| 1.2.0-beta.1 | 96 | 10/22/2025 | 
| 1.1.0-beta.3 | 151 | 9/20/2025 | 
| 1.1.0-beta.2 | 165 | 9/19/2025 | 
| 1.1.0-beta.1 | 171 | 9/19/2025 | 
| 1.0.0-beta.6 | 233 | 9/19/2025 | 
| 1.0.0-beta.5 | 229 | 9/19/2025 | 
| 1.0.0-beta.4 | 226 | 9/19/2025 | 
| 1.0.0-beta.3 | 227 | 9/19/2025 | 
| 1.0.0-beta.2 | 230 | 9/19/2025 | 
| 1.0.0-beta.1 | 242 | 9/19/2025 | 
| 1.0.0-alpha9 | 243 | 9/18/2025 | 
| 1.0.0-alpha8 | 246 | 9/18/2025 | 
| 1.0.0-alpha7 | 251 | 9/17/2025 | 
| 1.0.0-alpha5 | 248 | 9/16/2025 | 
| 1.0.0-alpha4 | 255 | 9/16/2025 | 
| 1.0.0-alpha3 | 252 | 9/16/2025 | 
| 1.0.0-alpha2 | 253 | 9/16/2025 | 
| 1.0.0-alpha11 | 245 | 9/19/2025 | 
| 1.0.0-alpha10 | 244 | 9/18/2025 | 
| 1.0.0-alpha1 | 199 | 9/15/2025 |