Skip to content

[WIP] Various identified issues#65

Open
koenbeuk wants to merge 3 commits into
mainfrom
fix/harnessing
Open

[WIP] Various identified issues#65
koenbeuk wants to merge 3 commits into
mainfrom
fix/harnessing

Conversation

@koenbeuk
Copy link
Copy Markdown
Collaborator

  • Prevent null reference exceptions during runtime.

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);

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.

2 participants