Skip to content

Various identified issues#65

Merged
koenbeuk merged 15 commits into
mainfrom
fix/harnessing
May 16, 2026
Merged

Various identified issues#65
koenbeuk merged 15 commits into
mainfrom
fix/harnessing

Conversation

@koenbeuk
Copy link
Copy Markdown
Collaborator

@koenbeuk koenbeuk commented May 10, 2026

Fixes #64 amongst other things

Copilot AI review requested due to automatic review settings May 10, 2026 23:53
Copy link
Copy Markdown
Contributor

Copilot AI left a comment

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 aims to prevent runtime null-reference failures by hardening generated polyfill interceptors (notably around params IExpressionTreeTransformer[] transformers) and adds targeted regression tests to cover previously identified edge cases.

Changes:

  • Add null-argument and null-element validation for transformers in generated ExpressionPolyfill.Create(..., params IExpressionTreeTransformer[] transformers) interceptors.
  • Add/extend unit, generator, and integration tests for expansion/polymorphism, polyfill edge cases (switch patterns, list patterns), and generator diagnostics behavior.

Reviewed changes

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

Show a summary per file
File Description
tests/ExpressiveSharp.Tests/Extensions/ExpressionPolyfillTests.cs Adds a regression test ensuring null transformer arguments throw ArgumentNullException.
tests/ExpressiveSharp.IntegrationTests/Tests/ExpansionEdgeCasesTests.cs Adds integration coverage for polymorphic dispatch and additional polyfill edge cases.
tests/ExpressiveSharp.Generator.Tests/PolyfillInterceptorGenerator/JoinTests.cs Adds a generator test that compiles the generated interceptor for GroupJoin with an anonymous result selector.
tests/ExpressiveSharp.Generator.Tests/ExpressiveGenerator/ListPatternTests.cs Adds a diagnostic-regression test for list patterns on arrays.
tests/ExpressiveSharp.Generator.Tests/ExpressiveGenerator/IndexRangeTests.cs Adds a diagnostic-regression test for string range slicing.
src/ExpressiveSharp.Generator/PolyfillInterceptorGenerator.cs Emits null checks for transformers and its elements to avoid runtime NREs during transformer application.

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

Comment on lines +174 to +178

var errors = outputCompilation.GetDiagnostics()
.Where(d => d.Severity == DiagnosticSeverity.Error)
.ToList();

}
""");
var result = RunExpressiveGenerator(compilation);

}
""");
var result = RunExpressiveGenerator(compilation);

@codecov
Copy link
Copy Markdown

codecov Bot commented May 16, 2026

@koenbeuk koenbeuk changed the title [WIP] Various identified issues Various identified issues May 16, 2026
@koenbeuk koenbeuk merged commit b3d8861 into main May 16, 2026
17 checks passed
@koenbeuk koenbeuk deleted the fix/harnessing branch May 16, 2026 18:24
Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment

Labels

None yet

Projects

None yet

Development

Successfully merging this pull request may close these issues.

ICollection<T> properties fail

2 participants