Skip to content

Fix processing non-public classes and generic types in AssemblyScheduler.cs#43377

Merged
akoeplinger merged 1 commit intomainfrom
fix-helix-scheduler
Sep 12, 2024
Merged

Fix processing non-public classes and generic types in AssemblyScheduler.cs#43377
akoeplinger merged 1 commit intomainfrom
fix-helix-scheduler

Conversation

@akoeplinger
Copy link
Copy Markdown
Member

While looking at why #43295 is having issues running on Helix I noticed that we were passing -class "Microsoft.WebTools.AspireServer.UnitTests.MockFactory`1" to the test script which caused a parse error because of the backtick.
image

We shouldn't pass generic types since xunit can't do anything with it.

Additionally I noticed that we were passing some nested types even though they were internal.
This is because we didn't check the visibility correctly, we must use TypeAttributes.VisibilityMask to check for just the visibility (the same also applies to checking for class).
See https://learn.microsoft.com/en-us/dotnet/api/system.reflection.typeattributes?view=net-8.0&redirectedfrom=MSDN#examples

@ghost ghost added Area-Infrastructure untriaged Request triage from a team member labels Sep 12, 2024
@KalleOlaviNiemitalo
Copy link
Copy Markdown
Contributor

KalleOlaviNiemitalo commented Sep 12, 2024

If the type is nested, I think ShouldIncludeType should also check the visibility of the containing type, in principle. But perhaps your test assemblies don't define any types for which this would matter.

@akoeplinger
Copy link
Copy Markdown
Member Author

akoeplinger commented Sep 12, 2024

Yeah it's not common and xunit won't run them anyway so we don't need to be 100% correct here, this just makes the calculation of the number of Helix partitions more accurate.

@akoeplinger
Copy link
Copy Markdown
Member Author

I see a slightly different test count when comparing this PR with main so let's not merge yet.

@akoeplinger
Copy link
Copy Markdown
Member Author

Ok false alarm, this is because a Helix workitem also gets reported as an AzDO test result and we're running a couple fewer workitems due to the new partitioning. I verified the number of actual tests is the same.

@akoeplinger akoeplinger merged commit e6da8ca into main Sep 12, 2024
@akoeplinger akoeplinger deleted the fix-helix-scheduler branch September 12, 2024 14:33
tmat pushed a commit to tmat/sdk that referenced this pull request Sep 18, 2024
…ler.cs (dotnet#43377)

While looking at why dotnet#43295 is having issues running on Helix I noticed that we were passing ``-class "Microsoft.WebTools.AspireServer.UnitTests.MockFactory`1"`` to the test script which caused a parse error because of the backtick.

We shouldn't pass generic types since xunit can't do anything with it.

Additionally I noticed that we were passing some nested types even though they were internal.
This is because we didn't check the visibility correctly, we must use `TypeAttributes.VisibilityMask` to check for just the visibility (the same also applies to checking for class).
See https://learn.microsoft.com/en-us/dotnet/api/system.reflection.typeattributes?view=net-8.0&redirectedfrom=MSDN#examples
tmat added a commit that referenced this pull request Sep 18, 2024
…in AssemblyScheduler.cs (#43377) (#43534)

Co-authored-by: Alexander Köplinger <alex.koeplinger@outlook.com>
Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment

Labels

Area-Infrastructure untriaged Request triage from a team member

Projects

None yet

Development

Successfully merging this pull request may close these issues.

3 participants