Skip to content

test: cover event store generator hosts#423

Merged
JerrettDavis merged 1 commit into
mainfrom
test/event-store-generator-coverage-413
May 29, 2026
Merged

test: cover event store generator hosts#423
JerrettDavis merged 1 commit into
mainfrom
test/event-store-generator-coverage-413

Conversation

@JerrettDavis

Copy link
Copy Markdown
Owner

Summary

  • add TinyBDD coverage for EventStore default store names, escaped names, abstract/sealed/internal/struct hosts, and malformed type arguments
  • fix nested event-store hosts by generating containing partial type wrappers instead of invalid top-level nested type declarations
  • add emit-validated nested host coverage for private/protected/private protected/protected internal event-store declarations
  • raise EventStoreGenerator source coverage from 81.8% to 98.8% in the generator-only report

Part of #413.

Validation

  • dotnet test test\PatternKit.Generators.Tests\PatternKit.Generators.Tests.csproj --configuration Release --framework net10.0 --filter "FullyQualifiedName~EventStoreGeneratorTests" --logger "console;verbosity=minimal"
  • dotnet test test\PatternKit.Generators.Tests\PatternKit.Generators.Tests.csproj --configuration Release --no-restore -p:TestTfmsInParallel=false --collect:"XPlat Code Coverage" --results-directory .\TestResults --logger "console;verbosity=minimal" -- DataCollectionRunSettings.DataCollectors.DataCollector.Configuration.Format=cobertura
  • dotnet tool run reportgenerator -reports:"TestResults*\coverage.cobertura.xml" -targetdir:"coverage-report-generators" -reporttypes:"TextSummary;Cobertura" -assemblyfilters:"+PatternKit.Generators" -filefilters:"-**/.Tests/;-/Tests/;-/obj/;-/bin/;-**/.g.cs"
  • 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"

Copilot AI review requested due to automatic review settings May 29, 2026 13:02
@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

Adds TinyBDD test coverage for the EventStore source generator and fixes nested host emission to wrap generated types in their containing partial type declarations rather than emitting invalid top-level nested types. This raises generator-only source coverage from 81.8% to 98.8%, contributing to issue #413.

Changes:

  • Extracted type-declaration emission into helper methods and added containing-type wrapper generation with proper indentation.
  • Added scenarios covering default store names, escaped names, abstract/sealed/internal/struct hosts, and malformed type arguments.
  • Added an emit-validated scenario for nested hosts with private/protected/private protected/protected internal accessibilities.

Reviewed changes

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

File Description
src/PatternKit.Generators/EventSourcing/EventStoreGenerator.cs Emit containing partial type wrappers around nested event store hosts with indentation tracking.
test/PatternKit.Generators.Tests/EventStoreGeneratorTests.cs New scenarios for defaults, host shapes, malformed args, and emit-verified nested hosts; adds CompileWithUpdated helper.

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

@github-actions

Copy link
Copy Markdown
Contributor

Test Results

    12 files      12 suites   9m 32s ⏱️
 3 620 tests  3 620 ✅ 0 💤 0 ❌
10 871 runs  10 871 ✅ 0 💤 0 ❌

Results for commit c142688.

@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.

@codecov

codecov Bot commented May 29, 2026

Copy link
Copy Markdown

Codecov Report

✅ All modified and coverable lines are covered by tests.
✅ Project coverage is 95.95%. Comparing base (72eb778) to head (c142688).

Additional details and impacted files
@@            Coverage Diff             @@
##             main     #423      +/-   ##
==========================================
+ Coverage   89.99%   95.95%   +5.96%     
==========================================
  Files         551      551              
  Lines       44186    44205      +19     
  Branches     6358     6361       +3     
==========================================
+ Hits        39765    42417    +2652     
+ Misses       1934     1788     -146     
+ Partials     2487        0    -2487     
Flag Coverage Δ
unittests 95.95% <100.00%> (+5.96%) ⬆️

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

Code Coverage

Summary
  Generated on: 05/29/2026 - 13:10:48
  Coverage date: 05/29/2026 - 13:08:22 - 05/29/2026 - 13:10:35
  Parser: MultiReport (12x Cobertura)
  Assemblies: 5
  Classes: 1616
  Files: 551
  Line coverage: 95.6%
  Covered lines: 42279
  Uncovered lines: 1926
  Coverable lines: 44205
  Total lines: 95420
  Branch coverage: 77.3% (12556 of 16231)
  Covered branches: 12556
  Total branches: 16231
  Method coverage: 96.4% (8354 of 8660)
  Full method coverage: 89.1% (7723 of 8660)
  Covered methods: 8354
  Fully covered methods: 7723
  Total methods: 8660

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%

@JerrettDavis JerrettDavis merged commit ba737fb into main May 29, 2026
13 checks passed
@JerrettDavis JerrettDavis deleted the test/event-store-generator-coverage-413 branch May 29, 2026 13:15
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