Welcome Guest! To enable all features please Login or Register.

Notification

Icon
Error

ImmutableHashSet static field causes 'Value does not fall within the expected range' exception.
garyp01
#1 Posted : Wednesday, April 2, 2025 8:18:17 AM(UTC)
Rank: Newbie

Groups: Registered
Joined: 10/3/2024(UTC)
Posts: 3
Location: United Kingdom

Thanks: 1 times
Was thanked: 1 time(s) in 1 post(s)
If I have a static ImmutableHashSet field, such as:

Quote:
private static readonly ImmutableHashSet<DayOfWeek> Days = [DayOfWeek.Wednesday, DayOfWeek.Thursday];


This can cause the exception:

Quote:
System.ArgumentException: Value does not fall within the expected range.
at System.Runtime.CompilerServices.RuntimeHelpers.GetSpanDataFrom(RuntimeFieldHandle fldHandle, RuntimeTypeHandle targetTypeHandle, Int32& count)
at System.Runtime.CompilerServices.RuntimeHelpers.CreateSpan[T](RuntimeFieldHandle fldHandle)


The tests succeed in the VS test runner.

To cause this error, I find that the following has to be true:
1. The field must be static.
2. The field must be of type ImmutableHashSet. Changing it to HashSet causes NCrunch to succeed.
3. The field must be accessed from a private method.
4. The private method must be accessed by NCrunch from a public method.

I thought that possibly this problem was related, but there you say that disabling RDI should resolve the problem, but in my case I have RDI disabled and have disabled it in-line in my tests, but the problem persists.

Minimal solution: https://github.com/garypendlebury/NCrunchFault

My environment: Visual Studio 2022 (17.14.0 Preview 2.0); NCrunch 5.12.0.10.

Any idea what's causing this?
Remco
#2 Posted : Wednesday, April 2, 2025 1:06:29 PM(UTC)
Rank: NCrunch Developer

Groups: Administrators
Joined: 4/16/2011(UTC)
Posts: 7,239

Thanks: 975 times
Was thanked: 1313 time(s) in 1218 post(s)
Thanks for sharing this issue and the project to reproduce it.

I've taken things apart as far as I can on this for now, and something smells fishy here.

The issue only appears on v5.12.0.10 of NCrunch. When I update to the latest dev build of NCrunch, the code works fine, even though the instrumented code is binary identical to the failing version.

I'll add that the current dev build of NCrunch (soon to be the v5.13 release) contains no fixes or changes in this area. As best as I can tell, the issue itself seems to be tied to the state of memory at the time the code runs ... which naturally is influenced by things such as assemblies loaded into the environment, and the size of those assemblies. At the moment I suspect this to be an issue in the runtime itself, but I can't pin it down consistently enough to prove anything.

I've included below the download links for the latest NCrunch build that's in development. For reasons I can't understand, the problem does not present itself in this build. You're welcome to use it as a workaround, but I strongly recommend restructuring this code to prevent it from giving you problems in future.

NCrunch_Console_5.13.0.3.msi
NCrunch_Console_5.13.0.3.zip
NCrunch_GridNodeServer_5.13.0.3.msi
NCrunch_GridNodeServer_5.13.0.3.zip
NCrunch_LicenseServer_5.13.0.3.zip
NCrunch_Rider_5.13.0.3.7z
NCrunch_Rider_5.13.0.3.zip
NCrunch_VS2010_5.13.0.3.msi
NCrunch_VS2010_5.13.0.3.zip
NCrunch_VS2012_5.13.0.3.msi
NCrunch_VS2012_5.13.0.3.zip
NCrunch_VS2013_5.13.0.3.msi
NCrunch_VS2013_5.13.0.3.zip
NCrunch_VS2015_5.13.0.3.msi
NCrunch_VS2015_5.13.0.3.msi.7z
NCrunch_VS2015_5.13.0.3.zip
NCrunch_VS2017_5.13.0.3.msi
NCrunch_VS2017_5.13.0.3.msi.7z
NCrunch_VS2017_5.13.0.3.zip
NCrunch_VS2019_5.13.0.3.msi
NCrunch_VS2019_5.13.0.3.msi.7z
NCrunch_VS2019_5.13.0.3.zip
NCrunch_VS2022_5.13.0.3.msi
NCrunch_VS2022_5.13.0.3.msi.7z
NCrunch_VS2022_5.13.0.3.zip
garyp01
#3 Posted : Thursday, April 3, 2025 8:28:29 AM(UTC)
Rank: Newbie

Groups: Registered
Joined: 10/3/2024(UTC)
Posts: 3
Location: United Kingdom

Thanks: 1 times
Was thanked: 1 time(s) in 1 post(s)
Thanks for following this up so quickly.

The problem has been affecting me for a few months through different versions of NCrunch. I've only just got round to reporting it. 😅

It's been strangely intermittent. Sometimes I'll be in the affected project for a few hours and not see the error, then suddenly it'll pop up. I have to temporarily change the code to allow NCrunch to function, then change it back before I push my changes. Suppose I could change the code, but I'd rather not have to.

I've installed 5.13.0.3 and the problem has gone away. I'll report back if it pops up again.
Users browsing this topic
Guest
Forum Jump  
You cannot post new topics in this forum.
You cannot reply to topics in this forum.
You cannot delete your posts in this forum.
You cannot edit your posts in this forum.
You cannot create polls in this forum.
You cannot vote in polls in this forum.

YAF | YAF © 2003-2011, Yet Another Forum.NET
This page was generated in 0.041 seconds.
Trial NCrunch
Take NCrunch for a spin
Do your fingers a favour and supercharge your testing workflow
Free Download