2022-01-21 20:41:47 +01:00
|
|
|
// Checks that the search results have the expected width.
|
2022-10-07 20:17:05 +02:00
|
|
|
goto: "file://" + |DOC_PATH| + "/test_docs/index.html"
|
2021-05-22 16:41:26 +02:00
|
|
|
size: (900, 1000)
|
|
|
|
write: (".search-input", "test")
|
2022-07-16 13:53:43 +02:00
|
|
|
// To be SURE that the search will be run.
|
|
|
|
press-key: 'Enter'
|
2022-08-10 15:50:20 +02:00
|
|
|
wait-for: "#crate-search"
|
2021-05-22 16:41:26 +02:00
|
|
|
// The width is returned by "getComputedStyle" which returns the exact number instead of the
|
|
|
|
// CSS rule which is "50%"...
|
2022-11-04 12:34:24 -07:00
|
|
|
assert-css: (".search-results div.desc", {"width": "310px"})
|
2021-05-22 16:41:26 +02:00
|
|
|
size: (600, 100)
|
|
|
|
// As counter-intuitive as it may seem, in this width, the width is "100%", which is why
|
|
|
|
// when computed it's larger.
|
2022-09-09 11:48:43 -07:00
|
|
|
assert-css: (".search-results div.desc", {"width": "566px"})
|
2022-07-09 15:54:36 +02:00
|
|
|
|
2022-09-12 14:04:11 -07:00
|
|
|
// The result set is all on one line.
|
|
|
|
assert-css: (".search-results .result-name > span", {"display": "inline"})
|
|
|
|
|
2022-07-09 15:54:36 +02:00
|
|
|
// Check that the crate filter `<select>` is correctly handled when it goes to next line.
|
|
|
|
// To do so we need to update the length of one of its `<option>`.
|
|
|
|
size: (900, 900)
|
|
|
|
|
2022-08-10 15:50:20 +02:00
|
|
|
// First we check the current width, height and position.
|
|
|
|
assert-css: ("#crate-search", {"width": "223px"})
|
2023-02-12 12:27:40 -07:00
|
|
|
assert-css: (".search-results-title", {"height": "50px", "width": "640px"})
|
2022-11-23 13:28:06 -07:00
|
|
|
assert-css: ("#search", {"width": "640px"})
|
2022-07-09 15:54:36 +02:00
|
|
|
|
2022-08-10 15:50:20 +02:00
|
|
|
// Then we update the text of one of the `<option>`.
|
|
|
|
text: (
|
|
|
|
"#crate-search option",
|
|
|
|
"sdjfaksdjfaksjdbfkadsbfkjsadbfkdsbkfbsadkjfbkdsabfkadsfkjdsafa",
|
|
|
|
)
|
2022-07-09 15:54:36 +02:00
|
|
|
|
2022-08-10 15:50:20 +02:00
|
|
|
// Then we compare again to confirm the height didn't change.
|
|
|
|
assert-css: ("#crate-search", {"width": "527px"})
|
2023-02-12 12:27:40 -07:00
|
|
|
assert-css: (".search-results-title", {"height": "50px", "width": "640px"})
|
2022-08-10 15:50:20 +02:00
|
|
|
// And we check that the `<select>` isn't bigger than its container (".search-results-title").
|
|
|
|
assert-css: ("#search", {"width": "640px"})
|
2022-11-07 18:08:24 +01:00
|
|
|
|
|
|
|
// Now checking that the crate filter is working as expected too.
|
|
|
|
show-text: true
|
|
|
|
define-function: (
|
|
|
|
"check-filter",
|
|
|
|
(theme, border, filter, hover_border, hover_filter),
|
2023-01-06 15:18:51 +01:00
|
|
|
block {
|
|
|
|
local-storage: {"rustdoc-theme": |theme|, "rustdoc-use-system-theme": "false"}
|
|
|
|
reload:
|
|
|
|
wait-for: "#crate-search"
|
|
|
|
assert-css: ("#crate-search", {"border": "1px solid " + |border|})
|
|
|
|
assert-css: ("#crate-search-div::after", {"filter": |filter|})
|
|
|
|
move-cursor-to: "#crate-search"
|
|
|
|
assert-css: ("#crate-search", {"border": "1px solid " + |hover_border|})
|
|
|
|
assert-css: ("#crate-search-div::after", {"filter": |hover_filter|})
|
|
|
|
move-cursor-to: ".search-input"
|
|
|
|
},
|
2022-11-07 18:08:24 +01:00
|
|
|
)
|
|
|
|
|
|
|
|
call-function: ("check-filter", {
|
|
|
|
"theme": "ayu",
|
|
|
|
"border": "rgb(92, 103, 115)",
|
|
|
|
"filter": "invert(0.41) sepia(0.12) saturate(4.87) hue-rotate(171deg) brightness(0.94) contrast(0.94)",
|
|
|
|
"hover_border": "rgb(224, 224, 224)",
|
|
|
|
"hover_filter": "invert(0.98) sepia(0.12) saturate(0.81) hue-rotate(343deg) brightness(1.13) contrast(0.76)",
|
|
|
|
})
|
|
|
|
call-function: ("check-filter", {
|
|
|
|
"theme": "dark",
|
|
|
|
"border": "rgb(224, 224, 224)",
|
|
|
|
"filter": "invert(0.94) sepia(0) saturate(7.21) hue-rotate(255deg) brightness(0.9) contrast(0.9)",
|
|
|
|
"hover_border": "rgb(33, 150, 243)",
|
|
|
|
"hover_filter": "invert(0.69) sepia(0.6) saturate(66.13) hue-rotate(184deg) brightness(1) contrast(0.91)",
|
|
|
|
})
|
|
|
|
call-function: ("check-filter", {
|
|
|
|
"theme": "light",
|
|
|
|
"border": "rgb(224, 224, 224)",
|
|
|
|
"filter": "invert(1) sepia(0) saturate(42.23) hue-rotate(289deg) brightness(1.14) contrast(0.76)",
|
|
|
|
"hover_border": "rgb(113, 113, 113)",
|
|
|
|
"hover_filter": "invert(0.44) sepia(0.18) saturate(0.23) hue-rotate(317deg) brightness(0.96) contrast(0.93)",
|
|
|
|
})
|