mirror of
https://github.com/gui-cs/Terminal.Gui.git
synced 2026-01-01 16:59:35 +01:00
* Subview clean up * New Add/Remove event pattern * Using Logging * cleanup * Subview -> SubView * Test code cleanup. Killed many warnings. * Fix tznind feedback * Refactored AllViewTest helpers * Moved keyboard tests to parallel * Moved mouse tests to parallel * Moved view tests to parallel * Test code cleanup. Killed many warnings. * dupe test * Some mouse tests can't run in parallel because MouseGrabView * Made SpinnerView more testable * Moved more tests * SubViews to IReadOnlyCollection<View> * SubViews to IReadOnlyCollection<View> 2 * scrollbar tests * shortcut tests * Use InternalSubViews vs. _subviews * Nuked View.IsAdded. Added View.SuperViewChanged. * API doc updats * Unit Test tweak * Unit Test tweak
115 lines
4.0 KiB
C#
115 lines
4.0 KiB
C#
using Terminal.Gui;
|
|
using UnitTests;
|
|
using Xunit.Abstractions;
|
|
|
|
namespace StressTests;
|
|
|
|
public class ApplicationStressTests : TestsAllViews
|
|
{
|
|
public ApplicationStressTests (ITestOutputHelper output)
|
|
{
|
|
ConsoleDriver.RunningUnitTests = true;
|
|
ConfigurationManager.Locations = ConfigLocations.Default;
|
|
}
|
|
|
|
private static volatile int _tbCounter;
|
|
#pragma warning disable IDE1006 // Naming Styles
|
|
private static readonly ManualResetEventSlim _wakeUp = new (false);
|
|
#pragma warning restore IDE1006 // Naming Styles
|
|
|
|
private const int NUM_PASSES = 50;
|
|
private const int NUM_INCREMENTS = 500;
|
|
private const int POLL_MS = 100;
|
|
|
|
[Theory]
|
|
[InlineData (typeof (FakeDriver))]
|
|
[InlineData (typeof (NetDriver), Skip = "System.IO.IOException: The handle is invalid")]
|
|
//[InlineData (typeof (ANSIDriver))]
|
|
[InlineData (typeof (WindowsDriver))]
|
|
[InlineData (typeof (CursesDriver), Skip = "Unable to load DLL 'libc' or one of its dependencies: The specified module could not be found. (0x8007007E)")]
|
|
public async Task InvokeLeakTest (Type driverType)
|
|
{
|
|
|
|
Application.Init (driverName: driverType.Name);
|
|
Random r = new ();
|
|
TextField tf = new ();
|
|
var top = new Toplevel ();
|
|
top.Add (tf);
|
|
|
|
_tbCounter = 0;
|
|
|
|
Task task = Task.Run (() => RunTest (r, tf, NUM_PASSES, NUM_INCREMENTS, POLL_MS));
|
|
|
|
// blocks here until the RequestStop is processed at the end of the test
|
|
Application.Run (top);
|
|
|
|
await task; // Propagate exception if any occurred
|
|
|
|
Assert.Equal (NUM_INCREMENTS * NUM_PASSES, _tbCounter);
|
|
top.Dispose ();
|
|
Application.Shutdown ();
|
|
|
|
return;
|
|
|
|
static void RunTest (Random r, TextField tf, int numPasses, int numIncrements, int pollMs)
|
|
{
|
|
for (var j = 0; j < numPasses; j++)
|
|
{
|
|
_wakeUp.Reset ();
|
|
|
|
for (var i = 0; i < numIncrements; i++)
|
|
{
|
|
Launch (r, tf, (j + 1) * numIncrements);
|
|
}
|
|
|
|
while (_tbCounter != (j + 1) * numIncrements) // Wait for tbCounter to reach expected value
|
|
{
|
|
int tbNow = _tbCounter;
|
|
_wakeUp.Wait (pollMs);
|
|
|
|
if (_tbCounter != tbNow)
|
|
{
|
|
continue;
|
|
}
|
|
|
|
// No change after wait: Idle handlers added via Application.Invoke have gone missing
|
|
Application.Invoke (() => Application.RequestStop ());
|
|
|
|
throw new TimeoutException (
|
|
$"Timeout: Increment lost. _tbCounter ({_tbCounter}) didn't "
|
|
+ $"change after waiting {pollMs} ms. Failed to reach {(j + 1) * numIncrements} on pass {j + 1}"
|
|
);
|
|
}
|
|
|
|
;
|
|
}
|
|
|
|
Application.Invoke (() => Application.RequestStop ());
|
|
}
|
|
|
|
static void Launch (Random r, TextField tf, int target)
|
|
{
|
|
Task.Run (
|
|
() =>
|
|
{
|
|
Thread.Sleep (r.Next (2, 4));
|
|
|
|
Application.Invoke (
|
|
() =>
|
|
{
|
|
tf.Text = $"index{r.Next ()}";
|
|
Interlocked.Increment (ref _tbCounter);
|
|
|
|
if (target == _tbCounter)
|
|
{
|
|
// On last increment wake up the check
|
|
_wakeUp.Set ();
|
|
}
|
|
}
|
|
);
|
|
}
|
|
);
|
|
}
|
|
}
|
|
}
|