From e0ae7bf1366e9c155e04ee7193aa7d883fd27ad6 Mon Sep 17 00:00:00 2001 From: Paul Irwin Date: Wed, 1 Jan 2025 21:34:19 -0700 Subject: [PATCH] Finish [SuppressTempFileChecks] attribute functionality, #898 --- .../Util/LuceneTestCase.cs | 21 ++++++++++--------- 1 file changed, 11 insertions(+), 10 deletions(-) diff --git a/src/Lucene.Net.TestFramework/Util/LuceneTestCase.cs b/src/Lucene.Net.TestFramework/Util/LuceneTestCase.cs index 51c64d50a2..3ab75d4984 100644 --- a/src/Lucene.Net.TestFramework/Util/LuceneTestCase.cs +++ b/src/Lucene.Net.TestFramework/Util/LuceneTestCase.cs @@ -440,7 +440,6 @@ public SuppressCodecsAttribute(params string[] value) public string[] Value { get; private set; } } - // LUCENENET TODO: Finish implementation /// /// Marks any suites which are known not to close all the temporary /// files. This may prevent temp files and folders from being cleaned @@ -3086,10 +3085,11 @@ private static void RegisterToRemoveAfterSuite(FileSystemInfo f) [MethodImpl(MethodImplOptions.NoInlining)] protected string GetFullMethodName([CallerMemberName] string memberName = "") { - return string.Format("{0}+{1}", this.GetType().Name, memberName); + return $"{this.GetType().Name}+{memberName}"; } - private static void CleanupTemporaryFiles() + // LUCENENET specific - this is equivalent to TemporaryFilesCleanupRule in Lucene + private void CleanupTemporaryFiles() { // Drain cleanup queue and clear it. FileSystemInfo[] everything; @@ -3126,19 +3126,20 @@ private static void CleanupTemporaryFiles() } catch (Exception e) when (e.IsIOException()) { - // Type suiteClass = RandomizedContext.Current.GetTargetType; - // if (suiteClass.IsAnnotationPresent(typeof(SuppressTempFileChecks))) - // { - Console.Error.WriteLine("WARNING: Leftover undeleted temporary files " + e.Message); - return; - // } + Type suiteClass = this.GetType(); + if (suiteClass.GetCustomAttribute(inherit: true) is { } suppressAttr) + { + Console.Error.WriteLine($"WARNING: Leftover undeleted temporary files (bugUrl: {suppressAttr.BugUrl}): {e.Message}"); + return; + } + throw; } } else { if (tempDirBasePath != null) { - Console.Error.WriteLine("NOTE: leaving temporary files on disk at: " + tempDirBasePath); + Console.Error.WriteLine($"NOTE: leaving temporary files on disk at: {tempDirBasePath}"); } } }