Skip to content

test(generators): cover bulkhead and rate limiting#444

Merged
JerrettDavis merged 1 commit into
mainfrom
test/rate-limit-bulkhead-coverage-413
May 30, 2026
Merged

test(generators): cover bulkhead and rate limiting#444
JerrettDavis merged 1 commit into
mainfrom
test/rate-limit-bulkhead-coverage-413

Conversation

@JerrettDavis

Copy link
Copy Markdown
Owner

Summary

  • harden Bulkhead Policy and Rate Limit Policy generation for nested/typed host shapes
  • convert both generator test files onto TinyBDD xUnit scenario chains
  • expand diagnostics, defaults, escaped names, malformed result type, and nested host coverage

Validation

  • 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"
  • local coverage pass: PatternKit.Generators 97.1%, BulkheadPolicyGenerator 99.1%, RateLimitPolicyGenerator 99.0%

Refs #413

@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 expands generator test coverage and hardens the Bulkhead and Rate Limit policy source generators, primarily around nested host type shapes and additional diagnostics/default behaviors (in support of #413’s generator coverage goals).

Changes:

  • Convert Bulkhead/Rate Limit generator tests to TinyBDD xUnit scenario chains and add coverage for more host shapes (nested/accessibility variants), defaults, and malformed inputs.
  • Update BulkheadPolicyGenerator and RateLimitPolicyGenerator emission to wrap generated members inside containing types (nested type support).
  • Expand diagnostic coverage for invalid configurations and non-partial hosts.

Reviewed changes

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

File Description
test/PatternKit.Generators.Tests/RateLimitPolicyGeneratorTests.cs Converts to TinyBDD.Xunit base + adds scenarios for defaults, nested hosts, invalid configs, and malformed result type.
test/PatternKit.Generators.Tests/BulkheadPolicyGeneratorTests.cs Same test structure conversion and coverage expansion for bulkhead generation branches.
src/PatternKit.Generators/RateLimiting/RateLimitPolicyGenerator.cs Adds nested containing-type wrapper emission for generated factory method.
src/PatternKit.Generators/Bulkhead/BulkheadPolicyGenerator.cs Adds nested containing-type wrapper emission for generated factory method.

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

Comment on lines +145 to 149
private static void AppendTypeDeclaration(StringBuilder sb, INamedTypeSymbol type, int indentLevel)
{
sb.Append(new string(' ', indentLevel * 4));
sb.Append(GetAccessibility(type.DeclaredAccessibility)).Append(' ');
if (type.IsStatic)
Comment on lines +102 to +106
var containingTypes = GetContainingTypes(type);
var indentLevel = 0;
foreach (var containingType in containingTypes)
{
AppendTypeDeclaration(sb, containingType, indentLevel);
Comment on lines +148 to 152
private static void AppendTypeDeclaration(StringBuilder sb, INamedTypeSymbol type, int indentLevel)
{
sb.Append(new string(' ', indentLevel * 4));
sb.Append(GetAccessibility(type.DeclaredAccessibility)).Append(' ');
if (type.IsStatic)
Comment on lines +104 to +108
var containingTypes = GetContainingTypes(type);
var indentLevel = 0;
foreach (var containingType in containingTypes)
{
AppendTypeDeclaration(sb, containingType, indentLevel);
@github-actions

Copy link
Copy Markdown
Contributor

Test Results

    12 files      12 suites   10m 46s ⏱️
 3 819 tests  3 819 ✅ 0 💤 0 ❌
11 888 runs  11 888 ✅ 0 💤 0 ❌

Results for commit 459012f.

@github-actions

Copy link
Copy Markdown
Contributor

Code Coverage

Summary
  Generated on: 05/30/2026 - 03:29:02
  Coverage date: 05/30/2026 - 03:26:26 - 05/30/2026 - 03:28:50
  Parser: MultiReport (12x Cobertura)
  Assemblies: 5
  Classes: 1616
  Files: 551
  Line coverage: 96.5%
  Covered lines: 43400
  Uncovered lines: 1540
  Coverable lines: 44940
  Total lines: 96704
  Branch coverage: 82.1% (13546 of 16499)
  Covered branches: 13546
  Total branches: 16499
  Method coverage: 96.6% (8437 of 8728)
  Full method coverage: 90.1% (7869 of 8728)
  Covered methods: 8437
  Fully covered methods: 7869
  Total methods: 8728

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 30, 2026

Copy link
Copy Markdown

Codecov Report

✅ All modified and coverable lines are covered by tests.
✅ Project coverage is 96.74%. Comparing base (05621f5) to head (459012f).

Additional details and impacted files
@@            Coverage Diff             @@
##             main     #444      +/-   ##
==========================================
+ Coverage   91.49%   96.74%   +5.24%     
==========================================
  Files         551      551              
  Lines       44900    44940      +40     
  Branches     6470     6476       +6     
==========================================
+ Hits        41082    43477    +2395     
+ Misses       1549     1463      -86     
+ Partials     2269        0    -2269     
Flag Coverage Δ
unittests 96.74% <100.00%> (+5.24%) ⬆️

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 a180842 into main May 30, 2026
13 checks passed
@JerrettDavis JerrettDavis deleted the test/rate-limit-bulkhead-coverage-413 branch May 30, 2026 03:35
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