Avi Drissman | 4e1b7bc3 | 2022-09-15 14:03:50 | [diff] [blame] | 1 | // Copyright 2019 The Chromium Authors |
Joey Arhar | 71a7c70 | 2020-01-03 01:18:29 | [diff] [blame] | 2 | // Use of this source code is governed by a BSD-style license that can be |
| 3 | // found in the LICENSE file. |
| 4 | |
Joey Arhar | fee2db4 | 2020-07-31 21:07:11 | [diff] [blame] | 5 | #include "base/files/file_util.h" |
Joey Arhar | 71a7c70 | 2020-01-03 01:18:29 | [diff] [blame] | 6 | #include "base/path_service.h" |
kylechar | 43c1b32 | 2025-02-04 14:09:47 | [diff] [blame] | 7 | #include "base/test/scoped_feature_list.h" |
Filip Gorski | ed6f8f3e | 2020-04-14 03:07:23 | [diff] [blame] | 8 | #include "build/build_config.h" |
| 9 | #include "cc/test/pixel_comparator.h" |
Joey Arhar | fee2db4 | 2020-07-31 21:07:11 | [diff] [blame] | 10 | #include "content/public/browser/render_widget_host_view.h" |
Joey Arhar | 71a7c70 | 2020-01-03 01:18:29 | [diff] [blame] | 11 | #include "content/public/common/content_paths.h" |
Lei Zhang | 5b0ddd0 | 2021-04-01 04:27:56 | [diff] [blame] | 12 | #include "content/public/common/content_switches.h" |
Peter Kasting | 919ce65 | 2020-05-07 10:22:36 | [diff] [blame] | 13 | #include "content/public/test/browser_test.h" |
Joey Arhar | 71a7c70 | 2020-01-03 01:18:29 | [diff] [blame] | 14 | #include "content/public/test/browser_test_utils.h" |
| 15 | #include "content/public/test/content_browser_test.h" |
| 16 | #include "content/public/test/content_browser_test_utils.h" |
| 17 | #include "content/public/test/test_utils.h" |
| 18 | #include "content/shell/browser/shell.h" |
Colin Blundell | bf6aaf7 | 2023-11-07 15:06:01 | [diff] [blame] | 19 | #include "gpu/config/gpu_finch_features.h" |
Joey Arhar | 71a7c70 | 2020-01-03 01:18:29 | [diff] [blame] | 20 | #include "ui/base/ui_base_features.h" |
Ionel Popescu | a8b4adb | 2021-01-15 01:08:34 | [diff] [blame] | 21 | #include "ui/base/ui_base_switches.h" |
Joey Arhar | 71a7c70 | 2020-01-03 01:18:29 | [diff] [blame] | 22 | |
Xiaohan Wang | 1ecfd00 | 2022-01-19 22:33:10 | [diff] [blame] | 23 | #if BUILDFLAG(IS_ANDROID) |
Andrew Grieve | 7bd9a4b | 2025-08-11 21:29:42 | [diff] [blame] | 24 | #include "base/android/android_info.h" |
Joey Arhar | fee2db4 | 2020-07-31 21:07:11 | [diff] [blame] | 25 | #endif |
| 26 | |
Alison Gale | 81f4f2c7 | 2024-04-22 19:33:31 | [diff] [blame] | 27 | // TODO(crbug.com/40625383): Move the baselines to skia gold for easier |
Joey Arhar | fee2db4 | 2020-07-31 21:07:11 | [diff] [blame] | 28 | // rebaselining when all platforms are supported. |
| 29 | |
| 30 | // To rebaseline this test on all platforms: |
| 31 | // 1. Run a CQ+1 dry run. |
| 32 | // 2. Click the failing bots for android, windows, mac, and linux. |
Aleks Totic | 3e3d947 | 2021-06-28 20:50:59 | [diff] [blame] | 33 | // 3. Find the failing content_browsertests step. |
Joey Arhar | fee2db4 | 2020-07-31 21:07:11 | [diff] [blame] | 34 | // 4. Click the "Deterministic failure" link for the failing test case. |
| 35 | // 5. Copy the "Actual pixels" data url and paste into browser. |
| 36 | // 6. Save the image into your chromium checkout in content/test/data/forms/. |
Joey Arhar | 71a7c70 | 2020-01-03 01:18:29 | [diff] [blame] | 37 | |
| 38 | namespace content { |
| 39 | |
| 40 | class FormControlsBrowserTest : public ContentBrowserTest { |
| 41 | public: |
kylechar | 43c1b32 | 2025-02-04 14:09:47 | [diff] [blame] | 42 | FormControlsBrowserTest() { |
| 43 | #if BUILDFLAG(IS_ANDROID) |
| 44 | // TODO(crbug.com/391378106): On Android the graphite results are different |
| 45 | // enough to need separate expected images. Force using ganesh until either |
| 46 | // all Android bots are running graphite or these tests support skia gold. |
| 47 | feature_list_.InitAndDisableFeature(features::kSkiaGraphite); |
| 48 | #endif |
| 49 | } |
| 50 | |
Joey Arhar | 71a7c70 | 2020-01-03 01:18:29 | [diff] [blame] | 51 | void SetUp() override { |
Joey Arhar | fee2db4 | 2020-07-31 21:07:11 | [diff] [blame] | 52 | EnablePixelOutput(/*force_device_scale_factor=*/1.f); |
Joey Arhar | 71a7c70 | 2020-01-03 01:18:29 | [diff] [blame] | 53 | ContentBrowserTest::SetUp(); |
| 54 | } |
| 55 | |
| 56 | void SetUpCommandLine(base::CommandLine* command_line) override { |
Joey Arhar | fee2db4 | 2020-07-31 21:07:11 | [diff] [blame] | 57 | // The --disable-lcd-text flag helps text render more similarly on |
| 58 | // different bots and platform. |
| 59 | command_line->AppendSwitch(switches::kDisableLCDText); |
Ionel Popescu | a8b4adb | 2021-01-15 01:08:34 | [diff] [blame] | 60 | |
| 61 | // This is required to allow dark mode to be used on some platforms. |
| 62 | command_line->AppendSwitch(switches::kForceDarkMode); |
Joey Arhar | 71a7c70 | 2020-01-03 01:18:29 | [diff] [blame] | 63 | } |
| 64 | |
Joey Arhar | fee2db4 | 2020-07-31 21:07:11 | [diff] [blame] | 65 | void RunTest(const std::string& screenshot_filename, |
| 66 | const std::string& body_html, |
| 67 | int screenshot_width, |
| 68 | int screenshot_height) { |
Hitoshi Yoshida | 5373889 | 2020-07-28 03:00:52 | [diff] [blame] | 69 | base::ScopedAllowBlockingForTesting allow_blocking; |
Joey Arhar | fee2db4 | 2020-07-31 21:07:11 | [diff] [blame] | 70 | |
Joey Arhar | fee2db4 | 2020-07-31 21:07:11 | [diff] [blame] | 71 | std::string platform_suffix; |
Xiaohan Wang | 1ecfd00 | 2022-01-19 22:33:10 | [diff] [blame] | 72 | #if BUILDFLAG(IS_MAC) |
Joey Arhar | fee2db4 | 2020-07-31 21:07:11 | [diff] [blame] | 73 | platform_suffix = "_mac"; |
Xiaohan Wang | 1ecfd00 | 2022-01-19 22:33:10 | [diff] [blame] | 74 | #elif BUILDFLAG(IS_WIN) |
Joey Arhar | fee2db4 | 2020-07-31 21:07:11 | [diff] [blame] | 75 | platform_suffix = "_win"; |
Xiaohan Wang | 1ecfd00 | 2022-01-19 22:33:10 | [diff] [blame] | 76 | #elif BUILDFLAG(IS_LINUX) |
Peng Huang | 292a2a18 | 2021-09-27 19:43:23 | [diff] [blame] | 77 | platform_suffix = "_linux"; |
Xiaohan Wang | 1ecfd00 | 2022-01-19 22:33:10 | [diff] [blame] | 78 | #elif BUILDFLAG(IS_CHROMEOS) |
Joey Arhar | fee2db4 | 2020-07-31 21:07:11 | [diff] [blame] | 79 | platform_suffix = "_chromeos"; |
Xiaohan Wang | 1ecfd00 | 2022-01-19 22:33:10 | [diff] [blame] | 80 | #elif BUILDFLAG(IS_ANDROID) |
Andrew Grieve | 7bd9a4b | 2025-08-11 21:29:42 | [diff] [blame] | 81 | int sdk_int = base::android::android_info::sdk_int(); |
| 82 | if (sdk_int >= base::android::android_info::SDK_VERSION_T) { |
Michael Thiessen | 634dba1b | 2024-06-27 13:47:24 | [diff] [blame] | 83 | platform_suffix = "_android_T"; |
Joey Arhar | fee2db4 | 2020-07-31 21:07:11 | [diff] [blame] | 84 | } else { |
| 85 | platform_suffix = "_android"; |
| 86 | } |
Xiaohan Wang | 1ecfd00 | 2022-01-19 22:33:10 | [diff] [blame] | 87 | #elif BUILDFLAG(IS_FUCHSIA) |
Fabrice de Gans | 749a41c4 | 2021-10-18 19:32:08 | [diff] [blame] | 88 | platform_suffix = "_fuchsia"; |
Ian Vollick | ecc53b77 | 2023-06-15 15:47:24 | [diff] [blame] | 89 | #elif BUILDFLAG(IS_IOS) |
| 90 | platform_suffix = "_ios"; |
Joey Arhar | fee2db4 | 2020-07-31 21:07:11 | [diff] [blame] | 91 | #endif |
Filip Gorski | ed6f8f3e | 2020-04-14 03:07:23 | [diff] [blame] | 92 | |
Joey Arhar | 71a7c70 | 2020-01-03 01:18:29 | [diff] [blame] | 93 | base::FilePath dir_test_data; |
| 94 | ASSERT_TRUE(base::PathService::Get(DIR_TEST_DATA, &dir_test_data)); |
Joey Arhar | fee2db4 | 2020-07-31 21:07:11 | [diff] [blame] | 95 | base::FilePath golden_filepath = |
| 96 | dir_test_data.AppendASCII("forms").AppendASCII(screenshot_filename + |
| 97 | ".png"); |
Hitoshi Yoshida | 5373889 | 2020-07-28 03:00:52 | [diff] [blame] | 98 | |
Joey Arhar | fee2db4 | 2020-07-31 21:07:11 | [diff] [blame] | 99 | base::FilePath golden_filepath_platform = |
| 100 | golden_filepath.InsertBeforeExtensionASCII(platform_suffix); |
| 101 | if (base::PathExists(golden_filepath_platform)) { |
| 102 | golden_filepath = golden_filepath_platform; |
| 103 | } |
| 104 | |
Ionel Popescu | a8b4adb | 2021-01-15 01:08:34 | [diff] [blame] | 105 | ASSERT_TRUE( |
| 106 | NavigateToURL(shell()->web_contents(), |
| 107 | GURL("data:text/html,<!DOCTYPE html>" + body_html))); |
Joey Arhar | fee2db4 | 2020-07-31 21:07:11 | [diff] [blame] | 108 | |
Ian Vollick | ecc53b77 | 2023-06-15 15:47:24 | [diff] [blame] | 109 | #if BUILDFLAG(IS_APPLE) |
Joey Arhar | fee2db4 | 2020-07-31 21:07:11 | [diff] [blame] | 110 | // This fuzzy pixel comparator handles several mac behaviors: |
| 111 | // - Different font rendering after 10.14 |
Joey Arhar | fee2db4 | 2020-07-31 21:07:11 | [diff] [blame] | 112 | // - Slight differences in radio and checkbox rendering in 10.15 |
Xianzhu Wang | 43fe444 | 2023-01-24 23:59:09 | [diff] [blame] | 113 | // TODO(wangxianzhu): Tighten these parameters. |
| 114 | auto comparator = cc::FuzzyPixelComparator() |
| 115 | .DiscardAlpha() |
Alex Ilin | 4b0deea | 2023-01-30 16:56:00 | [diff] [blame] | 116 | .SetErrorPixelsPercentageLimit(26.f) |
Xianzhu Wang | 43fe444 | 2023-01-24 23:59:09 | [diff] [blame] | 117 | .SetAvgAbsErrorLimit(20.f) |
Alex Ilin | 4b0deea | 2023-01-30 16:56:00 | [diff] [blame] | 118 | .SetAbsErrorLimit(120); |
Xiaohan Wang | 1ecfd00 | 2022-01-19 22:33:10 | [diff] [blame] | 119 | #elif BUILDFLAG(IS_ANDROID) || BUILDFLAG(IS_WIN) || (OS_LINUX) || \ |
| 120 | BUILDFLAG(IS_FUCHSIA) |
Joey Arhar | fee2db4 | 2020-07-31 21:07:11 | [diff] [blame] | 121 | // Different versions of android may have slight differences in rendering. |
| 122 | // Some versions have more significant differences than others, which are |
| 123 | // tracked separately in separate baseline image files. The less significant |
| 124 | // differences are accommodated for with this fuzzy pixel comparator. |
Xianzhu Wang | 43fe444 | 2023-01-24 23:59:09 | [diff] [blame] | 125 | // This also applies to different versions of other OSes. |
| 126 | auto comparator = cc::FuzzyPixelComparator() |
| 127 | .DiscardAlpha() |
Alex Ilin | 4b0deea | 2023-01-30 16:56:00 | [diff] [blame] | 128 | .SetErrorPixelsPercentageLimit(11.f) |
Michael Ludwig | 64abcf4 | 2025-08-05 10:37:15 | [diff] [blame] | 129 | .SetAvgAbsErrorLimit(12.f) |
Alex Ilin | 4b0deea | 2023-01-30 16:56:00 | [diff] [blame] | 130 | .SetAbsErrorLimit(140); |
Hitoshi Yoshida | 5373889 | 2020-07-28 03:00:52 | [diff] [blame] | 131 | #else |
Xianzhu Wang | 43fe444 | 2023-01-24 23:59:09 | [diff] [blame] | 132 | cc::AlphaDiscardingExactPixelComparator comparator; |
Hitoshi Yoshida | 5373889 | 2020-07-28 03:00:52 | [diff] [blame] | 133 | #endif |
Joey Arhar | fee2db4 | 2020-07-31 21:07:11 | [diff] [blame] | 134 | EXPECT_TRUE(CompareWebContentsOutputToReference( |
| 135 | shell()->web_contents(), golden_filepath, |
| 136 | gfx::Size(screenshot_width, screenshot_height), comparator)); |
Joey Arhar | 71a7c70 | 2020-01-03 01:18:29 | [diff] [blame] | 137 | } |
| 138 | |
Yu Han | 26a105a | 2021-02-09 22:05:32 | [diff] [blame] | 139 | // Check if the test can run on the current system. |
Yu Han | 87d8dc8 | 2021-02-11 08:15:44 | [diff] [blame] | 140 | bool SkipTestForOldAndroidVersions() const { |
Xiaohan Wang | 1ecfd00 | 2022-01-19 22:33:10 | [diff] [blame] | 141 | #if BUILDFLAG(IS_ANDROID) |
Yu Han | 26a105a | 2021-02-09 22:05:32 | [diff] [blame] | 142 | // Lower versions of android running on older devices, ex Nexus 5, render |
| 143 | // form controls with a too large of a difference -- >20% error -- to |
| 144 | // pixel compare. |
Andrew Grieve | 7bd9a4b | 2025-08-11 21:29:42 | [diff] [blame] | 145 | if (base::android::android_info::sdk_int() < |
| 146 | base::android::android_info::SDK_VERSION_OREO) { |
Yu Han | 87d8dc8 | 2021-02-11 08:15:44 | [diff] [blame] | 147 | return true; |
Yu Han | 26a105a | 2021-02-09 22:05:32 | [diff] [blame] | 148 | } |
Xiaohan Wang | 1ecfd00 | 2022-01-19 22:33:10 | [diff] [blame] | 149 | #endif // BUILDFLAG(IS_ANDROID) |
Yu Han | 87d8dc8 | 2021-02-11 08:15:44 | [diff] [blame] | 150 | return false; |
Yu Han | 26a105a | 2021-02-09 22:05:32 | [diff] [blame] | 151 | } |
kylechar | 43c1b32 | 2025-02-04 14:09:47 | [diff] [blame] | 152 | |
| 153 | base::test::ScopedFeatureList feature_list_; |
Joey Arhar | 71a7c70 | 2020-01-03 01:18:29 | [diff] [blame] | 154 | }; |
| 155 | |
Aleks Totic | 55ee62c4 | 2021-08-19 22:50:28 | [diff] [blame] | 156 | // Checkbox renders differently on Android x86. crbug.com/1238283 |
Christoph Schwering | 046f1e33 | 2025-03-14 19:26:55 | [diff] [blame] | 157 | // TODO(crbug.com/401594933): The test fails on Windows ARM64. |
| 158 | #if (BUILDFLAG(IS_ANDROID) && defined(ARCH_CPU_X86)) || \ |
| 159 | (BUILDFLAG(IS_WIN) && defined(ARCH_CPU_ARM64)) |
Aleks Totic | 55ee62c4 | 2021-08-19 22:50:28 | [diff] [blame] | 160 | #define MAYBE_Checkbox DISABLED_Checkbox |
| 161 | #else |
| 162 | #define MAYBE_Checkbox Checkbox |
| 163 | #endif |
Aleks Totic | 55ee62c4 | 2021-08-19 22:50:28 | [diff] [blame] | 164 | IN_PROC_BROWSER_TEST_F(FormControlsBrowserTest, MAYBE_Checkbox) { |
Alex Ilin | 4b0deea | 2023-01-30 16:56:00 | [diff] [blame] | 165 | if (SkipTestForOldAndroidVersions()) |
| 166 | return; |
Yu Han | 26a105a | 2021-02-09 22:05:32 | [diff] [blame] | 167 | |
Joey Arhar | fee2db4 | 2020-07-31 21:07:11 | [diff] [blame] | 168 | RunTest("form_controls_browsertest_checkbox", |
| 169 | "<input type=checkbox>" |
| 170 | "<input type=checkbox checked>" |
| 171 | "<input type=checkbox disabled>" |
| 172 | "<input type=checkbox checked disabled>" |
| 173 | "<input type=checkbox id=\"indeterminate\">" |
| 174 | "<script>" |
| 175 | " document.getElementById('indeterminate').indeterminate = true" |
| 176 | "</script>", |
| 177 | /* screenshot_width */ 130, |
| 178 | /* screenshot_height */ 40); |
Joey Arhar | 71a7c70 | 2020-01-03 01:18:29 | [diff] [blame] | 179 | } |
| 180 | |
Yu Han | 26a105a | 2021-02-09 22:05:32 | [diff] [blame] | 181 | IN_PROC_BROWSER_TEST_F(FormControlsBrowserTest, Radio) { |
Alex Ilin | 4b0deea | 2023-01-30 16:56:00 | [diff] [blame] | 182 | if (SkipTestForOldAndroidVersions()) |
| 183 | return; |
Yu Han | 26a105a | 2021-02-09 22:05:32 | [diff] [blame] | 184 | |
Joey Arhar | fee2db4 | 2020-07-31 21:07:11 | [diff] [blame] | 185 | RunTest("form_controls_browsertest_radio", |
| 186 | "<input type=radio>" |
| 187 | "<input type=radio checked>" |
| 188 | "<input type=radio disabled>" |
| 189 | "<input type=radio checked disabled>" |
| 190 | "<input type=radio id=\"indeterminate\">" |
| 191 | "<script>" |
| 192 | " document.getElementById('indeterminate').indeterminate = true" |
| 193 | "</script>", |
| 194 | /* screenshot_width */ 140, |
| 195 | /* screenshot_height */ 40); |
Joey Arhar | 71a7c70 | 2020-01-03 01:18:29 | [diff] [blame] | 196 | } |
| 197 | |
Kaylee Lubick | b2616d0d | 2025-03-10 15:10:51 | [diff] [blame] | 198 | #if BUILDFLAG(IS_MAC) |
Joey Arhar | b5660eb | 2023-05-13 00:23:54 | [diff] [blame] | 199 | #define MAYBE_DarkModeTextSelection DISABLED_DarkModeTextSelection |
| 200 | #else |
| 201 | #define MAYBE_DarkModeTextSelection DarkModeTextSelection |
| 202 | #endif |
| 203 | IN_PROC_BROWSER_TEST_F(FormControlsBrowserTest, MAYBE_DarkModeTextSelection) { |
Alex Ilin | 4b0deea | 2023-01-30 16:56:00 | [diff] [blame] | 204 | if (SkipTestForOldAndroidVersions()) |
| 205 | return; |
Yu Han | c107b26 | 2021-03-01 08:13:54 | [diff] [blame] | 206 | |
Ionel Popescu | a8b4adb | 2021-01-15 01:08:34 | [diff] [blame] | 207 | RunTest("form_controls_browsertest_dark_mode_text_selection", |
| 208 | "<meta name=\"color-scheme\" content=\"dark\">" |
| 209 | "<div id=\"target\">This is some basic text that we are going to " |
| 210 | "select.</div>" |
| 211 | "<script>" |
| 212 | " let container = document.getElementById('target');" |
| 213 | " container.focus();" |
| 214 | " let targetText = container.firstChild;" |
| 215 | " let selectionRange = window.getSelection();" |
| 216 | " selectionRange.setBaseAndExtent(targetText, 5, targetText, 35);" |
| 217 | "</script>", |
| 218 | /* screenshot_width */ 400, |
| 219 | /* screenshot_height */ 40); |
| 220 | } |
| 221 | |
Yu Han | c107b26 | 2021-03-01 08:13:54 | [diff] [blame] | 222 | IN_PROC_BROWSER_TEST_F(FormControlsBrowserTest, Input) { |
Alex Ilin | 4b0deea | 2023-01-30 16:56:00 | [diff] [blame] | 223 | if (SkipTestForOldAndroidVersions()) |
| 224 | return; |
Yu Han | c107b26 | 2021-03-01 08:13:54 | [diff] [blame] | 225 | |
Yu Han | ff3eeb2b | 2021-01-27 18:09:25 | [diff] [blame] | 226 | RunTest("form_controls_browsertest_input", |
Yu Han | ff3eeb2b | 2021-01-27 18:09:25 | [diff] [blame] | 227 | "<style>body {margin: 8px} input {width: 150px; " |
| 228 | "margin-bottom: 18px}</style>" |
| 229 | "<input type=\"text\" /><br>" |
| 230 | "<input type=\"number\" /><br>" |
| 231 | "<input type=\"search\" /><br>" |
| 232 | "<input type=\"email\" /><br>" |
| 233 | "<input type=\"password\" /><br>" |
| 234 | "<!-- border -->" |
| 235 | "<input type=\"text\" style=\"border: 3px solid lime;\"/><br>" |
| 236 | "<!-- shadow -->" |
| 237 | "<input type=\"text\" style=\"box-shadow: 4px 4px 10px " |
| 238 | "rgba(255,0,0,0.5), inset 4px 4px 4px rgba(0,255,0,0.5);\"/><br>" |
| 239 | "<!-- disabled -->" |
| 240 | "<input type=\"text\" disabled/>", |
| 241 | /* screenshot_width */ 200, |
| 242 | /* screenshot_height */ 330); |
| 243 | } |
| 244 | |
Christoph Schwering | 046f1e33 | 2025-03-14 19:26:55 | [diff] [blame] | 245 | // The test fails on Windows ARM64: crbug.com/401594933. |
| 246 | #if BUILDFLAG(IS_ANDROID) || BUILDFLAG(IS_CHROMEOS) || \ |
| 247 | (BUILDFLAG(IS_WIN) && defined(ARCH_CPU_ARM64)) |
Michael Wilson | 276c00c | 2024-02-13 18:35:17 | [diff] [blame] | 248 | #define MAYBE_Textarea DISABLED_Textarea |
| 249 | #else |
| 250 | #define MAYBE_Textarea Textarea |
| 251 | #endif |
| 252 | IN_PROC_BROWSER_TEST_F(FormControlsBrowserTest, MAYBE_Textarea) { |
Alex Ilin | 4b0deea | 2023-01-30 16:56:00 | [diff] [blame] | 253 | if (SkipTestForOldAndroidVersions()) |
| 254 | return; |
Yu Han | c107b26 | 2021-03-01 08:13:54 | [diff] [blame] | 255 | |
| 256 | RunTest("form_controls_browsertest_textarea", |
| 257 | R"HTML( |
| 258 | <style> |
| 259 | body {margin: 8px} textarea {width: 150px; margin-bottom: 18px} |
| 260 | </style> |
| 261 | <textarea></textarea><br> |
| 262 | <textarea style="border: 3px solid lime"></textarea><br> |
| 263 | <!-- shadow --> |
| 264 | <textarea style="box-shadow: 4px 4px 10px rgba(255,0,0,0.5), |
| 265 | inset 4px 4px 4px rgba(0,255,0,0.5);"></textarea><br> |
| 266 | <!-- disabled --> |
| 267 | <textarea disabled></textarea>)HTML", |
| 268 | /* screenshot_width */ 200, |
| 269 | /* screenshot_height */ 260); |
| 270 | } |
| 271 | |
| 272 | IN_PROC_BROWSER_TEST_F(FormControlsBrowserTest, Button) { |
Alex Ilin | 4b0deea | 2023-01-30 16:56:00 | [diff] [blame] | 273 | if (SkipTestForOldAndroidVersions()) |
| 274 | return; |
Yu Han | c107b26 | 2021-03-01 08:13:54 | [diff] [blame] | 275 | |
Yu Han | c107b26 | 2021-03-01 08:13:54 | [diff] [blame] | 276 | RunTest("form_controls_browsertest_button", |
| 277 | R"HTML( |
| 278 | <style>body {margin: 8px} input {margin-bottom: 18px;}</style> |
| 279 | <input type="button" value="button"/><br> |
| 280 | <input type="submit" /><br> |
| 281 | <input type="reset" /><br> |
| 282 | <input type="file" /><br> |
| 283 | <!-- border --> |
| 284 | <input type="button" value="button" |
| 285 | style="border: 3px solid lime;"/><br> |
| 286 | <!-- shadow --> |
| 287 | <input type="button" value="button" |
| 288 | style="box-shadow: 4px 4px 10px |
| 289 | rgba(255,0,0,0.5), inset 4px 4px 4px rgba(0,255,0,0.5);"/><br> |
| 290 | <!-- disabled --> |
| 291 | <input type="button" value="button" disabled/>)HTML", |
| 292 | /* screenshot_width */ 200, |
| 293 | /* screenshot_height */ 300); |
| 294 | } |
| 295 | |
Yu Han | 9dee550 | 2021-03-05 21:25:58 | [diff] [blame] | 296 | // TODO(crbug.com/1160104/#25) This test creates large average_error_rate on |
| 297 | // Android FYI SkiaRenderer Vulkan. Disable it until a resolution for is |
| 298 | // found. |
Christoph Schwering | 046f1e33 | 2025-03-14 19:26:55 | [diff] [blame] | 299 | // TODO(crbug.com/401594933): The test fails on Windows ARM64. |
David Baron | 21a012a | 2025-06-25 13:31:46 | [diff] [blame] | 300 | #if BUILDFLAG(IS_ANDROID) || (BUILDFLAG(IS_WIN) && defined(ARCH_CPU_ARM64)) |
Yu Han | 9dee550 | 2021-03-05 21:25:58 | [diff] [blame] | 301 | #define MAYBE_ColorInput DISABLED_ColorInput |
| 302 | #else |
| 303 | #define MAYBE_ColorInput ColorInput |
| 304 | #endif |
| 305 | IN_PROC_BROWSER_TEST_F(FormControlsBrowserTest, MAYBE_ColorInput) { |
Alex Ilin | 4b0deea | 2023-01-30 16:56:00 | [diff] [blame] | 306 | if (SkipTestForOldAndroidVersions()) |
| 307 | return; |
Yu Han | c107b26 | 2021-03-01 08:13:54 | [diff] [blame] | 308 | |
| 309 | RunTest("form_controls_browsertest_color_input", |
| 310 | R"HTML( |
| 311 | <style>body {margin: 8px} input {margin-bottom: 18px;}</style> |
| 312 | <input type="color" /><br> |
| 313 | <input type="color" value='%2300ff00' /><br> |
| 314 | <input type="color" list /><br> |
| 315 | <!-- border --> |
| 316 | <input type="color" value="%2300ff00" |
| 317 | style="border: 3px solid lime;"/><br> |
| 318 | <!-- disabled --> |
| 319 | <input type="color" disabled/>)HTML", |
| 320 | /* screenshot_width */ 200, |
| 321 | /* screenshot_height */ 250); |
| 322 | } |
| 323 | |
Christoph Schwering | 046f1e33 | 2025-03-14 19:26:55 | [diff] [blame] | 324 | // TODO(crbug.com/401594933): The test fails on Windows ARM64. |
| 325 | #if BUILDFLAG(IS_WIN) && defined(ARCH_CPU_ARM64) |
| 326 | #define MAYBE_Select DISABLED_Select |
| 327 | #else |
| 328 | #define MAYBE_Select DISABLED_Select |
| 329 | #endif |
| 330 | IN_PROC_BROWSER_TEST_F(FormControlsBrowserTest, MAYBE_Select) { |
Alex Ilin | 4b0deea | 2023-01-30 16:56:00 | [diff] [blame] | 331 | if (SkipTestForOldAndroidVersions()) |
| 332 | return; |
Yu Han | c107b26 | 2021-03-01 08:13:54 | [diff] [blame] | 333 | |
| 334 | RunTest("form_controls_browsertest_select", |
| 335 | R"HTML( |
| 336 | <style> |
| 337 | body {margin: 8px} |
| 338 | select {margin-bottom: 18px; width: 170px;} |
| 339 | </style> |
| 340 | <select></select><br> |
| 341 | <select style="color:darkturquoise"></select><br> |
| 342 | <!-- border --> |
| 343 | <select style="border: 3px solid lime;"></select><br> |
| 344 | <!-- shadow --> |
| 345 | <select style="box-shadow: 4px 4px 10px rgba(255,0,0,0.5), |
| 346 | inset 4px 4px 4px rgba(0,255,0,0.5);"></select><br> |
| 347 | <!-- disabled --> |
| 348 | <select disabled></select><br>)HTML", |
| 349 | /* screenshot_width */ 200, |
| 350 | /* screenshot_height */ 200); |
| 351 | } |
| 352 | |
Gastón Rodríguez | 947c41741 | 2025-02-21 16:46:29 | [diff] [blame] | 353 | // TODO(crbug.com/377986468) : Flaky on Windows. Seems to lose focus of top |
| 354 | // <select> in some runs which causes the results to be different from |
| 355 | // expectations. |
Vidhan Jain | d46b1ed1 | 2025-05-15 13:08:29 | [diff] [blame] | 356 | #if BUILDFLAG(IS_WIN) || BUILDFLAG(IS_CHROMEOS) |
Lei Zhang | 0cc6ac4 | 2024-11-15 21:40:27 | [diff] [blame] | 357 | #define MAYBE_MultiSelect DISABLED_MultiSelect |
| 358 | #else |
| 359 | #define MAYBE_MultiSelect MultiSelect |
| 360 | #endif |
| 361 | IN_PROC_BROWSER_TEST_F(FormControlsBrowserTest, MAYBE_MultiSelect) { |
Alex Ilin | 4b0deea | 2023-01-30 16:56:00 | [diff] [blame] | 362 | if (SkipTestForOldAndroidVersions()) |
| 363 | return; |
Yu Han | c107b26 | 2021-03-01 08:13:54 | [diff] [blame] | 364 | |
| 365 | RunTest("form_controls_browsertest_multi_select", |
| 366 | R"HTML( |
| 367 | <style> |
| 368 | body {margin: 8px} |
| 369 | select {margin-bottom: 18px; width: 170px; } |
| 370 | </style> |
| 371 | <select multiple autofocus size=5> |
| 372 | <optgroup label="unstyled select"></optgroup> |
| 373 | </select> <br> |
| 374 | <!-- border --> |
| 375 | <select multiple style="border: 3px solid lime;" size=5> |
| 376 | <optgroup label="thick lime border"></optgroup> |
| 377 | </select><br> |
| 378 | <!-- disabled --> |
| 379 | <select multiple disabled size=5> |
| 380 | <optgroup label="disabled select"> |
| 381 | </optgroup> |
| 382 | </select>)HTML", |
| 383 | /* screenshot_width */ 200, |
| 384 | /* screenshot_height */ 330); |
| 385 | } |
| 386 | |
| 387 | IN_PROC_BROWSER_TEST_F(FormControlsBrowserTest, Progress) { |
Alex Ilin | 4b0deea | 2023-01-30 16:56:00 | [diff] [blame] | 388 | if (SkipTestForOldAndroidVersions()) |
| 389 | return; |
Yu Han | c107b26 | 2021-03-01 08:13:54 | [diff] [blame] | 390 | |
Colin Blundell | 825adeba | 2023-11-08 12:39:38 | [diff] [blame] | 391 | #if BUILDFLAG(IS_MAC) && !defined(ARCH_CPU_ARM64) |
Colin Blundell | bf6aaf7 | 2023-11-07 15:06:01 | [diff] [blame] | 392 | // The pixel comparison fails on Mac Intel GPUs with Graphite due to MSAA |
| 393 | // issues. |
Alison Gale | 81f4f2c7 | 2024-04-22 19:33:31 | [diff] [blame] | 394 | // TODO(crbug.com/40940637): Re-enable test if possible. |
Colin Blundell | bf6aaf7 | 2023-11-07 15:06:01 | [diff] [blame] | 395 | if (features::IsSkiaGraphiteEnabled(base::CommandLine::ForCurrentProcess())) { |
| 396 | return; |
| 397 | } |
| 398 | #endif |
| 399 | |
Yu Han | c107b26 | 2021-03-01 08:13:54 | [diff] [blame] | 400 | RunTest("form_controls_browsertest_progress", |
| 401 | R"HTML( |
| 402 | <style> |
| 403 | body {margin: 8px} progress {margin-bottom: 18px} |
| 404 | </style> |
| 405 | <progress max="100" value="0"></progress><br> |
| 406 | <progress max="100" value="5"></progress><br> |
| 407 | <progress max="100" value="25"></progress><br><br> |
| 408 | <progress max="100" value="50"></progress><br><br> |
| 409 | <progress max="100" value="100"></progress><br><br> |
| 410 | <progress max="100" value="50" style="height:30px"></progress> |
| 411 | )HTML", |
| 412 | /* screenshot_width */ 200, |
| 413 | /* screenshot_height */ 300); |
| 414 | } |
| 415 | |
| 416 | IN_PROC_BROWSER_TEST_F(FormControlsBrowserTest, Meter) { |
Alex Ilin | 4b0deea | 2023-01-30 16:56:00 | [diff] [blame] | 417 | if (SkipTestForOldAndroidVersions()) |
| 418 | return; |
Yu Han | c107b26 | 2021-03-01 08:13:54 | [diff] [blame] | 419 | |
| 420 | RunTest("form_controls_browsertest_meter", |
| 421 | R"HTML( |
| 422 | <style> |
| 423 | body {margin: 8px} meter {margin-bottom: 10px} |
| 424 | </style> |
| 425 | <meter min="0" max="100" low="33" high="66" optimum="100" |
| 426 | value="20"></meter><br> |
| 427 | <meter min="0" max="100" low="33" high="66" optimum="100" |
| 428 | value="50"></meter><br> |
| 429 | <meter min="0" max="100" low="33" high="66" optimum="100" |
| 430 | value="66"></meter><br> |
| 431 | <meter min="0" max="100" low="33" high="66" optimum="100" |
| 432 | value="90"></meter><br> |
| 433 | <!-- border --> |
| 434 | <meter style="border-color: %23000000; border-style: solid; |
| 435 | border-width: 5px;" min="0" max="100" low="30" high="60" |
| 436 | optimum="100" value="80" ></meter><br> |
| 437 | <meter style="box-shadow: 4px 4px 10px rgba(255,0,0,0.5), |
| 438 | inset 4px 4px 4px rgba(0,255,0,0.5);"></meter>)HTML", |
| 439 | /* screenshot_width */ 150, |
| 440 | /* screenshot_height */ 200); |
| 441 | } |
| 442 | |
| 443 | IN_PROC_BROWSER_TEST_F(FormControlsBrowserTest, Range) { |
Alex Ilin | 4b0deea | 2023-01-30 16:56:00 | [diff] [blame] | 444 | if (SkipTestForOldAndroidVersions()) |
| 445 | return; |
Yu Han | c107b26 | 2021-03-01 08:13:54 | [diff] [blame] | 446 | |
| 447 | RunTest("form_controls_browsertest_range", |
| 448 | R"HTML( |
| 449 | <style> |
| 450 | body {margin: 8px} input {margin-bottom: 18px} |
| 451 | </style> |
| 452 | <input type="range"><br> |
| 453 | )HTML", |
| 454 | /* screenshot_width */ 150, |
| 455 | /* screenshot_height */ 150); |
| 456 | } |
| 457 | |
Joey Arhar | 71a7c70 | 2020-01-03 01:18:29 | [diff] [blame] | 458 | // TODO(jarhar): Add tests for other elements from |
| 459 | // https://concrete-hardboard.glitch.me |
| 460 | |
| 461 | } // namespace content |