Skip to content

System.Runtime.InteropServices.SafeHandle.InternalRelease Method errors with ObjectDisposedException on MacOS #112674

Open
@cschuchardt88

Description

@cschuchardt88

Description

When running test(s) on MacOS github action host. I keep getting an ObjectDisposedException than the test host process crashes. For the class SafeHandle on method InternalRelease from one of my tests where I use SafeHandle. Looks like System.GC.RunFinalizers is calling SafeHandle.InternalRelease` method that is causing the issue.

Reproduction Steps

Use this github repo https://github.com/neo-project/neo/tree/7d2a2ad4dc15db7cddefab7fcc2d892561b10216

Expected behavior

Work the same as it does on Windows.

Actual behavior

2025-02-18T19:19:37.3907020Z Test run for /Users/runner/work/neo/neo/tests/Neo.Build.Core.Tests/bin/Debug/net9.0/Neo.Build.Core.Tests.dll (.NETCoreApp,Version=v9.0)
2025-02-18T19:19:37.4610660Z VSTest version 17.12.0 (arm64)
2025-02-18T19:19:37.4616490Z 
2025-02-18T19:19:37.5087550Z Starting test execution, please wait...
2025-02-18T19:19:37.5211390Z A total of 1 test files matched the specified pattern.
2025-02-18T19:19:45.3053130Z The active test run was aborted. Reason: Test host process crashed : Unhandled exception. System.ObjectDisposedException: Cannot access a disposed object.
2025-02-18T19:19:45.3054680Z Object name: 'Neo.Build.Core.Security.UnmanagedBuffer'.
2025-02-18T19:19:45.3288240Z    at System.Runtime.InteropServices.SafeHandle.InternalRelease(Boolean disposeOrFinalizeOperation)
2025-02-18T19:19:45.3397230Z    at System.Runtime.InteropServices.SafeHandle.Finalize()
2025-02-18T19:19:45.3561040Z    at System.GC.RunFinalizers()

Regression?

unknown

Known Workarounds

Unknown

Configuration

https://productionresultssa9.blob.core.windows.net/actions-results/2a93e2b9-6b96-4204-b088-3a65e63d45f2/workflow-job-run-60607ce0-c0fe-5d7b-1e49-b0c53caa438e/logs/job/job-logs.txt?rsct=text%2Fplain&se=2025-02-19T01%3A39%3A48Z&sig=xevB0uDXZPvZUhVgR2fMYh%2FfeiW0GEeTl2TWpSiuX0A%3D&ske=2025-02-19T11%3A55%3A01Z&skoid=ca7593d4-ee42-46cd-af88-8b886a2f84eb&sks=b&skt=2025-02-18T23%3A55%3A01Z&sktid=398a6654-997b-47e9-b12b-9515b896b4de&skv=2025-01-05&sp=r&spr=https&sr=b&st=2025-02-19T01%3A29%3A43Z&sv=2025-01-05

Other information

These are the files that are using SafeHandle
https://github.com/neo-project/neo/blob/7d2a2ad4dc15db7cddefab7fcc2d892561b10216/src/Shared/Neo.Build.Core/Security/UnmanagedBuffer.cs
https://github.com/neo-project/neo/blob/7d2a2ad4dc15db7cddefab7fcc2d892561b10216/src/Shared/Neo.Build.Core/Security/SecureBuffer.cs
https://github.com/neo-project/neo/blob/7d2a2ad4dc15db7cddefab7fcc2d892561b10216/src/Shared/Neo.Build.Core/Security/SecureBuffer.Security.cs

Here are the tests for my above classes
https://github.com/neo-project/neo/blob/7d2a2ad4dc15db7cddefab7fcc2d892561b10216/tests/Neo.Build.Core.Tests/Security/UT_SecureBuffer.cs

Metadata

Metadata

Assignees

No one assigned

    Type

    No type

    Projects

    • Status

      No status

    Milestone

    No milestone

    Relationships

    None yet

    Development

    No branches or pull requests

    Issue actions