From 826088973ccdca278cd8ee115b9790267df72b0e Mon Sep 17 00:00:00 2001 From: Szabolcs Deme Date: Mon, 13 May 2024 20:19:06 +0200 Subject: [PATCH 1/4] Refining OS check --- .../Extensions/VisualVerificationUITestContextExtensions.cs | 3 ++- 1 file changed, 2 insertions(+), 1 deletion(-) diff --git a/Lombiq.Tests.UI/Extensions/VisualVerificationUITestContextExtensions.cs b/Lombiq.Tests.UI/Extensions/VisualVerificationUITestContextExtensions.cs index d76dd5d23..5ab970f42 100644 --- a/Lombiq.Tests.UI/Extensions/VisualVerificationUITestContextExtensions.cs +++ b/Lombiq.Tests.UI/Extensions/VisualVerificationUITestContextExtensions.cs @@ -18,6 +18,7 @@ using System.Linq; using System.Reflection; using System.Runtime.CompilerServices; +using System.Runtime.InteropServices; using System.Text; namespace Lombiq.Tests.UI.Extensions; @@ -74,7 +75,7 @@ public static void AssertVisualVerificationOnAllResolutions( if (checkOS) { - var oS = OperatingSystem.IsWindows() ? "Windows" : "Unix"; + var oS = RuntimeInformation.OSDescription; fileNameSuffix = $"{fileNameSuffix}-{oS}"; } From b46c587208b58947bef130b192aaff0434e3aca8 Mon Sep 17 00:00:00 2001 From: Szabolcs Deme Date: Mon, 13 May 2024 21:56:31 +0200 Subject: [PATCH 2/4] Reverting changes --- .../VisualVerificationUITestContextExtensions.cs | 13 +------------ 1 file changed, 1 insertion(+), 12 deletions(-) diff --git a/Lombiq.Tests.UI/Extensions/VisualVerificationUITestContextExtensions.cs b/Lombiq.Tests.UI/Extensions/VisualVerificationUITestContextExtensions.cs index 5ab970f42..bd4852947 100644 --- a/Lombiq.Tests.UI/Extensions/VisualVerificationUITestContextExtensions.cs +++ b/Lombiq.Tests.UI/Extensions/VisualVerificationUITestContextExtensions.cs @@ -18,7 +18,6 @@ using System.Linq; using System.Reflection; using System.Runtime.CompilerServices; -using System.Runtime.InteropServices; using System.Text; namespace Lombiq.Tests.UI.Extensions; @@ -54,7 +53,6 @@ public static void AssertVisualVerificationOnAllResolutions( IEnumerable sizes, Func getSelector, double pixelErrorPercentageThreshold = 0, - bool checkOS = false, Action configurator = null) { context.HideScrollbar(); @@ -71,16 +69,7 @@ public static void AssertVisualVerificationOnAllResolutions( pixelErrorPercentageThreshold: pixelErrorPercentageThreshold, configurator: configuration => { - var fileNameSuffix = StringHelper.CreateInvariant($"{size.Width}x{size.Height}"); - - if (checkOS) - { - var oS = RuntimeInformation.OSDescription; - - fileNameSuffix = $"{fileNameSuffix}-{oS}"; - } - - configuration.WithFileNameSuffix(fileNameSuffix); + configuration.WithFileNameSuffix(StringHelper.CreateInvariant($"{size.Width}x{size.Height}")); configurator?.Invoke(configuration); }); } From 0aec929f3c43b9522a78888d0fb3c68ca8e86652 Mon Sep 17 00:00:00 2001 From: Szabolcs Deme Date: Mon, 13 May 2024 22:55:04 +0200 Subject: [PATCH 3/4] Adding AssertVisualVerificationApprovedOnAllResolutionsWithPlatformSuffix --- ...sualVerificationUITestContextExtensions.cs | 35 +++++++++++++++++++ 1 file changed, 35 insertions(+) diff --git a/Lombiq.Tests.UI/Extensions/VisualVerificationUITestContextExtensions.cs b/Lombiq.Tests.UI/Extensions/VisualVerificationUITestContextExtensions.cs index bd4852947..b630983f3 100644 --- a/Lombiq.Tests.UI/Extensions/VisualVerificationUITestContextExtensions.cs +++ b/Lombiq.Tests.UI/Extensions/VisualVerificationUITestContextExtensions.cs @@ -93,6 +93,41 @@ public static void AssertVisualVerificationOnAllResolutions( context.RestoreHiddenScrollbar(); } + /// + /// Compares the baseline image and screenshot of the selected element on multiple different resolutions, based on + /// the operating system's platform. + /// + /// The comparison is performed on each of these resolutions. + /// + /// Returns the selector for the given screen size. This may return the same selector all the time, or a different + /// selector, e.g. if mobile and desktop views have different DOMs. + /// + /// Maximum acceptable pixel error in percentage. + /// Action callback to configure the behavior. Can be , but in the + /// method we are always using . + /// + /// + /// The parameter beforeAssertAsync was removed, because it sometimes polluted the stack trace, which was + /// used in visual verification tests, so it caused tests to fail. The point of beforeAssertAsync was, that + /// sometimes the page can change on the resize window event. So the navigation happening after the window resize + /// ensures that the currently loaded page only existed with the desired screen size. + /// + /// + [VisualVerificationApprovedMethod] + public static void AssertVisualVerificationApprovedOnAllResolutionsWithPlatformSuffix( + this UITestContext context, + IEnumerable sizes, + Func getSelector, + double pixelErrorPercentageThreshold = 0, + Action configurator = null) => + AssertVisualVerificationOnAllResolutions( + context, + sizes, + getSelector, + pixelErrorPercentageThreshold, + configurator: configuration => configuration.WithUsePlatformAsSuffix()); + /// /// Compares the baseline image and screenshot of the whole page. /// . From 7013ff9b95ec65d6915b9e266e1f1644d479eb36 Mon Sep 17 00:00:00 2001 From: =?UTF-8?q?Zolt=C3=A1n=20M=C3=A1t=C3=A9?= Date: Tue, 14 May 2024 00:07:25 +0200 Subject: [PATCH 4/4] Refactoring --- .../Extensions/VisualVerificationUITestContextExtensions.cs | 5 ++--- 1 file changed, 2 insertions(+), 3 deletions(-) diff --git a/Lombiq.Tests.UI/Extensions/VisualVerificationUITestContextExtensions.cs b/Lombiq.Tests.UI/Extensions/VisualVerificationUITestContextExtensions.cs index b630983f3..89a70938c 100644 --- a/Lombiq.Tests.UI/Extensions/VisualVerificationUITestContextExtensions.cs +++ b/Lombiq.Tests.UI/Extensions/VisualVerificationUITestContextExtensions.cs @@ -121,12 +121,11 @@ public static void AssertVisualVerificationApprovedOnAllResolutionsWithPlatformS Func getSelector, double pixelErrorPercentageThreshold = 0, Action configurator = null) => - AssertVisualVerificationOnAllResolutions( - context, + context.AssertVisualVerificationOnAllResolutions( sizes, getSelector, pixelErrorPercentageThreshold, - configurator: configuration => configuration.WithUsePlatformAsSuffix()); + configuration => configuration.WithUsePlatformAsSuffix()); /// /// Compares the baseline image and screenshot of the whole page.