Skip to content

Commit

Permalink
Revert "Make skia runtime tests green locally on Debug"
Browse files Browse the repository at this point in the history
  • Loading branch information
jeromelaban authored Nov 25, 2024
1 parent 37cac2e commit cda4e15
Show file tree
Hide file tree
Showing 15 changed files with 57 additions and 65 deletions.
8 changes: 5 additions & 3 deletions src/SamplesApp/SamplesApp.Shared/App.xaml.cs
Original file line number Diff line number Diff line change
Expand Up @@ -159,8 +159,11 @@ override void OnLaunched(LaunchActivatedEventArgs e)
}

var sw = Stopwatch.StartNew();
#if WINAPPSDK && DEBUG
// this.DebugSettings.EnableFrameRateCounter = true;
#if DEBUG
if (System.Diagnostics.Debugger.IsAttached)
{
// this.DebugSettings.EnableFrameRateCounter = true;
}
#endif
AssertInitialWindowSize();

Expand Down Expand Up @@ -546,7 +549,6 @@ static void ConfigureFeatureFlags()
#if HAS_UNO
Uno.UI.FeatureConfiguration.TextBox.UseOverlayOnSkia = false;
Uno.UI.FeatureConfiguration.ToolTip.UseToolTips = true;
Uno.UI.FeatureConfiguration.DependencyProperty.ValidatePropertyOwnerOnReadWrite = true;

Uno.UI.FeatureConfiguration.Font.DefaultTextFontFamily = "ms-appx:///Uno.Fonts.OpenSans/Fonts/OpenSans.ttf";
#endif
Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -940,7 +940,7 @@ await TestServices.WindowHelper.RootElementDispatcher.RunAsync(() =>
}
else if (test.ExpectedException is null || !test.ExpectedException.IsInstanceOfType(e))
{
if (_currentRun.CurrentRepeatCount < config.Attempts - 1)
if (_currentRun.CurrentRepeatCount < config.Attempts - 1 && !Debugger.IsAttached)
{
_currentRun.CurrentRepeatCount++;
canRetry = true;
Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -236,7 +236,7 @@ internal void VerifyNoSelectedDatesChanged()
{
// we expect no event here, so below statement will timeout and throw WEX.Common.Exception.
TestServices.VERIFY_THROWS_WINRT<Exception>(
async () => await m_selectedDatesChangedEvent.WaitFor(TimeSpan.FromMilliseconds(5000)),
async () => await m_selectedDatesChangedEvent.WaitFor(TimeSpan.FromMilliseconds(5000), true /* enforceUnderDebugger */),
"SelectedDatesChanged event should not raise!");
TestServices.VERIFY_IS_FALSE(m_selectedDatesChangedEvent.HasFired());
m_selectedDatesChangedRegistration.Detach();
Expand Down
10 changes: 10 additions & 0 deletions src/Uno.UI.RuntimeTests/IntegrationTests/dxaml/Event.cs
Original file line number Diff line number Diff line change
Expand Up @@ -74,5 +74,15 @@ public Task WaitFor(TimeSpan timeout, CancellationToken ct = default)
{
return WaitForDefault((int)timeout.TotalMilliseconds, ct);
}

internal Task WaitFor(TimeSpan timeout, bool enforceUnderDebugger, CancellationToken ct = default)
{
if (!enforceUnderDebugger && Debugger.IsAttached)
{
return Task.CompletedTask;
}

return WaitForDefault((int)timeout.TotalMilliseconds, ct);
}
}
}
37 changes: 22 additions & 15 deletions src/Uno.UI.RuntimeTests/MUX/Helpers/EventTester.cs
Original file line number Diff line number Diff line change
Expand Up @@ -15,7 +15,6 @@
using Microsoft.UI.Xaml;
using UIExecutor = MUXControlsTestApp.Utilities.RunOnUIThread;
using MUXControlsTestApp.Utilities;
using Uno.UI;

namespace Microsoft/* UWP don't rename */.UI.Xaml.Tests.Common
{
Expand Down Expand Up @@ -93,11 +92,11 @@ protected EventTester(TSender sender, Type senderType, string eventName, Action<
#if !__WASM__
if (this.options.HasFlag(EventTesterOptions.CaptureWindowBefore))
{
this.CaptureWindowAsync("Before").Wait(this.DefaultTimeout);
this.CaptureWindowAsync("Before").Wait(this.Timeout);

Check failure on line 95 in src/Uno.UI.RuntimeTests/MUX/Helpers/EventTester.cs

View check run for this annotation

Codacy Production / Codacy Static Code Analysis

src/Uno.UI.RuntimeTests/MUX/Helpers/EventTester.cs#L95

Replace this use of 'Task.Wait' with 'await'.
}
if (this.options.HasFlag(EventTesterOptions.CaptureScreenBefore))
{
this.CaptureScreenAsync("Before").Wait(this.DefaultTimeout);
this.CaptureScreenAsync("Before").Wait(this.Timeout);

Check failure on line 99 in src/Uno.UI.RuntimeTests/MUX/Helpers/EventTester.cs

View check run for this annotation

Codacy Production / Codacy Static Code Analysis

src/Uno.UI.RuntimeTests/MUX/Helpers/EventTester.cs#L99

Replace this use of 'Task.Wait' with 'await'.
}
#endif
}
Expand Down Expand Up @@ -154,14 +153,22 @@ public static EventTester<UIElement, TEventArgs> FromRoutedEvent(UIElement sende
return new RoutedEventTester<TEventArgs>(sender, eventName, action);
}

public TimeSpan DefaultTimeout =
#if HAS_UNO
FeatureConfiguration.DebugOptions.WaitIndefinitelyInEventTester
#else
Debugger.IsAttached
#endif
? TimeSpan.FromMilliseconds(-1)
: EventTesterConfig.Timeout;
public TimeSpan DefaultTimeout = EventTesterConfig.Timeout;

Check warning on line 156 in src/Uno.UI.RuntimeTests/MUX/Helpers/EventTester.cs

View check run for this annotation

Codacy Production / Codacy Static Code Analysis

src/Uno.UI.RuntimeTests/MUX/Helpers/EventTester.cs#L156

Make 'DefaultTimeout' private.

Check notice on line 156 in src/Uno.UI.RuntimeTests/MUX/Helpers/EventTester.cs

View check run for this annotation

Codacy Production / Codacy Static Code Analysis

src/Uno.UI.RuntimeTests/MUX/Helpers/EventTester.cs#L156

Make this field 'private' and encapsulate it in a 'public' property.

private TimeSpan Timeout
{
get
{
if (Debugger.IsAttached)
{
return TimeSpan.FromMilliseconds(-1); // Wait indefinitely if debugger is attached.
}
else
{
return this.DefaultTimeout;
}
}
}

private TSender Sender
{
Expand Down Expand Up @@ -251,7 +258,7 @@ public TEventArgs LastArgs

public async Task<bool> Wait()
{
return await this.Wait(this.DefaultTimeout);
return await this.Wait(this.Timeout);
}

public async Task<bool> Wait(TimeSpan timeout)
Expand Down Expand Up @@ -325,7 +332,7 @@ private async Task CaptureWindowAsync(string prefix = "")

public async Task<bool> WaitAsync()
{
return await this.WaitAsync(this.DefaultTimeout);
return await this.WaitAsync(this.Timeout);
}

public async Task<bool> WaitAsync(TimeSpan timeout)
Expand Down Expand Up @@ -434,11 +441,11 @@ private void Dispose(bool disposing)
#if !__WASM__
if (this.options.HasFlag(EventTesterOptions.CaptureWindowAfter))
{
this.CaptureWindowAsync("After").Wait(this.DefaultTimeout);
this.CaptureWindowAsync("After").Wait(this.Timeout);

Check failure on line 444 in src/Uno.UI.RuntimeTests/MUX/Helpers/EventTester.cs

View check run for this annotation

Codacy Production / Codacy Static Code Analysis

src/Uno.UI.RuntimeTests/MUX/Helpers/EventTester.cs#L444

Replace this use of 'Task.Wait' with 'await'.
}
if (this.options.HasFlag(EventTesterOptions.CaptureScreenAfter))
{
this.CaptureScreenAsync("After").Wait(this.DefaultTimeout);
this.CaptureScreenAsync("After").Wait(this.Timeout);

Check failure on line 448 in src/Uno.UI.RuntimeTests/MUX/Helpers/EventTester.cs

View check run for this annotation

Codacy Production / Codacy Static Code Analysis

src/Uno.UI.RuntimeTests/MUX/Helpers/EventTester.cs#L448

Replace this use of 'Task.Wait' with 'await'.
}
#endif

Expand Down
2 changes: 1 addition & 1 deletion src/Uno.UI.RuntimeTests/MUX/Utilities/TestHelpers.cs
Original file line number Diff line number Diff line change
Expand Up @@ -139,7 +139,7 @@ namespace MUXControlsTestApp.Utilities
{
public static class TestUtilities
{
public static int DefaultWaitMs = 5000;
public static int DefaultWaitMs = Debugger.IsAttached ? 120000 : 5000;

public static async Task SetAsVisualTreeRoot(FrameworkElement element)
{
Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -10,7 +10,6 @@ public class Given_UnitTest
{
static int When_UnhandledException_Count;

// This tests that automatic retry is working.
[TestMethod]
public void When_UnhandledException()
{
Expand All @@ -26,7 +25,6 @@ public class Given_UnitTest_Initialize
{
static int Initialize_Count;

// This tests that automatic retry is working.
[TestInitialize]
public void Initialize()
{
Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -663,8 +663,8 @@ public async Task When_Exif_Rotated_MsAppx_Unequal_Dimensions()
await WindowHelper.WaitFor(() => imageOpened);
var screenshot = await TakeScreenshot(image);
ImageAssert.HasColorAt(screenshot, 5, screenshot.Height / 2, Color.FromArgb(0xFF, 0xED, 0x1B, 0x24), tolerance: 5);
ImageAssert.HasColorAt(screenshot, screenshot.Width / 2.2f, screenshot.Height / 2, Color.FromArgb(0xFF, 0xED, 0x1B, 0x24), tolerance: 5);
ImageAssert.HasColorAt(screenshot, screenshot.Width / 1.8f, screenshot.Height / 2, Color.FromArgb(0xFF, 0x23, 0xB1, 0x4D), tolerance: 5);
ImageAssert.HasColorAt(screenshot, screenshot.Width / 2 - 10, screenshot.Height / 2, Color.FromArgb(0xFF, 0xED, 0x1B, 0x24), tolerance: 5);
ImageAssert.HasColorAt(screenshot, screenshot.Width / 2 + 10, screenshot.Height / 2, Color.FromArgb(0xFF, 0x23, 0xB1, 0x4D), tolerance: 5);
ImageAssert.HasColorAt(screenshot, screenshot.Width - 5, screenshot.Height / 2, Color.FromArgb(0xFF, 0x23, 0xB1, 0x4D), tolerance: 5);

}
Expand Down
23 changes: 0 additions & 23 deletions src/Uno.UI/FeatureConfiguration.cs
Original file line number Diff line number Diff line change
Expand Up @@ -841,29 +841,6 @@ public static class DependencyProperty
/// of having an undefined behavior and/or race conditions.
/// </summary>
public static bool DisableThreadingCheck { get; set; }

/// <summary>
/// Enables checks that make sure that <see cref="DependencyObjectStore.GetValue" /> and
/// <see cref="DependencyObjectStore.SetValue" /> are only called on the owner of the property being
/// set/got.
/// </summary>
public static bool ValidatePropertyOwnerOnReadWrite { get; set; } =
#if DEBUG
true;
#else
global::System.Diagnostics.Debugger.IsAttached;
#endif
}

/// <summary>
/// This is for internal use to facilitate turning on/off certain logic that makes it easier/harder
/// to debug.
/// </summary>
internal static class DebugOptions
{
public static bool PreventKeyboardStateTrackerFromResettingOnWindowActivationChange { get; set; }

public static bool WaitIndefinitelyInEventTester { get; set; }
}
}
}
3 changes: 1 addition & 2 deletions src/Uno.UI/UI/Xaml/Controls/AppBar/AppBar.Partial.cs
Original file line number Diff line number Diff line change
Expand Up @@ -769,8 +769,7 @@ private void OnIsOpenChanged(bool isOpen)
{
// If the AppBar is not live, then wait until it's loaded before
// responding to changes to opened state and firing our Opening/Opened events.
// Uno Specific: using IsLoaded instead of IsInLiveTree, which makes more sense because OnOpening (called below) -> SetupOverlayState expects OnApplyTemplate to have already been called
if (!IsLoaded)
if (!IsInLiveTree)
{
return;
}
Expand Down
4 changes: 3 additions & 1 deletion src/Uno.UI/UI/Xaml/DependencyObjectStore.cs
Original file line number Diff line number Diff line change
Expand Up @@ -107,6 +107,8 @@ public static class TraceProvider
/// </summary>
private SpecializedResourceDictionary.ResourceKey? _themeLastUsed;

private static readonly bool _validatePropertyOwner = Debugger.IsAttached;

#if UNO_HAS_ENHANCED_LIFECYCLE
internal bool IsDisposed => _isDisposed;
#endif
Expand Down Expand Up @@ -800,7 +802,7 @@ private void WritePropertyEventTrace(int eventId, DependencyProperty property, D
[MethodImpl(MethodImplOptions.AggressiveInlining)]
private void ValidatePropertyOwner(DependencyProperty property)
{
if (FeatureConfiguration.DependencyProperty.ValidatePropertyOwnerOnReadWrite)
if (_validatePropertyOwner)
{
var isFrameworkElement = _originalObjectType.Is(typeof(FrameworkElement));
var isMixinFrameworkElement = _originalObjectRef.Target is IFrameworkElement && !isFrameworkElement;
Expand Down
2 changes: 0 additions & 2 deletions src/Uno.UI/UI/Xaml/UIElementCollection.cs
Original file line number Diff line number Diff line change
Expand Up @@ -57,9 +57,7 @@ public UIElement this[int index]

public void Add(UIElement item)
{
#if !__CROSSRUNTIME__ // SetParent is already called in AddCore and calling it here messes up the check inside AddCore for a preexisting parent. VerifyNavigationViewItemToolTipPaneDisplayMode (in DEBUG) fails otherwise because Enter is called multiple times on the same element
item.SetParent(_owner);
#endif

AddCore(item);
OnCollectionChanged(new NotifyCollectionChangedEventArgs(NotifyCollectionChangedAction.Add, item));
Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -269,10 +269,7 @@ private void OnActivationStateChanged(CoreWindowActivationState state)
CoreWindow?.OnActivated(coreWindowActivatedEventArgs);
Activated?.Invoke(Window, activatedEventArgs);
SystemThemeHelper.RefreshSystemTheme();
if (!FeatureConfiguration.DebugOptions.PreventKeyboardStateTrackerFromResettingOnWindowActivationChange)
{
KeyboardStateTracker.Reset();
}
KeyboardStateTracker.Reset();
}

public bool Close()
Expand Down
8 changes: 1 addition & 7 deletions src/Uno.UWP/Buffers/DefaultArrayPoolBucket.cs
Original file line number Diff line number Diff line change
Expand Up @@ -40,13 +40,7 @@ private sealed class Bucket
/// </summary>
internal Bucket(int bufferLength, int numberOfBuffers, int poolId)
{
_lock = new SpinLock(
#if DEBUG // thread tracking adds non-trivial overheads to Enter/Exit
true
#else
global::System.Diagnostics.Debugger.IsAttached
#endif
);
_lock = new SpinLock(Debugger.IsAttached); // only enable thread tracking if debugger is attached; it adds non-trivial overheads to Enter/Exit
_buffers = new T[numberOfBuffers][];
_bufferLength = bufferLength;
_poolId = poolId;
Expand Down
10 changes: 9 additions & 1 deletion src/Uno.UWP/UI/Core/Internal/KeyboardStateTracker.cs
Original file line number Diff line number Diff line change
Expand Up @@ -98,7 +98,15 @@ private static void SetStateOnNonSideKeys(VirtualKey key)
}
}

internal static void Reset() => _keyStates.Clear();
internal static void Reset()
{
// Clearing state when debugger is attached would
// make it hard to debug key events.
if (!System.Diagnostics.Debugger.IsAttached)
{
_keyStates.Clear();
}
}

#if __WASM__
#pragma warning disable IDE0051 // Remove unused private members
Expand Down

0 comments on commit cda4e15

Please sign in to comment.