Skip to content

test: harden generator edge coverage#465

Merged
JerrettDavis merged 1 commit into
mainfrom
coverage/harden-generator-gaps-413
May 31, 2026
Merged

test: harden generator edge coverage#465
JerrettDavis merged 1 commit into
mainfrom
coverage/harden-generator-gaps-413

Conversation

@JerrettDavis

Copy link
Copy Markdown
Owner

Refs #413.

Summary

  • hardens generator coverage for builder, composer, decorator, and proxy edge cases
  • fixes decorator default literal generation for float/double/decimal values
  • fixes state-projection builder helper generation for ValueTask<T> projectors so helpers do not return nested ValueTask<ValueTask<T>>

Validation

  • dotnet test test\PatternKit.Generators.Tests\PatternKit.Generators.Tests.csproj --configuration Release -p:TestTfmsInParallel=false --filter "FullyQualifiedName~ProxyGeneratorTests|FullyQualifiedName~DecoratorGeneratorTests|FullyQualifiedName~ComposerGeneratorTests|FullyQualifiedName~BuilderGeneratorTests"
  • dotnet test test\PatternKit.Generators.Tests\PatternKit.Generators.Tests.csproj --configuration Release -p:TestTfmsInParallel=false --collect:"XPlat Code Coverage" --results-directory TestResults-generators-current -- DataCollectionRunSettings.DataCollectors.DataCollector.Configuration.Format=cobertura
  • PatternKit.Generators coverage: 97.27%

Copilot AI review requested due to automatic review settings May 31, 2026 02:08
@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 strengthens PatternKit’s source-generator test coverage (per #413) and fixes two generator edge-case emissions: default literal formatting in DecoratorGenerator and ValueTask<T> projector helper signatures in BuilderGenerator (avoiding nested ValueTask<ValueTask<T>>).

Changes:

  • Added TinyBDD scenarios covering additional generator diagnostics/emission branches for Proxy, Decorator, Composer, and Builder generators.
  • Updated DecoratorGenerator.FormatDefaultValue to preserve float/double/decimal default literals (with suffixes) in generated signatures.
  • Updated BuilderGenerator state-projection builder-method helper emission so ValueTask<T> projectors don’t produce nested ValueTask return types; simplified IsValueTask detection.

Reviewed changes

Copilot reviewed 6 out of 6 changed files in this pull request and generated 1 comment.

Show a summary per file
File Description
test/PatternKit.Generators.Tests/ProxyGeneratorTests.cs Adds coverage for string/numeric/char default literal formatting branches in proxy generation.
test/PatternKit.Generators.Tests/DecoratorGeneratorTests.cs Adds coverage asserting decorator generation preserves primitive/string/enum-cast default literals.
test/PatternKit.Generators.Tests/ComposerGeneratorTests.cs Adds a diagnostic scenario for invalid step “next” parameter type.
test/PatternKit.Generators.Tests/BuilderGeneratorTests.cs Adds diagnostic coverage and a regression test for ValueTask<T> projector build helper paths.
src/PatternKit.Generators/DecoratorGenerator.cs Adjusts default literal formatting for float/double/decimal optional parameters.
src/PatternKit.Generators/Builders/BuilderGenerator.cs Fixes async helper return types for ValueTask<T> projectors and updates IsValueTask detection.

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

Comment on lines +663 to +671
var value = param.ExplicitDefaultValue;
return value switch
{
float f => f.ToString(System.Globalization.CultureInfo.InvariantCulture) + "f",
double d => d.ToString(System.Globalization.CultureInfo.InvariantCulture) + "d",
decimal m => m.ToString(System.Globalization.CultureInfo.InvariantCulture) + "m",
_ => Microsoft.CodeAnalysis.CSharp.SymbolDisplay.FormatPrimitive(value, quoteStrings: true, useHexadecimalNumbers: false)
?? "default"
};
@github-actions

Copy link
Copy Markdown
Contributor

Code Coverage

Summary
  Generated on: 05/31/2026 - 02:14:42
  Coverage date: 05/31/2026 - 02:12:30 - 05/31/2026 - 02:14:32
  Parser: MultiReport (12x Cobertura)
  Assemblies: 5
  Classes: 1715
  Files: 579
  Line coverage: 96.9%
  Covered lines: 45734
  Uncovered lines: 1422
  Coverable lines: 47156
  Total lines: 100708
  Branch coverage: 82.7% (14264 of 17240)
  Covered branches: 14264
  Total branches: 17240
  Method coverage: 97.2% (8966 of 9223)
  Full method coverage: 91.1% (8411 of 9223)
  Covered methods: 8966
  Fully covered methods: 8411
  Total methods: 9223

PatternKit.Core                                                                                                       96%
  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.EventualConsistency.EventualConsistencyEvaluation<T>                                       92.3%
  PatternKit.Application.EventualConsistency.EventualConsistencyMonitor<T>                                          97.2%
  PatternKit.Application.EventualConsistency.EventualConsistencyMonitorState<T>                                      100%
  PatternKit.Application.EventualConsistency.EventualConsistencyWatermarks<T>                                       96.7%
  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.ManualTaskGates.ManualTaskGate<T>                                                          98.5%
  PatternKit.Application.ManualTaskGates.ManualTaskGateState<T>                                                      100%
  PatternKit.Application.ManualTaskGates.ManualTaskRecord<T>                                                        96.9%

@codecov

codecov Bot commented May 31, 2026

Copy link
Copy Markdown

Codecov Report

✅ All modified and coverable lines are covered by tests.
✅ Project coverage is 97.11%. Comparing base (081cdd1) to head (1032d61).

Additional details and impacted files
@@            Coverage Diff             @@
##             main     #465      +/-   ##
==========================================
+ Coverage   96.95%   97.11%   +0.16%     
==========================================
  Files         579      579              
  Lines       47147    47156       +9     
  Branches     3095     6210    +3115     
==========================================
+ Hits        45711    45796      +85     
+ Misses       1436     1360      -76     
Flag Coverage Δ
unittests 97.11% <100.00%> (+0.16%) ⬆️

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

Test Results

    12 files      12 suites   12m 8s ⏱️
 3 971 tests  3 971 ✅ 0 💤 0 ❌
12 344 runs  12 344 ✅ 0 💤 0 ❌

Results for commit 1032d61.

@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 063490e into main May 31, 2026
13 checks passed
@JerrettDavis JerrettDavis deleted the coverage/harden-generator-gaps-413 branch May 31, 2026 02:22
Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment

Labels

Projects

None yet

Development

Successfully merging this pull request may close these issues.

2 participants