diff --git a/src/Headless/Avalonia.Headless/HeadlessWindowExtensions.cs b/src/Headless/Avalonia.Headless/HeadlessWindowExtensions.cs
index 8fbc5ec6ef..a3bda25b19 100644
--- a/src/Headless/Avalonia.Headless/HeadlessWindowExtensions.cs
+++ b/src/Headless/Avalonia.Headless/HeadlessWindowExtensions.cs
@@ -44,53 +44,54 @@ public static class HeadlessWindowExtensions
/// Simulates keyboard press on the headless window/toplevel.
///
public static void KeyPress(this TopLevel topLevel, Key key, RawInputModifiers modifiers) =>
- RunJobsAndGetImpl(topLevel).KeyPress(key, modifiers);
+ RunJobsOnImpl(topLevel, w => w.KeyPress(key, modifiers));
///
/// Simulates keyboard release on the headless window/toplevel.
///
public static void KeyRelease(this TopLevel topLevel, Key key, RawInputModifiers modifiers) =>
- RunJobsAndGetImpl(topLevel).KeyRelease(key, modifiers);
+ RunJobsOnImpl(topLevel, w => w.KeyRelease(key, modifiers));
///
/// Simulates mouse down on the headless window/toplevel.
///
public static void MouseDown(this TopLevel topLevel, Point point, MouseButton button,
RawInputModifiers modifiers = RawInputModifiers.None) =>
- RunJobsAndGetImpl(topLevel).MouseDown(point, button, modifiers);
+ RunJobsOnImpl(topLevel, w => w.MouseDown(point, button, modifiers));
///
/// Simulates mouse move on the headless window/toplevel.
///
public static void MouseMove(this TopLevel topLevel, Point point,
RawInputModifiers modifiers = RawInputModifiers.None) =>
- RunJobsAndGetImpl(topLevel).MouseMove(point, modifiers);
+ RunJobsOnImpl(topLevel, w => w.MouseMove(point, modifiers));
///
/// Simulates mouse up on the headless window/toplevel.
///
public static void MouseUp(this TopLevel topLevel, Point point, MouseButton button,
RawInputModifiers modifiers = RawInputModifiers.None) =>
- RunJobsAndGetImpl(topLevel).MouseUp(point, button, modifiers);
+ RunJobsOnImpl(topLevel, w => w.MouseUp(point, button, modifiers));
///
/// Simulates mouse wheel on the headless window/toplevel.
///
public static void MouseWheel(this TopLevel topLevel, Point point, Vector delta,
RawInputModifiers modifiers = RawInputModifiers.None) =>
- RunJobsAndGetImpl(topLevel).MouseWheel(point, delta, modifiers);
+ RunJobsOnImpl(topLevel, w => w.MouseWheel(point, delta, modifiers));
///
/// Simulates drag'n'drop target on the headless window/toplevel.
///
public static void DragDrop(this TopLevel topLevel, Point point, RawDragEventType type, IDataObject data,
DragDropEffects effects, RawInputModifiers modifiers = RawInputModifiers.None) =>
- RunJobsAndGetImpl(topLevel).DragDrop(point, type, data, effects, modifiers);
+ RunJobsOnImpl(topLevel, w => w.DragDrop(point, type, data, effects, modifiers));
- private static IHeadlessWindow RunJobsAndGetImpl(this TopLevel topLevel)
+ private static void RunJobsOnImpl(this TopLevel topLevel, Action action)
{
Dispatcher.UIThread.RunJobs();
- return GetImpl(topLevel);
+ action(GetImpl(topLevel));
+ Dispatcher.UIThread.RunJobs();
}
private static IHeadlessWindow GetImpl(this TopLevel topLevel)
diff --git a/tests/Avalonia.Headless.UnitTests/InputTests.cs b/tests/Avalonia.Headless.UnitTests/InputTests.cs
index 5a7d3faae9..5e3b6e762f 100644
--- a/tests/Avalonia.Headless.UnitTests/InputTests.cs
+++ b/tests/Avalonia.Headless.UnitTests/InputTests.cs
@@ -46,7 +46,7 @@ public class InputTests
_window.MouseDown(new Point(50, 50), MouseButton.Left);
_window.MouseUp(new Point(50, 50), MouseButton.Left);
-
+
Assert.True(buttonClicked);
}