Skip to content

test(generators): cover domain events and sidecar#437

Merged
JerrettDavis merged 1 commit into
mainfrom
test/domain-events-sidecar-generator-coverage-413
May 30, 2026
Merged

test(generators): cover domain events and sidecar#437
JerrettDavis merged 1 commit into
mainfrom
test/domain-events-sidecar-generator-coverage-413

Conversation

@JerrettDavis

Copy link
Copy Markdown
Owner

Summary

  • add nested host wrapper generation for Domain Event Dispatcher and Sidecar source generators
  • expand TinyBDD generator coverage for invalid signatures, defaults, host shapes, escaped names, malformed type args, and nested hosts
  • make Domain Event generator tests compile generated output in addition to inspecting generated sources

Validation

  • dotnet test test\PatternKit.Generators.Tests\PatternKit.Generators.Tests.csproj --configuration Release --framework net10.0 --filter "FullyQualifiedNameDomainEventDispatcherGeneratorTests|FullyQualifiedNameSidecarGeneratorTests" --logger "console;verbosity=minimal"
  • dotnet test test\PatternKit.Generators.Tests\PatternKit.Generators.Tests.csproj --configuration Release -p:TestTfmsInParallel=false --collect:"XPlat Code Coverage" --results-directory .\TestResults --logger "console;verbosity=minimal" -- DataCollectionRunSettings.DataCollectors.DataCollector.Configuration.Format=cobertura
  • reportgenerator -reports:TestResults**\coverage.cobertura.xml -targetdir:coverage-report-generators -reporttypes:TextSummary
  • dotnet format PatternKit.slnx --verify-no-changes --verbosity minimal
  • dotnet test test\PatternKit.Generators.Tests\PatternKit.Generators.Tests.csproj --configuration Release --no-restore --no-build -p:TestTfmsInParallel=false --logger "console;verbosity=minimal"

Coverage

  • PatternKit.Generators: 96.2% local line coverage
  • DomainEventDispatcherGenerator: 99.2%
  • SidecarGenerator: 99.3%

Refs #413

Copilot AI review requested due to automatic review settings May 29, 2026 23:56
@github-actions

Copy link
Copy Markdown
Contributor

⚠️ Deprecation Warning: The deny-licenses option is deprecated for possible removal in the next major release. For more information, see issue 997.

Dependency Review

✅ No vulnerabilities or license issues or OpenSSF Scorecard issues found.

Scanned Files

None

Copilot AI left a comment

Copy link
Copy Markdown
Contributor

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

Pull request overview

This PR increases source-generator coverage (refs #413) by expanding TinyBDD scenarios for the Domain Event Dispatcher and Sidecar generators, and by validating that generated output compiles (EmitSuccess), including new nested-host wrapper generation paths.

Changes:

  • Add nested containing-type wrapper emission to the Sidecar and Domain Event Dispatcher generators.
  • Expand generator test matrices for invalid signatures/declarations, defaults, host shapes, escaped names, malformed type arguments, and nested hosts.
  • Update tests to emit/compile the post-generator compilation and assert EmitSuccess (in addition to source inspection).

Reviewed changes

Copilot reviewed 4 out of 4 changed files in this pull request and generated 2 comments.

File Description
src/PatternKit.Generators/Sidecar/SidecarGenerator.cs Generates nested containing-type wrappers when the sidecar host is nested.
src/PatternKit.Generators/DomainEvents/DomainEventDispatcherGenerator.cs Generates nested containing-type wrappers when the dispatcher host is nested.
test/PatternKit.Generators.Tests/SidecarGeneratorTests.cs Adds Theory-based invalid-case coverage + new scenarios for defaults/host shapes, nested wrappers, malformed type args; asserts emit success.
test/PatternKit.Generators.Tests/DomainEventDispatcherGeneratorTests.cs Expands invalid signature coverage + new scenarios for defaults/host shapes, nested wrappers, malformed type args; asserts emit success.

💡 Add Copilot custom instructions for smarter, more guided reviews. Learn how to get started.

Comment on lines +175 to +183
var containingTypes = GetContainingTypes(type);
var indentLevel = 0;
foreach (var containingType in containingTypes)
{
AppendTypeDeclaration(sb, containingType, indentLevel);
sb.AppendLine();
sb.AppendLine(new string(' ', indentLevel * 4) + "{");
indentLevel++;
}
Comment on lines 134 to +144

sb.Append(GetAccessibility(type.DeclaredAccessibility)).Append(' ');
if (type.IsStatic)
sb.Append("static ");
else if (type.IsAbstract && type.TypeKind == TypeKind.Class)
sb.Append("abstract ");
else if (type.IsSealed && type.TypeKind == TypeKind.Class)
sb.Append("sealed ");
sb.Append("partial ").Append(type.TypeKind == TypeKind.Struct ? "struct" : "class").Append(' ').Append(type.Name).AppendLine();
sb.AppendLine("{");
sb.Append(" public static global::PatternKit.Application.DomainEvents.DomainEventDispatcher<")
var containingTypes = GetContainingTypes(type);
var indentLevel = 0;
foreach (var containingType in containingTypes)
{
AppendTypeDeclaration(sb, containingType, indentLevel);
sb.AppendLine();
sb.AppendLine(new string(' ', indentLevel * 4) + "{");
indentLevel++;
}

@github-actions

Copy link
Copy Markdown
Contributor

Code Coverage

Summary
  Generated on: 05/30/2026 - 00:02:31
  Coverage date: 05/30/2026 - 00:00:36 - 05/30/2026 - 00:02:21
  Parser: MultiReport (12x Cobertura)
  Assemblies: 5
  Classes: 1616
  Files: 551
  Line coverage: 96.2%
  Covered lines: 42941
  Uncovered lines: 1686
  Coverable lines: 44627
  Total lines: 96155
  Branch coverage: 80.1% (13136 of 16381)
  Covered branches: 13136
  Total branches: 16381
  Method coverage: 96.6% (8407 of 8699)
  Full method coverage: 89.8% (7813 of 8699)
  Covered methods: 8407
  Fully covered methods: 7813
  Total methods: 8699

PatternKit.Core                                                                                                     95.4%
  PatternKit.Application.ActivityTracking.ActivityGateState                                                          100%
  PatternKit.Application.ActivityTracking.ActivityLease                                                              100%
  PatternKit.Application.ActivityTracking.ActivityRecord                                                             100%
  PatternKit.Application.ActivityTracking.ActivityTracker                                                            100%
  PatternKit.Application.Aggregates.AggregateCommandHandler<T1, T2, T3>                                              100%
  PatternKit.Application.Aggregates.AggregateCommandResult<T>                                                        100%
  PatternKit.Application.Aggregates.AggregateRoot<T1, T2>                                                            100%
  PatternKit.Application.AntiCorruption.AntiCorruptionLayer<T1, T2>                                                 90.4%
  PatternKit.Application.AntiCorruption.AntiCorruptionResult<T>                                                      100%
  PatternKit.Application.AuditLog.AuditLogAppendResult<T>                                                           85.7%
  PatternKit.Application.AuditLog.InMemoryAuditLog<T1, T2>                                                          95.4%
  PatternKit.Application.BoundedContexts.BoundedContextAdapter                                                       100%
  PatternKit.Application.BoundedContexts.BoundedContextCapability                                                   83.3%
  PatternKit.Application.BoundedContexts.BoundedContextDescriptor                                                   95.4%
  PatternKit.Application.ContextMaps.ContextMapDescriptor                                                           96.8%
  PatternKit.Application.ContextMaps.ContextMapRelationship                                                          100%
  PatternKit.Application.DataMapping.DataMapper<T1, T2>                                                             94.6%
  PatternKit.Application.DataMapping.DataMapperError                                                                  90%
  PatternKit.Application.DataMapping.DataMapperResult<T>                                                            84.6%
  PatternKit.Application.DomainEvents.DomainEventDispatcher<T>                                                      95.4%
  PatternKit.Application.DomainEvents.DomainEventDispatchResult                                                      100%
  PatternKit.Application.DomainServices.DomainServiceOperation<T1, T2>                                               100%
  PatternKit.Application.DomainServices.DomainServiceRegistry<T1, T2>                                                100%
  PatternKit.Application.EventSourcing.EventStoreAppendResult                                                        100%
  PatternKit.Application.EventSourcing.InMemoryEventStore<T1, T2>                                                   97.9%
  PatternKit.Application.EventSourcing.StoredEvent<T1, T2>                                                            80%
  PatternKit.Application.FeatureToggles.FeatureToggleDecision                                                       87.5%
  PatternKit.Application.FeatureToggles.FeatureToggleRule<T>                                                         100%
  PatternKit.Application.FeatureToggles.FeatureToggleSet<T>                                                         96.9%
  PatternKit.Application.IdentityMap.IdentityMap<T1, T2>                                                             100%
  PatternKit.Application.IdentityMap.IdentityMapResult<T>                                                           92.8%
  PatternKit.Application.MaterializedViews.MaterializedView<T1, T2>                                                 98.4%
  PatternKit.Application.Repository.InMemoryRepository<T1, T2>                                                      92.8%
  PatternKit.Application.Repository.RepositoryResult<T>                                                             93.3%
  PatternKit.Application.ServiceLayer.ServiceLayerOperation<T1, T2>                                                 96.7%
  PatternKit.Application.ServiceLayer.ServiceLayerResult<T>                                                         94.7%
  PatternKit.Application.ServiceLayer.ServiceLayerRule<T>                                                            100%
  PatternKit.Application.Specification.Specification<T>                                                              100%

@github-actions

Copy link
Copy Markdown
Contributor

Test Results

    12 files      12 suites   9m 23s ⏱️
 3 744 tests  3 744 ✅ 0 💤 0 ❌
11 513 runs  11 513 ✅ 0 💤 0 ❌

Results for commit b38ee70.

@codecov

codecov Bot commented May 30, 2026

Copy link
Copy Markdown

Codecov Report

✅ All modified and coverable lines are covered by tests.
✅ Project coverage is 96.44%. Comparing base (0265d44) to head (b38ee70).

Additional details and impacted files
@@            Coverage Diff             @@
##             main     #437      +/-   ##
==========================================
+ Coverage   90.86%   96.44%   +5.57%     
==========================================
  Files         551      551              
  Lines       44587    44627      +40     
  Branches     6420     6426       +6     
==========================================
+ Hits        40516    43042    +2526     
+ Misses       1707     1585     -122     
+ Partials     2364        0    -2364     
Flag Coverage Δ
unittests 96.44% <100.00%> (+5.57%) ⬆️

Flags with carried forward coverage won't be shown. Click here to find out more.

☔ View full report in Codecov by Sentry.
📢 Have feedback on the report? Share it here.

🚀 New features to boost your workflow:
  • ❄️ Test Analytics: Detect flaky tests, report on failures, and find test suite problems.

@github-actions

Copy link
Copy Markdown
Contributor

🔍 PR Validation Results

Version: ``

✅ Validation Steps

  • Build solution
  • Run tests
  • Build documentation
  • Dry-run NuGet packaging

📊 Artifacts

Dry-run artifacts have been uploaded and will be available for 7 days.


This comment was automatically generated by the PR validation workflow.

@JerrettDavis JerrettDavis merged commit 667db78 into main May 30, 2026
13 checks passed
@JerrettDavis JerrettDavis deleted the test/domain-events-sidecar-generator-coverage-413 branch May 30, 2026 00:08
Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment

Projects

None yet

Development

Successfully merging this pull request may close these issues.

2 participants