2021-10-19 11:42:59 +02:00
|
|
|
// Checks that the setting "line numbers" is working as expected.
|
2024-04-05 21:38:55 +02:00
|
|
|
include: "utils.goml"
|
2023-04-11 19:11:34 +02:00
|
|
|
go-to: "file://" + |DOC_PATH| + "/test_docs/fn.foo.html"
|
2021-10-19 11:42:59 +02:00
|
|
|
|
|
|
|
// We check that without this setting, there is no line number displayed.
|
2022-09-26 10:50:51 -07:00
|
|
|
assert-false: "pre.example-line-numbers"
|
2021-10-19 11:42:59 +02:00
|
|
|
|
2024-08-31 22:28:56 +02:00
|
|
|
// All corners should be rounded.
|
|
|
|
assert-css: (
|
|
|
|
".example-wrap .rust",
|
|
|
|
{
|
|
|
|
"border-top-left-radius": "6px",
|
|
|
|
"border-bottom-left-radius": "6px",
|
|
|
|
"border-top-right-radius": "6px",
|
|
|
|
"border-bottom-right-radius": "6px",
|
|
|
|
},
|
|
|
|
ALL,
|
|
|
|
)
|
|
|
|
|
2024-04-08 12:14:41 +02:00
|
|
|
// We set the setting to show the line numbers on code examples.
|
|
|
|
set-local-storage: {"rustdoc-line-numbers": "true"}
|
|
|
|
reload:
|
|
|
|
// We wait for the line numbers to be added into the DOM by the JS...
|
|
|
|
wait-for: "pre.example-line-numbers"
|
|
|
|
|
|
|
|
// Otherwise, we can't check text color
|
|
|
|
show-text: true
|
|
|
|
|
2021-10-19 11:42:59 +02:00
|
|
|
// Let's now check some CSS properties...
|
2022-12-23 22:55:04 -07:00
|
|
|
define-function: (
|
|
|
|
"check-colors",
|
2024-04-01 21:11:22 +02:00
|
|
|
[theme, color],
|
2023-01-06 15:18:51 +01:00
|
|
|
block {
|
2024-04-05 21:38:55 +02:00
|
|
|
// Page will be reloaded in "switch-theme".
|
|
|
|
call-function: ("switch-theme", {"theme": |theme|})
|
2022-12-23 22:55:04 -07:00
|
|
|
// If the test didn't fail, it means that it was found!
|
2023-01-06 15:18:51 +01:00
|
|
|
assert-css: (
|
2022-12-23 22:55:04 -07:00
|
|
|
"pre.example-line-numbers",
|
|
|
|
{
|
|
|
|
"color": |color|,
|
|
|
|
"margin": "0px",
|
|
|
|
"padding": "14px 8px",
|
|
|
|
"text-align": "right",
|
2024-08-31 22:28:56 +02:00
|
|
|
// There should not be a radius on the right of the line numbers.
|
|
|
|
"border-top-left-radius": "6px",
|
|
|
|
"border-bottom-left-radius": "6px",
|
|
|
|
"border-top-right-radius": "0px",
|
|
|
|
"border-bottom-right-radius": "0px",
|
2022-12-23 22:55:04 -07:00
|
|
|
},
|
|
|
|
ALL,
|
2023-01-06 15:18:51 +01:00
|
|
|
)
|
2024-08-31 22:28:56 +02:00
|
|
|
// There should not be a radius on the left of the line numbers.
|
|
|
|
assert-css: ("pre.example-line-numbers + .rust", {
|
|
|
|
"border-top-left-radius": "0px",
|
|
|
|
"border-bottom-left-radius": "0px",
|
|
|
|
"border-top-right-radius": "6px",
|
|
|
|
"border-bottom-right-radius": "6px",
|
|
|
|
})
|
2023-01-06 15:18:51 +01:00
|
|
|
},
|
2022-12-23 22:55:04 -07:00
|
|
|
)
|
|
|
|
call-function: ("check-colors", {
|
|
|
|
"theme": "ayu",
|
2023-06-25 10:49:28 +02:00
|
|
|
"color": "#5c6773",
|
2021-10-19 11:42:59 +02:00
|
|
|
})
|
2022-12-23 22:55:04 -07:00
|
|
|
call-function: ("check-colors", {
|
|
|
|
"theme": "dark",
|
2023-06-25 10:49:28 +02:00
|
|
|
"color": "#3b91e2",
|
2022-12-23 22:55:04 -07:00
|
|
|
})
|
|
|
|
call-function: ("check-colors", {
|
|
|
|
"theme": "light",
|
2023-06-25 10:49:28 +02:00
|
|
|
"color": "#c67e2d",
|
2022-12-23 22:55:04 -07:00
|
|
|
})
|
|
|
|
|
2021-10-19 11:42:59 +02:00
|
|
|
// The first code block has two lines so let's check its `<pre>` elements lists both of them.
|
2022-09-26 10:50:51 -07:00
|
|
|
assert-text: ("pre.example-line-numbers", "1\n2")
|
2022-09-21 15:43:38 -07:00
|
|
|
|
|
|
|
// Now, try changing the setting dynamically. We'll turn it off, using the settings menu,
|
|
|
|
// and make sure it goes away.
|
|
|
|
|
|
|
|
// First, open the settings menu.
|
|
|
|
click: "#settings-menu"
|
|
|
|
wait-for: "#settings"
|
|
|
|
assert-css: ("#settings", {"display": "block"})
|
|
|
|
|
|
|
|
// Then, click the toggle button.
|
2022-11-10 16:51:14 -07:00
|
|
|
click: "input#line-numbers"
|
2022-09-21 15:43:38 -07:00
|
|
|
wait-for: 100 // wait-for-false does not exist
|
2022-09-26 10:50:51 -07:00
|
|
|
assert-false: "pre.example-line-numbers"
|
2022-12-12 22:49:19 +01:00
|
|
|
assert-local-storage: {"rustdoc-line-numbers": "false" }
|
2022-09-21 15:43:38 -07:00
|
|
|
|
2024-08-31 22:28:56 +02:00
|
|
|
// Check that the rounded corners are back.
|
|
|
|
assert-css: (
|
|
|
|
".example-wrap .rust",
|
|
|
|
{
|
|
|
|
"border-top-left-radius": "6px",
|
|
|
|
"border-bottom-left-radius": "6px",
|
|
|
|
"border-top-right-radius": "6px",
|
|
|
|
"border-bottom-right-radius": "6px",
|
|
|
|
},
|
|
|
|
ALL,
|
|
|
|
)
|
|
|
|
|
2022-09-21 15:43:38 -07:00
|
|
|
// Finally, turn it on again.
|
2022-11-10 16:51:14 -07:00
|
|
|
click: "input#line-numbers"
|
2022-09-26 10:50:51 -07:00
|
|
|
wait-for: "pre.example-line-numbers"
|
2022-12-12 22:49:19 +01:00
|
|
|
assert-local-storage: {"rustdoc-line-numbers": "true" }
|
2024-08-31 22:28:56 +02:00
|
|
|
|
|
|
|
// Same check with scraped examples line numbers.
|
|
|
|
go-to: "file://" + |DOC_PATH| + "/scrape_examples/fn.test_many.html"
|
|
|
|
|
|
|
|
assert-css: (
|
|
|
|
".scraped-example pre.src-line-numbers",
|
|
|
|
{
|
|
|
|
// There should not be a radius on the right of the line numbers.
|
|
|
|
"border-top-left-radius": "6px",
|
|
|
|
"border-bottom-left-radius": "6px",
|
|
|
|
"border-top-right-radius": "0px",
|
|
|
|
"border-bottom-right-radius": "0px",
|
|
|
|
},
|
|
|
|
ALL,
|
|
|
|
)
|
|
|
|
assert-css: (
|
|
|
|
".scraped-example .rust",
|
|
|
|
{
|
|
|
|
// There should not be a radius on the left of the code.
|
|
|
|
"border-top-left-radius": "0px",
|
|
|
|
"border-bottom-left-radius": "0px",
|
|
|
|
"border-top-right-radius": "6px",
|
|
|
|
"border-bottom-right-radius": "6px",
|
|
|
|
},
|
|
|
|
ALL,
|
|
|
|
)
|