Skip to content

test: cover state machine generator edge cases#419

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

test: cover state machine generator edge cases#419
JerrettDavis merged 1 commit into
mainfrom
test/state-machine-generator-coverage-413

Conversation

@JerrettDavis

Copy link
Copy Markdown
Owner

Summary

  • adds TinyBDD StateMachineGenerator scenarios for signed/unknown/null hook enum values, invalid CancellationToken parameter signatures, and no-transition invalid-trigger policies
  • keeps the coverage work focused on generator behavior without runtime changes
  • continues Raise source-generator coverage toward 99% #413

Coverage

  • StateMachineGenerator uncovered lines dropped from 39 to 12 in the generator-only maintained-source report
  • Generator-only line coverage moved to 94.7%

Validation

  • dotnet test test/PatternKit.Generators.Tests/PatternKit.Generators.Tests.csproj --configuration Release --framework net10.0 --filter "FullyQualifiedName~StateMachineGeneratorTests" --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 format PatternKit.slnx --verify-no-changes --verbosity minimal

Copilot AI review requested due to automatic review settings May 29, 2026 03:36
@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 additional TinyBDD/xUnit scenarios to increase maintained-source coverage for StateMachineGenerator edge cases, continuing the generator-coverage work in #413.

Changes:

  • Add scenario covering hook collection behavior when hook enum values are signed/negative, null, or unknown.
  • Add scenario asserting diagnostics for invalid CancellationToken parameter signatures on transitions/guards/hooks.
  • Add scenario covering invalid-trigger policy emission when a state machine defines no transitions.

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

Comment on lines +1218 to +1221
[Scenario("NamedHookArgumentsAndSignedEnums CoverHookCollectionBranches")]
[Fact]
public void NamedHookArgumentsAndSignedEnums_CoverHookCollectionBranches()
{
Comment on lines +1323 to +1329
static void AssertDiagnostic(string source, string id, string assemblyName)
{
var comp = RoslynTestHelpers.CreateCompilation(source, assemblyName);
var gen = new StateMachineGenerator();
_ = RoslynTestHelpers.Run(comp, gen, out var result, out _);
ScenarioExpect.Contains(result.Results.SelectMany(r => r.Diagnostics), d => d.Id == id);
}
@github-actions

Copy link
Copy Markdown
Contributor

Test Results

    12 files      12 suites   9m 53s ⏱️
 3 608 tests  3 608 ✅ 0 💤 0 ❌
10 835 runs  10 835 ✅ 0 💤 0 ❌

Results for commit 030d14b.

@github-actions

Copy link
Copy Markdown
Contributor

Code Coverage

Summary
  Generated on: 05/29/2026 - 03:43:37
  Coverage date: 05/29/2026 - 03:41:28 - 05/29/2026 - 03:43:25
  Parser: MultiReport (12x Cobertura)
  Assemblies: 5
  Classes: 1616
  Files: 551
  Line coverage: 95.4%
  Covered lines: 42189
  Uncovered lines: 1994
  Coverable lines: 44183
  Total lines: 95379
  Branch coverage: 76.8% (12471 of 16223)
  Covered branches: 12471
  Total branches: 16223
  Method coverage: 96.4% (8351 of 8658)
  Full method coverage: 89% (7707 of 8658)
  Covered methods: 8351
  Fully covered methods: 7707
  Total methods: 8658

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%

@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.81%. Comparing base (3710e2a) to head (030d14b).

Additional details and impacted files
@@            Coverage Diff             @@
##             main     #419      +/-   ##
==========================================
+ Coverage   89.74%   95.81%   +6.07%     
==========================================
  Files         551      551              
  Lines       44183    44183              
  Branches     6357     6357              
==========================================
+ Hits        39650    42333    +2683     
+ Misses       2018     1850     -168     
+ Partials     2515        0    -2515     
Flag Coverage Δ
unittests 95.81% <ø> (+6.07%) ⬆️

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 6c078e8 into main May 29, 2026
13 checks passed
@JerrettDavis JerrettDavis deleted the test/state-machine-generator-coverage-413 branch May 29, 2026 03:49
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