Skip to content

test: cover repository generator hosts#432

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

test: cover repository generator hosts#432
JerrettDavis merged 1 commit into
mainfrom
test/repository-generator-coverage-413

Conversation

@JerrettDavis

Copy link
Copy Markdown
Owner

Summary

  • emit containing partial type wrappers for nested repository generator hosts
  • convert repository generator coverage to TinyBDD xUnit scenarios
  • cover invalid selector branches, malformed type arguments, host shape preservation, and emitted compilation

Validation

  • dotnet test test/PatternKit.Generators.Tests/PatternKit.Generators.Tests.csproj --configuration Release --framework net10.0 --filter "FullyQualifiedName~RepositoryGeneratorTests" --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: RepositoryGenerator 99.1%; PatternKit.Generators 95.6% locally.

@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

Expands the repository source generator to support nested host types by emitting wrapping partial declarations, and rewrites the generator test suite as TinyBDD scenarios that cover more invalid-input branches plus host-shape and emission-success assertions.

Changes:

  • Emit containing-type partial wrappers (with indentation and accessibility) so [GenerateRepository] works on nested types.
  • Refactor GenerateSource to share an AppendTypeDeclaration helper between the host type and its containers.
  • Convert RepositoryGeneratorTests to TinyBDD [Scenario] tests covering invalid selectors, malformed typeof arguments, default factory names, host shapes (abstract/sealed/struct), and nested hosts; add a shared Compile helper and GeneratorResult record that also verifies emit success.

Reviewed changes

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

File Description
src/PatternKit.Generators/Repository/RepositoryGenerator.cs Emit containing-type wrappers and refactor type-declaration emission into a helper with indentation support.
test/PatternKit.Generators.Tests/RepositoryGeneratorTests.cs Rewrite tests as TinyBDD scenarios; broaden coverage to nested hosts, varied host shapes, malformed attribute args, and emission success.

💡 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 53s ⏱️
 3 670 tests  3 670 ✅ 0 💤 0 ❌
11 078 runs  11 078 ✅ 0 💤 0 ❌

Results for commit 6a1814b.

@github-actions

Copy link
Copy Markdown
Contributor

Code Coverage

Summary
  Generated on: 05/29/2026 - 20:21:31
  Coverage date: 05/29/2026 - 20:19:06 - 05/29/2026 - 20:21:18
  Parser: MultiReport (12x Cobertura)
  Assemblies: 5
  Classes: 1616
  Files: 551
  Line coverage: 95.8%
  Covered lines: 42559
  Uncovered lines: 1833
  Coverable lines: 44392
  Total lines: 95750
  Branch coverage: 78.5% (12794 of 16287)
  Covered branches: 12794
  Total branches: 16287
  Method coverage: 96.4% (8372 of 8678)
  Full method coverage: 89.3% (7757 of 8678)
  Covered methods: 8372
  Fully covered methods: 7757
  Total methods: 8678

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

🔍 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 96.14%. Comparing base (2014641) to head (6a1814b).

Additional details and impacted files
@@            Coverage Diff             @@
##             main     #432      +/-   ##
==========================================
+ Coverage   90.36%   96.14%   +5.77%     
==========================================
  Files         551      551              
  Lines       44372    44392      +20     
  Branches     6385     6388       +3     
==========================================
+ Hits        40097    42680    +2583     
+ Misses       1836     1712     -124     
+ Partials     2439        0    -2439     
Flag Coverage Δ
unittests 96.14% <100.00%> (+5.77%) ⬆️

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.

@JerrettDavis JerrettDavis merged commit a3fe0b9 into main May 29, 2026
13 checks passed
@JerrettDavis JerrettDavis deleted the test/repository-generator-coverage-413 branch May 29, 2026 20:27
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