diff options
Diffstat (limited to 'src/test/rustdoc-gui')
130 files changed, 0 insertions, 5699 deletions
diff --git a/src/test/rustdoc-gui/README.md b/src/test/rustdoc-gui/README.md deleted file mode 100644 index d9854e2e7..000000000 --- a/src/test/rustdoc-gui/README.md +++ /dev/null @@ -1,34 +0,0 @@ -The tests present here are used to test the generated HTML from rustdoc. The -goal is to prevent unsound/unexpected GUI changes. - -This is using the [browser-ui-test] framework to do so. It works as follows: - -It wraps [puppeteer] to send commands to a web browser in order to navigate and -test what's being currently displayed in the web page. - -You can find more information and its documentation in its [repository][browser-ui-test]. - -If you need to have more information on the tests run, you can use `--test-args`: - -```bash -$ ./x.py test src/test/rustdoc-gui --stage 1 --test-args --debug -``` - -If you don't want to run in headless mode (helpful to debug sometimes), you can use -`--no-headless`: - -```bash -$ ./x.py test src/test/rustdoc-gui --stage 1 --test-args --no-headless -``` - -To see the supported options, use `--help`. - -Important to be noted: if the chromium instance crashes when you run it, you might need to -use `--no-sandbox` to make it work: - -```bash -$ ./x.py test src/test/rustdoc-gui --stage 1 --test-args --no-sandbox -``` - -[browser-ui-test]: https://github.com/GuillaumeGomez/browser-UI-test/ -[puppeteer]: https://pptr.dev/ diff --git a/src/test/rustdoc-gui/anchor-navigable.goml b/src/test/rustdoc-gui/anchor-navigable.goml deleted file mode 100644 index 9d5c55a1e..000000000 --- a/src/test/rustdoc-gui/anchor-navigable.goml +++ /dev/null @@ -1,11 +0,0 @@ -// The `impl Foo` heading underneath `Implementations` has a § -// anchor to its left (used for linking to that heading). The anchor only shows -// up when hovering the `impl Foo`. This test ensures there's no gap between the -// anchor and the `impl Foo`. If there were a gap, this would cause an annoying -// problem: you hover `impl Foo` to see the anchor, then when you move your -// mouse to the left, the anchor disappears before you reach it. -goto: "file://" + |DOC_PATH| + "/test_docs/struct.Foo.html" -// We check that ".item-info" is bigger than its content. -move-cursor-to: ".impl" -assert-property: (".impl > a.anchor", {"offsetWidth": "8"}) -assert-css: (".impl > a.anchor", {"left": "-8px"}) diff --git a/src/test/rustdoc-gui/anchors.goml b/src/test/rustdoc-gui/anchors.goml deleted file mode 100644 index fb8e288fa..000000000 --- a/src/test/rustdoc-gui/anchors.goml +++ /dev/null @@ -1,107 +0,0 @@ -// This test is to ensure that the anchors (`§`) have the expected color and position. - -define-function: ( - "check-colors", - (theme, main_color, title_color, fqn_color, fqn_type_color, src_link_color, sidebar_link_color), - [ - ("goto", "file://" + |DOC_PATH| + "/staged_api/struct.Foo.html"), - // This is needed to ensure that the text color is computed. - ("show-text", true), - - // Setting the theme. - ("local-storage", {"rustdoc-theme": |theme|, "rustdoc-use-system-theme": "false"}), - // We reload the page so the local storage settings are being used. - ("reload"), - - ("assert-css", ("#toggle-all-docs", {"color": |main_color|})), - ("assert-css", (".fqn a:nth-of-type(1)", {"color": |fqn_color|})), - ("assert-css", (".fqn a:nth-of-type(2)", {"color": |fqn_type_color|})), - ("assert-css", ( - ".rightside .srclink", - {"color": |src_link_color|, "text-decoration": "none solid " + |src_link_color|}, - ALL, - )), - ( - "compare-elements-css", - (".rightside .srclink", ".rightside.srclink", ["color", "text-decoration"]), - ), - ( - "compare-elements-css", - (".main-heading .srclink", ".rightside.srclink", ["color", "text-decoration"]), - ), - - ("move-cursor-to", ".main-heading .srclink"), - ("assert-css", ( - ".main-heading .srclink", - {"color": |src_link_color|, "text-decoration": "underline solid " + |src_link_color|}, - )), - ("move-cursor-to", ".impl-items .rightside .srclink"), - ("assert-css", ( - ".impl-items .rightside .srclink", - {"color": |src_link_color|, "text-decoration": "none solid " + |src_link_color|}, - )), - ("move-cursor-to", ".impl-items .rightside.srclink"), - ("assert-css", ( - ".impl-items .rightside.srclink", - {"color": |src_link_color|, "text-decoration": "none solid " + |src_link_color|}, - )), - - ("goto", "file://" + |DOC_PATH| + "/test_docs/struct.HeavilyDocumentedStruct.html"), - // Since we changed page, we need to set the theme again. - ("local-storage", {"rustdoc-theme": |theme|, "rustdoc-use-system-theme": "false"}), - // We reload the page so the local storage settings are being used. - ("reload"), - - ("assert-css", ("#top-doc-prose-title", {"color": |title_color|})), - - ("assert-css", (".sidebar a", {"color": |sidebar_link_color|})), - ("assert-css", ("h1.fqn a", {"color": |title_color|})), - - // We move the cursor over the "Implementations" title so the anchor is displayed. - ("move-cursor-to", "h2#implementations"), - ("assert-css", ("h2#implementations a.anchor", {"color": |main_color|})), - - // Same thing with the impl block title. - ("move-cursor-to", "#impl-HeavilyDocumentedStruct"), - ("assert-css", ("#impl-HeavilyDocumentedStruct a.anchor", {"color": |main_color|})), - - ("assert-css", ("#title-for-struct-impl-item-doc", {"margin-left": "0px"})), - ], -) - -call-function: ( - "check-colors", - { - "theme": "ayu", - "main_color": "rgb(197, 197, 197)", - "title_color": "rgb(255, 255, 255)", - "fqn_color": "rgb(255, 255, 255)", - "fqn_type_color": "rgb(255, 160, 165)", - "src_link_color": "rgb(57, 175, 215)", - "sidebar_link_color": "rgb(83, 177, 219)", - }, -) -call-function: ( - "check-colors", - { - "theme": "dark", - "main_color": "rgb(221, 221, 221)", - "title_color": "rgb(221, 221, 221)", - "fqn_color": "rgb(221, 221, 221)", - "fqn_type_color": "rgb(45, 191, 184)", - "src_link_color": "rgb(210, 153, 29)", - "sidebar_link_color": "rgb(253, 191, 53)", - }, -) -call-function: ( - "check-colors", - { - "theme": "light", - "main_color": "rgb(0, 0, 0)", - "title_color": "rgb(0, 0, 0)", - "fqn_color": "rgb(0, 0, 0)", - "fqn_type_color": "rgb(173, 55, 138)", - "src_link_color": "rgb(56, 115, 173)", - "sidebar_link_color": "rgb(53, 109, 164)", - }, -) diff --git a/src/test/rustdoc-gui/auto-hide-trait-implementations.goml b/src/test/rustdoc-gui/auto-hide-trait-implementations.goml deleted file mode 100644 index 0a619c352..000000000 --- a/src/test/rustdoc-gui/auto-hide-trait-implementations.goml +++ /dev/null @@ -1,13 +0,0 @@ -// Checks that the setting "auto hide trait implementations" is working as expected. -goto: "file://" + |DOC_PATH| + "/test_docs/struct.Foo.html" - -// By default, the trait implementations are not collapsed. -assert-attribute: ("#trait-implementations-list > details", {"open": ""}, ALL) - -// We now set the setting to auto hide all trait implementations. -local-storage: {"rustdoc-auto-hide-trait-implementations": "true" } -// We reload to ensure the trait implementations are collapsed as expected. -reload: - -// We now check that all matching elements don't have the open attributes. -assert-attribute-false: ("#trait-implementations-list > details", {"open": ""}, ALL) diff --git a/src/test/rustdoc-gui/basic-code.goml b/src/test/rustdoc-gui/basic-code.goml deleted file mode 100644 index f4ba5a128..000000000 --- a/src/test/rustdoc-gui/basic-code.goml +++ /dev/null @@ -1,3 +0,0 @@ -goto: "file://" + |DOC_PATH| + "/test_docs/index.html" -click: ".srclink" -assert-count: (".src-line-numbers", 1) diff --git a/src/test/rustdoc-gui/check-code-blocks-margin.goml b/src/test/rustdoc-gui/check-code-blocks-margin.goml deleted file mode 100644 index c2cec0020..000000000 --- a/src/test/rustdoc-gui/check-code-blocks-margin.goml +++ /dev/null @@ -1,6 +0,0 @@ -// This test ensures that the docblock elements have the appropriate left margin. -goto: "file://" + |DOC_PATH| + "/test_docs/fn.foo.html" -// The top docblock elements shouldn't have left margin... -assert-css: ("#main-content .item-decl", {"margin-left": "0px"}) -// ... but all the others should! -assert-css: ("#main-content .docblock", {"margin-left": "24px"}) diff --git a/src/test/rustdoc-gui/check-stab-in-docblock.goml b/src/test/rustdoc-gui/check-stab-in-docblock.goml deleted file mode 100644 index 266fa9997..000000000 --- a/src/test/rustdoc-gui/check-stab-in-docblock.goml +++ /dev/null @@ -1,27 +0,0 @@ -// This test checks that using `.stab` attributes in `.docblock` elements doesn't -// create scrollable paragraphs. -goto: "file://" + |DOC_PATH| + "/test_docs/index.html" -// Needs the text to be display to check for scrollable content. -show-text: true -size: (786, 600) -// Confirms that there 3 paragraphs. -assert-count: (".top-doc .docblock p", 3) -// Checking that there is no scrollable content. -store-property: (clientHeight, ".top-doc .docblock p:nth-of-type(1)", "clientHeight") -store-property: (clientWidth, ".top-doc .docblock p:nth-of-type(1)", "clientWidth") -assert-property: ( - ".top-doc .docblock p:nth-of-type(1)", - {"scrollHeight": |clientHeight|, "scrollWidth": |clientWidth|}, -) -store-property: (clientHeight, ".top-doc .docblock p:nth-of-type(2)", "clientHeight") -store-property: (clientWidth, ".top-doc .docblock p:nth-of-type(2)", "clientWidth") -assert-property: ( - ".top-doc .docblock p:nth-of-type(2)", - {"scrollHeight": |clientHeight|, "scrollWidth": |clientWidth|}, -) -store-property: (clientHeight, ".top-doc .docblock p:nth-of-type(3)", "clientHeight") -store-property: (clientWidth, ".top-doc .docblock p:nth-of-type(3)", "clientWidth") -assert-property: ( - ".top-doc .docblock p:nth-of-type(3)", - {"scrollHeight": |clientHeight|, "scrollWidth": |clientWidth|}, -) diff --git a/src/test/rustdoc-gui/check_info_sign_position.goml b/src/test/rustdoc-gui/check_info_sign_position.goml deleted file mode 100644 index f36e73fc5..000000000 --- a/src/test/rustdoc-gui/check_info_sign_position.goml +++ /dev/null @@ -1,11 +0,0 @@ -// This test checks the position of the information on the code blocks (like -// `compile_fail` or `ignore`). -goto: "file://" + |DOC_PATH| + "/test_docs/index.html" -goto: "./fn.check_list_code_block.html" -// If the codeblock is the first element of the docblock, the information tooltip must have -// have some top margin to avoid going over the toggle (the "[+]"). -assert-css: (".docblock > .example-wrap.compile_fail .tooltip", { "margin-top": "16px" }) -// Checks that the other codeblocks don't have this top margin. -assert-css: ("ol > li > .example-wrap.compile_fail .tooltip", { "margin-top": "0px" }) -assert-css: ("ol > li > .example-wrap.ignore .tooltip", { "margin-top": "0px" }) -assert-css: (".docblock > .example-wrap.ignore .tooltip", { "margin-top": "0px" }) diff --git a/src/test/rustdoc-gui/code-blocks-overflow.goml b/src/test/rustdoc-gui/code-blocks-overflow.goml deleted file mode 100644 index fbf0e890b..000000000 --- a/src/test/rustdoc-gui/code-blocks-overflow.goml +++ /dev/null @@ -1,8 +0,0 @@ -// This test ensures that codeblocks content don't overflow. -goto: "file://" + |DOC_PATH| + "/lib2/sub_mod/struct.Foo.html" -size: (1080, 600) -// There should be two codeblocks: a rust one and a non-rust one. -assert-count: (".docblock > .example-wrap", 2) -assert: ".docblock > .example-wrap > .language-txt" -assert: ".docblock > .example-wrap > .rust-example-rendered" -assert-css: (".docblock > .example-wrap > pre", {"width": "796px", "overflow-x": "auto"}, ALL) diff --git a/src/test/rustdoc-gui/code-color.goml b/src/test/rustdoc-gui/code-color.goml deleted file mode 100644 index 118f04ad6..000000000 --- a/src/test/rustdoc-gui/code-color.goml +++ /dev/null @@ -1,24 +0,0 @@ -// The ayu theme has a different color for the "<code>" tags in the doc blocks. We need to -// check that the rule isn't applied on other "<code>" elements. -// -// While we're at it, we also check it for the other themes. -goto: "file://" + |DOC_PATH| + "/test_docs/fn.foo.html" -// If the text isn't displayed, the browser doesn't compute color style correctly... -show-text: true - -define-function: ( - "check-colors", - (theme, doc_code_color, doc_inline_code_color), - [ - // Set the theme. - ("local-storage", {"rustdoc-theme": |theme|, "rustdoc-use-system-theme": "false"}), - // We reload the page so the local storage settings are being used. - ("reload"), - ("assert-css", (".docblock pre > code", {"color": |doc_code_color|}, ALL)), - ("assert-css", (".docblock > p > code", {"color": |doc_inline_code_color|}, ALL)), - ], -) - -call-function: ("check-colors", ("ayu", "rgb(230, 225, 207)", "rgb(255, 180, 84)")) -call-function: ("check-colors", ("dark", "rgb(221, 221, 221)", "rgb(221, 221, 221)")) -call-function: ("check-colors", ("light", "rgb(0, 0, 0)", "rgb(0, 0, 0)")) diff --git a/src/test/rustdoc-gui/code-sidebar-toggle.goml b/src/test/rustdoc-gui/code-sidebar-toggle.goml deleted file mode 100644 index 00a0ea1e1..000000000 --- a/src/test/rustdoc-gui/code-sidebar-toggle.goml +++ /dev/null @@ -1,7 +0,0 @@ -// This test checks that the source code pages sidebar toggle is working as expected. -goto: "file://" + |DOC_PATH| + "/test_docs/index.html" -click: ".srclink" -wait-for: "#sidebar-toggle" -click: "#sidebar-toggle" -fail: true -assert-css: ("#source-sidebar", { "left": "-300px" }) diff --git a/src/test/rustdoc-gui/code-tags.goml b/src/test/rustdoc-gui/code-tags.goml deleted file mode 100644 index 94c1a6525..000000000 --- a/src/test/rustdoc-gui/code-tags.goml +++ /dev/null @@ -1,24 +0,0 @@ -// This test ensures that items and documentation code blocks are wrapped in <pre><code> - -// We need to disable this check because `implementors/test_docs/trait.AnotherOne.js` -// doesn't exist. -fail-on-request-error: false -goto: "file://" + |DOC_PATH| + "/test_docs/fn.foo.html" -size: (1080, 600) -// There should be four doc codeblocks. -// Check that their content is inside <pre><code> -assert-count: (".example-wrap pre > code", 4) -// Check that function signature is inside <pre><code> -assert: "pre.rust.fn > code" - -goto: "file://" + |DOC_PATH| + "/test_docs/struct.Foo.html" -assert: "pre.rust.struct > code" - -goto: "file://" + |DOC_PATH| + "/test_docs/enum.AnEnum.html" -assert: "pre.rust.enum > code" - -goto: "file://" + |DOC_PATH| + "/test_docs/trait.AnotherOne.html" -assert: "pre.rust.trait > code" - -goto: "file://" + |DOC_PATH| + "/test_docs/type.SomeType.html" -assert: "pre.rust.typedef > code" diff --git a/src/test/rustdoc-gui/codeblock-tooltip.goml b/src/test/rustdoc-gui/codeblock-tooltip.goml deleted file mode 100644 index 4d923be3e..000000000 --- a/src/test/rustdoc-gui/codeblock-tooltip.goml +++ /dev/null @@ -1,152 +0,0 @@ -// Checking the colors of the codeblocks tooltips. -goto: "file://" + |DOC_PATH| + "/test_docs/fn.foo.html" -show-text: true - -define-function: ( - "check-colors", - (theme, background, color, border), - [ - // Setting the theme. - ("local-storage", {"rustdoc-theme": |theme|, "rustdoc-use-system-theme": "false"}), - ("reload"), - - // compile_fail block - ("assert-css", ( - ".docblock .example-wrap.compile_fail .tooltip", - {"color": "rgba(255, 0, 0, 0.5)"}, - )), - ("assert-css", ( - ".docblock .example-wrap.compile_fail", - {"border-left": "2px solid rgba(255, 0, 0, 0.5)"}, - )), - - ("move-cursor-to", ".docblock .example-wrap.compile_fail"), - - ("assert-css", ( - ".docblock .example-wrap.compile_fail .tooltip", - {"color": "rgb(255, 0, 0)"}, - )), - ("assert-css", ( - ".docblock .example-wrap.compile_fail", - {"border-left": "2px solid rgb(255, 0, 0)"}, - )), - ("assert-css", ( - ".docblock .example-wrap.compile_fail .tooltip::after", - { - "content": '"This example deliberately fails to compile"', - "text-align": "center", - "padding": "5px 3px 3px", - "background-color": |background|, - "color": |color|, - "border": "1px solid " + |border|, - }, - )), - ("assert-css", ( - ".docblock .example-wrap.compile_fail .tooltip::before", - { - "border-width": "5px", - "border-style": "solid", - "border-color": "rgba(0, 0, 0, 0) " + |background| + " rgba(0, 0, 0, 0) rgba(0, 0, 0, 0)", - }, - )), - - // should_panic block - ("assert-css", ( - ".docblock .example-wrap.should_panic .tooltip", - {"color": "rgba(255, 0, 0, 0.5)"}, - )), - ("assert-css", ( - ".docblock .example-wrap.should_panic", - {"border-left": "2px solid rgba(255, 0, 0, 0.5)"}, - )), - - ("move-cursor-to", ".docblock .example-wrap.should_panic"), - - ("assert-css", ( - ".docblock .example-wrap.should_panic .tooltip", - {"color": "rgb(255, 0, 0)"}, - )), - ("assert-css", ( - ".docblock .example-wrap.should_panic", - {"border-left": "2px solid rgb(255, 0, 0)"}, - )), - ("assert-css", ( - ".docblock .example-wrap.should_panic .tooltip::after", - { - "content": '"This example panics"', - "text-align": "center", - "padding": "5px 3px 3px", - "background-color": |background|, - "color": |color|, - "border": "1px solid " + |border|, - }, - )), - ("assert-css", ( - ".docblock .example-wrap.should_panic .tooltip::before", - { - "border-width": "5px", - "border-style": "solid", - "border-color": "rgba(0, 0, 0, 0) " + |background| + " rgba(0, 0, 0, 0) rgba(0, 0, 0, 0)", - }, - )), - - // ignore block - ("assert-css", ( - ".docblock .example-wrap.ignore .tooltip", - {"color": "rgba(255, 142, 0, 0.6)"}, - )), - ("assert-css", ( - ".docblock .example-wrap.ignore", - {"border-left": "2px solid rgba(255, 142, 0, 0.6)"}, - )), - - ("move-cursor-to", ".docblock .example-wrap.ignore"), - - ("assert-css", ( - ".docblock .example-wrap.ignore .tooltip", - {"color": "rgb(255, 142, 0)"}, - )), - ("assert-css", ( - ".docblock .example-wrap.ignore", - {"border-left": "2px solid rgb(255, 142, 0)"}, - )), - ("assert-css", ( - ".docblock .example-wrap.ignore .tooltip::after", - { - "content": '"This example is not tested"', - "text-align": "center", - "padding": "5px 3px 3px", - "background-color": |background|, - "color": |color|, - "border": "1px solid " + |border|, - }, - )), - ("assert-css", ( - ".docblock .example-wrap.ignore .tooltip::before", - { - "border-width": "5px", - "border-style": "solid", - "border-color": "rgba(0, 0, 0, 0) " + |background| + " rgba(0, 0, 0, 0) rgba(0, 0, 0, 0)", - }, - )), - ], -) - -call-function: ("check-colors", { - "theme": "ayu", - "background": "rgb(49, 69, 89)", - "color": "rgb(197, 197, 197)", - "border": "rgb(92, 103, 115)", -}) -call-function: ("check-colors", { - "theme": "dark", - "background": "rgb(0, 0, 0)", - "color": "rgb(255, 255, 255)", - "border": "rgb(224, 224, 224)", -}) -call-function: ("check-colors", { - "theme": "light", - "background": "rgb(0, 0, 0)", - "color": "rgb(255, 255, 255)", - "border": "rgb(224, 224, 224)", -}) diff --git a/src/test/rustdoc-gui/cursor.goml b/src/test/rustdoc-gui/cursor.goml deleted file mode 100644 index b2e91cb81..000000000 --- a/src/test/rustdoc-gui/cursor.goml +++ /dev/null @@ -1,24 +0,0 @@ -// This test ensures that several clickable items actually have the pointer cursor. -goto: "file://" + |DOC_PATH| + "/lib2/struct.Foo.html" - -// the `[+]/[-]` button -assert-css: ("#toggle-all-docs", {"cursor": "pointer"}) - -// the button next to the path header -assert-css: ("#copy-path", {"cursor": "pointer"}) - -// the search tabs -write: (".search-input", "Foo") -// To be SURE that the search will be run. -press-key: 'Enter' -// Waiting for the search results to appear... -wait-for: "#titles" -assert-css: ("#titles > button", {"cursor": "pointer"}) - -// mobile sidebar toggle button -size: (500, 700) -assert-css: (".sidebar-menu-toggle", {"cursor": "pointer"}) - -// the sidebar toggle button on the source code pages -goto: "file://" + |DOC_PATH| + "/src/lib2/lib.rs.html" -assert-css: ("#sidebar-toggle > button", {"cursor": "pointer"}) diff --git a/src/test/rustdoc-gui/default-settings.goml b/src/test/rustdoc-gui/default-settings.goml deleted file mode 100644 index ab27b001e..000000000 --- a/src/test/rustdoc-gui/default-settings.goml +++ /dev/null @@ -1,8 +0,0 @@ -// This test ensures that the default settings are correctly applied. -// -// The "settings" crate uses "ayu" as default setting, which is what we will -// check. -goto: "file://" + |DOC_PATH| + "/settings/index.html" -// Wait a bit to be sure the default theme is applied. -// If the theme isn't applied, the command will time out. -wait-for-css: ("body", {"background-color": "rgb(15, 20, 25)"}) diff --git a/src/test/rustdoc-gui/docblock-big-code-mobile.goml b/src/test/rustdoc-gui/docblock-big-code-mobile.goml deleted file mode 100644 index 9f8df44d7..000000000 --- a/src/test/rustdoc-gui/docblock-big-code-mobile.goml +++ /dev/null @@ -1,9 +0,0 @@ -// If we have a long `<code>`, we need to ensure that it'll be fully displayed on mobile, meaning -// that it'll be on two lines. -emulate: "iPhone 8" // it has the following size: (375, 667) -goto: "file://" + |DOC_PATH| + "/test_docs/long_code_block/index.html" -// We now check that the block is on two lines: -show-text: true // We need to enable text draw to be able to have the "real" size -// Little explanations for this test: if the text wasn't displayed on two lines, it would take -// around 20px (which is the font size). -assert-property: (".docblock p > code", {"offsetHeight": "44"}) diff --git a/src/test/rustdoc-gui/docblock-code-block-line-number.goml b/src/test/rustdoc-gui/docblock-code-block-line-number.goml deleted file mode 100644 index fec21ad35..000000000 --- a/src/test/rustdoc-gui/docblock-code-block-line-number.goml +++ /dev/null @@ -1,39 +0,0 @@ -// Checks that the setting "line numbers" is working as expected. -goto: "file://" + |DOC_PATH| + "/test_docs/fn.foo.html" - -// We check that without this setting, there is no line number displayed. -assert-false: "pre.example-line-numbers" - -// We now set the setting to show the line numbers on code examples. -local-storage: {"rustdoc-line-numbers": "true" } -// We reload to make the line numbers appear. -reload: - -// We wait for them to be added into the DOM by the JS... -wait-for: "pre.example-line-numbers" -// If the test didn't fail, it means that it was found! -// Let's now check some CSS properties... -assert-css: ("pre.example-line-numbers", { - "margin": "0px", - "padding": "13px 8px", - "text-align": "right", -}) -// The first code block has two lines so let's check its `<pre>` elements lists both of them. -assert-text: ("pre.example-line-numbers", "1\n2") - -// 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. -click: "input#line-numbers" -wait-for: 100 // wait-for-false does not exist -assert-false: "pre.example-line-numbers" - -// Finally, turn it on again. -click: "input#line-numbers" -wait-for: "pre.example-line-numbers" diff --git a/src/test/rustdoc-gui/docblock-details.goml b/src/test/rustdoc-gui/docblock-details.goml deleted file mode 100644 index 9ae571efb..000000000 --- a/src/test/rustdoc-gui/docblock-details.goml +++ /dev/null @@ -1,34 +0,0 @@ -// This ensures that the `<details>`/`<summary>` elements are displayed as expected. -goto: "file://" + |DOC_PATH| + "/test_docs/details/struct.Details.html" -show-text: true -local-storage: {"rustdoc-theme": "dark", "rustdoc-use-system-theme": "false"} -reload: - -// We first check that the headers in the `.top-doc` doc block still have their -// bottom border. -assert-text: (".top-doc .docblock > h3", "Hello") -assert-css: ( - ".top-doc .docblock > h3", - {"border-bottom": "1px solid rgb(210, 210, 210)"}, -) -// We now check that the `<summary>` doesn't have a bottom border and has the correct display. -assert-css: ( - ".top-doc .docblock summary h4", - {"border-bottom-width": "0px"}, -) -// This allows to ensure that summary is on one line only! -assert-property: (".top-doc .docblock summary h4", {"offsetHeight": "33"}) -assert-css: (".top-doc .docblock summary h4", {"margin-top": "15px", "margin-bottom": "5px"}) -// So `33 + 15 + 5` == `53` -assert-property: (".top-doc .docblock summary", {"offsetHeight": "53"}) - -// We now check the `<summary>` on a method. -assert-css: ( - ".method-toggle .docblock summary h4", - {"border-bottom-width": "0px"}, -) -// This allows to ensure that summary is on one line only! -assert-property: (".method-toggle .docblock summary h4", {"offsetHeight": "30"}) -assert-css: (".method-toggle .docblock summary h4", {"margin-top": "15px", "margin-bottom": "5px"}) -// So `30 + 15 + 5` == `50` -assert-property: (".method-toggle .docblock summary", {"offsetHeight": "50"}) diff --git a/src/test/rustdoc-gui/docblock-table-overflow.goml b/src/test/rustdoc-gui/docblock-table-overflow.goml deleted file mode 100644 index d8670089a..000000000 --- a/src/test/rustdoc-gui/docblock-table-overflow.goml +++ /dev/null @@ -1,21 +0,0 @@ -// This test ensures that the type declaration content overflow is handled inside the <pre> directly. -goto: "file://" + |DOC_PATH| + "/lib2/long_table/struct.Foo.html" -// We set a fixed size so there is no chance of "random" resize. -size: (1100, 800) -// Logically, the ".docblock" and the "<p>" should have the same scroll width. -compare-elements-property: (".top-doc .docblock", ".top-doc .docblock > p", ["scrollWidth"]) -assert-property: (".top-doc .docblock", {"scrollWidth": "816"}) -// However, since there is overflow in the <table>, its scroll width is bigger. -assert-property: (".top-doc .docblock table", {"scrollWidth": "1572"}) - -// Checking it works on other doc blocks as well... - -// Logically, the ".docblock" and the "<p>" should have the same scroll width. -compare-elements-property: ( - "#implementations-list > details .docblock", - "#implementations-list > details .docblock > p", - ["scrollWidth"], -) -assert-property: ("#implementations-list > details .docblock", {"scrollWidth": "816"}) -// However, since there is overflow in the <table>, its scroll width is bigger. -assert-property: ("#implementations-list > details .docblock table", {"scrollWidth": "1572"}) diff --git a/src/test/rustdoc-gui/docblock-table.goml b/src/test/rustdoc-gui/docblock-table.goml deleted file mode 100644 index 8645c1b19..000000000 --- a/src/test/rustdoc-gui/docblock-table.goml +++ /dev/null @@ -1,51 +0,0 @@ -goto: "file://" + |DOC_PATH| + "/test_docs/doc_block_table/struct.DocBlockTable.html#method.func" - -compare-elements-css: (".impl-items .docblock table th", ".top-doc .docblock table th", ["border"]) -compare-elements-css: (".impl-items .docblock table td", ".top-doc .docblock table td", ["border"]) - -define-function: ( - "check-colors", - (theme, border_color, zebra_stripe_color), - [ - ("local-storage", {"rustdoc-use-system-theme": "false", "rustdoc-theme": |theme|}), - ("reload"), - ("assert-css", (".top-doc .docblock table tbody tr:nth-child(1)", { - "background-color": "rgba(0, 0, 0, 0)", - })), - ("assert-css", (".top-doc .docblock table tbody tr:nth-child(2)", { - "background-color": |zebra_stripe_color|, - })), - ("assert-css", (".top-doc .docblock table tbody tr:nth-child(3)", { - "background-color": "rgba(0, 0, 0, 0)", - })), - ("assert-css", (".top-doc .docblock table tbody tr:nth-child(4)", { - "background-color": |zebra_stripe_color|, - })), - ("assert-css", (".top-doc .docblock table td", { - "border-style": "solid", - "border-width": "1px", - "border-color": |border_color|, - })), - ("assert-css", (".top-doc .docblock table th", { - "border-style": "solid", - "border-width": "1px", - "border-color": |border_color|, - })), - ] -) - -call-function: ("check-colors", { - "theme": "dark", - "border_color": "rgb(224, 224, 224)", - "zebra_stripe_color": "rgb(42, 42, 42)", -}) -call-function: ("check-colors", { - "theme": "ayu", - "border_color": "rgb(92, 103, 115)", - "zebra_stripe_color": "rgb(25, 31, 38)", -}) -call-function: ("check-colors", { - "theme": "light", - "border_color": "rgb(224, 224, 224)", - "zebra_stripe_color": "rgb(245, 245, 245)", -}) diff --git a/src/test/rustdoc-gui/duplicate-macro-reexport.goml b/src/test/rustdoc-gui/duplicate-macro-reexport.goml deleted file mode 100644 index 496203c12..000000000 --- a/src/test/rustdoc-gui/duplicate-macro-reexport.goml +++ /dev/null @@ -1,14 +0,0 @@ -// This test ensures that there is no macro duplicates in the sidebar. -goto: "file://" + |DOC_PATH| + "/test_docs/macro.a.html" -// Waiting for the elements in the sidebar to be rendered. -wait-for: ".sidebar-elems .macro" -// Check there is only one macro named "a" listed in the sidebar. -assert-count: ( - "//*[@class='sidebar-elems']//*[@class='block macro']//li/a[text()='a']", - 1, -) -// Check there is only one macro named "b" listed in the sidebar. -assert-count: ( - "//*[@class='sidebar-elems']//*[@class='block macro']//li/a[text()='b']", - 1, -) diff --git a/src/test/rustdoc-gui/enum-variants.goml b/src/test/rustdoc-gui/enum-variants.goml deleted file mode 100644 index 8dfc49285..000000000 --- a/src/test/rustdoc-gui/enum-variants.goml +++ /dev/null @@ -1,10 +0,0 @@ -// Verifies that there is non-zero margin on variants and their docblocks. -goto: "file://" + |DOC_PATH| + "/test_docs/enum.WhoLetTheDogOut.html" - -assert-css: (".variants > .variant", {"margin": "0px 0px 12px"}) -assert-css: (".variants > .docblock", {"margin": "0px 0px 32px 24px"}) - -assert-css: ( - "details.non-exhaustive > summary", - {"font-family": '"Fira Sans", Arial, NanumBarunGothic, sans-serif'}, -) diff --git a/src/test/rustdoc-gui/escape-key.goml b/src/test/rustdoc-gui/escape-key.goml deleted file mode 100644 index 78e9f2309..000000000 --- a/src/test/rustdoc-gui/escape-key.goml +++ /dev/null @@ -1,35 +0,0 @@ -// This test ensures that the "Escape" shortcut is handled correctly based on the -// current content displayed. -goto: "file://" + |DOC_PATH| + "/test_docs/index.html" -// First, we check that the search results are hidden when the Escape key is pressed. -write: (".search-input", "test") -// To be SURE that the search will be run. -press-key: 'Enter' -wait-for: "#search h1" // The search element is empty before the first search -// Check that the currently displayed element is search. -wait-for: "#alternative-display #search" -assert-attribute: ("#main-content", {"class": "content hidden"}) -assert-document-property: ({"URL": "index.html?search=test"}, ENDS_WITH) -press-key: "Escape" -// Checks that search is no longer in the displayed content. -wait-for: "#not-displayed #search" -assert-false: "#alternative-display #search" -assert-attribute: ("#main-content", {"class": "content"}) -assert-document-property: ({"URL": "index.html"}, [ENDS_WITH]) - -// Check that focusing the search input brings back the search results -focus: ".search-input" -wait-for: "#alternative-display #search" -assert-attribute: ("#main-content", {"class": "content hidden"}) -assert-document-property: ({"URL": "index.html?search=test"}, ENDS_WITH) - -// Check that Escape hides the search results when a search result is focused. -focus: ".search-input" -assert: ".search-input:focus" -press-key: "ArrowDown" -assert-false: ".search-input:focus" -assert: "#results a:focus" -press-key: "Escape" -wait-for: "#not-displayed #search" -assert-false: "#alternative-display #search" -assert-attribute: ("#main-content", {"class": "content"}) diff --git a/src/test/rustdoc-gui/font-weight.goml b/src/test/rustdoc-gui/font-weight.goml deleted file mode 100644 index 8ba005b0c..000000000 --- a/src/test/rustdoc-gui/font-weight.goml +++ /dev/null @@ -1,44 +0,0 @@ -// This test checks that the font weight is correctly applied. -goto: "file://" + |DOC_PATH| + "/lib2/struct.Foo.html" -assert-css: ("//*[@class='item-decl']//a[text()='Alias']", {"font-weight": "400"}) -assert-css: ( - "//*[@class='structfield small-section-header']//a[text()='Alias']", - {"font-weight": "400"}, -) -assert-css: ("#method\.a_method > .code-header", {"font-weight": "600"}) -assert-css: ("#associatedtype\.X > .code-header", {"font-weight": "600"}) -assert-css: ("#associatedconstant\.Y > .code-header", {"font-weight": "600"}) - -goto: "file://" + |DOC_PATH| + "/test_docs/type.SomeType.html" -assert-css: (".top-doc .docblock p", {"font-weight": "400"}, ALL) - -goto: "file://" + |DOC_PATH| + "/test_docs/struct.Foo.html" -assert-css: (".impl-items .method > .code-header", {"font-weight": "600"}, ALL) - -goto: "file://" + |DOC_PATH| + "/lib2/trait.Trait.html" - -// This is a complex selector, so here's how it works: -// -// * //*[@class='item-decl'] — selects element of any tag with classes docblock and item-decl -// * /pre[@class='rust trait'] — selects immediate child with tag pre and classes rust and trait -// * /code — selects immediate child with tag code -// * /a[@class='constant'] — selects immediate child with tag a and class constant -// * //text() — selects child that is text node -// * /parent::* — selects immediate parent of the text node (the * means it can be any tag) -// -// This uses '/parent::*' as a proxy for the style of the text node. -// We can't just select the '<a>' because intermediate tags could be added. -assert-count: ( - "//*[@class='item-decl']/pre[@class='rust trait']/code/a[@class='constant']//text()/parent::*", - 1, -) -assert-css: ( - "//*[@class='item-decl']/pre[@class='rust trait']/code/a[@class='constant']//text()/parent::*", - {"font-weight": "400"}, -) - -assert-count: (".methods .associatedtype", 1) -assert-css: (".methods .associatedtype", {"font-weight": "600"}) -assert-count: (".methods .constant", 1) -assert-css: (".methods .constant", {"font-weight": "600"}) -assert-css: (".methods .method > .code-header", {"font-weight": "600"}) diff --git a/src/test/rustdoc-gui/hash-item-expansion.goml b/src/test/rustdoc-gui/hash-item-expansion.goml deleted file mode 100644 index 3cf94f624..000000000 --- a/src/test/rustdoc-gui/hash-item-expansion.goml +++ /dev/null @@ -1,11 +0,0 @@ -// This test ensures that the element corresponding to the hash is displayed. -goto: "file://" + |DOC_PATH| + "/test_docs/struct.Foo.html#method.borrow" -// In the blanket implementations list, "Borrow" is the second one, hence the ":nth(2)". -assert-attribute: ("#blanket-implementations-list > details:nth-child(2)", {"open": ""}) -// We first check that the impl block is open by default. -assert-attribute: ("#implementations-list details", {"open": ""}) -// To ensure that we will click on the currently hidden method. -assert-text: (".sidebar-elems section .block li > a", "must_use") -click: ".sidebar-elems section .block li > a" -// We check that the impl block was opened as expected so that we can see the method. -assert-attribute: ("#implementations-list > details", {"open": ""}) diff --git a/src/test/rustdoc-gui/headers-color.goml b/src/test/rustdoc-gui/headers-color.goml deleted file mode 100644 index c80a49c52..000000000 --- a/src/test/rustdoc-gui/headers-color.goml +++ /dev/null @@ -1,70 +0,0 @@ -// This test check for headers text and background colors for the different themes. - -define-function: ( - "check-colors", - (theme, color, code_header_color, focus_background_color, headings_color), - [ - ("goto", "file://" + |DOC_PATH| + "/test_docs/struct.Foo.html"), - // This is needed so that the text color is computed. - ("show-text", true), - ("local-storage", {"rustdoc-theme": |theme|, "rustdoc-use-system-theme": "false"}), - ("reload"), - ("assert-css", ( - ".impl", - {"color": |color|, "background-color": "rgba(0, 0, 0, 0)"}, - ALL, - )), - ("assert-css", ( - ".impl .code-header", - {"color": |code_header_color|, "background-color": "rgba(0, 0, 0, 0)"}, - ALL, - )), - ("goto", "file://" + |DOC_PATH| + "/test_docs/struct.Foo.html#impl-Foo"), - ("assert-css", ( - "#impl-Foo", - {"color": |color|, "background-color": |focus_background_color|}, - )), - ("goto", "file://" + |DOC_PATH| + "/test_docs/struct.Foo.html#method.must_use"), - ("assert-css", ( - "#method\.must_use", - {"color": |color|, "background-color": |focus_background_color|}, - ALL, - )), - ("goto", "file://" + |DOC_PATH| + "/test_docs/index.html"), - ("assert-css", (".small-section-header a", {"color": |color|}, ALL)), - ("goto", "file://" + |DOC_PATH| + "/test_docs/struct.HeavilyDocumentedStruct.html"), - // We select headings (h2, h3, h...). - ("assert-css", (".docblock > :not(p) > a", {"color": |headings_color|}, ALL)), - ], -) - -call-function: ( - "check-colors", - { - "theme": "ayu", - "color": "rgb(197, 197, 197)", - "code_header_color": "rgb(230, 225, 207)", - "focus_background_color": "rgba(255, 236, 164, 0.06)", - "headings_color": "rgb(57, 175, 215)", - }, -) -call-function: ( - "check-colors", - { - "theme": "dark", - "color": "rgb(221, 221, 221)", - "code_header_color": "rgb(221, 221, 221)", - "focus_background_color": "rgb(73, 74, 61)", - "headings_color": "rgb(210, 153, 29)", - }, -) -call-function: ( - "check-colors", - { - "theme": "light", - "color": "rgb(0, 0, 0)", - "code_header_color": "rgb(0, 0, 0)", - "focus_background_color": "rgb(253, 255, 211)", - "headings_color": "rgb(56, 115, 173)", - }, -) diff --git a/src/test/rustdoc-gui/headings.goml b/src/test/rustdoc-gui/headings.goml deleted file mode 100644 index 85e17ca95..000000000 --- a/src/test/rustdoc-gui/headings.goml +++ /dev/null @@ -1,234 +0,0 @@ -// This test checks that headers (a) have the correct heading level, (b) are the right size, -// and (c) have the correct underlining (or absence of underlining). -// The sizes may change as design changes, but try to make sure a lower header is never bigger than -// its parent headers. Also make sure lower headers don't have underlines when their parents lack -// an underline. -// Most of these sizes are set in CSS in `em` units, so here's a conversion chart based on our -// default 16px font size: -// 24px 1.5em -// 22px 1.375rem -// 20px 1.25rem -// 18px 1.125em -// 16px 1rem -// 14px 0.875rem -goto: "file://" + |DOC_PATH| + "/test_docs/struct.HeavilyDocumentedStruct.html" - -assert-css: ("h1.fqn", {"font-size": "24px"}) - -assert-css: ("h2#top-doc-prose-title", {"font-size": "22px"}) -assert-css: ("h2#top-doc-prose-title", {"border-bottom-width": "1px"}) -assert-css: ("h3#top-doc-prose-sub-heading", {"font-size": "20px"}) -assert-css: ("h3#top-doc-prose-sub-heading", {"border-bottom-width": "1px"}) -assert-css: ("h4#top-doc-prose-sub-sub-heading", {"font-size": "18px"}) -assert-css: ("h4#top-doc-prose-sub-sub-heading", {"border-bottom-width": "1px"}) - -assert-css: ("h2#fields", {"font-size": "22px"}) -assert-css: ("h2#fields", {"border-bottom-width": "1px"}) -assert-css: ("h3#title-for-field", {"font-size": "20px"}) -assert-css: ("h3#title-for-field", {"border-bottom-width": "0px"}) -assert-css: ("h4#sub-heading-for-field", {"font-size": "16px"}) -assert-css: ("h4#sub-heading-for-field", {"border-bottom-width": "0px"}) - -assert-css: ("h2#implementations", {"font-size": "22px"}) -assert-css: ("h2#implementations", {"border-bottom-width": "1px"}) - -assert-css: ("#impl-HeavilyDocumentedStruct > h3.code-header", {"font-size": "18px"}) -assert-css: ("#impl-HeavilyDocumentedStruct > h3.code-header", {"border-bottom-width": "0px"}) -assert-css: ("#method\.do_nothing > h4.code-header", {"font-size": "16px"}) -assert-css: ("#method\.do_nothing > h4.code-header", {"border-bottom-width": "0px"}) - -assert-css: ("h4#title-for-struct-impl-doc", {"font-size": "16px"}) -assert-css: ("h4#title-for-struct-impl-doc", {"border-bottom-width": "0px"}) -assert-css: ("h5#sub-heading-for-struct-impl-doc", {"font-size": "16px"}) -assert-css: ("h5#sub-heading-for-struct-impl-doc", {"border-bottom-width": "0px"}) -assert-css: ("h6#sub-sub-heading-for-struct-impl-doc", {"font-size": "14px"}) -assert-css: ("h6#sub-sub-heading-for-struct-impl-doc", {"border-bottom-width": "0px"}) - -assert-css: ("h5#title-for-struct-impl-item-doc", {"font-size": "16px"}) -assert-css: ("h5#title-for-struct-impl-item-doc", {"border-bottom-width": "0px"}) -assert-css: ("h6#sub-heading-for-struct-impl-item-doc", {"font-size": "14px"}) -assert-css: ("h6#sub-heading-for-struct-impl-item-doc", {"border-bottom-width": "0px"}) -assert-css: ("h6#sub-sub-heading-for-struct-impl-item-doc", {"font-size": "14px"}) - -goto: "file://" + |DOC_PATH| + "/test_docs/enum.HeavilyDocumentedEnum.html" - -assert-css: ("h1.fqn", {"font-size": "24px"}) - -assert-css: ("h2#top-doc-prose-title", {"font-size": "22px"}) -assert-css: ("h2#top-doc-prose-title", {"border-bottom-width": "1px"}) -assert-css: ("h3#top-doc-prose-sub-heading", {"font-size": "20px"}) -assert-css: ("h3#top-doc-prose-sub-heading", {"border-bottom-width": "1px"}) -assert-css: ("h4#top-doc-prose-sub-sub-heading", {"font-size": "18px"}) -assert-css: ("h4#top-doc-prose-sub-sub-heading", {"border-bottom-width": "1px"}) - -assert-css: ("h2#variants", {"font-size": "22px"}) -assert-css: ("h2#variants", {"border-bottom-width": "1px"}) - -assert-css: ("h4#none-prose-title", {"font-size": "16px"}) -assert-css: ("h4#none-prose-title", {"border-bottom-width": "0px"}) -assert-css: ("h5#none-prose-sub-heading", {"font-size": "16px"}) -assert-css: ("h5#none-prose-sub-heading", {"border-bottom-width": "0px"}) - -assert-css: ("h4#wrapped-prose-title", {"font-size": "16px"}) -assert-css: ("h4#wrapped-prose-title", {"border-bottom-width": "0px"}) -assert-css: ("h5#wrapped-prose-sub-heading", {"font-size": "16px"}) -assert-css: ("h5#wrapped-prose-sub-heading", {"border-bottom-width": "0px"}) - -assert-css: ("h5#wrapped0-prose-title", {"font-size": "16px"}) -assert-css: ("h5#wrapped0-prose-title", {"border-bottom-width": "0px"}) -assert-css: ("h6#wrapped0-prose-sub-heading", {"font-size": "14px"}) -assert-css: ("h6#wrapped0-prose-sub-heading", {"border-bottom-width": "0px"}) - -assert-css: ("h5#structy-prose-title", {"font-size": "16px"}) -assert-css: ("h5#structy-prose-title", {"border-bottom-width": "0px"}) -assert-css: ("h6#structy-prose-sub-heading", {"font-size": "14px"}) -assert-css: ("h6#structy-prose-sub-heading", {"border-bottom-width": "0px"}) - -assert-css: ("h2#implementations", {"font-size": "22px"}) -assert-css: ("h2#implementations", {"border-bottom-width": "1px"}) - -assert-css: ("#impl-HeavilyDocumentedEnum > h3.code-header", {"font-size": "18px"}) -assert-css: ("#impl-HeavilyDocumentedEnum > h3.code-header", {"border-bottom-width": "0px"}) -assert-css: ("#method\.do_nothing > h4.code-header", {"font-size": "16px"}) -assert-css: ("#method\.do_nothing > h4.code-header", {"border-bottom-width": "0px"}) - -assert-css: ("h4#title-for-enum-impl-doc", {"font-size": "16px"}) -assert-css: ("h4#title-for-enum-impl-doc", {"border-bottom-width": "0px"}) -assert-css: ("h5#sub-heading-for-enum-impl-doc", {"font-size": "16px"}) -assert-css: ("h5#sub-heading-for-enum-impl-doc", {"border-bottom-width": "0px"}) -assert-css: ("h6#sub-sub-heading-for-enum-impl-doc", {"font-size": "14px"}) -assert-css: ("h6#sub-sub-heading-for-enum-impl-doc", {"border-bottom-width": "0px"}) - -assert-css: ("h5#title-for-enum-impl-item-doc", {"font-size": "16px"}) -assert-css: ("h5#title-for-enum-impl-item-doc", {"border-bottom-width": "0px"}) -assert-css: ("h6#sub-heading-for-enum-impl-item-doc", {"font-size": "14px"}) -assert-css: ("h6#sub-heading-for-enum-impl-item-doc", {"border-bottom-width": "0px"}) -assert-css: ("h6#sub-sub-heading-for-enum-impl-item-doc", {"font-size": "14px"}) -assert-css: ("h6#sub-sub-heading-for-enum-impl-item-doc", {"border-bottom-width": "0px"}) - -assert-text: ("//ul[@class='block mod']/preceding-sibling::h3", "Modules") -assert-css: ("//ul[@class='block mod']/preceding-sibling::h3", {"border-bottom-width": "0px"}, ALL) - -goto: "file://" + |DOC_PATH| + "/test_docs/union.HeavilyDocumentedUnion.html" - -assert-css: ("h1.fqn", {"font-size": "24px"}) - -assert-css: ("h2#top-doc-prose-title", {"font-size": "22px"}) -assert-css: ("h2#top-doc-prose-title", {"border-bottom-width": "1px"}) -assert-css: ("h3#top-doc-prose-sub-heading", {"font-size": "20px"}) -assert-css: ("h3#top-doc-prose-sub-heading", {"border-bottom-width": "1px"}) - -assert-css: ("h2#fields", {"font-size": "22px"}) -assert-css: ("h2#fields", {"border-bottom-width": "1px"}) - -assert-css: ("h3#title-for-union-variant", {"font-size": "20px"}) -assert-css: ("h3#title-for-union-variant", {"border-bottom-width": "0px"}) -assert-css: ("h4#sub-heading-for-union-variant", {"font-size": "16px"}) -assert-css: ("h4#sub-heading-for-union-variant", {"border-bottom-width": "0px"}) - -assert-css: ("h2#implementations", {"font-size": "22px"}) -assert-css: ("h2#implementations", {"border-bottom-width": "1px"}) - -assert-css: ("#impl-HeavilyDocumentedUnion > h3.code-header", {"font-size": "18px"}) -assert-css: ("#impl-HeavilyDocumentedUnion > h3.code-header", {"border-bottom-width": "0px"}) -assert-css: ("h4#title-for-union-impl-doc", {"font-size": "16px"}) -assert-css: ("h4#title-for-union-impl-doc", {"border-bottom-width": "0px"}) -assert-css: ("h5#sub-heading-for-union-impl-doc", {"font-size": "16px"}) -assert-css: ("h5#sub-heading-for-union-impl-doc", {"border-bottom-width": "0px"}) - -assert-css: ("h5#title-for-union-impl-item-doc", {"font-size": "16px"}) -assert-css: ("h5#title-for-union-impl-item-doc", {"border-bottom-width": "0px"}) -assert-css: ("h6#sub-heading-for-union-impl-item-doc", {"font-size": "14px"}) -assert-css: ("h6#sub-heading-for-union-impl-item-doc", {"border-bottom-width": "0px"}) - -goto: "file://" + |DOC_PATH| + "/test_docs/macro.heavily_documented_macro.html" - -assert-css: ("h1.fqn", {"font-size": "24px"}) - -assert-css: ("h2#top-doc-prose-title", {"font-size": "22px"}) -assert-css: ("h2#top-doc-prose-title", {"border-bottom-width": "1px"}) -assert-css: ("h3#top-doc-prose-sub-heading", {"font-size": "20px"}) -assert-css: ("h3#top-doc-prose-sub-heading", {"border-bottom-width": "1px"}) - -// Needed to check colors -show-text: true -goto: "file://" + |DOC_PATH| + "/test_docs/struct.HeavilyDocumentedStruct.html" - -define-function: ( - "check-colors", - (theme, heading_color, small_heading_color, heading_border_color), - [ - ("local-storage", {"rustdoc-theme": |theme|, "rustdoc-use-system-theme": "false"}), - ("reload"), - ("assert-css", ( - ".top-doc .docblock h2", - {"color": |heading_color|, "border-bottom": "1px solid " + |heading_border_color|}, - )), - ("assert-css", ( - ".top-doc .docblock h3", - {"color": |heading_color|, "border-bottom": "1px solid " + |heading_border_color|}, - )), - ("assert-css", ( - ".top-doc .docblock h4", - {"color": |heading_color|, "border-bottom": "1px solid " + |heading_border_color|}, - )), - ("assert-css", ( - ".top-doc .docblock h5", - {"color": |small_heading_color|, "border-bottom-width": "0px"}, - )), - ("assert-css", ( - "#implementations-list .docblock h4", - {"color": |heading_color|, "border-bottom-width": "0px"}, - )), - ("assert-css", ( - "#implementations-list .docblock h5", - {"color": |small_heading_color|, "border-bottom-width": "0px"}, - )), - ("assert-css", ( - "#implementations-list .docblock h6", - {"color": |small_heading_color|, "border-bottom-width": "0px"}, - )), - ], -) -call-function: ( - "check-colors", - { - "theme": "ayu", - "heading_color": "rgb(255, 255, 255)", - "small_heading_color": "rgb(197, 197, 197)", - "heading_border_color": "rgb(92, 103, 115)", - }, -) -call-function: ( - "check-colors", - { - "theme": "dark", - "heading_color": "rgb(221, 221, 221)", - "small_heading_color": "rgb(221, 221, 221)", - "heading_border_color": "rgb(210, 210, 210)", - }, -) -call-function: ( - "check-colors", - { - "theme": "light", - "heading_color": "rgb(0, 0, 0)", - "small_heading_color": "rgb(0, 0, 0)", - "heading_border_color": "rgb(221, 221, 221)", - }, -) - -define-function: ( - "check-since-color", - (theme), - [ - ("local-storage", {"rustdoc-theme": |theme|}), - ("reload"), - ("assert-css", (".since", {"color": "rgb(128, 128, 128)"}, ALL)), - ], -) - -goto: "file://" + |DOC_PATH| + "/staged_api/struct.Foo.html" -call-function: ("check-since-color", ("ayu")) -call-function: ("check-since-color", ("dark")) -call-function: ("check-since-color", ("light")) diff --git a/src/test/rustdoc-gui/help-page.goml b/src/test/rustdoc-gui/help-page.goml deleted file mode 100644 index 799ba851c..000000000 --- a/src/test/rustdoc-gui/help-page.goml +++ /dev/null @@ -1,64 +0,0 @@ -// This test ensures that opening the help page in its own tab works. -goto: "file://" + |DOC_PATH| + "/help.html" -size: (1000, 1000) // Try desktop size first. -wait-for: "#help" -assert-css: ("#help", {"display": "block"}) -assert-css: ("#help dd", {"font-size": "16px"}) -click: "#help-button > a" -assert-css: ("#help", {"display": "block"}) -compare-elements-property: (".sub", "#help", ["offsetWidth"]) -compare-elements-position: (".sub", "#help", ("x")) -size: (500, 1000) // Try mobile next. -assert-css: ("#help", {"display": "block"}) -compare-elements-property: (".sub", "#help", ["offsetWidth"]) -compare-elements-position: (".sub", "#help", ("x")) - -// Checking the color of the elements of the help menu. -show-text: true -define-function: ( - "check-colors", - (theme, color, background, box_shadow), - [ - // Setting the theme. - ("local-storage", {"rustdoc-theme": |theme|, "rustdoc-use-system-theme": "false"}), - // We reload the page so the local storage settings are being used. - ("reload"), - ("assert-css", ("#help kbd", { - "color": |color|, - "background-color": |background|, - "box-shadow": |box_shadow| + " 0px -1px 0px 0px inset", - "cursor": "default", - }, ALL)), - ], -) - -call-function: ("check-colors", { - "theme": "ayu", - "color": "rgb(197, 197, 197)", - "background": "rgb(49, 69, 89)", - "box_shadow": "rgb(92, 103, 115)", -}) -call-function: ("check-colors", { - "theme": "dark", - "color": "rgb(221, 221, 221)", - "background": "rgb(250, 251, 252)", - "box_shadow": "rgb(198, 203, 209)", -}) -call-function: ("check-colors", { - "theme": "light", - "color": "rgb(0, 0, 0)", - "background": "rgb(250, 251, 252)", - "box_shadow": "rgb(198, 203, 209)", -}) - -// This test ensures that opening the help popover without switching pages works. -goto: "file://" + |DOC_PATH| + "/test_docs/index.html" -size: (1000, 1000) // Only supported on desktop. -assert-false: "#help" -click: "#help-button > a" -assert-css: ("#help", {"display": "block"}) -assert-css: ("#help dd", {"font-size": "16px"}) -click: "#help-button > a" -assert-css: ("#help", {"display": "none"}) -compare-elements-property-false: (".sub", "#help", ["offsetWidth"]) -compare-elements-position-false: (".sub", "#help", ("x")) diff --git a/src/test/rustdoc-gui/highlight-colors.goml b/src/test/rustdoc-gui/highlight-colors.goml deleted file mode 100644 index ff1be389d..000000000 --- a/src/test/rustdoc-gui/highlight-colors.goml +++ /dev/null @@ -1,94 +0,0 @@ -// This test checks the highlight colors in the source code pages. -goto: "file://" + |DOC_PATH| + "/src/test_docs/lib.rs.html" -show-text: true - -define-function: ( - "check-colors", - ( - theme, - kw, - kw2, - prelude_ty, - prelude_val, - lifetime, - number, - string, - bool_val, - self, - attr, - macro, - question_mark, - comment, - doc_comment, - ), - [ - ("local-storage", {"rustdoc-theme": |theme|, "rustdoc-use-system-theme": "false"}), - ("reload"), - ("assert-css", ("pre.rust .kw", {"color": |kw|}, ALL)), - ("assert-css", ("pre.rust .kw-2", {"color": |kw2|}, ALL)), - ("assert-css", ("pre.rust .prelude-ty", {"color": |prelude_ty|}, ALL)), - ("assert-css", ("pre.rust .prelude-val", {"color": |prelude_val|}, ALL)), - ("assert-css", ("pre.rust .lifetime", {"color": |lifetime|}, ALL)), - ("assert-css", ("pre.rust .number", {"color": |number|}, ALL)), - ("assert-css", ("pre.rust .string", {"color": |string|}, ALL)), - ("assert-css", ("pre.rust .bool-val", {"color": |bool_val|}, ALL)), - ("assert-css", ("pre.rust .self", {"color": |self|}, ALL)), - ("assert-css", ("pre.rust .attr", {"color": |attr|}, ALL)), - ("assert-css", ("pre.rust .macro", {"color": |macro|}, ALL)), - ("assert-css", ("pre.rust .question-mark", {"color": |question_mark|}, ALL)), - ("assert-css", ("pre.rust .comment", {"color": |comment|}, ALL)), - ("assert-css", ("pre.rust .doccomment", {"color": |doc_comment|}, ALL)), - ], -) - -call-function: ("check-colors", { - "theme": "ayu", - "kw": "rgb(255, 119, 51)", - "kw2": "rgb(255, 119, 51)", - "prelude_ty": "rgb(105, 242, 223)", - "prelude_val": "rgb(255, 119, 51)", - "lifetime": "rgb(255, 119, 51)", - "number": "rgb(184, 204, 82)", - "string": "rgb(184, 204, 82)", - "bool_val": "rgb(255, 119, 51)", - "self": "rgb(54, 163, 217)", - "attr": "rgb(230, 225, 207)", - "macro": "rgb(163, 122, 204)", - "question_mark": "rgb(255, 144, 17)", - "comment": "rgb(120, 135, 151)", - "doc_comment": "rgb(161, 172, 136)", -}) -call-function: ("check-colors", { - "theme": "dark", - "kw": "rgb(171, 138, 193)", - "kw2": "rgb(118, 154, 203)", - "prelude_ty": "rgb(118, 154, 203)", - "prelude_val": "rgb(238, 104, 104)", - "lifetime": "rgb(217, 127, 38)", - "number": "rgb(131, 163, 0)", - "string": "rgb(131, 163, 0)", - "bool_val": "rgb(238, 104, 104)", - "self": "rgb(238, 104, 104)", - "attr": "rgb(238, 104, 104)", - "macro": "rgb(62, 153, 159)", - "question_mark": "rgb(255, 144, 17)", - "comment": "rgb(141, 141, 139)", - "doc_comment": "rgb(140, 163, 117)", -}) -call-function: ("check-colors", { - "theme": "light", - "kw": "rgb(137, 89, 168)", - "kw2": "rgb(66, 113, 174)", - "prelude_ty": "rgb(66, 113, 174)", - "prelude_val": "rgb(200, 40, 41)", - "lifetime": "rgb(183, 101, 20)", - "number": "rgb(113, 140, 0)", - "string": "rgb(113, 140, 0)", - "bool_val": "rgb(200, 40, 41)", - "self": "rgb(200, 40, 41)", - "attr": "rgb(200, 40, 41)", - "macro": "rgb(62, 153, 159)", - "question_mark": "rgb(255, 144, 17)", - "comment": "rgb(142, 144, 140)", - "doc_comment": "rgb(77, 77, 76)", -}) diff --git a/src/test/rustdoc-gui/huge-collection-of-constants.goml b/src/test/rustdoc-gui/huge-collection-of-constants.goml deleted file mode 100644 index 3ccd33f1c..000000000 --- a/src/test/rustdoc-gui/huge-collection-of-constants.goml +++ /dev/null @@ -1,9 +0,0 @@ -// Make sure that the last two entries are more than 12 pixels apart and not stacked on each other. - -goto: "file://" + |DOC_PATH| + "/test_docs/huge_amount_of_consts/index.html" - -compare-elements-position-near-false: ( - "//*[@class='item-table']//div[last()-1]", - "//*[@class='item-table']//div[last()-3]", - {"y": 12}, -) diff --git a/src/test/rustdoc-gui/huge-logo.goml b/src/test/rustdoc-gui/huge-logo.goml deleted file mode 100644 index 01f06771c..000000000 --- a/src/test/rustdoc-gui/huge-logo.goml +++ /dev/null @@ -1,21 +0,0 @@ -// huge_logo crate has a custom 712x860 logo -// test to ensure the maximum size in the layout works correctly -goto: "file://" + |DOC_PATH| + "/huge_logo/index.html" - -size: (1280, 1024) -// offsetWidth = width of sidebar -assert-property: (".sidebar .logo-container", {"offsetWidth": "200", "offsetHeight": 100}) -assert-property: (".sidebar .logo-container img", {"offsetWidth": "100", "offsetHeight": 100}) - -size: (400, 600) -// offset = size + margin -assert-property: (".mobile-topbar .logo-container", {"offsetWidth": "55", "offsetHeight": 45}) -assert-property: (".mobile-topbar .logo-container img", {"offsetWidth": "35", "offsetHeight": 35}) - -goto: "file://" + |DOC_PATH| + "/src/huge_logo/lib.rs.html" - -size: (1280, 1024) -assert-property: (".sub-logo-container", {"offsetWidth": "60", "offsetHeight": 60}) - -size: (400, 600) -assert-property: (".sub-logo-container", {"offsetWidth": "35", "offsetHeight": 35}) diff --git a/src/test/rustdoc-gui/impl-default-expansion.goml b/src/test/rustdoc-gui/impl-default-expansion.goml deleted file mode 100644 index c3f9240cc..000000000 --- a/src/test/rustdoc-gui/impl-default-expansion.goml +++ /dev/null @@ -1,3 +0,0 @@ -// This test ensures that the impl blocks are open by default. -goto: "file://" + |DOC_PATH| + "/test_docs/struct.Foo.html" -assert-attribute: ("#implementations-list details.implementors-toggle", {"open": ""}) diff --git a/src/test/rustdoc-gui/implementors.goml b/src/test/rustdoc-gui/implementors.goml deleted file mode 100644 index 4999283dc..000000000 --- a/src/test/rustdoc-gui/implementors.goml +++ /dev/null @@ -1,35 +0,0 @@ -// The goal of this test is to check that the external trait implementors, generated with JS, -// have the same display than the "local" ones. -goto: "file://" + |DOC_PATH| + "/implementors/trait.Whatever.html" -assert: "#implementors-list" -// There are supposed to be two implementors listed. -assert-count: ("#implementors-list .impl", 2) -// Now we check that both implementors have an anchor, an ID and a similar DOM. -assert: ("#implementors-list .impl:nth-child(1) > a.anchor") -assert-attribute: ("#implementors-list .impl:nth-child(1)", {"id": "impl-Whatever-for-Struct"}) -assert-attribute: ("#implementors-list .impl:nth-child(1) > a.anchor", {"href": "#impl-Whatever-for-Struct"}) -assert: "#implementors-list .impl:nth-child(1) > .code-header" - -assert: ("#implementors-list .impl:nth-child(2) > a.anchor") -assert-attribute: ("#implementors-list .impl:nth-child(2)", {"id": "impl-Whatever-1"}) -assert-attribute: ("#implementors-list .impl:nth-child(2) > a.anchor", {"href": "#impl-Whatever-1"}) -assert: "#implementors-list .impl:nth-child(2) > .code-header" - -goto: "file://" + |DOC_PATH| + "/test_docs/struct.HasEmptyTraits.html" -compare-elements-position-near-false: ( - "#impl-EmptyTrait1-for-HasEmptyTraits", - "#impl-EmptyTrait2-for-HasEmptyTraits", - {"y": 34}, -) -compare-elements-position-near: ( - "#impl-EmptyTrait3-for-HasEmptyTraits h3", - "#impl-EmptyTrait3-for-HasEmptyTraits .item-info", - {"y": 34}, -) - -// Now check that re-exports work correctly. -// There should be exactly one impl shown on both of these pages. -goto: "file://" + |DOC_PATH| + "/lib2/trait.TraitToReexport.html" -assert-count: ("#implementors-list .impl", 1) -goto: "file://" + |DOC_PATH| + "/implementors/trait.TraitToReexport.html" -assert-count: ("#implementors-list .impl", 1) diff --git a/src/test/rustdoc-gui/item-decl-colors.goml b/src/test/rustdoc-gui/item-decl-colors.goml deleted file mode 100644 index 2e07f19b1..000000000 --- a/src/test/rustdoc-gui/item-decl-colors.goml +++ /dev/null @@ -1,79 +0,0 @@ -// This test ensures that the color of the items in the type decl are working as expected. - -// We need to disable this check because `implementors/test_docs/trait.TraitWithoutGenerics.js` -// doesn't exist. -fail-on-request-error: false - -define-function: ( - "check-colors", - ( - theme, - attr_color, - trait_color, - struct_color, - enum_color, - primitive_color, - constant_color, - fn_color, - assoc_type_color, - ), - [ - ("goto", "file://" + |DOC_PATH| + "/test_docs/struct.WithGenerics.html"), - ("show-text", true), - ("local-storage", {"rustdoc-theme": |theme|, "rustdoc-use-system-theme": "false"}), - ("reload"), - ("assert-css", (".item-decl .code-attribute", {"color": |attr_color|}, ALL)), - ("assert-css", (".item-decl .trait", {"color": |trait_color|}, ALL)), - // We need to add `code` here because otherwise it would select the parent too. - ("assert-css", (".item-decl code .struct", {"color": |struct_color|}, ALL)), - ("assert-css", (".item-decl .enum", {"color": |enum_color|}, ALL)), - ("assert-css", (".item-decl .primitive", {"color": |primitive_color|}, ALL)), - ("goto", "file://" + |DOC_PATH| + "/test_docs/trait.TraitWithoutGenerics.html"), - ("assert-css", (".item-decl .constant", {"color": |constant_color|}, ALL)), - ("assert-css", (".item-decl .fn", {"color": |fn_color|}, ALL)), - ("assert-css", (".item-decl .associatedtype", {"color": |assoc_type_color|}, ALL)), - ], -) - -call-function: ( - "check-colors", - { - "theme": "ayu", - "attr_color": "rgb(153, 153, 153)", - "trait_color": "rgb(57, 175, 215)", - "struct_color": "rgb(255, 160, 165)", - "enum_color": "rgb(255, 160, 165)", - "primitive_color": "rgb(255, 160, 165)", - "constant_color": "rgb(57, 175, 215)", - "fn_color": "rgb(253, 214, 135)", - "assoc_type_color": "rgb(57, 175, 215)", - }, -) -call-function: ( - "check-colors", - { - "theme": "dark", - "attr_color": "rgb(153, 153, 153)", - "trait_color": "rgb(183, 140, 242)", - "struct_color": "rgb(45, 191, 184)", - "enum_color": "rgb(45, 191, 184)", - "primitive_color": "rgb(45, 191, 184)", - "constant_color": "rgb(210, 153, 29)", - "fn_color": "rgb(43, 171, 99)", - "assoc_type_color": "rgb(210, 153, 29)", - }, -) -call-function: ( - "check-colors", - { - "theme": "light", - "attr_color": "rgb(153, 153, 153)", - "trait_color": "rgb(110, 79, 201)", - "struct_color": "rgb(173, 55, 138)", - "enum_color": "rgb(173, 55, 138)", - "primitive_color": "rgb(173, 55, 138)", - "constant_color": "rgb(56, 115, 173)", - "fn_color": "rgb(173, 124, 55)", - "assoc_type_color": "rgb(56, 115, 173)", - }, -) diff --git a/src/test/rustdoc-gui/item-info-alignment.goml b/src/test/rustdoc-gui/item-info-alignment.goml deleted file mode 100644 index 94b52f005..000000000 --- a/src/test/rustdoc-gui/item-info-alignment.goml +++ /dev/null @@ -1,10 +0,0 @@ -// This test ensures that the "item-info" looks about the same -// whether or not it's inside a toggle. -goto: "file://" + |DOC_PATH| + "/lib2/struct.ItemInfoAlignmentTest.html" - -// First, we try it in "desktop" mode. -size: (1200, 870) -compare-elements-position: (".impl-items > .item-info", "summary > .item-info", ("x")) -// Next, we try it in "mobile" mode (max-width: 700px). -size: (650, 650) -compare-elements-position: (".impl-items > .item-info", "summary > .item-info", ("x")) diff --git a/src/test/rustdoc-gui/item-info-overflow.goml b/src/test/rustdoc-gui/item-info-overflow.goml deleted file mode 100644 index 8ea14621c..000000000 --- a/src/test/rustdoc-gui/item-info-overflow.goml +++ /dev/null @@ -1,31 +0,0 @@ -// This test ensures that the "item-info" elements don't overflow. -goto: "file://" + |DOC_PATH| + "/lib2/struct.LongItemInfo.html" -// We set a fixed size so there is no chance of "random" resize. -size: (1200, 870) -// Logically, the "item-decl" and the "item-info" should have the same scroll width. -compare-elements-property: (".item-decl", ".item-info", ["scrollWidth"]) -assert-property: (".item-info", {"scrollWidth": "940"}) -// Just to be sure we're comparing the correct "item-info": -assert-text: ( - ".item-info", - "Available on Android or Linux or Emscripten or DragonFly BSD", - STARTS_WITH, -) - -// Checking the "item-info" on an impl block as well: -goto: "file://" + |DOC_PATH| + "/lib2/struct.LongItemInfo2.html" -compare-elements-property: ( - "#impl-SimpleTrait-for-LongItemInfo2 .item-info", - "#impl-SimpleTrait-for-LongItemInfo2 + .docblock", - ["scrollWidth"], -) -assert-property: ( - "#impl-SimpleTrait-for-LongItemInfo2 .item-info", - {"scrollWidth": "916"}, -) -// Just to be sure we're comparing the correct "item-info": -assert-text: ( - "#impl-SimpleTrait-for-LongItemInfo2 .item-info", - "Available on Android or Linux or Emscripten or DragonFly BSD", - STARTS_WITH, -) diff --git a/src/test/rustdoc-gui/item-info.goml b/src/test/rustdoc-gui/item-info.goml deleted file mode 100644 index 6780dfca6..000000000 --- a/src/test/rustdoc-gui/item-info.goml +++ /dev/null @@ -1,32 +0,0 @@ -// This test ensures a few things for item info elements. -goto: "file://" + |DOC_PATH| + "/lib2/struct.Foo.html" -// Ensuring that the item information don't take 100% of the width if unnecessary. -// We set a fixed size so there is no chance of "random" resize. -size: (1100, 800) -// We check that ".item-info" is bigger than its content. -assert-css: (".item-info", {"width": "840px"}) -assert-css: (".item-info .stab", {"width": "289px"}) -assert-position: (".item-info .stab", {"x": 245}) - -// Now we ensure that they're not rendered on the same line. -goto: "file://" + |DOC_PATH| + "/lib2/trait.Trait.html" -// We first ensure that there are two item info on the trait. -assert-count: ("#main-content > .item-info .stab", 2) -// They should not have the same `y` position! -compare-elements-position-false: ( - "#main-content > .item-info .stab:nth-of-type(1)", - "#main-content > .item-info .stab:nth-of-type(2)", - ("y"), -) -// But they should have the same `x` position. -compare-elements-position: ( - "#main-content > .item-info .stab:nth-of-type(1)", - "#main-content > .item-info .stab:nth-of-type(2)", - ("x"), -) -// They are supposed to have the same height too. -compare-elements-css: ( - "#main-content > .item-info .stab:nth-of-type(1)", - "#main-content > .item-info .stab:nth-of-type(2)", - ["height"], -) diff --git a/src/test/rustdoc-gui/item-summary-table.goml b/src/test/rustdoc-gui/item-summary-table.goml deleted file mode 100644 index 2a92e9da5..000000000 --- a/src/test/rustdoc-gui/item-summary-table.goml +++ /dev/null @@ -1,6 +0,0 @@ -// This test ensures that <table> elements aren't display in items summary. -goto: "file://" + |DOC_PATH| + "/lib2/summary_table/index.html" -// We check that we picked the right item first. -assert-text: (".item-table .item-left", "Foo") -// Then we check that its summary is empty. -assert-false: ".item-table .item-right" diff --git a/src/test/rustdoc-gui/javascript-disabled.goml b/src/test/rustdoc-gui/javascript-disabled.goml deleted file mode 100644 index edf179d0d..000000000 --- a/src/test/rustdoc-gui/javascript-disabled.goml +++ /dev/null @@ -1,6 +0,0 @@ -// When JavaScript is disabled, we hide the search bar, because it -// can't be used without JS. -javascript: false - -goto: "file://" + |DOC_PATH| + "/test_docs/struct.Foo.html" -assert-css: (".sub", {"display": "none"}) diff --git a/src/test/rustdoc-gui/jump-to-def-background.goml b/src/test/rustdoc-gui/jump-to-def-background.goml deleted file mode 100644 index b65faf13d..000000000 --- a/src/test/rustdoc-gui/jump-to-def-background.goml +++ /dev/null @@ -1,22 +0,0 @@ -// We check the background color on the jump to definition links in the source code page. -goto: "file://" + |DOC_PATH| + "/src/link_to_definition/lib.rs.html" - -define-function: ( - "check-background-color", - (theme, background_color), - [ - // Set the theme. - ("local-storage", { "rustdoc-theme": |theme|, "rustdoc-use-system-theme": "false" }), - // We reload the page so the local storage settings are being used. - ("reload"), - ("assert-css", ( - "body.source .example-wrap pre.rust a", - {"background-color": |background_color|}, - ALL, - )), - ], -) - -call-function: ("check-background-color", ("ayu", "rgb(51, 51, 51)")) -call-function: ("check-background-color", ("dark", "rgb(51, 51, 51)")) -call-function: ("check-background-color", ("light", "rgb(238, 238, 238)")) diff --git a/src/test/rustdoc-gui/label-next-to-symbol.goml b/src/test/rustdoc-gui/label-next-to-symbol.goml deleted file mode 100644 index 05f8ddc71..000000000 --- a/src/test/rustdoc-gui/label-next-to-symbol.goml +++ /dev/null @@ -1,66 +0,0 @@ -// These tests verify that labels like "UNIX" and "Deprecated" stay on the same line as their symbol. -// It also verifies the staggered layout on mobile. -goto: "file://" + |DOC_PATH| + "/test_docs/index.html" - -// Desktop view -size: (1080, 600) -assert: (".stab.deprecated") -assert: (".stab.portability") - -// make sure that deprecated and portability have the right colors -assert-css: ( - ".item-table .item-left .stab.deprecated", - { "background-color": "rgb(255, 245, 214)" }, -) -assert-css: ( - ".item-table .item-left .stab.portability", - { "background-color": "rgb(255, 245, 214)" }, -) - -// table like view -assert-css: (".item-right.docblock-short", { "padding-left": "0px" }) -compare-elements-position-near: ( - "//*[@class='item-left module-item']//a[text()='replaced_function']", - ".item-left .stab.deprecated", - {"y": 2}, -) -compare-elements-position: ( - ".item-left .stab.deprecated", - ".item-left .stab.portability", - ("y"), -) - -// Ensure no wrap -compare-elements-position: ( - "//*[@class='item-left module-item']//a[text()='replaced_function']/..", - "//*[@class='item-right docblock-short'][text()='a thing with a label']", - ("y"), -) - - -// Mobile view -size: (600, 600) -// staggered layout with 2em spacing -assert-css: (".item-right.docblock-short", { "padding-left": "32px" }) -compare-elements-position-near: ( - "//*[@class='item-left module-item']//a[text()='replaced_function']", - ".item-left .stab.deprecated", - {"y": 2}, -) -compare-elements-position: ( - ".item-left .stab.deprecated", - ".item-left .stab.portability", - ("y"), -) - -// Ensure wrap -compare-elements-position-false: ( - "//*[@class='item-left module-item']//a[text()='replaced_function']/..", - "//*[@class='item-right docblock-short'][text()='a thing with a label']", - ("y"), -) -compare-elements-position-false: ( - ".item-left .stab.deprecated", - "//*[@class='item-right docblock-short'][text()='a thing with a label']", - ("y"), -) diff --git a/src/test/rustdoc-gui/links-color.goml b/src/test/rustdoc-gui/links-color.goml deleted file mode 100644 index 839629ad9..000000000 --- a/src/test/rustdoc-gui/links-color.goml +++ /dev/null @@ -1,85 +0,0 @@ -// This test checks links colors. -goto: "file://" + |DOC_PATH| + "/test_docs/index.html" - -// This is needed so that the text color is computed. -show-text: true - -// Ayu theme -local-storage: { - "rustdoc-theme": "ayu", - "rustdoc-use-system-theme": "false", -} -reload: - -assert-css: (".item-table .mod", {"color": "rgb(57, 175, 215)"}, ALL) -assert-css: (".item-table .macro", {"color": "rgb(163, 122, 204)"}, ALL) -assert-css: (".item-table .struct", {"color": "rgb(255, 160, 165)"}, ALL) -assert-css: (".item-table .enum", {"color": "rgb(255, 160, 165)"}, ALL) -assert-css: (".item-table .trait", {"color": "rgb(57, 175, 215)"}, ALL) -assert-css: (".item-table .fn", {"color": "rgb(253, 214, 135)"}, ALL) -assert-css: (".item-table .type", {"color": "rgb(255, 160, 165)"}, ALL) -assert-css: (".item-table .union", {"color": "rgb(255, 160, 165)"}, ALL) -assert-css: (".item-table .keyword", {"color": "rgb(57, 175, 215)"}, ALL) - -assert-css: ( - ".sidebar-elems a:not(.current)", - {"color": "rgb(83, 177, 219)", "background-color": "rgba(0, 0, 0, 0)", "font-weight": "400"}, - ALL, -) -assert-css: ( - ".sidebar-elems a.current", - {"color": "rgb(255, 180, 76)", "background-color": "rgba(0, 0, 0, 0)", "font-weight": "500"}, - ALL, -) - - -// Dark theme -local-storage: {"rustdoc-theme": "dark"} -reload: - -assert-css: (".item-table .mod", {"color": "rgb(210, 153, 29)"}, ALL) -assert-css: (".item-table .macro", {"color": "rgb(9, 189, 0)"}, ALL) -assert-css: (".item-table .struct", {"color": "rgb(45, 191, 184)"}, ALL) -assert-css: (".item-table .enum", {"color": "rgb(45, 191, 184)"}, ALL) -assert-css: (".item-table .trait", {"color": "rgb(183, 140, 242)"}, ALL) -assert-css: (".item-table .fn", {"color": "rgb(43, 171, 99)"}, ALL) -assert-css: (".item-table .type", {"color": "rgb(45, 191, 184)"}, ALL) -assert-css: (".item-table .union", {"color": "rgb(45, 191, 184)"}, ALL) -assert-css: (".item-table .keyword", {"color": "rgb(210, 153, 29)"}, ALL) - -assert-css: ( - ".sidebar-elems a:not(.current)", - {"color": "rgb(253, 191, 53)", "background-color": "rgba(0, 0, 0, 0)", "font-weight": "400"}, - ALL, -) -assert-css: ( - ".sidebar-elems a.current", - {"color": "rgb(253, 191, 53)", "background-color": "rgb(68, 68, 68)", "font-weight": "500"}, - ALL, -) - - -// Light theme -local-storage: {"rustdoc-theme": "light"} -reload: - -assert-css: (".item-table .mod", {"color": "rgb(56, 115, 173)"}, ALL) -assert-css: (".item-table .macro", {"color": "rgb(6, 128, 0)"}, ALL) -assert-css: (".item-table .struct", {"color": "rgb(173, 55, 138)"}, ALL) -assert-css: (".item-table .enum", {"color": "rgb(173, 55, 138)"}, ALL) -assert-css: (".item-table .trait", {"color": "rgb(110, 79, 201)"}, ALL) -assert-css: (".item-table .fn", {"color": "rgb(173, 124, 55)"}, ALL) -assert-css: (".item-table .type", {"color": "rgb(173, 55, 138)"}, ALL) -assert-css: (".item-table .union", {"color": "rgb(173, 55, 138)"}, ALL) -assert-css: (".item-table .keyword", {"color": "rgb(56, 115, 173)"}, ALL) - -assert-css: ( - ".sidebar-elems a:not(.current)", - {"color": "rgb(53, 109, 164)", "background-color": "rgba(0, 0, 0, 0)", "font-weight": "400"}, - ALL, -) -assert-css: ( - ".sidebar-elems a.current", - {"color": "rgb(53, 109, 164)", "background-color": "rgb(255, 255, 255)", "font-weight": "500"}, - ALL, -) diff --git a/src/test/rustdoc-gui/list_code_block.goml b/src/test/rustdoc-gui/list_code_block.goml deleted file mode 100644 index 3423a449d..000000000 --- a/src/test/rustdoc-gui/list_code_block.goml +++ /dev/null @@ -1,4 +0,0 @@ -// This test checks that code blocks in list are supported. -goto: "file://" + |DOC_PATH| + "/test_docs/index.html" -goto: "./fn.check_list_code_block.html" -assert: ("pre.rust.fn") diff --git a/src/test/rustdoc-gui/method-margins.goml b/src/test/rustdoc-gui/method-margins.goml deleted file mode 100644 index ed36bcdec..000000000 --- a/src/test/rustdoc-gui/method-margins.goml +++ /dev/null @@ -1,18 +0,0 @@ -// This test ensures that the margins on methods are coherent inside an impl block. -goto: "file://" + |DOC_PATH| + "/test_docs/trait_members/struct.HasTrait.html#impl-TraitMembers-for-HasTrait" - -assert-count: ("#trait-implementations-list > .rustdoc-toggle", 1) - -compare-elements-css: ( - // compare margin on type with margin on method - "#trait-implementations-list .impl-items > .rustdoc-toggle:nth-child(1) > summary", - "#trait-implementations-list .impl-items > .rustdoc-toggle:nth-child(2) > summary", - ["margin"] -) - -compare-elements-css: ( - // compare margin on type with margin on method - "#trait-implementations-list .impl-items > .rustdoc-toggle:nth-child(1)", - "#trait-implementations-list .impl-items > .rustdoc-toggle:nth-child(2)", - ["margin"] -) diff --git a/src/test/rustdoc-gui/mobile.goml b/src/test/rustdoc-gui/mobile.goml deleted file mode 100644 index 704542a39..000000000 --- a/src/test/rustdoc-gui/mobile.goml +++ /dev/null @@ -1,30 +0,0 @@ -// Test various properties of the mobile UI -goto: "file://" + |DOC_PATH| + "/staged_api/struct.Foo.html" -size: (400, 600) - -font-size: 18 -wait-for: 100 // wait a bit for the resize and the font-size change to be fully taken into account. - -// The out-of-band info (source, stable version, collapse) should be below the -// h1 when the screen gets narrow enough. -assert-css: (".main-heading", { - "display": "flex", - "flex-direction": "column" -}) - -assert-property: (".mobile-topbar h2", {"offsetHeight": 36}) - -// Note: We can't use assert-text here because the 'Since' is set by CSS and -// is therefore not part of the DOM. -assert-css: (".content .out-of-band .since::before", { "content": "\"Since \"" }) - -size: (1000, 1000) -wait-for: 100 // wait a bit for the resize to be fully taken into account. -assert-css-false: (".content .out-of-band .since::before", { "content": "\"Since \"" }) - -// On the settings page, the theme buttons should not line-wrap. Instead, they should -// all be placed as a group on a line below the setting name "Theme." -goto: "file://" + |DOC_PATH| + "/settings.html" -size: (400, 600) -// Ignored for now https://github.com/rust-lang/rust/issues/93784. -// compare-elements-position-near-false: ("#preferred-light-theme .setting-name", "#preferred-light-theme .choice", {"y": 16}) diff --git a/src/test/rustdoc-gui/module-items-font.goml b/src/test/rustdoc-gui/module-items-font.goml deleted file mode 100644 index cd3676a98..000000000 --- a/src/test/rustdoc-gui/module-items-font.goml +++ /dev/null @@ -1,67 +0,0 @@ -// This test checks that the correct font is used on module items (in index.html pages). -goto: "file://" + |DOC_PATH| + "/test_docs/index.html" -assert-css: ( - ".item-table .module-item a", - {"font-family": '"Fira Sans", Arial, NanumBarunGothic, sans-serif'}, - ALL, -) -assert-css: ( - ".item-table .docblock-short", - {"font-family": '"Source Serif 4", NanumBarunGothic, serif'}, - ALL, -) - -// modules -assert-css: ( - "#modules + .item-table .item-left a", - {"font-family": '"Fira Sans", Arial, NanumBarunGothic, sans-serif'}, -) -assert-css: ( - "#modules + .item-table .item-right.docblock-short", - {"font-family": '"Source Serif 4", NanumBarunGothic, serif'}, -) -// structs -assert-css: ( - "#structs + .item-table .item-left a", - {"font-family": '"Fira Sans", Arial, NanumBarunGothic, sans-serif'}, -) -assert-css: ( - "#structs + .item-table .item-right.docblock-short", - {"font-family": '"Source Serif 4", NanumBarunGothic, serif'}, -) -// enums -assert-css: ( - "#enums + .item-table .item-left a", - {"font-family": '"Fira Sans", Arial, NanumBarunGothic, sans-serif'}, -) -assert-css: ( - "#enums + .item-table .item-right.docblock-short", - {"font-family": '"Source Serif 4", NanumBarunGothic, serif'}, -) -// traits -assert-css: ( - "#traits + .item-table .item-left a", - {"font-family": '"Fira Sans", Arial, NanumBarunGothic, sans-serif'}, -) -assert-css: ( - "#traits + .item-table .item-right.docblock-short", - {"font-family": '"Source Serif 4", NanumBarunGothic, serif'}, -) -// functions -assert-css: ( - "#functions + .item-table .item-left a", - {"font-family": '"Fira Sans", Arial, NanumBarunGothic, sans-serif'}, -) -assert-css: ( - "#functions + .item-table .item-right.docblock-short", - {"font-family": '"Source Serif 4", NanumBarunGothic, serif'}, -) -// keywords -assert-css: ( - "#keywords + .item-table .item-left a", - {"font-family": '"Fira Sans", Arial, NanumBarunGothic, sans-serif'}, -) -assert-css: ( - "#keywords + .item-table .item-right.docblock-short", - {"font-family": '"Source Serif 4", NanumBarunGothic, serif'}, -) diff --git a/src/test/rustdoc-gui/no-docblock.goml b/src/test/rustdoc-gui/no-docblock.goml deleted file mode 100644 index 17a955064..000000000 --- a/src/test/rustdoc-gui/no-docblock.goml +++ /dev/null @@ -1,13 +0,0 @@ -// This test checks that there are margins applied to methods with no docblocks. - -// We need to disable this check because `implementors/test_docs/trait.TraitWithNoDocblock.js` -// doesn't exist. -fail-on-request-error: false - -goto: "file://" + |DOC_PATH| + "/test_docs/trait.TraitWithNoDocblocks.html" -// Check that the two methods are more than 24px apart. -compare-elements-position-near-false: ("//*[@id='tymethod.first_fn']", "//*[@id='tymethod.second_fn']", {"y": 24}) - -goto: "file://" + |DOC_PATH| + "/test_docs/struct.TypeWithNoDocblocks.html" -// Check that the two methods are more than 24px apart. -compare-elements-position-near-false: ("//*[@id='method.first_fn']", "//*[@id='method.second_fn']", {"y": 24}) diff --git a/src/test/rustdoc-gui/notable-trait.goml b/src/test/rustdoc-gui/notable-trait.goml deleted file mode 100644 index 7d4bd27d4..000000000 --- a/src/test/rustdoc-gui/notable-trait.goml +++ /dev/null @@ -1,276 +0,0 @@ -// This test checks the position of the `i` for the notable traits. -goto: "file://" + |DOC_PATH| + "/test_docs/struct.NotableStructWithLongName.html" -show-text: true -// We start with a wide screen. -size: (1100, 600) -// Checking they have the same y position. -compare-elements-position: ( - "//*[@id='method.create_an_iterator_from_read']//a[text()='NotableStructWithLongName']", - "//*[@id='method.create_an_iterator_from_read']//*[@class='notable-traits']", - ("y"), -) -// Checking they don't have the same x position. -compare-elements-position-false: ( - "//*[@id='method.create_an_iterator_from_read']//a[text()='NotableStructWithLongName']", - "//*[@id='method.create_an_iterator_from_read']//*[@class='notable-traits']", - ("x"), -) -// The `i` should be *after* the type. -assert-position: ( - "//*[@id='method.create_an_iterator_from_read']//a[text()='NotableStructWithLongName']", - {"x": 677}, -) -assert-position: ( - "//*[@id='method.create_an_iterator_from_read']//*[@class='notable-traits']", - {"x": 955}, -) -// The tooltip should be below the `i` -// Also, clicking the tooltip should bring its text into the DOM -assert-count: ("//*[@class='notable popover']", 0) -click: "//*[@id='method.create_an_iterator_from_read']//*[@class='notable-traits']" -assert-count: ("//*[@class='notable popover']", 1) -compare-elements-position-near: ( - "//*[@id='method.create_an_iterator_from_read']//*[@class='notable-traits']", - "//*[@class='notable popover']", - {"y": 30} -) -compare-elements-position-false: ( - "//*[@id='method.create_an_iterator_from_read']//*[@class='notable-traits']", - "//*[@class='notable popover']", - ("x") -) -click: "//*[@id='method.create_an_iterator_from_read']//*[@class='notable-traits']" -move-cursor-to: "//h1" -assert-count: ("//*[@class='notable popover']", 0) - -// Now only the `i` should be on the next line. -size: (1055, 600) -compare-elements-position-false: ( - "//*[@id='method.create_an_iterator_from_read']//a[text()='NotableStructWithLongName']", - "//*[@id='method.create_an_iterator_from_read']//*[@class='notable-traits']", - ("y", "x"), -) - -// Now both the `i` and the struct name should be on the next line. -size: (980, 600) -// Checking they have the same y position. -compare-elements-position: ( - "//*[@id='method.create_an_iterator_from_read']//a[text()='NotableStructWithLongName']", - "//*[@id='method.create_an_iterator_from_read']//*[@class='notable-traits']", - ("y"), -) -// Checking they don't have the same x position. -compare-elements-position-false: ( - "//*[@id='method.create_an_iterator_from_read']//a[text()='NotableStructWithLongName']", - "//*[@id='method.create_an_iterator_from_read']//*[@class='notable-traits']", - ("x"), -) -// The `i` should be *after* the type. -assert-position: ( - "//*[@id='method.create_an_iterator_from_read']//a[text()='NotableStructWithLongName']", - {"x": 245}, -) -assert-position: ( - "//*[@id='method.create_an_iterator_from_read']//*[@class='notable-traits']", - {"x": 523}, -) - -// Checking on mobile now. -size: (650, 600) -// Checking they have the same y position. -compare-elements-position: ( - "//*[@id='method.create_an_iterator_from_read']//a[text()='NotableStructWithLongName']", - "//*[@id='method.create_an_iterator_from_read']//*[@class='notable-traits']", - ("y"), -) -// Checking they don't have the same x position. -compare-elements-position-false: ( - "//*[@id='method.create_an_iterator_from_read']//a[text()='NotableStructWithLongName']", - "//*[@id='method.create_an_iterator_from_read']//*[@class='notable-traits']", - ("x"), -) -// The `i` should be *after* the type. -assert-position: ( - "//*[@id='method.create_an_iterator_from_read']//a[text()='NotableStructWithLongName']", - {"x": 15}, -) -assert-position: ( - "//*[@id='method.create_an_iterator_from_read']//*[@class='notable-traits']", - {"x": 293}, -) -// The tooltip should STILL be below `i` -click: "//*[@id='method.create_an_iterator_from_read']//*[@class='notable-traits']" -assert-count: ("//*[@class='notable popover']", 1) -compare-elements-position-near: ( - "//*[@id='method.create_an_iterator_from_read']//*[@class='notable-traits']", - "//*[@class='notable popover']", - {"y": 30} -) -compare-elements-position-false: ( - "//*[@id='method.create_an_iterator_from_read']//*[@class='notable-traits']", - "//*[@class='notable popover']", - ("x") -) -assert-position: ( - "//*[@class='notable popover']", - {"x": 0} -) -click: "//*[@id='method.create_an_iterator_from_read']//*[@class='notable-traits']" -move-cursor-to: "//h1" -assert-count: ("//*[@class='notable popover']", 0) - -// Now check the colors. -define-function: ( - "check-colors", - (theme, header_color, content_color, type_color, trait_color), - [ - ("goto", "file://" + |DOC_PATH| + "/test_docs/struct.NotableStructWithLongName.html"), - // This is needed to ensure that the text color is computed. - ("show-text", true), - - // Setting the theme. - ("local-storage", {"rustdoc-theme": |theme|, "rustdoc-use-system-theme": "false"}), - // We reload the page so the local storage settings are being used. - ("reload"), - - ("move-cursor-to", "//*[@id='method.create_an_iterator_from_read']//*[@class='notable-traits']"), - ("assert-count", (".notable.popover", 1)), - - ("assert-css", ( - ".notable.popover h3", - {"color": |header_color|}, - ALL, - )), - ("assert-css", ( - ".notable.popover pre", - {"color": |content_color|}, - ALL, - )), - ("assert-css", ( - ".notable.popover pre a.struct", - {"color": |type_color|}, - ALL, - )), - ("assert-css", ( - ".notable.popover pre a.trait", - {"color": |trait_color|}, - ALL, - )), - ] -) - -call-function: ( - "check-colors", - { - "theme": "ayu", - "content_color": "rgb(230, 225, 207)", - "header_color": "rgb(255, 255, 255)", - "type_color": "rgb(255, 160, 165)", - "trait_color": "rgb(57, 175, 215)", - }, -) - -call-function: ( - "check-colors", - { - "theme": "dark", - "content_color": "rgb(221, 221, 221)", - "header_color": "rgb(221, 221, 221)", - "type_color": "rgb(45, 191, 184)", - "trait_color": "rgb(183, 140, 242)", - }, -) - -call-function: ( - "check-colors", - { - "theme": "light", - "content_color": "rgb(0, 0, 0)", - "header_color": "rgb(0, 0, 0)", - "type_color": "rgb(173, 55, 138)", - "trait_color": "rgb(110, 79, 201)", - }, -) - -reload: - -// Check that pressing escape works -click: "//*[@id='method.create_an_iterator_from_read']//*[@class='notable-traits']" -move-cursor-to: "//*[@class='notable popover']" -assert-count: ("//*[@class='notable popover']", 1) -press-key: "Escape" -assert-count: ("//*[@class='notable popover']", 0) -assert: "#method\.create_an_iterator_from_read .notable-traits:focus" - -// Check that clicking outside works. -click: "//*[@id='method.create_an_iterator_from_read']//*[@class='notable-traits']" -assert-count: ("//*[@class='notable popover']", 1) -click: ".search-input" -assert-count: ("//*[@class='notable popover']", 0) -assert-false: "#method\.create_an_iterator_from_read .notable-traits:focus" - -// Check that pressing tab over and over works. -click: "//*[@id='method.create_an_iterator_from_read']//*[@class='notable-traits']" -move-cursor-to: "//*[@class='notable popover']" -assert-count: ("//*[@class='notable popover']", 1) -press-key: "Tab" -press-key: "Tab" -press-key: "Tab" -press-key: "Tab" -press-key: "Tab" -press-key: "Tab" -press-key: "Tab" -assert-count: ("//*[@class='notable popover']", 0) -assert: "#method\.create_an_iterator_from_read .notable-traits:focus" - -// Now we check that the focus isn't given back to the wrong item when opening -// another popover. -store-window-property: (scroll, "scrollY") -click: "#method\.create_an_iterator_from_read .fn" -// We ensure that the scroll position changed. -assert-window-property-false: {"scrollY": |scroll|} -// Store the new position. -store-window-property: (scroll, "scrollY") -click: "//*[@id='method.create_an_iterator_from_read']//*[@class='notable-traits']" -wait-for: "//*[@class='notable popover']" -click: "#settings-menu a" -click: ".search-input" -// We ensure we didn't come back to the previous focused item. -assert-window-property-false: {"scrollY": |scroll|} - -// Same but with Escape handling. -store-window-property: (scroll, "scrollY") -click: "#method\.create_an_iterator_from_read .fn" -// We ensure that the scroll position changed. -assert-window-property-false: {"scrollY": |scroll|} -// Store the new position. -store-window-property: (scroll, "scrollY") -click: "//*[@id='method.create_an_iterator_from_read']//*[@class='notable-traits']" -wait-for: "//*[@class='notable popover']" -click: "#settings-menu a" -press-key: "Escape" -// We ensure we didn't come back to the previous focused item. -assert-window-property-false: {"scrollY": |scroll|} - -// Opening the mobile sidebar should close the popover. -size: (650, 600) -click: "//*[@id='method.create_an_iterator_from_read']//*[@class='notable-traits']" -assert-count: ("//*[@class='notable popover']", 1) -click: ".sidebar-menu-toggle" -assert: "//*[@class='sidebar shown']" -assert-count: ("//*[@class='notable popover']", 0) -assert-false: "#method\.create_an_iterator_from_read .notable-traits:focus" -// Clicking a notable popover should close the sidebar. -click: "//*[@id='method.create_an_iterator_from_read']//*[@class='notable-traits']" -assert-count: ("//*[@class='notable popover']", 1) -assert-false: "//*[@class='sidebar shown']" - -// Also check the focus handling for the help button. -size: (1100, 600) -reload: -assert-count: ("//*[@class='notable popover']", 0) -click: "//*[@id='method.create_an_iterator_from_read']//*[@class='notable-traits']" -assert-count: ("//*[@class='notable popover']", 1) -click: "#help-button a" -assert-count: ("//*[@class='notable popover']", 0) -assert-false: "#method\.create_an_iterator_from_read .notable-traits:focus" diff --git a/src/test/rustdoc-gui/overflow-tooltip-information.goml b/src/test/rustdoc-gui/overflow-tooltip-information.goml deleted file mode 100644 index 09ad6cdd7..000000000 --- a/src/test/rustdoc-gui/overflow-tooltip-information.goml +++ /dev/null @@ -1,8 +0,0 @@ -// The goal of this test is to ensure that the tooltip `.information` class doesn't -// have overflow and max-width CSS rules set because they create a bug in firefox on -// mac. For more information: https://github.com/rust-lang/rust/issues/89185 -goto: "file://" + |DOC_PATH| + "/test_docs/fn.foo.html" -assert-css: (".docblock > .example-wrap .tooltip", { - "overflow-x": "visible", - "max-width": "none" -}, ALL) diff --git a/src/test/rustdoc-gui/pocket-menu.goml b/src/test/rustdoc-gui/pocket-menu.goml deleted file mode 100644 index c3649dc7b..000000000 --- a/src/test/rustdoc-gui/pocket-menu.goml +++ /dev/null @@ -1,98 +0,0 @@ -// This test ensures that the "pocket menus" are working as expected. -goto: "file://" + |DOC_PATH| + "/test_docs/index.html" -// First we check that the help menu doesn't exist yet. -assert-false: "#help-button .popover" -// Then we display the help menu. -click: "#help-button" -assert: "#help-button .popover" -assert-css: ("#help-button .popover", {"display": "block"}) - -// Now we click somewhere else on the page to ensure it is handling the blur event -// correctly. -click: ".sidebar" -assert-css: ("#help-button .popover", {"display": "none"}) - -// Now we will check that we cannot have two "pocket menus" displayed at the same time. -click: "#help-button" -assert-css: ("#help-button .popover", {"display": "block"}) -click: "#settings-menu" -assert-css: ("#help-button .popover", {"display": "none"}) -assert-css: ("#settings-menu .popover", {"display": "block"}) - -// Now the other way. -click: "#help-button" -assert-css: ("#help-button .popover", {"display": "block"}) -assert-css: ("#settings-menu .popover", {"display": "none"}) - -// Now verify that clicking the help menu again closes it. -click: "#help-button" -assert-css: ("#help-button .popover", {"display": "none"}) -assert-css: ("#settings-menu .popover", {"display": "none"}) - -// We check the borders color now: - -// Ayu theme -local-storage: { - "rustdoc-theme": "ayu", - "rustdoc-use-system-theme": "false", -} -reload: - -click: "#help-button" -assert-css: ( - "#help-button .popover", - {"display": "block", "border-color": "rgb(92, 103, 115)"}, -) -compare-elements-css: ("#help-button .popover", "#help-button .top", ["border-color"]) -compare-elements-css: ("#help-button .popover", "#help-button .bottom", ["border-color"]) - -// Dark theme -local-storage: { - "rustdoc-theme": "dark", - "rustdoc-use-system-theme": "false", -} -reload: - -click: "#help-button" -assert-css: ( - "#help-button .popover", - {"display": "block", "border-color": "rgb(224, 224, 224)"}, -) -compare-elements-css: ("#help-button .popover", "#help-button .top", ["border-color"]) -compare-elements-css: ("#help-button .popover", "#help-button .bottom", ["border-color"]) - -// Light theme -local-storage: { - "rustdoc-theme": "light", - "rustdoc-use-system-theme": "false", -} -reload: - -click: "#help-button" -assert-css: ( - "#help-button .popover", - {"display": "block", "border-color": "rgb(224, 224, 224)"}, -) -compare-elements-css: ("#help-button .popover", "#help-button .top", ["border-color"]) -compare-elements-css: ("#help-button .popover", "#help-button .bottom", ["border-color"]) - -// Opening the mobile sidebar should close the settings popover. -size: (650, 600) -click: "#settings-menu a" -assert-css: ("#settings-menu .popover", {"display": "block"}) -click: ".sidebar-menu-toggle" -assert: "//*[@class='sidebar shown']" -assert-css: ("#settings-menu .popover", {"display": "none"}) -// Opening the settings popover should close the sidebar. -click: "#settings-menu a" -assert-css: ("#settings-menu .popover", {"display": "block"}) -assert-false: "//*[@class='sidebar shown']" - -// Opening the settings popover at start (which async loads stuff) should also close. -reload: -click: ".sidebar-menu-toggle" -assert: "//*[@class='sidebar shown']" -assert-false: "#settings-menu .popover" -click: "#settings-menu a" -assert-false: "//*[@class='sidebar shown']" -wait-for: "#settings-menu .popover" diff --git a/src/test/rustdoc-gui/run-on-hover.goml b/src/test/rustdoc-gui/run-on-hover.goml deleted file mode 100644 index 57d63049f..000000000 --- a/src/test/rustdoc-gui/run-on-hover.goml +++ /dev/null @@ -1,54 +0,0 @@ -// Example code blocks sometimes have a "Run" button to run them on the -// Playground. That button is hidden until the user hovers over the code block. -// This test checks that it is hidden, and that it shows on hover. It also -// checks for its color. -goto: "file://" + |DOC_PATH| + "/test_docs/fn.foo.html" -show-text: true - -define-function: ( - "check-run-button", - (theme, color, background, hover_color, hover_background), - [ - ("local-storage", {"rustdoc-theme": |theme|, "rustdoc-use-system-theme": "false"}), - ("reload"), - ("assert-css", (".test-arrow", {"visibility": "hidden"})), - ("move-cursor-to", ".example-wrap"), - ("assert-css", (".test-arrow", { - "visibility": "visible", - "color": |color|, - "background-color": |background|, - "font-size": "22px", - "border-radius": "5px", - })), - ("move-cursor-to", ".test-arrow"), - ("assert-css", (".test-arrow:hover", { - "visibility": "visible", - "color": |hover_color|, - "background-color": |hover_background|, - "font-size": "22px", - "border-radius": "5px", - })), - ], -) - -call-function: ("check-run-button", { - "theme": "ayu", - "color": "rgb(120, 135, 151)", - "background": "rgba(57, 175, 215, 0.09)", - "hover_color": "rgb(197, 197, 197)", - "hover_background": "rgba(57, 175, 215, 0.37)", -}) -call-function: ("check-run-button", { - "theme": "dark", - "color": "rgb(222, 222, 222)", - "background": "rgba(78, 139, 202, 0.2)", - "hover_color": "rgb(222, 222, 222)", - "hover_background": "rgb(78, 139, 202)", -}) -call-function: ("check-run-button", { - "theme": "light", - "color": "rgb(245, 245, 245)", - "background": "rgba(78, 139, 202, 0.2)", - "hover_color": "rgb(245, 245, 245)", - "hover_background": "rgb(78, 139, 202)", -}) diff --git a/src/test/rustdoc-gui/rust-logo.goml b/src/test/rustdoc-gui/rust-logo.goml deleted file mode 100644 index 816cc9abd..000000000 --- a/src/test/rustdoc-gui/rust-logo.goml +++ /dev/null @@ -1,43 +0,0 @@ -// This test ensures that the correct style is applied to the rust logo in the sidebar. -goto: "file://" + |DOC_PATH| + "/test_docs/index.html" - -define-function: ( - "check-logo", - (theme, filter), - [ - // Going to the doc page. - ("goto", "file://" + |DOC_PATH| + "/test_docs/index.html"), - // Changing theme. - ("local-storage", {"rustdoc-theme": |theme|, "rustdoc-use-system-theme": "false"}), - ("reload"), - ("assert-css", (".rust-logo", {"filter": |filter|})), - // Going to the source code page. - ("goto", "file://" + |DOC_PATH| + "/src/test_docs/lib.rs.html"), - // Changing theme (since it's local files, the local storage works by folder). - ("local-storage", {"rustdoc-theme": |theme|, "rustdoc-use-system-theme": "false"}), - ("reload"), - ("assert-css", (".rust-logo", {"filter": |filter|})), - // Now we check that the non-rust logos don't have a CSS filter set. - ("goto", "file://" + |DOC_PATH| + "/huge_logo/index.html"), - // Changing theme on the new page (again...). - ("local-storage", {"rustdoc-theme": |theme|, "rustdoc-use-system-theme": "false"}), - ("reload"), - // Check there is no rust logo - ("assert-false", ".rust-logo"), - // Check there is no filter. - ("assert-css", (".sidebar .logo-container img", {"filter": "none"})), - ], -) - -call-function: ( - "check-logo", - ("ayu", "drop-shadow(rgb(255, 255, 255) 1px 0px 0px) drop-shadow(rgb(255, 255, 255) 0px 1px 0px) drop-shadow(rgb(255, 255, 255) -1px 0px 0px) drop-shadow(rgb(255, 255, 255) 0px -1px 0px)"), -) -call-function: ( - "check-logo", - ("dark", "drop-shadow(rgb(255, 255, 255) 1px 0px 0px) drop-shadow(rgb(255, 255, 255) 0px 1px 0px) drop-shadow(rgb(255, 255, 255) -1px 0px 0px) drop-shadow(rgb(255, 255, 255) 0px -1px 0px)"), -) -call-function: ( - "check-logo", - ("light", "none"), -) diff --git a/src/test/rustdoc-gui/scrape-examples-button-focus.goml b/src/test/rustdoc-gui/scrape-examples-button-focus.goml deleted file mode 100644 index bba518db0..000000000 --- a/src/test/rustdoc-gui/scrape-examples-button-focus.goml +++ /dev/null @@ -1,29 +0,0 @@ -goto: "file://" + |DOC_PATH| + "/scrape_examples/fn.test.html" - -// The next/prev buttons vertically scroll the code viewport between examples -store-property: (initialScrollTop, ".scraped-example-list > .scraped-example pre", "scrollTop") -focus: ".scraped-example-list > .scraped-example .next" -press-key: "Enter" -assert-property-false: (".scraped-example-list > .scraped-example pre", { - "scrollTop": |initialScrollTop| -}) -focus: ".scraped-example-list > .scraped-example .prev" -press-key: "Enter" -assert-property: (".scraped-example-list > .scraped-example pre", { - "scrollTop": |initialScrollTop| -}) - -// The expand button increases the scrollHeight of the minimized code viewport -store-property: (smallOffsetHeight, ".scraped-example-list > .scraped-example pre", "offsetHeight") -assert-property-false: (".scraped-example-list > .scraped-example pre", { - "scrollHeight": |smallOffsetHeight| -}) -focus: ".scraped-example-list > .scraped-example .expand" -press-key: "Enter" -assert-property-false: (".scraped-example-list > .scraped-example pre", { - "offsetHeight": |smallOffsetHeight| -}) -store-property: (fullOffsetHeight, ".scraped-example-list > .scraped-example pre", "offsetHeight") -assert-property: (".scraped-example-list > .scraped-example pre", { - "scrollHeight": |fullOffsetHeight| -}) diff --git a/src/test/rustdoc-gui/scrape-examples-fonts.goml b/src/test/rustdoc-gui/scrape-examples-fonts.goml deleted file mode 100644 index b7d7f4ccb..000000000 --- a/src/test/rustdoc-gui/scrape-examples-fonts.goml +++ /dev/null @@ -1,8 +0,0 @@ -goto: "file://" + |DOC_PATH| + "/scrape_examples/fn.test_many.html" - -store-value: (font, '"Fira Sans", Arial, NanumBarunGothic, sans-serif') - -wait-for-css: (".scraped-example-title", {"font-family": |font|}) -wait-for-css: (".more-examples-toggle summary", {"font-family": |font|}) -wait-for-css: (".more-examples-toggle .hide-more", {"font-family": |font|}) -wait-for-css: (".example-links a", {"font-family": |font|}) diff --git a/src/test/rustdoc-gui/scrape-examples-toggle.goml b/src/test/rustdoc-gui/scrape-examples-toggle.goml deleted file mode 100644 index ee720afb7..000000000 --- a/src/test/rustdoc-gui/scrape-examples-toggle.goml +++ /dev/null @@ -1,14 +0,0 @@ -goto: "file://" + |DOC_PATH| + "/scrape_examples/fn.test_many.html" - -// Clicking "More examples..." will open additional examples -assert-attribute-false: (".more-examples-toggle", {"open": ""}) -click: ".more-examples-toggle" -assert-attribute: (".more-examples-toggle", {"open": ""}) - -// Toggling all docs will close additional examples -click: "#toggle-all-docs" -assert-attribute-false: (".more-examples-toggle", {"open": ""}) - -// After re-opening the docs, the additional examples should stay closed -click: "#toggle-all-docs" -assert-attribute-false: (".more-examples-toggle", {"open": ""}) diff --git a/src/test/rustdoc-gui/search-filter.goml b/src/test/rustdoc-gui/search-filter.goml deleted file mode 100644 index e0228694e..000000000 --- a/src/test/rustdoc-gui/search-filter.goml +++ /dev/null @@ -1,85 +0,0 @@ -// Checks that the crate search filtering is handled correctly and changes the results. -goto: "file://" + |DOC_PATH| + "/test_docs/index.html" -show-text: true -write: (".search-input", "test") -// To be SURE that the search will be run. -press-key: 'Enter' -// Waiting for the search results to appear... -wait-for: "#titles" -assert-text: ("#results .externcrate", "test_docs") - -wait-for: "#crate-search" -// We now want to change the crate filter. -click: "#crate-search" -// We select "lib2" option then press enter to change the filter. -press-key: "ArrowDown" -press-key: "ArrowDown" -press-key: "ArrowDown" -press-key: "Enter" -// Waiting for the search results to appear... -wait-for: "#titles" -assert-document-property: ({"URL": "&filter-crate="}, CONTAINS) -// We check that there is no more "test_docs" appearing. -assert-false: "#results .externcrate" -// We also check that "lib2" is the filter crate. -assert-property: ("#crate-search", {"value": "lib2"}) - -// Now we check that leaving the search results and putting them back keeps the -// crate filtering. -press-key: "Escape" -wait-for-css: ("#main-content", {"display": "block"}) -focus: ".search-input" -wait-for-css: ("#main-content", {"display": "none"}) -// We check that there is no more "test_docs" appearing. -assert-false: "#results .externcrate" -assert-property: ("#crate-search", {"value": "lib2"}) - -// Selecting back "All crates" -click: "#crate-search" -press-key: "ArrowUp" -press-key: "ArrowUp" -press-key: "ArrowUp" -press-key: "Enter" -// Waiting for the search results to appear... -wait-for: "#titles" -assert-property: ("#crate-search", {"value": "all crates"}) - -// Checking that the URL parameter is taken into account for crate filtering. -goto: "file://" + |DOC_PATH| + "/test_docs/index.html?search=test&filter-crate=lib2" -wait-for: "#crate-search" -assert-property: ("#crate-search", {"value": "lib2"}) -assert-false: "#results .externcrate" - -// Checking that the text for the "title" is correct (the "all crates" comes from the "<select>"). -assert-text: (".search-results-title", "Results in all crates", STARTS_WITH) - -// Checking the display of the crate filter. -// We start with the light theme. -local-storage: {"rustdoc-theme": "light", "rustdoc-use-system-theme": "false"} -reload: - -timeout: 2000 -wait-for: "#crate-search" -assert-css: ("#crate-search", { - "border": "1px solid rgb(224, 224, 224)", - "color": "rgb(0, 0, 0)", - "background-color": "rgb(255, 255, 255)", -}) - -// We now check the dark theme. -click: "#settings-menu" -wait-for: "#settings" -click: "#theme-dark" -wait-for-css: ("#crate-search", { - "border": "1px solid rgb(224, 224, 224)", - "color": "rgb(221, 221, 221)", - "background-color": "rgb(53, 53, 53)", -}) - -// And finally we check the ayu theme. -click: "#theme-ayu" -wait-for-css: ("#crate-search", { - "border": "1px solid rgb(92, 103, 115)", - "color": "rgb(255, 255, 255)", - "background-color": "rgb(15, 20, 25)", -}) diff --git a/src/test/rustdoc-gui/search-form-elements.goml b/src/test/rustdoc-gui/search-form-elements.goml deleted file mode 100644 index 542db348c..000000000 --- a/src/test/rustdoc-gui/search-form-elements.goml +++ /dev/null @@ -1,263 +0,0 @@ -// This test ensures that the elements in ".search-form" have the expected display. -goto: "file://" + |DOC_PATH| + "/test_docs/index.html" -show-text: true - -// Ayu theme -local-storage: { - "rustdoc-theme": "ayu", - "rustdoc-use-system-theme": "false", -} -reload: - -assert-css: ( - ".search-input", - { - "border-color": "rgb(92, 103, 115)", - "background-color": "rgb(20, 25, 32)", - "color": "rgb(255, 255, 255)", - }, -) -focus: ".search-input" -// Nothing should change. -assert-css: ( - ".search-input", - { - "border-color": "rgb(92, 103, 115)", - "background-color": "rgb(20, 25, 32)", - "color": "rgb(255, 255, 255)", - }, -) - -assert-css: ( - "#help-button", - {"border-color": "rgb(197, 197, 197)"}, -) -assert-css: ( - "#help-button > a", - { - "color": "rgb(255, 255, 255)", - "border-color": "rgb(92, 103, 115)", - "background-color": "rgb(20, 25, 32)", - }, -) -move-cursor-to: "#help-button" -assert-css: ( - "#help-button:hover", - {"border-color": "rgb(197, 197, 197)"}, -) -// Only "border-color" should change. -assert-css: ( - "#help-button:hover > a", - { - "color": "rgb(255, 255, 255)", - "border-color": "rgb(224, 224, 224)", - "background-color": "rgb(20, 25, 32)", - }, -) -// Link color inside -click: "#help-button" -assert-css: ( - "#help a", - { - "color": "rgb(57, 175, 215)", - }, -) - -assert-css: ( - "#settings-menu", - {"border-color": "rgb(197, 197, 197)"}, -) -assert-css: ( - "#settings-menu > a", - { - "border-color": "rgb(92, 103, 115)", - "background-color": "rgb(20, 25, 32)", - }, -) -move-cursor-to: "#settings-menu" -assert-css: ( - "#settings-menu:hover", - {"border-color": "rgb(197, 197, 197)"}, -) -// Only "border-color" should change. -assert-css: ( - "#settings-menu:hover > a", - { - "border-color": "rgb(224, 224, 224)", - "background-color": "rgb(20, 25, 32)", - }, -) - -// Dark theme -local-storage: { - "rustdoc-theme": "dark", - "rustdoc-use-system-theme": "false", -} -reload: - -assert-css: ( - ".search-input", - { - "border-color": "rgb(224, 224, 224)", - "background-color": "rgb(240, 240, 240)", - "color": "rgb(17, 17, 17)", - }, -) -focus: ".search-input" -// Only "border-color" should change. -assert-css: ( - ".search-input", - { - "border-color": "rgb(0, 141, 253)", - "background-color": "rgb(240, 240, 240)", - "color": "rgb(17, 17, 17)", - }, -) - -assert-css: ( - "#help-button", - {"border-color": "rgb(221, 221, 221)"}, -) -assert-css: ( - "#help-button > a", - { - "color": "rgb(0, 0, 0)", - "border-color": "rgb(224, 224, 224)", - "background-color": "rgb(240, 240, 240)", - }, -) -move-cursor-to: "#help-button" -assert-css: ( - "#help-button:hover", - {"border-color": "rgb(221, 221, 221)"}, -) -// Only "border-color" should change. -assert-css: ( - "#help-button:hover > a", - { - "color": "rgb(0, 0, 0)", - "border-color": "rgb(255, 185, 0)", - "background-color": "rgb(240, 240, 240)", - }, -) -// Link color inside -click: "#help-button" -assert-css: ( - "#help a", - { - "color": "rgb(210, 153, 29)", - }, -) - -assert-css: ( - "#settings-menu", - {"border-color": "rgb(221, 221, 221)"}, -) -assert-css: ( - "#settings-menu > a", - { - "border-color": "rgb(224, 224, 224)", - "background-color": "rgb(240, 240, 240)", - }, -) -move-cursor-to: "#settings-menu" -assert-css: ( - "#settings-menu:hover", - {"border-color": "rgb(221, 221, 221)"}, -) -// Only "border-color" should change. -assert-css: ( - "#settings-menu:hover > a", - { - "color": "rgb(0, 0, 0)", - "border-color": "rgb(255, 185, 0)", - "background-color": "rgb(240, 240, 240)", - }, -) - -// Light theme -local-storage: { - "rustdoc-theme": "light", - "rustdoc-use-system-theme": "false", -} -reload: - -assert-css: ( - ".search-input", - { - "border-color": "rgb(224, 224, 224)", - "background-color": "rgb(255, 255, 255)", - "color": "rgb(0, 0, 0)", - }, -) -focus: ".search-input" -// Nothing should change. -assert-css: ( - ".search-input", - { - "border-color": "rgb(102, 175, 233)", - "background-color": "rgb(255, 255, 255)", - "color": "rgb(0, 0, 0)", - }, -) - -assert-css: ( - "#help-button", - {"border-color": "rgb(0, 0, 0)"}, -) -assert-css: ( - "#help-button > a", - { - "color": "rgb(0, 0, 0)", - "border-color": "rgb(224, 224, 224)", - "background-color": "rgb(255, 255, 255)", - }, -) -move-cursor-to: "#help-button" -assert-css: ( - "#help-button:hover", - {"border-color": "rgb(0, 0, 0)"}, -) -// Only "border-color" should change. -assert-css: ( - "#help-button:hover > a", - { - "color": "rgb(0, 0, 0)", - "border-color": "rgb(113, 113, 113)", - "background-color": "rgb(255, 255, 255)", - }, -) -// Link color inside -click: "#help-button" -assert-css: ( - "#help a", - { - "color": "rgb(56, 115, 173)", - }, -) - -assert-css: ( - "#settings-menu", - {"border-color": "rgb(0, 0, 0)"}, -) -assert-css: ( - "#settings-menu > a", - { - "border-color": "rgb(224, 224, 224)", - "background-color": "rgb(255, 255, 255)", - }, -) -move-cursor-to: "#settings-menu" -assert-css: ( - "#settings-menu:hover", - {"border-color": "rgb(0, 0, 0)"}, -) -// Only "border-color" should change. -assert-css: ( - "#settings-menu:hover > a", - { - "color": "rgb(0, 0, 0)", - "border-color": "rgb(113, 113, 113)", - "background-color": "rgb(255, 255, 255)", - }, -) diff --git a/src/test/rustdoc-gui/search-input-mobile.goml b/src/test/rustdoc-gui/search-input-mobile.goml deleted file mode 100644 index ce0cef77c..000000000 --- a/src/test/rustdoc-gui/search-input-mobile.goml +++ /dev/null @@ -1,11 +0,0 @@ -// Test to ensure that you can click on the search input, whatever the width. -// The PR which fixed it is: https://github.com/rust-lang/rust/pull/81592 -goto: "file://" + |DOC_PATH| + "/test_docs/index.html" -size: (463, 700) -// We first check that the search input isn't already focused. -assert-false: ("input.search-input:focus") -click: "input.search-input" -reload: -size: (750, 700) -click: "input.search-input" -assert: ("input.search-input:focus") diff --git a/src/test/rustdoc-gui/search-keyboard.goml b/src/test/rustdoc-gui/search-keyboard.goml deleted file mode 100644 index be642fc49..000000000 --- a/src/test/rustdoc-gui/search-keyboard.goml +++ /dev/null @@ -1,28 +0,0 @@ -// Checks that the search tab results work correctly with function signature syntax -// First, try a search-by-name -goto: "file://" + |DOC_PATH| + "/test_docs/index.html" -write: (".search-input", "Foo") -// To be SURE that the search will be run. -press-key: 'Enter' -// Waiting for the search results to appear... -wait-for: "#titles" - -// Now use the keyboard commands to switch to the third result. -press-key: "ArrowDown" -press-key: "ArrowDown" -press-key: "ArrowDown" -assert: ".search-results.active > a:focus:nth-of-type(3)" - -// Now switch to the second tab, then back to the first one, then arrow back up. -press-key: "ArrowRight" -assert: ".search-results.active:nth-of-type(2) > a:focus:nth-of-type(1)" -press-key: "ArrowLeft" -assert: ".search-results.active:nth-of-type(1) > a:focus:nth-of-type(3)" -press-key: "ArrowUp" -assert: ".search-results.active > a:focus:nth-of-type(2)" -press-key: "ArrowUp" -assert: ".search-results.active > a:focus:nth-of-type(1)" -press-key: "ArrowUp" -assert: ".search-input:focus" -press-key: "ArrowDown" -assert: ".search-results.active > a:focus:nth-of-type(1)" diff --git a/src/test/rustdoc-gui/search-no-result.goml b/src/test/rustdoc-gui/search-no-result.goml deleted file mode 100644 index b88be32c9..000000000 --- a/src/test/rustdoc-gui/search-no-result.goml +++ /dev/null @@ -1,36 +0,0 @@ -// The goal of this test is to check the color of the "no result" links. -goto: "file://" + |DOC_PATH| + "/lib2/index.html?search=sdkfskjfsdks" -show-text: true - -define-function: ( - "check-no-result", - (theme, link, link_hover), - [ - // Changing theme. - ("local-storage", {"rustdoc-theme": |theme|, "rustdoc-use-system-theme": "false"}), - ("reload"), - ("wait-for", "#results"), - ("assert", ".search-failed.active"), - ("assert-css", ("#results a", {"color": |link|}, ALL)), - ("move-cursor-to", "#results a"), - ("assert-css", ("#results a:hover", {"color": |link_hover|})), - // Moving the cursor to some other place to not create issues with next function run. - ("move-cursor-to", ".search-input"), - ] -) - -call-function: ("check-no-result", { - "theme": "ayu", - "link": "rgb(57, 175, 215)", - "link_hover": "rgb(57, 175, 215)", -}) -call-function: ("check-no-result", { - "theme": "dark", - "link": "rgb(210, 153, 29)", - "link_hover": "rgb(210, 153, 29)", -}) -call-function: ("check-no-result", { - "theme": "light", - "link": "rgb(56, 115, 173)", - "link_hover": "rgb(56, 115, 173)", -}) diff --git a/src/test/rustdoc-gui/search-reexport.goml b/src/test/rustdoc-gui/search-reexport.goml deleted file mode 100644 index dd19f03bd..000000000 --- a/src/test/rustdoc-gui/search-reexport.goml +++ /dev/null @@ -1,33 +0,0 @@ -// Checks that the reexports are present in the search index, can have -// doc aliases and are highligted when their ID is the hash of the page. -goto: "file://" + |DOC_PATH| + "/test_docs/index.html" -local-storage: {"rustdoc-theme": "dark", "rustdoc-use-system-theme": "false"} -reload: -// First we check that the reexport has the correct ID and no background color. -assert-text: ("//*[@id='reexport.TheStdReexport']", "pub use ::std as TheStdReexport;") -assert-css: ("//*[@id='reexport.TheStdReexport']", {"background-color": "rgba(0, 0, 0, 0)"}) -write: (".search-input", "TheStdReexport") -// To be SURE that the search will be run. -press-key: 'Enter' -wait-for: "//a[@class='result-import']" -assert-attribute: ( - "//a[@class='result-import']", - {"href": "../test_docs/index.html#reexport.TheStdReexport"}, -) -assert-text: ("//a[@class='result-import']", "test_docs::TheStdReexport") -click: "//a[@class='result-import']" -// We check that it has the background modified thanks to the focus. -wait-for-css: ("//*[@id='reexport.TheStdReexport']", {"background-color": "rgb(73, 74, 61)"}) - -// We now check that the alias is working as well on the reexport. -// To be SURE that the search will be run. -press-key: 'Enter' -write: (".search-input", "AliasForTheStdReexport") -wait-for: "//a[@class='result-import']" -assert-text: ( - "//a[@class='result-import']", - "AliasForTheStdReexport - see test_docs::TheStdReexport", -) -// Same thing again, we click on it to ensure the background is once again set as expected. -click: "//a[@class='result-import']" -wait-for-css: ("//*[@id='reexport.TheStdReexport']", {"background-color": "rgb(73, 74, 61)"}) diff --git a/src/test/rustdoc-gui/search-result-color.goml b/src/test/rustdoc-gui/search-result-color.goml deleted file mode 100644 index dde43b1c9..000000000 --- a/src/test/rustdoc-gui/search-result-color.goml +++ /dev/null @@ -1,407 +0,0 @@ -// The goal of this test is to ensure the color of the text is the one expected. - -define-function: ( - "check-result-color", - (result_kind, color, hover_color), - [ - ( - "assert-css", - (".result-" + |result_kind| + " ." + |result_kind|, {"color": |color|}, ALL), - ), - ( - "assert-css", - ( - ".result-" + |result_kind|, - {"color": |entry_color|, "background-color": |background_color|}, - ), - ), - ( - "move-cursor-to", - ".result-" + |result_kind|, - ), - ( - "assert-css", - ( - ".result-" + |result_kind| + ":hover", - {"color": |hover_entry_color|, "background-color": |hover_background_color|}, - ), - ), - ( - "assert-css", - (".result-" + |result_kind| + ":hover ." + |result_kind|, {"color": |hover_color|}), - ), - ( - "move-cursor-to", - ".search-input", - ), - ( - "focus", - ".result-" + |result_kind|, - ), - ( - "assert-css", - ( - ".result-" + |result_kind| + ":focus", - {"color": |hover_entry_color|, "background-color": |hover_background_color|}, - ), - ), - ( - "assert-css", - (".result-" + |result_kind| + ":focus ." + |result_kind|, {"color": |hover_color|}), - ), - ], -) - -goto: "file://" + |DOC_PATH| + "/test_docs/index.html?search=coo" - -// This is needed so that the text color is computed. -show-text: true - -// Ayu theme -local-storage: { - "rustdoc-theme": "ayu", - "rustdoc-use-system-theme": "false", -} -reload: - -// Waiting for the search results to appear... -wait-for: "#titles" -assert-css: ( - "//*[@class='desc'][text()='Just a normal struct.']", - {"color": "rgb(197, 197, 197)"}, -) -assert-css: ( - "//*[@class='result-name']/*[text()='test_docs::']", - {"color": "rgb(0, 150, 207)"}, -) - -// Checking the color of the bottom border. -assert-css: ( - ".search-results > a", - {"border-bottom-color": "rgba(170, 170, 170, 0.2)"} -) - -// Checking the color of "keyword" text. -assert-css: ( - "//*[@class='result-name']//*[text()='(keyword)']", - {"color": "rgb(120, 135, 151)"}, -) - -store-value: (entry_color, "rgb(0, 150, 207)") // color of the search entry -store-value: (hover_entry_color, "rgb(255, 255, 255)") // color of the hovered/focused search entry -store-value: (background_color, "rgba(0, 0, 0, 0)") // background color -store-value: (hover_background_color, "rgb(60, 60, 60)") // hover background color - -call-function: ( - "check-result-color", ( - "keyword", // item kind - "rgb(57, 175, 215)", // color of item kind - "rgb(57, 175, 215)", // color of hovered/focused item kind - ), -) -call-function: ( - "check-result-color", ( - "struct", // item kind - "rgb(255, 160, 165)", // color of item kind - "rgb(255, 160, 165)", // color of hovered/focused item kind - ), -) -call-function: ( - "check-result-color", ( - "associatedtype", // item kind - "rgb(57, 175, 215)", // color of item kind - "rgb(57, 175, 215)", // color of hovered/focused item kind - ), -) -call-function: ( - "check-result-color", ( - "tymethod", // item kind - "rgb(253, 214, 135)", // color of item kind - "rgb(253, 214, 135)", // color of hovered/focused item kind - ), -) -call-function: ( - "check-result-color", ( - "method", // item kind - "rgb(253, 214, 135)", // color of item kind - "rgb(253, 214, 135)", // color of hovered/focused item kind - ), -) -call-function: ( - "check-result-color", ( - "structfield", // item kind - "rgb(0, 150, 207)", // color of item kind - "rgb(255, 255, 255)", // color of hovered/focused item kind - ), -) -call-function: ( - "check-result-color", ( - "macro", // item kind - "rgb(163, 122, 204)", // color of item kind - "rgb(163, 122, 204)", // color of hovered/focused item kind - ), -) -call-function: ( - "check-result-color", ( - "fn", // item kind - "rgb(253, 214, 135)", // color of item kind - "rgb(253, 214, 135)", // color of hovered/focused item kind - ), -) - -// Checking the `<a>` container. -move-cursor-to: ".search-input" -focus: ".search-input" // To ensure the `<a>` container isnt focus or hover. -assert-css: ( - "//*[@class='result-name']/*[text()='test_docs::']/ancestor::a", - {"color": "rgb(0, 150, 207)", "background-color": "rgba(0, 0, 0, 0)"}, - ALL, -) - -// Checking color and background on hover. -move-cursor-to: "//*[@class='desc'][text()='Just a normal struct.']" -assert-css: ( - "//*[@class='result-name']/*[text()='test_docs::']", - {"color": "rgb(255, 255, 255)"}, -) -assert-css: ( - "//*[@class='result-name']/*[text()='test_docs::']/ancestor::a", - {"color": "rgb(255, 255, 255)", "background-color": "rgb(60, 60, 60)"}, -) - -// Dark theme -local-storage: { - "rustdoc-theme": "dark", - "rustdoc-use-system-theme": "false", -} -reload: - -// Waiting for the search results to appear... -wait-for: "#titles" -assert-css: ( - "//*[@class='desc'][text()='Just a normal struct.']", - {"color": "rgb(221, 221, 221)"}, -) -assert-css: ( - "//*[@class='result-name']/*[text()='test_docs::']", - {"color": "rgb(221, 221, 221)"}, -) - -// Checking the color of the bottom border. -assert-css: ( - ".search-results > a", - {"border-bottom-color": "rgba(170, 170, 170, 0.2)"} -) - -// Checking the color for "keyword" text. -assert-css: ( - "//*[@class='result-name']//*[text()='(keyword)']", - {"color": "rgb(221, 221, 221)"}, -) - -store-value: (entry_color, "rgb(221, 221, 221)") // color of the search entry -store-value: (hover_entry_color, "rgb(221, 221, 221)") // color of the hovered/focused search entry -store-value: (background_color, "rgba(0, 0, 0, 0)") // background color -store-value: (hover_background_color, "rgb(97, 97, 97)") // hover background color - -call-function: ( - "check-result-color", ( - "keyword", // item kind - "rgb(210, 153, 29)", // color of item kind - "rgb(210, 153, 29)", // color of hovered/focused item kind - ), -) -call-function: ( - "check-result-color", ( - "struct", // item kind - "rgb(45, 191, 184)", // color of item kind - "rgb(45, 191, 184)", // color of hovered/focused item kind - ), -) -call-function: ( - "check-result-color", ( - "associatedtype", // item kind - "rgb(210, 153, 29)", // color of item kind - "rgb(210, 153, 29)", // color of hovered/focused item kind - ), -) -call-function: ( - "check-result-color", ( - "tymethod", // item kind - "rgb(43, 171, 99)", // color of item kind - "rgb(43, 171, 99)", // color of hovered/focused item kind - ), -) -call-function: ( - "check-result-color", ( - "method", // item kind - "rgb(43, 171, 99)", // color of item kind - "rgb(43, 171, 99)", // color of hovered/focused item kind - ), -) -call-function: ( - "check-result-color", ( - "structfield", // item kind - "rgb(221, 221, 221)", // color of item kind - "rgb(221, 221, 221)", // color of hovered/focused item kind - ), -) -call-function: ( - "check-result-color", ( - "macro", // item kind - "rgb(9, 189, 0)", // color of item kind - "rgb(9, 189, 0)", // color of hovered/focused item kind - ), -) -call-function: ( - "check-result-color", ( - "fn", // item kind - "rgb(43, 171, 99)", // color of item kind - "rgb(43, 171, 99)", // color of hovered/focused item kind - ), -) - -// Checking the `<a>` container. -move-cursor-to: ".search-input" -focus: ".search-input" // To ensure the `<a>` container isnt focus or hover. -assert-css: ( - "//*[@class='result-name']/*[text()='test_docs::']/ancestor::a", - {"color": "rgb(221, 221, 221)", "background-color": "rgba(0, 0, 0, 0)"}, -) - -// Light theme -local-storage: {"rustdoc-theme": "light", "rustdoc-use-system-theme": "false"} -reload: - -// Waiting for the search results to appear... -wait-for: "#titles" -assert-css: ( - "//*[@class='desc'][text()='Just a normal struct.']", - {"color": "rgb(0, 0, 0)"}, -) -assert-css: ( - "//*[@class='result-name']/*[text()='test_docs::']", - {"color": "rgb(0, 0, 0)"}, -) - -// Checking the color of the bottom border. -assert-css: ( - ".search-results > a", - {"border-bottom-color": "rgba(170, 170, 170, 0.2)"} -) - -// Checking the color for "keyword" text. -assert-css: ( - "//*[@class='result-name']//*[text()='(keyword)']", - {"color": "rgb(0, 0, 0)"}, -) - -store-value: (entry_color, "rgb(0, 0, 0)") // color of the search entry -store-value: (hover_entry_color, "rgb(0, 0, 0)") // color of the hovered/focused search entry -store-value: (background_color, "rgba(0, 0, 0, 0)") // background color -store-value: (hover_background_color, "rgb(204, 204, 204)") // hover background color - -call-function: ( - "check-result-color", ( - "keyword", // item kind - "rgb(56, 115, 173)", // color of item kind - "rgb(56, 115, 173)", // color of hovered/focused item kind - ), -) -call-function: ( - "check-result-color", ( - "struct", // item kind - "rgb(173, 55, 138)", // color of item kind - "rgb(173, 55, 138)", // color of hovered/focused item kind - ), -) -call-function: ( - "check-result-color", ( - "associatedtype", // item kind - "rgb(56, 115, 173)", // color of item kind - "rgb(56, 115, 173)", // color of hovered/focused item kind - ), -) -call-function: ( - "check-result-color", ( - "tymethod", // item kind - "rgb(173, 124, 55)", // color of item kind - "rgb(173, 124, 55)", // color of hovered/focused item kind - ), -) -call-function: ( - "check-result-color", ( - "method", // item kind - "rgb(173, 124, 55)", // color of item kind - "rgb(173, 124, 55)", // color of hovered/focused item kind - ), -) -call-function: ( - "check-result-color", ( - "structfield", // item kind - "rgb(0, 0, 0)", // color of item kind - "rgb(0, 0, 0)", // color of hovered/focused item kind - ), -) -call-function: ( - "check-result-color", ( - "macro", // item kind - "rgb(6, 128, 0)", // color of item kind - "rgb(6, 128, 0)", // color of hovered/focused item kind - ), -) -call-function: ( - "check-result-color", ( - "fn", // item kind - "rgb(173, 124, 55)", // color of item kind - "rgb(173, 124, 55)", // color of hovered/focused item kind - ), -) - -// Checking the `<a>` container. -move-cursor-to: ".search-input" -focus: ".search-input" // To ensure the `<a>` container isnt focus or hover. -assert-css: ( - "//*[@class='result-name']/*[text()='test_docs::']/ancestor::a", - {"color": "rgb(0, 0, 0)", "background-color": "rgba(0, 0, 0, 0)"}, -) - -// Check the alias. -goto: "file://" + |DOC_PATH| + "/test_docs/index.html" -// If the text isn't displayed, the browser doesn't compute color style correctly... -show-text: true - -define-function: ( - "check-alias", - (theme, alias, grey), - [ - ("local-storage", {"rustdoc-theme": |theme|, "rustdoc-use-system-theme": "false"}), - ("reload"), - ("write", (".search-input", "thisisanalias")), - // To be SURE that the search will be run. - ("press-key", 'Enter'), - // Waiting for the search results to appear... - ("wait-for", "#titles"), - // Checking that the colors for the alias element are the ones expected. - ("assert-css", (".result-name > .alias", {"color": |alias|})), - ("assert-css", (".result-name > .alias > .grey", {"color": |grey|})), - // Leave the search results to prevent reloading with an already filled search input. - ("press-key", "Escape"), - ], -) - -call-function: ("check-alias", { - "theme": "ayu", - "alias": "rgb(197, 197, 197)", - "grey": "rgb(153, 153, 153)", -}) -call-function: ("check-alias", { - "theme": "dark", - "alias": "rgb(255, 255, 255)", - "grey": "rgb(204, 204, 204)", -}) -call-function: ("check-alias", { - "theme": "light", - "alias": "rgb(0, 0, 0)", - "grey": "rgb(153, 153, 153)", -}) diff --git a/src/test/rustdoc-gui/search-result-description.goml b/src/test/rustdoc-gui/search-result-description.goml deleted file mode 100644 index 53a335b63..000000000 --- a/src/test/rustdoc-gui/search-result-description.goml +++ /dev/null @@ -1,5 +0,0 @@ -// This test is to ensure that the codeblocks are correctly rendered in the search results. -goto: "file://" + |DOC_PATH| + "/test_docs/index.html?search=some_more_function" -// Waiting for the search results to appear... -wait-for: "#titles" -assert-text: (".search-results .desc code", "format!") diff --git a/src/test/rustdoc-gui/search-result-display.goml b/src/test/rustdoc-gui/search-result-display.goml deleted file mode 100644 index 13a5e4c71..000000000 --- a/src/test/rustdoc-gui/search-result-display.goml +++ /dev/null @@ -1,78 +0,0 @@ -// Checks that the search results have the expected width. -goto: "file://" + |DOC_PATH| + "/test_docs/index.html" -size: (900, 1000) -write: (".search-input", "test") -// To be SURE that the search will be run. -press-key: 'Enter' -wait-for: "#crate-search" -// The width is returned by "getComputedStyle" which returns the exact number instead of the -// CSS rule which is "50%"... -assert-css: (".search-results div.desc", {"width": "310px"}) -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. -assert-css: (".search-results div.desc", {"width": "566px"}) - -// The result set is all on one line. -assert-css: (".search-results .result-name > span", {"display": "inline"}) - -// 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) - -// First we check the current width, height and position. -assert-css: ("#crate-search", {"width": "223px"}) -assert-css: (".search-results-title", {"height": "44px", "width": "640px"}) -assert-css: ("#search", {"width": "640px"}) - -// Then we update the text of one of the `<option>`. -text: ( - "#crate-search option", - "sdjfaksdjfaksjdbfkadsbfkjsadbfkdsbkfbsadkjfbkdsabfkadsfkjdsafa", -) - -// Then we compare again to confirm the height didn't change. -assert-css: ("#crate-search", {"width": "527px"}) -assert-css: (".search-results-title", {"height": "44px", "width": "640px"}) -// And we check that the `<select>` isn't bigger than its container (".search-results-title"). -assert-css: ("#search", {"width": "640px"}) - -// 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), - [ - ("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"), - ], -) - -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)", -}) diff --git a/src/test/rustdoc-gui/search-result-go-to-first.goml b/src/test/rustdoc-gui/search-result-go-to-first.goml deleted file mode 100644 index eeddf5ef6..000000000 --- a/src/test/rustdoc-gui/search-result-go-to-first.goml +++ /dev/null @@ -1,19 +0,0 @@ -// This test ensures that the "go_to_first" feature is working as expected. - -// First, we check that the first page doesn't have the string we're looking for to ensure -// that the feature is changing page as expected. -goto: "file://" + |DOC_PATH| + "/test_docs/index.html" -assert-text-false: (".fqn", "Struct test_docs::Foo") - -// We now check that we land on the search result page if "go_to_first" isn't set. -goto: "file://" + |DOC_PATH| + "/test_docs/index.html?search=struct%3AFoo" -// Waiting for the search results to appear... -wait-for: "#titles" -assert-text-false: (".fqn", "Struct test_docs::Foo") -// Ensure that the search results are displayed, not the "normal" content. -assert-css: ("#main-content", {"display": "none"}) - -// Now we can check that the feature is working as expected! -goto: "file://" + |DOC_PATH| + "/test_docs/index.html?search=struct%3AFoo&go_to_first=true" -// Waiting for the page to load... -wait-for-text: (".fqn", "Struct test_docs::Foo") diff --git a/src/test/rustdoc-gui/search-result-keyword.goml b/src/test/rustdoc-gui/search-result-keyword.goml deleted file mode 100644 index 66e63155a..000000000 --- a/src/test/rustdoc-gui/search-result-keyword.goml +++ /dev/null @@ -1,13 +0,0 @@ -// Checks that the "keyword" results have the expected text alongside them. -goto: "file://" + |DOC_PATH| + "/test_docs/index.html" -write: (".search-input", "CookieMonster") -// To be SURE that the search will be run. -press-key: 'Enter' -// Waiting for the search results to appear... -wait-for: "#titles" -// Note: The two next assert commands could be merged as one but readability would be -// less good. -// -// Checking that the CSS is displaying " (keyword)" in italic. -assert-text: (".result-name span.keyword > i", "(keyword)") -assert-text: (".result-name span.keyword", "CookieMonster (keyword)") diff --git a/src/test/rustdoc-gui/search-tab-change-title-fn-sig.goml b/src/test/rustdoc-gui/search-tab-change-title-fn-sig.goml deleted file mode 100644 index a19dc6a8b..000000000 --- a/src/test/rustdoc-gui/search-tab-change-title-fn-sig.goml +++ /dev/null @@ -1,74 +0,0 @@ -// Checks that the search tab results work correctly with function signature syntax -// First, try a search-by-name -goto: "file://" + |DOC_PATH| + "/test_docs/index.html" -write: (".search-input", "Foo") -// To be SURE that the search will be run. -press-key: 'Enter' -// Waiting for the search results to appear... -wait-for: "#titles" -assert-attribute: ("#titles > button:nth-of-type(1)", {"class": "selected"}) -assert-text: ("#titles > button:nth-of-type(1)", "In Names", STARTS_WITH) -assert: "input.search-input:focus" -// Use left-right keys -press-key: "ArrowDown" -assert: "#results > .search-results.active > a:nth-of-type(1):focus" -press-key: "ArrowRight" -wait-for-attribute: ("#titles > button:nth-of-type(2)", {"class": "selected"}) -press-key: "ArrowRight" -wait-for-attribute: ("#titles > button:nth-of-type(3)", {"class": "selected"}) -press-key: "ArrowRight" -wait-for-attribute: ("#titles > button:nth-of-type(1)", {"class": "selected"}) -press-key: "ArrowLeft" -wait-for-attribute: ("#titles > button:nth-of-type(3)", {"class": "selected"}) - -// Now try search-by-return -goto: "file://" + |DOC_PATH| + "/test_docs/index.html" -write: (".search-input", "-> String") -// To be SURE that the search will be run. -press-key: 'Enter' -// Waiting for the search results to appear... -wait-for: "#titles" -assert-attribute: ("#titles > button:nth-of-type(1)", {"class": "selected"}) -assert-text: ("#titles > button:nth-of-type(1)", "In Function Return Types", STARTS_WITH) -assert: "input.search-input:focus" -// Use left-right keys -press-key: "ArrowDown" -assert: "#results > .search-results.active > a:nth-of-type(1):focus" -press-key: "ArrowRight" -wait-for-attribute: ("#titles > button:nth-of-type(1)", {"class": "selected"}) -press-key: "ArrowRight" -wait-for-attribute: ("#titles > button:nth-of-type(1)", {"class": "selected"}) -press-key: "ArrowRight" -wait-for-attribute: ("#titles > button:nth-of-type(1)", {"class": "selected"}) -press-key: "ArrowLeft" -wait-for-attribute: ("#titles > button:nth-of-type(1)", {"class": "selected"}) - -// Try with a search-by-return with no results -goto: "file://" + |DOC_PATH| + "/test_docs/index.html" -write: (".search-input", "-> Something") -// To be SURE that the search will be run. -press-key: 'Enter' -// Waiting for the search results to appear... -wait-for: "#titles" -assert-attribute: ("#titles > button:nth-of-type(1)", {"class": "selected"}) -assert-text: ("#titles > button:nth-of-type(1)", "In Function Return Types", STARTS_WITH) - -// Try with a search-by-parameter -goto: "file://" + |DOC_PATH| + "/test_docs/index.html" -write: (".search-input", "usize pattern") -// To be SURE that the search will be run. -press-key: 'Enter' -// Waiting for the search results to appear... -wait-for: "#titles" -assert-attribute: ("#titles > button:nth-of-type(1)", {"class": "selected"}) -assert-text: ("#titles > button:nth-of-type(1)", "In Function Parameters", STARTS_WITH) - -// Try with a search-by-parameter-and-return -goto: "file://" + |DOC_PATH| + "/test_docs/index.html" -write: (".search-input", "pattern -> str") -// To be SURE that the search will be run. -press-key: 'Enter' -// Waiting for the search results to appear... -wait-for: "#titles" -assert-attribute: ("#titles > button:nth-of-type(1)", {"class": "selected"}) -assert-text: ("#titles > button:nth-of-type(1)", "In Function Signatures", STARTS_WITH) diff --git a/src/test/rustdoc-gui/settings.goml b/src/test/rustdoc-gui/settings.goml deleted file mode 100644 index fc3beaa53..000000000 --- a/src/test/rustdoc-gui/settings.goml +++ /dev/null @@ -1,200 +0,0 @@ -// This test ensures that the settings menu display is working as expected and that -// the settings page is also rendered as expected. -goto: "file://" + |DOC_PATH| + "/test_docs/index.html" -show-text: true // needed when we check for colors below. -// First, we check that the settings page doesn't exist. -assert-false: "#settings" -// We now click on the settings button. -click: "#settings-menu" -wait-for: "#settings" -assert-css: ("#settings", {"display": "block"}) -// Let's close it by clicking on the same button. -click: "#settings-menu" -wait-for-css: ("#settings", {"display": "none"}) - -// Let's check that pressing "ESCAPE" is closing it. -click: "#settings-menu" -wait-for-css: ("#settings", {"display": "block"}) -press-key: "Escape" -wait-for-css: ("#settings", {"display": "none"}) - -// Let's click on it when the search results are displayed. -focus: ".search-input" -write: "test" -// To be SURE that the search will be run. -press-key: 'Enter' -wait-for: "#alternative-display #search" -click: "#settings-menu" -wait-for-css: ("#settings", {"display": "block"}) -// Ensure that the search is still displayed. -wait-for: "#alternative-display #search" -assert: "#main-content.hidden" - -// Now let's check the content of the settings menu. -local-storage: {"rustdoc-theme": "dark", "rustdoc-use-system-theme": "false"} -reload: -click: "#settings-menu" -wait-for: "#settings" - -// We check that the "Use system theme" is disabled. -assert-property: ("#theme-system-preference", {"checked": "false"}) -// Meaning that only the "theme" menu is showing up. -assert: ".setting-line:not(.hidden) #theme" -assert: ".setting-line.hidden #preferred-dark-theme" -assert: ".setting-line.hidden #preferred-light-theme" - -// We check that the correct theme is selected. -assert-property: ("#theme .choices #theme-dark", {"checked": "true"}) - -// Some style checks... -move-cursor-to: "#settings-menu > a" -// First we check the "default" display for radio buttons. -assert-css: ( - "#theme-dark", - { - "border-color": "rgb(221, 221, 221)", - "box-shadow": "rgb(53, 53, 53) 0px 0px 0px 3px inset", - }, -) -assert-css: ("#theme-light", {"border-color": "rgb(221, 221, 221)", "box-shadow": "none"}) -// Let's start with the hover for radio buttons. -move-cursor-to: "#theme-dark" -assert-css: ( - "#theme-dark", - { - "border-color": "rgb(33, 150, 243)", - "box-shadow": "rgb(53, 53, 53) 0px 0px 0px 3px inset", - }, -) -move-cursor-to: "#theme-light" -assert-css: ("#theme-light", {"border-color": "rgb(33, 150, 243)", "box-shadow": "none"}) -move-cursor-to: "#theme-ayu" -// Let's now check with the focus for radio buttons. -focus: "#theme-dark" -assert-css: ( - "#theme-dark", - { - "border-color": "rgb(221, 221, 221)", - "box-shadow": "rgb(53, 53, 53) 0px 0px 0px 3px inset, rgb(33, 150, 243) 0px 0px 2px 2px", - }, -) -focus: "#theme-light" -assert-css: ( - "#theme-light", - { - "border-color": "rgb(221, 221, 221)", - "box-shadow": "rgb(33, 150, 243) 0px 0px 1px 1px", - }, -) -// Now we check we both focus and hover for radio buttons. -move-cursor-to: "#theme-dark" -focus: "#theme-dark" -assert-css: ( - "#theme-dark", - { - "border-color": "rgb(33, 150, 243)", - "box-shadow": "rgb(53, 53, 53) 0px 0px 0px 3px inset, rgb(33, 150, 243) 0px 0px 2px 2px", - }, -) -move-cursor-to: "#theme-light" -focus: "#theme-light" -assert-css: ( - "#theme-light", - { - "border-color": "rgb(33, 150, 243)", - "box-shadow": "rgb(33, 150, 243) 0px 0px 1px 1px", - }, -) - -// First we check the "default" display for toggles. -assert-css: ( - "#auto-hide-large-items", - { - "background-color": "rgb(33, 150, 243)", - "border-color": "rgb(221, 221, 221)", - }, -) -// Let's start with the hover for toggles. -move-cursor-to: "#auto-hide-large-items" -assert-css: ( - "#auto-hide-large-items", - { - "background-color": "rgb(33, 150, 243)", - "border-color": "rgb(33, 150, 243)", - }, -) -move-cursor-to: "#settings-menu > a" -// Let's now check with the focus for toggles. -focus: "#auto-hide-large-items" -assert-css: ( - "#auto-hide-large-items", - { - "background-color": "rgb(33, 150, 243)", - "border-color": "rgb(221, 221, 221)", - "box-shadow": "rgb(33, 150, 243) 0px 0px 1px 1px", - }, -) -// Now we check we both focus and hover for toggles. -move-cursor-to: "#auto-hide-large-items" -focus: "#auto-hide-large-items" -assert-css: ( - "#auto-hide-large-items", - { - "background-color": "rgb(33, 150, 243)", - "border-color": "rgb(33, 150, 243)", - "box-shadow": "rgb(33, 150, 243) 0px 0px 1px 1px", - }, -) - -// We now switch the display. -click: "#theme-system-preference" -// Wait for the hidden element to show up. -wait-for: ".setting-line:not(.hidden) #preferred-dark-theme" -assert: ".setting-line:not(.hidden) #preferred-light-theme" - -// We check their text as well. -assert-text: ("#preferred-dark-theme .setting-name", "Preferred dark theme") -assert-text: ("#preferred-light-theme .setting-name", "Preferred light theme") - -// We now check that clicking on the toggles' text is like clicking on the checkbox. -// To test it, we use the "Disable keyboard shortcuts". -local-storage: {"rustdoc-disable-shortcuts": "false"} -click: ".setting-line:last-child .toggle .label" -assert-local-storage: {"rustdoc-disable-shortcuts": "true"} - -// Make sure that "Disable keyboard shortcuts" actually took effect. -press-key: "Escape" -press-key: "?" -assert-false: "#help-button .popover" -wait-for-css: ("#settings-menu .popover", {"display": "block"}) - -// Now turn keyboard shortcuts back on, and see if they work. -click: ".setting-line:last-child .toggle .label" -assert-local-storage: {"rustdoc-disable-shortcuts": "false"} -press-key: "Escape" -press-key: "?" -wait-for-css: ("#help-button .popover", {"display": "block"}) -assert-css: ("#settings-menu .popover", {"display": "none"}) - -// Now we go to the settings page to check that the CSS is loaded as expected. -goto: "file://" + |DOC_PATH| + "/settings.html" -wait-for: "#settings" -assert-css: (".setting-line", {"position": "relative"}) - -assert-attribute-false: ("#settings", {"class": "popover"}, CONTAINS) -compare-elements-position: (".sub form", "#settings", ("x")) - -// We now check the display with JS disabled. -assert-false: "noscript section" -javascript: false -reload: -assert-css: ("noscript section", {"display": "block"}) -javascript: true - -// Check for the display on small screen -show-text: true -reload: -size: (300, 1000) -click: "#settings-menu" -wait-for: "#settings" -assert-css: (".setting-line", {"position": "relative"}) diff --git a/src/test/rustdoc-gui/shortcuts.goml b/src/test/rustdoc-gui/shortcuts.goml deleted file mode 100644 index 9068680d6..000000000 --- a/src/test/rustdoc-gui/shortcuts.goml +++ /dev/null @@ -1,31 +0,0 @@ -// Check that the various shortcuts are working. -goto: "file://" + |DOC_PATH| + "/test_docs/index.html" -// We first check that the search input isn't already focused. -assert-false: "input.search-input:focus" -press-key: "s" -assert: "input.search-input:focus" -press-key: "Escape" -assert-false: "input.search-input:focus" -// We now check for the help popup. -press-key: "?" -assert-css: ("#help-button .popover", {"display": "block"}) -press-key: "Escape" -assert-css: ("#help-button .popover", {"display": "none"}) -// Checking doc collapse and expand. -// It should be displaying a "-": -assert-text: ("#toggle-all-docs", "[\u2212]") -press-key: "-" -wait-for-text: ("#toggle-all-docs", "[+]") -assert-attribute: ("#toggle-all-docs", {"class": "will-expand"}) -// Pressing it again shouldn't do anything. -press-key: "-" -assert-text: ("#toggle-all-docs", "[+]") -assert-attribute: ("#toggle-all-docs", {"class": "will-expand"}) -// Expanding now. -press-key: "+" -wait-for-text: ("#toggle-all-docs", "[\u2212]") -assert-attribute: ("#toggle-all-docs", {"class": ""}) -// Pressing it again shouldn't do anything. -press-key: "+" -assert-text: ("#toggle-all-docs", "[\u2212]") -assert-attribute: ("#toggle-all-docs", {"class": ""}) diff --git a/src/test/rustdoc-gui/sidebar-links-color.goml b/src/test/rustdoc-gui/sidebar-links-color.goml deleted file mode 100644 index 7ef7ec90c..000000000 --- a/src/test/rustdoc-gui/sidebar-links-color.goml +++ /dev/null @@ -1,171 +0,0 @@ -// This test checks links colors in sidebar before and after hover. -goto: "file://" + |DOC_PATH| + "/test_docs/struct.Foo.html" - -// This is needed so that the text color is computed. -show-text: true - -define-function: ( - "check-colors", - ( - theme, struct, struct_hover, struct_hover_background, enum, enum_hover, - enum_hover_background, union, union_hover, union_hover_background, trait, trait_hover, - trait_hover_background, fn, fn_hover, fn_hover_background, type, type_hover, - type_hover_background, keyword, keyword_hover, keyword_hover_background, - ), - [ - ("local-storage", { "rustdoc-theme": |theme|, "rustdoc-use-system-theme": "false" }), - ("reload"), - // Struct - ("assert-css", ( - ".sidebar .block.struct a:not(.current)", - {"color": |struct|, "background-color": "rgba(0, 0, 0, 0)"}, - )), - ("move-cursor-to", ".sidebar .block.struct a:not(.current)"), - ("assert-css", ( - ".sidebar .block.struct a:hover", - {"color": |struct_hover|, "background-color": |struct_hover_background|}, - )), - // Enum - ("assert-css", ( - ".sidebar .block.enum a", - {"color": |enum|, "background-color": "rgba(0, 0, 0, 0)"}, - )), - ("move-cursor-to", ".sidebar .block.enum a"), - ("assert-css", ( - ".sidebar .block.enum a:hover", - {"color": |enum_hover|, "background-color": |enum_hover_background|}, - )), - // Union - ("assert-css", ( - ".sidebar .block.union a", - {"color": |union|, "background-color": "rgba(0, 0, 0, 0)"}, - )), - ("move-cursor-to", ".sidebar .block.union a"), - ("assert-css", ( - ".sidebar .block.union a:hover", - {"color": |union_hover|, "background-color": |union_hover_background|}, - )), - // Trait - ("assert-css", ( - ".sidebar .block.trait a", - {"color": |trait|, "background-color": "rgba(0, 0, 0, 0)"}, - )), - ("move-cursor-to", ".sidebar .block.trait a"), - ("assert-css", ( - ".sidebar .block.trait a:hover", - {"color": |trait_hover|, "background-color": |trait_hover_background|}, - )), - // Function - ("assert-css", ( - ".sidebar .block.fn a", - {"color": |fn|, "background-color": "rgba(0, 0, 0, 0)"}, - )), - ("move-cursor-to", ".sidebar .block.fn a"), - ("assert-css", ( - ".sidebar .block.fn a:hover", - {"color": |fn_hover|, "background-color": |fn_hover_background|}, - )), - // Type definition - ("assert-css", ( - ".sidebar .block.type a", - {"color": |type|, "background-color": "rgba(0, 0, 0, 0)"}, - )), - ("move-cursor-to", ".sidebar .block.type a"), - ("assert-css", ( - ".sidebar .block.type a:hover", - {"color": |type_hover|, "background-color": |type_hover_background|}, - )), - // Keyword - ("assert-css", ( - ".sidebar .block.keyword a", - {"color": |keyword|, "background-color": "rgba(0, 0, 0, 0)"}, - )), - ("move-cursor-to", ".sidebar .block.keyword a"), - ("assert-css", ( - ".sidebar .block.keyword a:hover", - {"color": |keyword_hover|, "background-color": |keyword_hover_background|}, - )), - ] -) - -call-function: ( - "check-colors", - { - "theme": "ayu", - "struct": "rgb(83, 177, 219)", - "struct_hover": "rgb(255, 180, 76)", - "struct_hover_background": "rgba(0, 0, 0, 0)", - "enum": "rgb(83, 177, 219)", - "enum_hover": "rgb(255, 180, 76)", - "enum_hover_background": "rgba(0, 0, 0, 0)", - "union": "rgb(83, 177, 219)", - "union_hover": "rgb(255, 180, 76)", - "union_hover_background": "rgba(0, 0, 0, 0)", - "trait": "rgb(83, 177, 219)", - "trait_hover": "rgb(255, 180, 76)", - "trait_hover_background": "rgba(0, 0, 0, 0)", - "fn": "rgb(83, 177, 219)", - "fn_hover": "rgb(255, 180, 76)", - "fn_hover_background": "rgba(0, 0, 0, 0)", - "type": "rgb(83, 177, 219)", - "type_hover": "rgb(255, 180, 76)", - "type_hover_background": "rgba(0, 0, 0, 0)", - "keyword": "rgb(83, 177, 219)", - "keyword_hover": "rgb(255, 180, 76)", - "keyword_hover_background": "rgba(0, 0, 0, 0)", - } -) -call-function: ( - "check-colors", - { - "theme": "dark", - "struct": "rgb(253, 191, 53)", - "struct_hover": "rgb(253, 191, 53)", - "struct_hover_background": "rgb(68, 68, 68)", - "enum": "rgb(253, 191, 53)", - "enum_hover": "rgb(253, 191, 53)", - "enum_hover_background": "rgb(68, 68, 68)", - "union": "rgb(253, 191, 53)", - "union_hover": "rgb(253, 191, 53)", - "union_hover_background": "rgb(68, 68, 68)", - "trait": "rgb(253, 191, 53)", - "trait_hover": "rgb(253, 191, 53)", - "trait_hover_background": "rgb(68, 68, 68)", - "fn": "rgb(253, 191, 53)", - "fn_hover": "rgb(253, 191, 53)", - "fn_hover_background": "rgb(68, 68, 68)", - "type": "rgb(253, 191, 53)", - "type_hover": "rgb(253, 191, 53)", - "type_hover_background": "rgb(68, 68, 68)", - "keyword": "rgb(253, 191, 53)", - "keyword_hover": "rgb(253, 191, 53)", - "keyword_hover_background": "rgb(68, 68, 68)", - } -) -call-function: ( - "check-colors", - { - "theme": "light", - "struct": "rgb(53, 109, 164)", - "struct_hover": "rgb(53, 109, 164)", - "struct_hover_background": "rgb(255, 255, 255)", - "enum": "rgb(53, 109, 164)", - "enum_hover": "rgb(53, 109, 164)", - "enum_hover_background": "rgb(255, 255, 255)", - "union": "rgb(53, 109, 164)", - "union_hover": "rgb(53, 109, 164)", - "union_hover_background": "rgb(255, 255, 255)", - "trait": "rgb(53, 109, 164)", - "trait_hover": "rgb(53, 109, 164)", - "trait_hover_background": "rgb(255, 255, 255)", - "fn": "rgb(53, 109, 164)", - "fn_hover": "rgb(53, 109, 164)", - "fn_hover_background": "rgb(255, 255, 255)", - "type": "rgb(53, 109, 164)", - "type_hover": "rgb(53, 109, 164)", - "type_hover_background": "rgb(255, 255, 255)", - "keyword": "rgb(53, 109, 164)", - "keyword_hover": "rgb(53, 109, 164)", - "keyword_hover_background": "rgb(255, 255, 255)", - } -) diff --git a/src/test/rustdoc-gui/sidebar-macro-reexport.goml b/src/test/rustdoc-gui/sidebar-macro-reexport.goml deleted file mode 100644 index b5c1b6a43..000000000 --- a/src/test/rustdoc-gui/sidebar-macro-reexport.goml +++ /dev/null @@ -1,5 +0,0 @@ -// This test ensures that the reexport of a macro doesn't make the original macro -// displayed twice in the sidebar. -goto: "file://" + |DOC_PATH| + "/test_docs/macro.repro.html" -wait-for: ".sidebar-elems .block.macro a" -assert-count: ("//*[@class='sidebar-elems']//*[@class='block macro']//a[text()='repro']", 1) diff --git a/src/test/rustdoc-gui/sidebar-mobile-scroll.goml b/src/test/rustdoc-gui/sidebar-mobile-scroll.goml deleted file mode 100644 index 2449269b1..000000000 --- a/src/test/rustdoc-gui/sidebar-mobile-scroll.goml +++ /dev/null @@ -1,31 +0,0 @@ -// This test ensures that the mobile sidebar preserves scroll position. -goto: "file://" + |DOC_PATH| + "/test_docs/struct.Foo.html" -// Switching to "mobile view" by reducing the width to 600px. -size: (700, 600) -assert-css: (".sidebar", {"display": "block", "left": "-1000px"}) - -// Scroll down. -scroll-to: "//h2[@id='blanket-implementations']" -assert-window-property: {"pageYOffset": "627"} - -// Open the sidebar menu. -click: ".sidebar-menu-toggle" -wait-for-css: (".sidebar", {"left": "0px"}) - -// We are no longer "scrolled". It's important that the user can't -// scroll the body at all, but these test scripts are run only in Chrome, -// and we need to use a more complicated solution to this problem because -// of Mobile Safari... -assert-window-property: {"pageYOffset": "0"} - -// Close the sidebar menu. Make sure the scroll position gets restored. -click: ".sidebar-menu-toggle" -wait-for-css: (".sidebar", {"left": "-1000px"}) -assert-window-property: {"pageYOffset": "627"} - -// Now test that scrollability returns when the browser window is just resized. -click: ".sidebar-menu-toggle" -wait-for-css: (".sidebar", {"left": "0px"}) -assert-window-property: {"pageYOffset": "0"} -size: (900, 600) -assert-window-property: {"pageYOffset": "627"} diff --git a/src/test/rustdoc-gui/sidebar-mobile.goml b/src/test/rustdoc-gui/sidebar-mobile.goml deleted file mode 100644 index 38d01f7f6..000000000 --- a/src/test/rustdoc-gui/sidebar-mobile.goml +++ /dev/null @@ -1,88 +0,0 @@ -// This test ensure that the sidebar isn't "hidden" on mobile but instead moved out of the viewport. -// This is especially important for devices for "text-first" content (like for users with -// sight issues). -goto: "file://" + |DOC_PATH| + "/test_docs/struct.Foo.html" -// Switching to "mobile view" by reducing the width to 600px. -size: (600, 600) -assert-css: (".sidebar", {"display": "block", "left": "-1000px"}) -// Opening the sidebar menu. -click: ".sidebar-menu-toggle" -assert-css: (".sidebar", {"display": "block", "left": "0px"}) -// Closing the sidebar menu. -click: ".sidebar-menu-toggle" -assert-css: (".sidebar", {"display": "block", "left": "-1000px"}) -// Force the sidebar open by focusing a link inside it. -// This makes it easier for keyboard users to get to it. -focus: ".sidebar-elems h3 a" -assert-css: (".sidebar", {"display": "block", "left": "0px"}) -// When we tab out of the sidebar, close it. -focus: ".search-input" -assert-css: (".sidebar", {"display": "block", "left": "-1000px"}) - -// Open the sidebar menu. -click: ".sidebar-menu-toggle" -assert-css: (".sidebar", {"left": "0px"}) - -// Make sure the "struct Foo" header is hidden, since the mobile topbar already does it. -assert-css: ("//nav[contains(@class, 'sidebar')]//h2/a[text()='Foo']/parent::h2", {"display": "none"}) -// Make sure the global navigation is still here. -assert-css: ("//nav[contains(@class, 'sidebar')]//h2/a[text()='In test_docs']/parent::h2", {"display": "block"}) - -// Click elsewhere. -click: "body" -assert-css: (".sidebar", {"display": "block", "left": "-1000px"}) - -// Open the sidebar menu, and make sure pressing Escape closes it. -click: ".sidebar-menu-toggle" -assert-css: (".sidebar", {"left": "0px"}) -press-key: "Escape" -assert-css: (".sidebar", {"display": "block", "left": "-1000px"}) - -// Check that the topbar is visible -assert-property: (".mobile-topbar", {"clientHeight": "45"}) - -// Check that clicking an element from the sidebar scrolls to the right place -// so the target is not obscured by the topbar. -click: ".sidebar-menu-toggle" -click: ".sidebar-elems section .block li > a" -assert-position: ("#method\.must_use", {"y": 45}) - -// Check that the bottom-most item on the sidebar menu can be scrolled fully into view. -click: ".sidebar-menu-toggle" -scroll-to: ".block.keyword li:nth-child(1)" -compare-elements-position-near: (".block.keyword li:nth-child(1)", ".mobile-topbar", {"y": 543.19}) - -// Now checking the background color of the sidebar. -show-text: true - -define-function: ( - "check-colors", - (theme, color, background), - [ - ("local-storage", {"rustdoc-use-system-theme": "false", "rustdoc-theme": |theme|}), - ("reload"), - - // Open the sidebar menu. - ("click", ".sidebar-menu-toggle"), - ("assert-css", (".sidebar", { - "background-color": |background|, - "color": |color|, - })), - ], -) - -call-function: ("check-colors", { - "theme": "ayu", - "color": "rgb(197, 197, 197)", - "background": "rgb(20, 25, 31)", -}) -call-function: ("check-colors", { - "theme": "dark", - "color": "rgb(221, 221, 221)", - "background": "rgb(80, 80, 80)", -}) -call-function: ("check-colors", { - "theme": "light", - "color": "rgb(0, 0, 0)", - "background": "rgb(245, 245, 245)", -}) diff --git a/src/test/rustdoc-gui/sidebar-source-code-display.goml b/src/test/rustdoc-gui/sidebar-source-code-display.goml deleted file mode 100644 index 40ae4af81..000000000 --- a/src/test/rustdoc-gui/sidebar-source-code-display.goml +++ /dev/null @@ -1,215 +0,0 @@ -// This test ensures that the elements in the sidebar are displayed correctly. -javascript: false -goto: "file://" + |DOC_PATH| + "/src/test_docs/lib.rs.html" -// Since the javascript is disabled, there shouldn't be a toggle. -assert-false: "#sidebar-toggle" -wait-for-css: (".sidebar", {"display": "none"}) - -// Let's retry with javascript enabled. -javascript: true -reload: -wait-for: "#sidebar-toggle" -assert-css: ("#sidebar-toggle", {"visibility": "visible"}) -assert-css: (".sidebar > *:not(#sidebar-toggle)", {"visibility": "hidden"}) -// Let's expand the sidebar now. -click: "#sidebar-toggle" -wait-for-css: ("#sidebar-toggle", {"visibility": "visible"}) - -// We now check that opening the sidebar and clicking a link will leave it open. -// The behavior here on desktop is different than the behavior on mobile, -// but since the sidebar doesn't fill the entire screen here, it makes sense to have the -// sidebar stay resident. -wait-for-css: (".sidebar", {"width": "300px"}) -assert-local-storage: {"rustdoc-source-sidebar-show": "true"} -click: ".sidebar a.selected" -goto: "file://" + |DOC_PATH| + "/src/test_docs/lib.rs.html" -wait-for-css: (".sidebar", {"width": "300px"}) -assert-local-storage: {"rustdoc-source-sidebar-show": "true"} - -// Now we check the display of the sidebar items. -show-text: true - -define-function: ( - "check-colors", - ( - theme, color, color_hover, background, background_hover, background_toggle, - background_toggle_hover, - ), - [ - ("local-storage", {"rustdoc-theme": |theme|, "rustdoc-use-system-theme": "false"}), - ("reload"), - ("wait-for-css", ("#sidebar-toggle", {"visibility": "visible"})), - ("assert-css", ( - "#source-sidebar details[open] > .files a.selected", - {"color": |color_hover|, "background-color": |background|}, - )), - - // Without hover or focus. - ("assert-css", ("#sidebar-toggle > button", {"background-color": |background_toggle|})), - // With focus. - ("focus", "#sidebar-toggle > button"), - ("assert-css", ( - "#sidebar-toggle > button:focus", - {"background-color": |background_toggle_hover|}, - )), - ("focus", ".search-input"), - // With hover. - ("move-cursor-to", "#sidebar-toggle > button"), - ("assert-css", ( - "#sidebar-toggle > button:hover", - {"background-color": |background_toggle_hover|}, - )), - - // Without hover or focus. - ("assert-css", ( - "#source-sidebar details[open] > .files a:not(.selected)", - {"color": |color|, "background-color": |background_toggle|}, - )), - // With focus. - ("focus", "#source-sidebar details[open] > .files a:not(.selected)"), - ("wait-for-css", ( - "#source-sidebar details[open] > .files a:not(.selected):focus", - {"color": |color_hover|, "background-color": |background_hover|}, - )), - ("focus", ".search-input"), - // With hover. - ("move-cursor-to", "#source-sidebar details[open] > .files a:not(.selected)"), - ("assert-css", ( - "#source-sidebar details[open] > .files a:not(.selected):hover", - {"color": |color_hover|, "background-color": |background_hover|}, - )), - - // Without hover or focus. - ("assert-css", ( - "#source-sidebar .dir-entry summary", - {"color": |color|, "background-color": |background_toggle|}, - )), - // With focus. - ("focus", "#source-sidebar .dir-entry summary"), - ("wait-for-css", ( - "#source-sidebar .dir-entry summary:focus", - {"color": |color_hover|, "background-color": |background_hover|}, - )), - ("focus", ".search-input"), - // With hover. - ("move-cursor-to", "#source-sidebar .dir-entry summary"), - ("assert-css", ( - "#source-sidebar .dir-entry summary:hover", - {"color": |color_hover|, "background-color": |background_hover|}, - )), - - // Without hover or focus. - ("assert-css", ( - "#source-sidebar details[open] > .folders > details > summary", - {"color": |color|, "background-color": |background_toggle|}, - )), - // With focus. - ("focus", "#source-sidebar details[open] > .folders > details > summary"), - ("wait-for-css", ( - "#source-sidebar details[open] > .folders > details > summary:focus", - {"color": |color_hover|, "background-color": |background_hover|}, - )), - ("focus", ".search-input"), - // With hover. - ("move-cursor-to", "#source-sidebar details[open] > .folders > details > summary"), - ("assert-css", ( - "#source-sidebar details[open] > .folders > details > summary:hover", - {"color": |color_hover|, "background-color": |background_hover|}, - )), - ], -) - -call-function: ("check-colors", { - "theme": "light", - "color": "rgb(0, 0, 0)", - "color_hover": "rgb(0, 0, 0)", - "background": "rgb(255, 255, 255)", - "background_hover": "rgb(224, 224, 224)", - "background_toggle": "rgba(0, 0, 0, 0)", - "background_toggle_hover": "rgb(224, 224, 224)", -}) -call-function: ("check-colors", { - "theme": "dark", - "color": "rgb(221, 221, 221)", - "color_hover": "rgb(221, 221, 221)", - "background": "rgb(51, 51, 51)", - "background_hover": "rgb(68, 68, 68)", - "background_toggle": "rgba(0, 0, 0, 0)", - "background_toggle_hover": "rgb(103, 103, 103)", -}) -call-function: ("check-colors", { - "theme": "ayu", - "color": "rgb(197, 197, 197)", - "color_hover": "rgb(255, 180, 76)", - "background": "rgb(20, 25, 31)", - "background_hover": "rgb(20, 25, 31)", - "background_toggle": "rgba(0, 0, 0, 0)", - "background_toggle_hover": "rgba(70, 70, 70, 0.33)", -}) - -// Now checking on mobile devices. -size: (500, 700) -reload: -// Waiting for the sidebar to be displayed... -wait-for-css: ("#sidebar-toggle", {"visibility": "visible"}) - -// We now check it takes the full size of the display. -assert-property: ("body", {"clientWidth": "500", "clientHeight": "700"}) -assert-property: (".sidebar", {"clientWidth": "500", "clientHeight": "700"}) - -// We now check the display of the toggle once the sidebar is expanded. -assert-property: ("#sidebar-toggle", {"clientWidth": "500", "clientHeight": "39"}) -assert-css: ( - "#sidebar-toggle", - { - "border-top-width": "0px", - "border-right-width": "0px", - "border-left-width": "0px", - "border-bottom-width": "1px", - }, -) - -// We now check that the scroll position is kept when opening the sidebar. -click: "#sidebar-toggle" -wait-for-css: (".sidebar", {"width": "0px"}) -// We scroll to line 117 to change the scroll position. -scroll-to: '//*[@id="117"]' -assert-window-property: {"pageYOffset": "2542"} -// Expanding the sidebar... -click: "#sidebar-toggle" -wait-for-css: (".sidebar", {"width": "500px"}) -click: "#sidebar-toggle" -wait-for-css: (".sidebar", {"width": "0px"}) -// The "scrollTop" property should be the same. -assert-window-property: {"pageYOffset": "2542"} - -// We now check that the scroll position is restored if the window is resized. -size: (500, 700) -click: "#sidebar-toggle" -wait-for-css: ("#source-sidebar", {"visibility": "visible"}) -assert-window-property: {"pageYOffset": "0"} -size: (900, 900) -assert-window-property: {"pageYOffset": "2542"} -size: (500, 700) -click: "#sidebar-toggle" -wait-for-css: ("#source-sidebar", {"visibility": "hidden"}) - -// We now check that opening the sidebar and clicking a link will close it. -// The behavior here on mobile is different than the behavior on desktop, -// but common sense dictates that if you have a list of files that fills the entire screen, and -// you click one of them, you probably want to actually see the file's contents, and not just -// make it the current selection. -click: "#sidebar-toggle" -wait-for-css: ("#source-sidebar", {"visibility": "visible"}) -assert-local-storage: {"rustdoc-source-sidebar-show": "true"} -click: ".sidebar a.selected" -goto: "file://" + |DOC_PATH| + "/src/test_docs/lib.rs.html" -wait-for-css: ("#source-sidebar", {"visibility": "hidden"}) -assert-local-storage: {"rustdoc-source-sidebar-show": "false"} -// Resize back to desktop size, to check that the sidebar doesn't spontaneously open. -size: (1000, 1000) -wait-for-css: ("#source-sidebar", {"visibility": "hidden"}) -assert-local-storage: {"rustdoc-source-sidebar-show": "false"} -click: "#sidebar-toggle" -wait-for-css: ("#source-sidebar", {"visibility": "visible"}) -assert-local-storage: {"rustdoc-source-sidebar-show": "true"} diff --git a/src/test/rustdoc-gui/sidebar-source-code.goml b/src/test/rustdoc-gui/sidebar-source-code.goml deleted file mode 100644 index 36e4d555b..000000000 --- a/src/test/rustdoc-gui/sidebar-source-code.goml +++ /dev/null @@ -1,45 +0,0 @@ -// The goal of this test is to ensure that the sidebar is working as expected in the source -// code pages. -goto: "file://" + |DOC_PATH| + "/src/test_docs/lib.rs.html" -// First: desktop mode. -size: (1100, 800) -// We check that the sidebar isn't expanded and has the expected width. -assert-css: ("nav.sidebar", {"width": "50px"}) -// We now click on the button to expand the sidebar. -click: (10, 10) -// We wait for the sidebar to be expanded. -wait-for-css: (".source-sidebar-expanded nav.sidebar", {"width": "300px"}) -assert-css: (".source-sidebar-expanded nav.sidebar a", {"font-size": "14px"}) -// We collapse the sidebar. -click: (10, 10) -// We ensure that the class has been removed. -wait-for: "html:not(.expanded)" -assert: "nav.sidebar" - -// Checking that only the path to the current file is "open". -goto: "file://" + |DOC_PATH| + "/src/lib2/another_folder/sub_mod/mod.rs.html" -// First we expand the sidebar again. -click: (10, 10) -// We wait for the sidebar to be expanded. -wait-for-css: (".source-sidebar-expanded nav.sidebar", {"width": "300px"}) -assert: "//*[@class='dir-entry' and @open]/*[text()='lib2']" -assert: "//*[@class='dir-entry' and @open]/*[text()='another_folder']" -assert: "//*[@class='dir-entry' and @open]/*[text()='sub_mod']" -// Only "another_folder" should be "open" in "lib2". -assert: "//*[@class='dir-entry' and not(@open)]/*[text()='another_mod']" -// All other trees should be collapsed. -assert-count: ("//*[@id='source-sidebar']/details[not(text()='lib2') and not(@open)]", 7) - -// We now switch to mobile mode. -size: (600, 600) -wait-for-css: (".source-sidebar-expanded nav.sidebar", {"width": "600px"}) -// We collapse the sidebar. -click: (10, 10) -// We check that the sidebar has the expected width (0). -assert-css: ("nav.sidebar", {"width": "0px"}) -// We ensure that the class has been removed. -assert-false: ".source-sidebar-expanded" -assert: "nav.sidebar" - -// Check that the topbar is not visible -assert-false: ".mobile-topbar" diff --git a/src/test/rustdoc-gui/sidebar.goml b/src/test/rustdoc-gui/sidebar.goml deleted file mode 100644 index 5058630f4..000000000 --- a/src/test/rustdoc-gui/sidebar.goml +++ /dev/null @@ -1,107 +0,0 @@ -// Checks multiple things on the sidebar display (width of its elements, colors, etc). -goto: "file://" + |DOC_PATH| + "/test_docs/index.html" -assert-property: (".sidebar", {"clientWidth": "200"}) -show-text: true -local-storage: {"rustdoc-theme": "light"} -// We reload the page so the local storage settings are being used. -reload: - -assert-text: (".sidebar > .location", "Crate test_docs") -// In modules, we only have one "location" element. -assert-count: (".sidebar .location", 1) -assert-count: (".sidebar h2", 1) -assert-text: ("#all-types", "All Items") -assert-css: ("#all-types", {"color": "rgb(53, 109, 164)"}) -// We check that we have the crates list and that the "current" on is "test_docs". -assert-text: (".sidebar-elems ul.crate > li > a.current", "test_docs") -// And we're also supposed to have the list of items in the current module. -assert-text: (".sidebar-elems section ul > li:nth-child(1)", "Re-exports") -assert-text: (".sidebar-elems section ul > li:nth-child(2)", "Modules") -assert-text: (".sidebar-elems section ul > li:nth-child(3)", "Macros") -assert-text: (".sidebar-elems section ul > li:nth-child(4)", "Structs") -assert-text: (".sidebar-elems section ul > li:nth-child(5)", "Enums") -assert-text: (".sidebar-elems section ul > li:nth-child(6)", "Constants") -assert-text: (".sidebar-elems section ul > li:nth-child(7)", "Traits") -assert-text: (".sidebar-elems section ul > li:nth-child(8)", "Functions") -assert-text: (".sidebar-elems section ul > li:nth-child(9)", "Type Definitions") -assert-text: (".sidebar-elems section ul > li:nth-child(10)", "Unions") -assert-text: (".sidebar-elems section ul > li:nth-child(11)", "Keywords") -assert-text: ("#structs + .item-table .item-left > a", "Foo") -click: "#structs + .item-table .item-left > a" - -// PAGE: struct.Foo.html -assert-count: (".sidebar .location", 1) -assert-count: (".sidebar h2", 2) -// We check that there is no crate listed outside of the top level. -assert-false: ".sidebar-elems > .crate" - -click: ".sidebar-elems section .block li > a" -assert-property-false: ("html", {"scrollTop": "0"}) - -click: ".sidebar h2.location a" -assert-property: ("html", {"scrollTop": "0"}) - -// We now go back to the crate page to click on the "lib2" crate link. -goto: "file://" + |DOC_PATH| + "/test_docs/index.html" -assert-property: (".sidebar", {"clientWidth": "200"}) -assert-css: (".sidebar-elems ul.crate > li:first-child > a", {"color": "rgb(53, 109, 164)"}) -click: ".sidebar-elems ul.crate > li:first-child > a" - -// PAGE: lib2/index.html -goto: "file://" + |DOC_PATH| + "/lib2/index.html" -assert-property: (".sidebar", {"clientWidth": "200"}) -assert-text: (".sidebar > .location", "Crate lib2") -// We check that we have the crates list and that the "current" on is now "lib2". -assert-text: (".sidebar-elems ul.crate > li > a.current", "lib2") -// We now go to the "foobar" function page. -assert-text: (".sidebar-elems > section ul.block > li:nth-child(1)", "Modules") -assert-text: (".sidebar-elems > section ul.block > li:nth-child(2)", "Structs") -assert-text: (".sidebar-elems > section ul.block > li:nth-child(3)", "Traits") -assert-text: (".sidebar-elems > section ul.block > li:nth-child(4)", "Functions") -assert-text: (".sidebar-elems > section ul.block > li:nth-child(5)", "Type Definitions") -assert-text: ("#functions + .item-table .item-left > a", "foobar") -click: "#functions + .item-table .item-left > a" - -// PAGE: fn.foobar.html -// In items containing no items (like functions or constants) and in modules, we have no -// "location" elements. Only the parent module h2. -assert-count: (".sidebar .location", 0) -assert-count: (".sidebar h2", 1) -assert-text: (".sidebar .sidebar-elems h2", "In lib2") -// We check that we don't have the crate list. -assert-false: ".sidebar-elems > .crate" - -goto: "./module/index.html" -assert-property: (".sidebar", {"clientWidth": "200"}) -assert-text: (".sidebar > .location", "Module module") -// We check that we don't have the crate list. -assert-false: ".sidebar-elems > .crate" - -goto: "./sub_module/sub_sub_module/index.html" -assert-property: (".sidebar", {"clientWidth": "200"}) -assert-text: (".sidebar > .location", "Module sub_sub_module") -// We check that we don't have the crate list. -assert-false: ".sidebar-elems .crate" -assert-text: (".sidebar-elems > section ul > li:nth-child(1)", "Functions") -assert-text: ("#functions + .item-table .item-left > a", "foo") - -// Links to trait implementations in the sidebar should not wrap even if they are long. -goto: "file://" + |DOC_PATH| + "/lib2/struct.HasALongTraitWithParams.html" -assert-property: (".sidebar", {"clientWidth": "200"}) -assert-property: (".sidebar-elems section .block li > a", {"offsetHeight": 29}) - -// Test that clicking on of the "In <module>" headings in the sidebar links to the -// appropriate anchor in index.html. -goto: "file://" + |DOC_PATH| + "/test_docs/struct.Foo.html" -assert-property: (".sidebar", {"clientWidth": "200"}) -click: "//ul[@class='block mod']/preceding-sibling::h3/a" -// PAGE: index.html -assert-css: ("#modules", {"background-color": "rgb(253, 255, 211)"}) - -// Finally, assert that the `[+]/[−]` toggle doesn't affect sidebar width. -click: "#toggle-all-docs" -assert-text: ("#toggle-all-docs", "[+]") -assert-property: (".sidebar", {"clientWidth": "200"}) -click: "#toggle-all-docs" -assert-text: ("#toggle-all-docs", "[−]") -assert-property: (".sidebar", {"clientWidth": "200"})
\ No newline at end of file diff --git a/src/test/rustdoc-gui/source-anchor-scroll.goml b/src/test/rustdoc-gui/source-anchor-scroll.goml deleted file mode 100644 index ddfe0c3d1..000000000 --- a/src/test/rustdoc-gui/source-anchor-scroll.goml +++ /dev/null @@ -1,20 +0,0 @@ -// We check that when the anchor changes and is output of the displayed content, -// the page is scrolled to it. -goto: "file://" + |DOC_PATH| + "/src/link_to_definition/lib.rs.html" - -// We reduce the window size to make it easier to make an element "out of the page". -size: (600, 800) -// We check that the scroll is at the top first. -assert-property: ("html", {"scrollTop": "0"}) - -click: '//a[text() = "barbar"]' -assert-property: ("html", {"scrollTop": "125"}) -click: '//a[text() = "bar"]' -assert-property: ("html", {"scrollTop": "156"}) -click: '//a[text() = "sub_fn"]' -assert-property: ("html", {"scrollTop": "53"}) - -// We now check that clicking on lines doesn't change the scroll -// Extra information: the "sub_fn" function header is on line 1. -click: '//*[@id="6"]' -assert-property: ("html", {"scrollTop": "53"}) diff --git a/src/test/rustdoc-gui/source-code-page.goml b/src/test/rustdoc-gui/source-code-page.goml deleted file mode 100644 index b3b837ad3..000000000 --- a/src/test/rustdoc-gui/source-code-page.goml +++ /dev/null @@ -1,137 +0,0 @@ -// Checks that the interactions with the source code pages are working as expected. -goto: "file://" + |DOC_PATH| + "/src/test_docs/lib.rs.html" -show-text: true -// Check that we can click on the line number. -click: ".src-line-numbers > a:nth-child(4)" // This is the anchor for line 4. -// Ensure that the page URL was updated. -assert-document-property: ({"URL": "lib.rs.html#4"}, ENDS_WITH) -assert-attribute: ("//*[@id='4']", {"class": "line-highlighted"}) -// Ensure that the default style, with the right border, isn't used. -assert-css: ("//*[@id='4']", {"border-right-width": "0px"}) -reload: -assert-attribute: ("//*[@id='4']", {"class": "line-highlighted"}) -assert-css: ("//*[@id='4']", {"border-right-width": "0px"}) -// We now check that the good anchors are highlighted -goto: "file://" + |DOC_PATH| + "/src/test_docs/lib.rs.html#4-6" -assert-attribute-false: (".src-line-numbers > a:nth-child(3)", {"class": "line-highlighted"}) -assert-attribute: (".src-line-numbers > a:nth-child(4)", {"class": "line-highlighted"}) -assert-attribute: (".src-line-numbers > a:nth-child(5)", {"class": "line-highlighted"}) -assert-attribute: (".src-line-numbers > a:nth-child(6)", {"class": "line-highlighted"}) -assert-attribute-false: (".src-line-numbers > a:nth-child(7)", {"class": "line-highlighted"}) - -define-function: ( - "check-colors", - (theme, color, background_color, highlight_color, highlight_background_color), - [ - ("local-storage", {"rustdoc-theme": |theme|, "rustdoc-use-system-theme": "false"}), - ("reload"), - ("assert-css", ( - ".src-line-numbers > a:not(.line-highlighted)", - {"color": |color|, "background-color": |background_color|}, - ALL, - )), - ("assert-css", ( - ".src-line-numbers > a.line-highlighted", - {"color": |highlight_color|, "background-color": |highlight_background_color|}, - ALL, - )), - ], -) - -call-function: ("check-colors", { - "theme": "ayu", - "color": "rgb(92, 103, 115)", - "background_color": "rgba(0, 0, 0, 0)", - "highlight_color": "rgb(112, 128, 144)", - "highlight_background_color": "rgba(255, 236, 164, 0.06)", -}) -call-function: ("check-colors", { - "theme": "dark", - "color": "rgb(59, 145, 226)", - "background_color": "rgba(0, 0, 0, 0)", - "highlight_color": "rgb(59, 145, 226)", - "highlight_background_color": "rgb(10, 4, 47)", -}) -call-function: ("check-colors", { - "theme": "light", - "color": "rgb(198, 126, 45)", - "background_color": "rgba(0, 0, 0, 0)", - "highlight_color": "rgb(198, 126, 45)", - "highlight_background_color": "rgb(253, 255, 211)", -}) - -// This is to ensure that the content is correctly align with the line numbers. -compare-elements-position: ("//*[@id='1']", ".rust > code > span", ("y")) -// Check the `href` property so that users can treat anchors as links. -assert-property: (".src-line-numbers > a:nth-child(1)", { - "href": "file://" + |DOC_PATH| + "/src/test_docs/lib.rs.html#1" -}) -assert-property: (".src-line-numbers > a:nth-child(2)", { - "href": "file://" + |DOC_PATH| + "/src/test_docs/lib.rs.html#2" -}) -assert-property: (".src-line-numbers > a:nth-child(3)", { - "href": "file://" + |DOC_PATH| + "/src/test_docs/lib.rs.html#3" -}) -assert-property: (".src-line-numbers > a:nth-child(4)", { - "href": "file://" + |DOC_PATH| + "/src/test_docs/lib.rs.html#4" -}) -assert-property: (".src-line-numbers > a:nth-child(5)", { - "href": "file://" + |DOC_PATH| + "/src/test_docs/lib.rs.html#5" -}) -assert-property: (".src-line-numbers > a:nth-child(6)", { - "href": "file://" + |DOC_PATH| + "/src/test_docs/lib.rs.html#6" -}) - -// Assert that the line numbers text is aligned to the right. -assert-css: (".src-line-numbers", {"text-align": "right"}) - -// Now let's check that clicking on something else than the line number doesn't -// do anything (and certainly not add a `#NaN` to the URL!). -goto: "file://" + |DOC_PATH| + "/src/test_docs/lib.rs.html" -// We use this assert-position to know where we will click. -assert-position: ("//*[@id='1']", {"x": 104, "y": 112}) -// We click on the left of the "1" anchor but still in the "src-line-number" `<pre>`. -click: (103, 103) -assert-document-property: ({"URL": "/lib.rs.html"}, ENDS_WITH) - -// Checking the source code sidebar. - -// First we "open" it. -click: "#sidebar-toggle" -assert: ".source-sidebar-expanded" - -// We check that the first entry of the sidebar is collapsed -assert-property: ("#source-sidebar details:first-of-type", {"open": "false"}) -assert-text: ("#source-sidebar details:first-of-type > summary", "huge_logo") -// We now click on it. -click: "#source-sidebar details:first-of-type > summary" -assert-property: ("#source-sidebar details:first-of-type", {"open": "true"}) - -// And now we collapse it again. -click: "#source-sidebar details:first-of-type > summary" -assert-property: ("#source-sidebar details:first-of-type", {"open": "false"}) - -// Check the spacing. -assert-css: ("#source-sidebar > details.dir-entry", {"padding-left": "4px"}) - -// Check the search form -assert-css: ("nav.sub", {"flex-direction": "row"}) -// The goal of this test is to ensure the search input is perfectly centered -// between the top of the page and the top of the gray code block. -// To check this, we maintain the invariant: -// -// offsetTop[nav.sub form] = offsetTop[#main-content] - offsetHeight[nav.sub form] - offsetTop[nav.sub form] -assert-property: ("nav.sub form", {"offsetTop": 28, "offsetHeight": 34}) -assert-property: ("#main-content", {"offsetTop": 90}) -// 28 = 90 - 34 - 28 - -// Now do the same check on moderately-sized mobile. -size: (700, 700) -assert-css: ("nav.sub", {"flex-direction": "row"}) -assert-property: ("nav.sub form", {"offsetTop": 21, "offsetHeight": 34}) -assert-property: ("#main-content", {"offsetTop": 76}) -// 21 = 76 - 34 - 21 - -// Tiny mobile gets a different display where the logo is stacked on top. -size: (450, 700) -assert-css: ("nav.sub", {"flex-direction": "column"}) diff --git a/src/test/rustdoc-gui/src-font-size.goml b/src/test/rustdoc-gui/src-font-size.goml deleted file mode 100644 index 9233f3744..000000000 --- a/src/test/rustdoc-gui/src-font-size.goml +++ /dev/null @@ -1,16 +0,0 @@ -// This test ensures that the "[src]" have the same font size as their headers -// to avoid having some weird height difference in the background when the element -// is selected. -goto: "file://" + |DOC_PATH| + "/test_docs/struct.Foo.html" -show-text: true -// Check the impl headers. -assert-css: (".impl.has-srclink .srclink", {"font-size": "16px", "font-weight": 400}, ALL) -assert-css: (".impl.has-srclink .code-header", {"font-size": "18px", "font-weight": 600}, ALL) -// Check the impl items. -assert-css: (".impl-items .has-srclink .srclink", {"font-size": "16px", "font-weight": 400}, ALL) -assert-css: (".impl-items .has-srclink .code-header", {"font-size": "16px", "font-weight": 600}, ALL) - -// Check that we can click on source link -store-document-property: (url, "URL") -click: ".impl-items .has-srclink .srclink" -assert-document-property-false: {"URL": |url|} diff --git a/src/test/rustdoc-gui/src/huge_logo/Cargo.lock b/src/test/rustdoc-gui/src/huge_logo/Cargo.lock deleted file mode 100644 index 142805750..000000000 --- a/src/test/rustdoc-gui/src/huge_logo/Cargo.lock +++ /dev/null @@ -1,7 +0,0 @@ -# This file is automatically @generated by Cargo. -# It is not intended for manual editing. -version = 3 - -[[package]] -name = "huge_logo" -version = "0.1.0" diff --git a/src/test/rustdoc-gui/src/huge_logo/Cargo.toml b/src/test/rustdoc-gui/src/huge_logo/Cargo.toml deleted file mode 100644 index 3f10d09c8..000000000 --- a/src/test/rustdoc-gui/src/huge_logo/Cargo.toml +++ /dev/null @@ -1,8 +0,0 @@ -[package] -name = "huge_logo" -version = "0.1.0" -edition = "2021" - -# See more keys and their definitions at https://doc.rust-lang.org/cargo/reference/manifest.html - -[dependencies] diff --git a/src/test/rustdoc-gui/src/huge_logo/src/lib.rs b/src/test/rustdoc-gui/src/huge_logo/src/lib.rs deleted file mode 100644 index ec137fb9a..000000000 --- a/src/test/rustdoc-gui/src/huge_logo/src/lib.rs +++ /dev/null @@ -1,17 +0,0 @@ -// ignore-tidy-linelength -#![doc(html_logo_url = "")] - -pub fn add(left: usize, right: usize) -> usize { - left + right -} - -#[cfg(test)] -mod tests { - use super::*; - - #[test] - fn it_works() { - let result = add(2, 2); - assert_eq!(result, 4); - } -} diff --git a/src/test/rustdoc-gui/src/lib2/Cargo.lock b/src/test/rustdoc-gui/src/lib2/Cargo.lock deleted file mode 100644 index a5873ceb3..000000000 --- a/src/test/rustdoc-gui/src/lib2/Cargo.lock +++ /dev/null @@ -1,14 +0,0 @@ -# This file is automatically @generated by Cargo. -# It is not intended for manual editing. -version = 3 - -[[package]] -name = "implementors" -version = "0.1.0" - -[[package]] -name = "lib2" -version = "0.1.0" -dependencies = [ - "implementors", -] diff --git a/src/test/rustdoc-gui/src/lib2/Cargo.toml b/src/test/rustdoc-gui/src/lib2/Cargo.toml deleted file mode 100644 index 2e37f3f66..000000000 --- a/src/test/rustdoc-gui/src/lib2/Cargo.toml +++ /dev/null @@ -1,10 +0,0 @@ -[package] -name = "lib2" -version = "0.1.0" -edition = "2018" - -[lib] -path = "lib.rs" - -[dependencies] -implementors = { path = "./implementors" } diff --git a/src/test/rustdoc-gui/src/lib2/another_folder/mod.rs b/src/test/rustdoc-gui/src/lib2/another_folder/mod.rs deleted file mode 100644 index ec9a20859..000000000 --- a/src/test/rustdoc-gui/src/lib2/another_folder/mod.rs +++ /dev/null @@ -1,3 +0,0 @@ -pub fn another_fn() {} - -pub mod sub_mod; diff --git a/src/test/rustdoc-gui/src/lib2/another_folder/sub_mod/mod.rs b/src/test/rustdoc-gui/src/lib2/another_folder/sub_mod/mod.rs deleted file mode 100644 index f16722cf3..000000000 --- a/src/test/rustdoc-gui/src/lib2/another_folder/sub_mod/mod.rs +++ /dev/null @@ -1 +0,0 @@ -pub fn subsubsub() {} diff --git a/src/test/rustdoc-gui/src/lib2/another_mod/mod.rs b/src/test/rustdoc-gui/src/lib2/another_mod/mod.rs deleted file mode 100644 index 9a4f007a2..000000000 --- a/src/test/rustdoc-gui/src/lib2/another_mod/mod.rs +++ /dev/null @@ -1 +0,0 @@ -pub fn tadam() {} diff --git a/src/test/rustdoc-gui/src/lib2/implementors/Cargo.lock b/src/test/rustdoc-gui/src/lib2/implementors/Cargo.lock deleted file mode 100644 index cad99a991..000000000 --- a/src/test/rustdoc-gui/src/lib2/implementors/Cargo.lock +++ /dev/null @@ -1,7 +0,0 @@ -# This file is automatically @generated by Cargo. -# It is not intended for manual editing. -version = 3 - -[[package]] -name = "implementors" -version = "0.1.0" diff --git a/src/test/rustdoc-gui/src/lib2/implementors/Cargo.toml b/src/test/rustdoc-gui/src/lib2/implementors/Cargo.toml deleted file mode 100644 index 7ef1052c4..000000000 --- a/src/test/rustdoc-gui/src/lib2/implementors/Cargo.toml +++ /dev/null @@ -1,7 +0,0 @@ -[package] -name = "implementors" -version = "0.1.0" -edition = "2018" - -[lib] -path = "lib.rs" diff --git a/src/test/rustdoc-gui/src/lib2/implementors/lib.rs b/src/test/rustdoc-gui/src/lib2/implementors/lib.rs deleted file mode 100644 index 1620e8422..000000000 --- a/src/test/rustdoc-gui/src/lib2/implementors/lib.rs +++ /dev/null @@ -1,20 +0,0 @@ -pub trait Whatever { - type Foo; - - fn method() {} -} - -pub struct Struct; - -impl Whatever for Struct { - type Foo = u8; -} - -mod traits { - pub trait TraitToReexport { - fn method() {} - } -} - -#[doc(inline)] -pub use traits::TraitToReexport; diff --git a/src/test/rustdoc-gui/src/lib2/lib.rs b/src/test/rustdoc-gui/src/lib2/lib.rs deleted file mode 100644 index 24aecc70d..000000000 --- a/src/test/rustdoc-gui/src/lib2/lib.rs +++ /dev/null @@ -1,185 +0,0 @@ -// ignore-tidy-linelength - -#![feature(doc_cfg)] - -pub mod another_folder; -pub mod another_mod; - -pub mod module { - pub mod sub_module { - pub mod sub_sub_module { - pub fn foo() {} - } - pub fn bar() {} - } - pub fn whatever() {} -} - -pub fn foobar() {} - -pub type Alias = u32; - -#[doc(cfg(feature = "foo-method"))] -pub struct Foo { - pub x: Alias, -} - -impl Foo { - /// Some documentation - /// # A Heading - pub fn a_method(&self) {} -} - -#[doc(cfg(feature = "foo-method"))] -#[deprecated = "Whatever [`Foo::a_method`](#method.a_method)"] -pub trait Trait { - type X; - const Y: u32; - - #[deprecated = "Whatever [`Foo`](#tadam)"] - fn foo() {} - fn fooo(); -} - -impl Trait for Foo { - type X = u32; - const Y: u32 = 0; - - fn fooo() {} -} - -impl implementors::Whatever for Foo { - type Foo = u32; -} - -#[doc(inline)] -pub use implementors::TraitToReexport; - -pub struct StructToImplOnReexport; - -impl TraitToReexport for StructToImplOnReexport {} - -pub mod sub_mod { - /// ```txt - /// aaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaa - /// ``` - /// - /// ``` - /// aaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaa - /// ``` - pub struct Foo; -} - -pub mod long_trait { - use std::ops::DerefMut; - - pub trait ALongNameBecauseItHelpsTestingTheCurrentProblem: - DerefMut<Target = u32> + From<u128> + Send + Sync + AsRef<str> + 'static - { - } -} - -pub mod long_table { - /// | This::is::a::kinda::very::long::header::number::one | This::is::a::kinda::very::long::header::number::two | This::is::a::kinda::very::long::header::number::one | This::is::a::kinda::very::long::header::number::two | - /// | ----------- | ----------- | ----------- | ----------- | - /// | This::is::a::kinda::long::content::number::one | This::is::a::kinda::very::long::content::number::two | This::is::a::kinda::long::content::number::one | This::is::a::kinda::very::long::content::number::two | - /// - /// I wanna sqdkfnqds f dsqf qds f dsqf dsq f dsq f qds f qds f qds f dsqq f dsf sqdf dsq fds f dsq f dq f ds fq sd fqds f dsq f sqd fsq df sd fdsqfqsd fdsq f dsq f dsqfd s dfq - pub struct Foo; - - /// | This::is::a::kinda::very::long::header::number::one | This::is::a::kinda::very::long::header::number::two | This::is::a::kinda::very::long::header::number::one | This::is::a::kinda::very::long::header::number::two | - /// | ----------- | ----------- | ----------- | ----------- | - /// | This::is::a::kinda::long::content::number::one | This::is::a::kinda::very::long::content::number::two | This::is::a::kinda::long::content::number::one | This::is::a::kinda::very::long::content::number::two | - /// - /// I wanna sqdkfnqds f dsqf qds f dsqf dsq f dsq f qds f qds f qds f dsqq f dsf sqdf dsq fds f dsq f dq f ds fq sd fqds f dsq f sqd fsq df sd fdsqfqsd fdsq f dsq f dsqfd s dfq - impl Foo { - pub fn foo(&self) {} - } -} - -pub mod summary_table { - /// | header 1 | header 2 | - /// | -------- | -------- | - /// | content | content | - pub struct Foo; -} - -pub mod too_long { - pub type ReallyLongTypeNameLongLongLong = - Option<unsafe extern "C" fn(a: *const u8, b: *const u8) -> *const u8>; - - pub const ReallyLongTypeNameLongLongLongConstBecauseWhyNotAConstRightGigaGigaSupraLong: u32 = 0; - - /// This also has a really long doccomment. Lorem ipsum dolor sit amet, - /// consectetur adipiscing elit. Suspendisse id nibh malesuada, hendrerit - /// massa vel, tincidunt est. Nulla interdum, sem ac efficitur ornare, arcu - /// nunc dignissim nibh, at rutrum diam augue ac mauris. Fusce tincidunt et - /// ligula sed viverra. Aenean sed facilisis dui, non volutpat felis. In - /// vitae est dui. Donec felis nibh, blandit at nibh eu, tempor suscipit - /// nisl. Vestibulum ornare porta libero, eu faucibus purus iaculis ut. Ut - /// quis tincidunt nunc, in mollis purus. Nulla sed interdum quam. Nunc - /// vitae cursus ex. - pub struct SuperIncrediblyLongLongLongLongLongLongLongGigaGigaGigaMegaLongLongLongStructName { - pub a: u32, - } - - impl SuperIncrediblyLongLongLongLongLongLongLongGigaGigaGigaMegaLongLongLongStructName { - /// ``` - /// let x = SuperIncrediblyLongLongLongLongLongLongLongGigaGigaGigaMegaLongLongLongStructName { a: 0 }; - /// ``` - pub fn foo(&self) {} - } -} - -pub struct HasALongTraitWithParams {} - -pub trait LongTraitWithParamsBananaBananaBanana<T> {} - -impl LongTraitWithParamsBananaBananaBanana<usize> for HasALongTraitWithParams {} - -#[doc(cfg(any(target_os = "android", target_os = "linux", target_os = "emscripten", target_os = "dragonfly", target_os = "freebsd", target_os = "netbsd", target_os = "openbsd")))] -pub struct LongItemInfo; - -pub trait SimpleTrait {} -pub struct LongItemInfo2; - -/// Some docs. -#[doc(cfg(any(target_os = "android", target_os = "linux", target_os = "emscripten", target_os = "dragonfly", target_os = "freebsd", target_os = "netbsd", target_os = "openbsd")))] -impl SimpleTrait for LongItemInfo2 {} - -pub struct WhereWhitespace<T>; - -impl<T> WhereWhitespace<T> { - pub fn new<F>(f: F) -> Self - where - F: FnMut() -> i32, - {} -} - -impl<K, T> Whitespace<&K> for WhereWhitespace<T> -where - K: std::fmt::Debug, -{ - type Output = WhereWhitespace<T>; - fn index(&self, _key: &K) -> &Self::Output { - self - } -} - -pub trait Whitespace<Idx> -where - Idx: ?Sized, -{ - type Output; - fn index(&self, index: Idx) -> &Self::Output; -} - -pub struct ItemInfoAlignmentTest; - -impl ItemInfoAlignmentTest { - /// This method has docs - #[deprecated] - pub fn foo() {} - #[deprecated] - pub fn bar() {} -} diff --git a/src/test/rustdoc-gui/src/link_to_definition/Cargo.lock b/src/test/rustdoc-gui/src/link_to_definition/Cargo.lock deleted file mode 100644 index e4b4e52d0..000000000 --- a/src/test/rustdoc-gui/src/link_to_definition/Cargo.lock +++ /dev/null @@ -1,7 +0,0 @@ -# This file is automatically @generated by Cargo. -# It is not intended for manual editing. -version = 3 - -[[package]] -name = "link_to_definition" -version = "0.1.0" diff --git a/src/test/rustdoc-gui/src/link_to_definition/Cargo.toml b/src/test/rustdoc-gui/src/link_to_definition/Cargo.toml deleted file mode 100644 index cdd294d74..000000000 --- a/src/test/rustdoc-gui/src/link_to_definition/Cargo.toml +++ /dev/null @@ -1,7 +0,0 @@ -[package] -name = "link_to_definition" -version = "0.1.0" -edition = "2018" - -[lib] -path = "lib.rs" diff --git a/src/test/rustdoc-gui/src/link_to_definition/lib.rs b/src/test/rustdoc-gui/src/link_to_definition/lib.rs deleted file mode 100644 index 419a9ccee..000000000 --- a/src/test/rustdoc-gui/src/link_to_definition/lib.rs +++ /dev/null @@ -1,35 +0,0 @@ -pub fn sub_fn() { - barbar(); -} -fn barbar() { - bar(vec![], vec![], vec![], vec![], Bar { a: "a".into(), b: 0 }); -} - -pub struct Bar { - pub a: String, - pub b: u32, -} - -pub fn foo(_b: &Bar) {} - -// The goal now is to add -// a lot of lines so -// that the next content -// will be out of the screen -// to allow us to test that -// if the anchor changes to -// something outside of the -// current view, it'll -// scroll to it as expected. - -// More filling content. - -pub fn bar( - _a: Vec<String>, - _b: Vec<String>, - _c: Vec<String>, - _d: Vec<String>, - _e: Bar, -) { - sub_fn(); -} diff --git a/src/test/rustdoc-gui/src/scrape_examples/Cargo.lock b/src/test/rustdoc-gui/src/scrape_examples/Cargo.lock deleted file mode 100644 index 7cd6d0844..000000000 --- a/src/test/rustdoc-gui/src/scrape_examples/Cargo.lock +++ /dev/null @@ -1,7 +0,0 @@ -# This file is automatically @generated by Cargo. -# It is not intended for manual editing. -version = 3 - -[[package]] -name = "scrape_examples" -version = "0.1.0" diff --git a/src/test/rustdoc-gui/src/scrape_examples/Cargo.toml b/src/test/rustdoc-gui/src/scrape_examples/Cargo.toml deleted file mode 100644 index aea9b657d..000000000 --- a/src/test/rustdoc-gui/src/scrape_examples/Cargo.toml +++ /dev/null @@ -1,8 +0,0 @@ -[package] -name = "scrape_examples" -version = "0.1.0" -edition = "2021" - -# See more keys and their definitions at https://doc.rust-lang.org/cargo/reference/manifest.html - -[dependencies] diff --git a/src/test/rustdoc-gui/src/scrape_examples/examples/check-many-1.rs b/src/test/rustdoc-gui/src/scrape_examples/examples/check-many-1.rs deleted file mode 100644 index 1d1bc5002..000000000 --- a/src/test/rustdoc-gui/src/scrape_examples/examples/check-many-1.rs +++ /dev/null @@ -1,3 +0,0 @@ -fn main() { - scrape_examples::test_many(); -} diff --git a/src/test/rustdoc-gui/src/scrape_examples/examples/check-many-2.rs b/src/test/rustdoc-gui/src/scrape_examples/examples/check-many-2.rs deleted file mode 100644 index 1d1bc5002..000000000 --- a/src/test/rustdoc-gui/src/scrape_examples/examples/check-many-2.rs +++ /dev/null @@ -1,3 +0,0 @@ -fn main() { - scrape_examples::test_many(); -} diff --git a/src/test/rustdoc-gui/src/scrape_examples/examples/check-many-3.rs b/src/test/rustdoc-gui/src/scrape_examples/examples/check-many-3.rs deleted file mode 100644 index 1d1bc5002..000000000 --- a/src/test/rustdoc-gui/src/scrape_examples/examples/check-many-3.rs +++ /dev/null @@ -1,3 +0,0 @@ -fn main() { - scrape_examples::test_many(); -} diff --git a/src/test/rustdoc-gui/src/scrape_examples/examples/check-many-4.rs b/src/test/rustdoc-gui/src/scrape_examples/examples/check-many-4.rs deleted file mode 100644 index 1d1bc5002..000000000 --- a/src/test/rustdoc-gui/src/scrape_examples/examples/check-many-4.rs +++ /dev/null @@ -1,3 +0,0 @@ -fn main() { - scrape_examples::test_many(); -} diff --git a/src/test/rustdoc-gui/src/scrape_examples/examples/check-many-5.rs b/src/test/rustdoc-gui/src/scrape_examples/examples/check-many-5.rs deleted file mode 100644 index 1d1bc5002..000000000 --- a/src/test/rustdoc-gui/src/scrape_examples/examples/check-many-5.rs +++ /dev/null @@ -1,3 +0,0 @@ -fn main() { - scrape_examples::test_many(); -} diff --git a/src/test/rustdoc-gui/src/scrape_examples/examples/check-many-6.rs b/src/test/rustdoc-gui/src/scrape_examples/examples/check-many-6.rs deleted file mode 100644 index 1d1bc5002..000000000 --- a/src/test/rustdoc-gui/src/scrape_examples/examples/check-many-6.rs +++ /dev/null @@ -1,3 +0,0 @@ -fn main() { - scrape_examples::test_many(); -} diff --git a/src/test/rustdoc-gui/src/scrape_examples/examples/check-many-7.rs b/src/test/rustdoc-gui/src/scrape_examples/examples/check-many-7.rs deleted file mode 100644 index 1d1bc5002..000000000 --- a/src/test/rustdoc-gui/src/scrape_examples/examples/check-many-7.rs +++ /dev/null @@ -1,3 +0,0 @@ -fn main() { - scrape_examples::test_many(); -} diff --git a/src/test/rustdoc-gui/src/scrape_examples/examples/check.rs b/src/test/rustdoc-gui/src/scrape_examples/examples/check.rs deleted file mode 100644 index b3f682fe4..000000000 --- a/src/test/rustdoc-gui/src/scrape_examples/examples/check.rs +++ /dev/null @@ -1,26 +0,0 @@ -fn main() { - for i in 0..9 { - println!("hello world!"); - println!("hello world!"); - println!("hello world!"); - println!("hello world!"); - println!("hello world!"); - println!("hello world!"); - println!("hello world!"); - println!("hello world!"); - println!("hello world!"); - } - scrape_examples::test(); - for i in 0..9 { - println!("hello world!"); - println!("hello world!"); - println!("hello world!"); - println!("hello world!"); - println!("hello world!"); - println!("hello world!"); - println!("hello world!"); - println!("hello world!"); - println!("hello world!"); - } - scrape_examples::test(); -} diff --git a/src/test/rustdoc-gui/src/scrape_examples/src/lib.rs b/src/test/rustdoc-gui/src/scrape_examples/src/lib.rs deleted file mode 100644 index 88b03cf26..000000000 --- a/src/test/rustdoc-gui/src/scrape_examples/src/lib.rs +++ /dev/null @@ -1,9 +0,0 @@ -/// # Examples -/// -/// ``` -/// test(); -/// test(); -/// ``` -pub fn test() {} - -pub fn test_many() {} diff --git a/src/test/rustdoc-gui/src/settings/.cargo/config.toml b/src/test/rustdoc-gui/src/settings/.cargo/config.toml deleted file mode 100644 index bbb8d11a2..000000000 --- a/src/test/rustdoc-gui/src/settings/.cargo/config.toml +++ /dev/null @@ -1,2 +0,0 @@ -[build] -rustdocflags = ["--default-theme", "ayu"] diff --git a/src/test/rustdoc-gui/src/settings/Cargo.lock b/src/test/rustdoc-gui/src/settings/Cargo.lock deleted file mode 100644 index 6f0de1ac1..000000000 --- a/src/test/rustdoc-gui/src/settings/Cargo.lock +++ /dev/null @@ -1,7 +0,0 @@ -# This file is automatically @generated by Cargo. -# It is not intended for manual editing. -version = 3 - -[[package]] -name = "settings" -version = "0.1.0" diff --git a/src/test/rustdoc-gui/src/settings/Cargo.toml b/src/test/rustdoc-gui/src/settings/Cargo.toml deleted file mode 100644 index c8a211a47..000000000 --- a/src/test/rustdoc-gui/src/settings/Cargo.toml +++ /dev/null @@ -1,7 +0,0 @@ -[package] -name = "settings" -version = "0.1.0" -edition = "2018" - -[lib] -path = "lib.rs" diff --git a/src/test/rustdoc-gui/src/settings/lib.rs b/src/test/rustdoc-gui/src/settings/lib.rs deleted file mode 100644 index b76b4321d..000000000 --- a/src/test/rustdoc-gui/src/settings/lib.rs +++ /dev/null @@ -1 +0,0 @@ -pub fn foo() {} diff --git a/src/test/rustdoc-gui/src/staged_api/Cargo.lock b/src/test/rustdoc-gui/src/staged_api/Cargo.lock deleted file mode 100644 index 6e8eba56c..000000000 --- a/src/test/rustdoc-gui/src/staged_api/Cargo.lock +++ /dev/null @@ -1,7 +0,0 @@ -# This file is automatically @generated by Cargo. -# It is not intended for manual editing. -version = 3 - -[[package]] -name = "staged_api" -version = "0.1.0" diff --git a/src/test/rustdoc-gui/src/staged_api/Cargo.toml b/src/test/rustdoc-gui/src/staged_api/Cargo.toml deleted file mode 100644 index b231be6ee..000000000 --- a/src/test/rustdoc-gui/src/staged_api/Cargo.toml +++ /dev/null @@ -1,12 +0,0 @@ -[package] -name = "staged_api" -version = "0.1.0" -edition = "2021" - -[lib] -path = "lib.rs" - -[features] -default = ["some_feature", "some_other_feature"] -some_feature = [] -some_other_feature = [] diff --git a/src/test/rustdoc-gui/src/staged_api/lib.rs b/src/test/rustdoc-gui/src/staged_api/lib.rs deleted file mode 100644 index 5934593a8..000000000 --- a/src/test/rustdoc-gui/src/staged_api/lib.rs +++ /dev/null @@ -1,12 +0,0 @@ -#![feature(staged_api)] -#![stable(feature = "some_feature", since = "1.3.5")] - -#[stable(feature = "some_feature", since = "1.3.5")] -pub struct Foo {} - -impl Foo { - #[stable(feature = "some_feature", since = "1.3.5")] - pub fn bar() {} - #[stable(feature = "some_other_feature", since = "1.3.6")] - pub fn yo() {} -} diff --git a/src/test/rustdoc-gui/src/test_docs/Cargo.lock b/src/test/rustdoc-gui/src/test_docs/Cargo.lock deleted file mode 100644 index 6b80f6e88..000000000 --- a/src/test/rustdoc-gui/src/test_docs/Cargo.lock +++ /dev/null @@ -1,7 +0,0 @@ -# This file is automatically @generated by Cargo. -# It is not intended for manual editing. -version = 3 - -[[package]] -name = "test_docs" -version = "0.1.0" diff --git a/src/test/rustdoc-gui/src/test_docs/Cargo.toml b/src/test/rustdoc-gui/src/test_docs/Cargo.toml deleted file mode 100644 index 8be819b76..000000000 --- a/src/test/rustdoc-gui/src/test_docs/Cargo.toml +++ /dev/null @@ -1,13 +0,0 @@ -[package] -name = "test_docs" -version = "0.1.0" -edition = "2018" - -build = "build.rs" - -[lib] -path = "lib.rs" - -[features] -default = ["some-feature"] -some-feature = [] diff --git a/src/test/rustdoc-gui/src/test_docs/build.rs b/src/test/rustdoc-gui/src/test_docs/build.rs deleted file mode 100644 index 16c96ded9..000000000 --- a/src/test/rustdoc-gui/src/test_docs/build.rs +++ /dev/null @@ -1,15 +0,0 @@ -//! generate 2000 constants for testing - -use std::{fs::write, path::PathBuf}; - -fn main() -> std::io::Result<()> { - let out_dir = std::env::var("OUT_DIR").expect("OUT_DIR is not defined"); - - let mut output = String::new(); - for i in 0..2000 { - let line = format!("/// Some const A{0}\npub const A{0}: isize = 0;\n", i); - output.push_str(&*line); - }; - - write(&[&*out_dir, "huge_amount_of_consts.rs"].iter().collect::<PathBuf>(), output) -} diff --git a/src/test/rustdoc-gui/src/test_docs/lib.rs b/src/test/rustdoc-gui/src/test_docs/lib.rs deleted file mode 100644 index d6eeab803..000000000 --- a/src/test/rustdoc-gui/src/test_docs/lib.rs +++ /dev/null @@ -1,444 +0,0 @@ -//! The point of this crate is to be able to have enough different "kinds" of -//! documentation generated so we can test each different features. -#![doc(html_playground_url="https://play.rust-lang.org/")] - -#![crate_name = "test_docs"] -#![feature(rustdoc_internals)] -#![feature(doc_cfg)] -#![feature(associated_type_defaults)] - -/*! -Enable the feature <span class="stab portability"><code>some-feature</code></span> to enjoy -this crate even more! -Enable the feature <span class="stab portability"><code>some-feature</code></span> to enjoy -this crate even more! -Enable the feature <span class="stab portability"><code>some-feature</code></span> to enjoy -this crate even more! - -Also, stop using `bar` as it's <span class="stab deprecated" title="">deprecated</span>. -Also, stop using `bar` as it's <span class="stab deprecated" title="">deprecated</span>. -Also, stop using `bar` as it's <span class="stab deprecated" title="">deprecated</span>. - -Finally, you can use `quz` only on <span class="stab portability"><code>Unix or x86-64</code> -</span>. -Finally, you can use `quz` only on <span class="stab portability"><code>Unix or x86-64</code> -</span>. -*/ - -use std::convert::AsRef; -use std::fmt; - -/// Basic function with some code examples: -/// -/// ``` -/// println!("nothing fancy"); -/// println!("but with two lines!"); -/// ``` -/// -/// A failing to compile one: -/// -/// ```compile_fail -/// println!("where did my argument {} go? :'("); -/// ``` -/// -/// An ignored one: -/// -/// ```ignore (it's a test) -/// Let's say I'm just some text will ya? -/// ``` -/// -/// A failing to run one: -/// -/// ```should_panic -/// panic!("tadam"); -/// ``` -/// -/// An inlined `code`! -pub fn foo() {} - -/// Just a normal struct. -pub struct Foo; - -impl Foo { - #[must_use] - pub fn must_use(&self) -> bool { - true - } -} - -impl AsRef<str> for Foo { - fn as_ref(&self) -> &str { - "hello" - } -} - -/// Just a normal enum. -/// -/// # title! -#[doc(alias = "ThisIsAnAlias")] -#[non_exhaustive] -pub enum WhoLetTheDogOut { - /// Woof! - Woof, - /// Meoooooooow... - Meow, -} - -/// Who doesn't love to wrap a `format!` call? -pub fn some_more_function<T: fmt::Debug>(t: &T) -> String { - format!("{:?}", t) -} - -/// Woohoo! A trait! -pub trait AnotherOne { - /// Some func 3. - fn func3(); - - /// Some func 1. - fn func1(); - - fn another(); - fn why_not(); - - /// Some func 2. - fn func2(); - - fn hello(); -} - -/// ```compile_fail -/// whatever -/// ``` -/// -/// Check for "i" signs in lists! -/// -/// 1. elem 1 -/// 2. test 1 -/// ```compile_fail -/// fn foo() {} -/// ``` -/// 3. elem 3 -/// 4. ```ignore (it's a test) -/// fn foo() {} -/// ``` -/// 5. elem 5 -/// -/// Final one: -/// -/// ```ignore (still a test) -/// let x = 12; -/// ``` -pub fn check_list_code_block() {} - -/// a thing with a label -#[deprecated(since = "1.0.0", note = "text why this deprecated")] -#[doc(cfg(unix))] -pub fn replaced_function() {} - -/// Some doc with `code`! -pub enum AnEnum { - WithVariants { and: usize, sub: usize, variants: usize }, -} - -#[doc(keyword = "CookieMonster")] -/// Some keyword. -pub mod keyword {} - -/// Just some type alias. -pub type SomeType = u32; - -pub mod huge_amount_of_consts { - include!(concat!(env!("OUT_DIR"), "/huge_amount_of_consts.rs")); -} - -/// Very long code text `hereIgoWithLongTextBecauseWhyNotAndWhyWouldntI`. -pub mod long_code_block {} - -#[macro_export] -macro_rules! repro { - () => {}; -} - -pub use crate::repro as repro2; - -/// # Top-doc Prose title -/// -/// Text below title. -/// -/// ## Top-doc Prose sub-heading -/// -/// Text below sub-heading. -/// -/// ### Top-doc Prose sub-sub-heading -/// -/// Text below sub-sub-heading -/// -/// #### You know the drill. -/// -/// More text. -pub struct HeavilyDocumentedStruct { - /// # Title for field - /// ## Sub-heading for field - pub nothing: (), -} - -/// # Title for struct impl doc -/// -/// Text below heading. -/// -/// ## Sub-heading for struct impl doc -/// -/// Text below sub-heading. -/// -/// ### Sub-sub-heading for struct impl doc -/// -/// Text below sub-sub-heading. -/// -impl HeavilyDocumentedStruct { - /// # Title for struct impl-item doc - /// Text below title. - /// ## Sub-heading for struct impl-item doc - /// Text below sub-heading. - /// ### Sub-sub-heading for struct impl-item doc - /// Text below sub-sub-heading. - pub fn do_nothing() {} -} - -/// # Top-doc Prose title -/// -/// Text below title. -/// -/// ## Top-doc Prose sub-heading -/// -/// Text below sub-heading. -/// -/// ### Top-doc Prose sub-sub-heading -/// -/// Text below sub-sub-heading -pub enum HeavilyDocumentedEnum { - /// # None prose title - /// ## None prose sub-heading - None, - /// # Wrapped prose title - /// ## Wrapped prose sub-heading - Wrapped( - /// # Wrapped.0 prose title - /// ## Wrapped.0 prose sub-heading - String, - String, - ), - Structy { - /// # Structy prose title - /// ## Structy prose sub-heading - alpha: String, - beta: String, - }, -} - -/// # Title for enum impl doc -/// -/// Text below heading. -/// -/// ## Sub-heading for enum impl doc -/// -/// Text below sub-heading. -/// -/// ### Sub-sub-heading for enum impl doc -/// -/// Text below sub-sub-heading. -/// -impl HeavilyDocumentedEnum { - /// # Title for enum impl-item doc - /// Text below title. - /// ## Sub-heading for enum impl-item doc - /// Text below sub-heading. - /// ### Sub-sub-heading for enum impl-item doc - /// Text below sub-sub-heading. - pub fn do_nothing() {} -} - -/// # Top-doc prose title -/// -/// Text below heading. -/// -/// ## Top-doc prose sub-heading -/// -/// Text below heading. -pub union HeavilyDocumentedUnion { - /// # Title for union variant - /// ## Sub-heading for union variant - pub nothing: (), - pub something: f32, -} - -/// # Title for union impl doc -/// ## Sub-heading for union impl doc -impl HeavilyDocumentedUnion { - /// # Title for union impl-item doc - /// ## Sub-heading for union impl-item doc - pub fn do_nothing() {} -} - -/// # Top-doc prose title -/// -/// Text below heading. -/// -/// ## Top-doc prose sub-heading -/// -/// Text below heading. -#[macro_export] -macro_rules! heavily_documented_macro { - () => {}; -} - -pub trait EmptyTrait1 {} -pub trait EmptyTrait2 {} -pub trait EmptyTrait3 {} - -pub struct HasEmptyTraits{} - -impl EmptyTrait1 for HasEmptyTraits {} -impl EmptyTrait2 for HasEmptyTraits {} -#[doc(cfg(feature = "some-feature"))] -impl EmptyTrait3 for HasEmptyTraits {} - -mod macros; -pub use macros::*; - -#[doc(alias = "AliasForTheStdReexport")] -pub use ::std as TheStdReexport; - -pub mod details { - /// We check the appearance of the `<details>`/`<summary>` in here. - /// - /// ## Hello - /// - /// <details> - /// <summary><h4>I'm a summary</h4></summary> - /// <div>I'm the content of the details!</div> - /// </details> - pub struct Details; - - impl Details { - /// We check the appearance of the `<details>`/`<summary>` in here. - /// - /// ## Hello - /// - /// <details> - /// <summary><h4>I'm a summary</h4></summary> - /// <div>I'm the content of the details!</div> - /// </details> - pub fn method() {} - } -} - -pub mod doc_block_table { - - pub trait DocBlockTableTrait { - fn func(); - } - - /// Struct doc. - /// - /// | header1 | header2 | - /// |--------------------------|--------------------------| - /// | Lorem Ipsum, Lorem Ipsum | Lorem Ipsum, Lorem Ipsum | - /// | Lorem Ipsum, Lorem Ipsum | Lorem Ipsum, Lorem Ipsum | - /// | Lorem Ipsum, Lorem Ipsum | Lorem Ipsum, Lorem Ipsum | - /// | Lorem Ipsum, Lorem Ipsum | Lorem Ipsum, Lorem Ipsum | - pub struct DocBlockTable {} - - impl DocBlockTableTrait for DocBlockTable { - /// Trait impl func doc for struct. - /// - /// | header1 | header2 | - /// |--------------------------|--------------------------| - /// | Lorem Ipsum, Lorem Ipsum | Lorem Ipsum, Lorem Ipsum | - fn func() { - println!(); - } - } - -} - -pub struct NotableStructWithLongName<R>(R); - -impl<R: std::io::Read> NotableStructWithLongName<R> { - pub fn create_an_iterator_from_read(r: R) -> NotableStructWithLongName<R> { Self(r) } -} - -impl<R: std::io::Read> std::iter::Iterator for NotableStructWithLongName<R> { - type Item = (); - - fn next(&mut self) -> Option<Self::Item> { () } -} - -pub trait TraitWithNoDocblocks { - fn first_fn(&self); - fn second_fn(&self); -} - -pub struct TypeWithNoDocblocks; - -impl TypeWithNoDocblocks { - fn x() -> Option<Self> { - Some(Self) - } - fn y() -> Option<u32> { - // code comment - let t = Self::x()?; - Some(0) - } -} - -impl TypeWithNoDocblocks { - pub fn first_fn(&self) {} - pub fn second_fn<'a>(&'a self) { - let x = 12; - let y = "a"; - let z = false; - } -} - -pub unsafe fn unsafe_fn() {} - -pub fn safe_fn() {} - -#[repr(C)] -pub struct WithGenerics<T: TraitWithNoDocblocks, S = String, E = WhoLetTheDogOut, P = i8> { - s: S, - t: T, - e: E, - p: P, -} - -pub struct StructWithPublicUndocumentedFields { - pub first: u32, - pub second: u32, -} - -pub const CONST: u8 = 0; - -pub trait TraitWithoutGenerics { - const C: u8 = CONST; - type T = SomeType; - - fn foo(); -} - -pub mod trait_members { - pub trait TraitMembers { - /// Some type - type Type; - /// Some function - fn function(); - /// Some other function - fn function2(); - } - pub struct HasTrait; - impl TraitMembers for HasTrait { - type Type = u8; - fn function() {} - fn function2() {} - } -} diff --git a/src/test/rustdoc-gui/src/test_docs/macros.rs b/src/test/rustdoc-gui/src/test_docs/macros.rs deleted file mode 100644 index 07b2b9792..000000000 --- a/src/test/rustdoc-gui/src/test_docs/macros.rs +++ /dev/null @@ -1,4 +0,0 @@ -#[macro_export] -macro_rules! a{ () => {}} -#[macro_export] -macro_rules! b{ () => {}} diff --git a/src/test/rustdoc-gui/struct-fields.goml b/src/test/rustdoc-gui/struct-fields.goml deleted file mode 100644 index 3ec60b58c..000000000 --- a/src/test/rustdoc-gui/struct-fields.goml +++ /dev/null @@ -1,5 +0,0 @@ -goto: "file://" + |DOC_PATH| + "/test_docs/struct.StructWithPublicUndocumentedFields.html" - -// Both fields must be on their own line. In other words, they have display: block. -store-property: (first_top, "//*[@id='structfield.first']", "offsetTop") -assert-property-false: ("//*[@id='structfield.second']", { "offsetTop": |first_top| }) diff --git a/src/test/rustdoc-gui/target.goml b/src/test/rustdoc-gui/target.goml deleted file mode 100644 index 3e5c30dc7..000000000 --- a/src/test/rustdoc-gui/target.goml +++ /dev/null @@ -1,35 +0,0 @@ -// Check that the targetted element has the expected styles. -goto: "file://" + |DOC_PATH| + "/lib2/struct.Foo.html#method.a_method" -show-text: true - -// Confirming that the method is the target. -assert: "#method\.a_method:target" - -define-function: ( - "check-style", - (theme, background, border), - [ - ("local-storage", {"rustdoc-theme": |theme|, "rustdoc-use-system-theme": "false"}), - ("reload"), - ("assert-css", ("#method\.a_method:target", { - "background-color": |background|, - "border-right": "3px solid " + |border|, - })), - ], -) - -call-function: ("check-style", { - "theme": "ayu", - "background": "rgba(255, 236, 164, 0.06)", - "border": "rgba(255, 180, 76, 0.85)", -}) -call-function: ("check-style", { - "theme": "dark", - "background": "rgb(73, 74, 61)", - "border": "rgb(187, 116, 16)", -}) -call-function: ("check-style", { - "theme": "light", - "background": "rgb(253, 255, 211)", - "border": "rgb(173, 124, 55)", -}) diff --git a/src/test/rustdoc-gui/theme-change.goml b/src/test/rustdoc-gui/theme-change.goml deleted file mode 100644 index cc47f1f45..000000000 --- a/src/test/rustdoc-gui/theme-change.goml +++ /dev/null @@ -1,67 +0,0 @@ -// Ensures that the theme change is working as expected. -goto: "file://" + |DOC_PATH| + "/test_docs/index.html" -local-storage: {"rustdoc-use-system-theme": "false", "rustdoc-theme": "dark"} -reload: - -store-value: (background_light, "rgb(255, 255, 255)") -store-value: (background_dark, "rgb(53, 53, 53)") -store-value: (background_ayu, "rgb(15, 20, 25)") - -click: "#settings-menu" -wait-for: "#theme-ayu" -click: "#theme-ayu" -// should be the ayu theme so let's check the color. -wait-for-css: ("body", { "background-color": |background_ayu| }) -assert-local-storage: { "rustdoc-theme": "ayu" } -click: "#theme-light" -// should be the light theme so let's check the color. -wait-for-css: ("body", { "background-color": |background_light| }) -assert-local-storage: { "rustdoc-theme": "light" } -click: "#theme-dark" -// Should be the dark theme so let's check the color. -wait-for-css: ("body", { "background-color": |background_dark| }) -assert-local-storage: { "rustdoc-theme": "dark" } - -local-storage: { - "rustdoc-preferred-light-theme": "light", - "rustdoc-preferred-dark-theme": "light", -} -goto: "file://" + |DOC_PATH| + "/settings.html" - -wait-for: "#settings" -click: "#theme-light" -wait-for-css: ("body", { "background-color": |background_light| }) -assert-local-storage: { "rustdoc-theme": "light" } - -click: "#theme-dark" -wait-for-css: ("body", { "background-color": |background_dark| }) -assert-local-storage: { "rustdoc-theme": "dark" } - -click: "#theme-ayu" -wait-for-css: ("body", { "background-color": |background_ayu| }) -assert-local-storage: { "rustdoc-theme": "ayu" } - -assert-local-storage-false: { "rustdoc-use-system-theme": "true" } -click: "#theme-system-preference" -wait-for: ".setting-line:not(.hidden) #preferred-light-theme" -assert-local-storage: { "rustdoc-use-system-theme": "true" } -// We click on both preferred light and dark themes to be sure that there is a change. -click: "#preferred-light-theme-dark" -click: "#preferred-dark-theme-dark" -wait-for-css: ("body", { "background-color": |background_dark| }) - -reload: -// Ensure that the "preferred themes" are still displayed. -wait-for: ".setting-line:not(.hidden) #preferred-light-theme" -click: "#theme-light" -wait-for-css: ("body", { "background-color": |background_light| }) -assert-local-storage: { "rustdoc-theme": "light" } -// Ensure it's now hidden again -wait-for: ".setting-line.hidden #preferred-light-theme" -// And ensure the theme was rightly set. -wait-for-css: ("body", { "background-color": |background_light| }) -assert-local-storage: { "rustdoc-theme": "light" } - -reload: -wait-for: "#settings" -assert: ".setting-line.hidden #preferred-light-theme" diff --git a/src/test/rustdoc-gui/theme-in-history.goml b/src/test/rustdoc-gui/theme-in-history.goml deleted file mode 100644 index 10508e86a..000000000 --- a/src/test/rustdoc-gui/theme-in-history.goml +++ /dev/null @@ -1,27 +0,0 @@ -// Ensures that the theme is working when going back in history. -goto: "file://" + |DOC_PATH| + "/test_docs/index.html" -// Set the theme to dark. -local-storage: { - "rustdoc-theme": "dark", - "rustdoc-use-system-theme": "false", -} -// We reload the page so the local storage settings are being used. -reload: -assert-css: ("body", { "background-color": "rgb(53, 53, 53)" }) -assert-local-storage: { "rustdoc-theme": "dark" } - -// Now we go to the settings page. -goto: "file://" + |DOC_PATH| + "/settings.html" -wait-for: "#settings" -// We change the theme to "light". -click: "#theme-light" -wait-for-css: ("body", { "background-color": "rgb(255, 255, 255)" }) -assert-local-storage: { "rustdoc-theme": "light" } - -// We go back in history. -history-go-back: -// Confirm that we're not on the settings page. -assert-false: "#settings" -// Check that the current theme is still "light". -assert-css: ("body", { "background-color": "rgb(255, 255, 255)" }) -assert-local-storage: { "rustdoc-theme": "light" } diff --git a/src/test/rustdoc-gui/toggle-click-deadspace.goml b/src/test/rustdoc-gui/toggle-click-deadspace.goml deleted file mode 100644 index 029403ee1..000000000 --- a/src/test/rustdoc-gui/toggle-click-deadspace.goml +++ /dev/null @@ -1,15 +0,0 @@ -// This test ensures that clicking on a method summary, but not on the "[-]", -// doesn't toggle the <details>. -goto: "file://" + |DOC_PATH| + "/lib2/struct.Foo.html" -assert-attribute: (".impl-items .rustdoc-toggle", {"open": ""}) -click: "h4.code-header" // This is the position of "pub" in "pub fn a_method" -assert-attribute: (".impl-items .rustdoc-toggle", {"open": ""}) -click-with-offset: ( - ".impl-items .rustdoc-toggle summary", - {"x": -24, "y": 8}, // This is the position of "[-]" next to that pub fn. -) -assert-attribute-false: (".impl-items .rustdoc-toggle", {"open": ""}) - -// Click the "Trait" part of "impl Trait" and verify it navigates. -click: "#impl-Trait-for-Foo h3 a:first-of-type" -assert-text: (".fqn", "Trait lib2::Trait") diff --git a/src/test/rustdoc-gui/toggle-docs-mobile.goml b/src/test/rustdoc-gui/toggle-docs-mobile.goml deleted file mode 100644 index 6ce24a81b..000000000 --- a/src/test/rustdoc-gui/toggle-docs-mobile.goml +++ /dev/null @@ -1,33 +0,0 @@ -// Checks that the documentation toggles on mobile have the correct position, style and work -// as expected. -goto: "file://" + |DOC_PATH| + "/test_docs/struct.Foo.html" -size: (433, 600) -assert-attribute: (".top-doc", {"open": ""}) -click: (4, 270) // This is the position of the top doc comment toggle -assert-attribute-false: (".top-doc", {"open": ""}) -click: (4, 270) -assert-attribute: (".top-doc", {"open": ""}) -// To ensure that the toggle isn't over the text, we check that the toggle isn't clicked. -click: (3, 270) -assert-attribute: (".top-doc", {"open": ""}) - -// Assert the position of the toggle on the top doc block. -assert-position: (".top-doc summary::before", {"x": 4}) -// Assert the position of the toggle on the impl block. -assert-position: ("#implementations-list > details > summary::before", {"x": 4}) -// Assert the position of the toggle on a method. -assert-position: ( - "#trait-implementations-list .impl-items .method-toggle > summary::before", - {"x": 4}, -) - -// Now we do the same but with a little bigger width -size: (600, 600) -assert-attribute: (".top-doc", {"open": ""}) -click: (4, 270) // New Y position since all search elements are back on one line. -assert-attribute-false: (".top-doc", {"open": ""}) -click: (4, 270) -assert-attribute: (".top-doc", {"open": ""}) -// To ensure that the toggle isn't over the text, we check that the toggle isn't clicked. -click: (3, 270) -assert-attribute: (".top-doc", {"open": ""}) diff --git a/src/test/rustdoc-gui/toggle-docs.goml b/src/test/rustdoc-gui/toggle-docs.goml deleted file mode 100644 index 45bb8daf1..000000000 --- a/src/test/rustdoc-gui/toggle-docs.goml +++ /dev/null @@ -1,75 +0,0 @@ -// Checks that the documentation toggles have the correct position, style and work as expected. -goto: "file://" + |DOC_PATH| + "/test_docs/index.html" -assert-attribute: ("#main-content > details.top-doc", {"open": ""}) -assert-text: ("#toggle-all-docs", "[−]") -click: "#toggle-all-docs" -wait-for: 50 -// This is now collapsed so there shouldn't be the "open" attribute on details. -assert-attribute-false: ("#main-content > details.top-doc", {"open": ""}) -assert-text: ("#toggle-all-docs", "[+]") -assert-css: ( - "#main-content > details.top-doc > summary", - {"font-family": '"Fira Sans", Arial, NanumBarunGothic, sans-serif'}, -) -click: "#toggle-all-docs" -// Not collapsed anymore so the "open" attribute should be back. -wait-for-attribute: ("#main-content > details.top-doc", {"open": ""}) -assert-text: ("#toggle-all-docs", "[−]") - -// Check that it works on non-module pages as well. -goto: "file://" + |DOC_PATH| + "/test_docs/struct.Foo.html" -// We first check that everything is visible. -assert-text: ("#toggle-all-docs", "[−]") -assert-attribute: ("#implementations-list details.rustdoc-toggle", {"open": ""}, ALL) -assert-attribute: ("#trait-implementations-list details.rustdoc-toggle", {"open": ""}, ALL) -assert-attribute-false: ( - "#blanket-implementations-list > details.rustdoc-toggle", - {"open": ""}, - ALL, -) - -// We collapse them all. -click: "#toggle-all-docs" -wait-for-text: ("#toggle-all-docs", "[+]") -// We check that all <details> are collapsed (except for the impl block ones). -assert-attribute-false: ("details.rustdoc-toggle:not(.implementors-toggle)", {"open": ""}, ALL) -assert-attribute: ("#implementations-list > details.implementors-toggle", {"open": ""}) -// We now check that the other impl blocks are collapsed. -assert-attribute-false: ( - "#blanket-implementations-list > details.rustdoc-toggle.implementors-toggle", - {"open": ""}, - ALL, -) -// We open them all again. -click: "#toggle-all-docs" -wait-for-text: ("#toggle-all-docs", "[−]") -assert-attribute: ("details.rustdoc-toggle", {"open": ""}, ALL) - -// Checking the toggles style. -show-text: true -define-function: ( - "check-color", - (theme, filter), - [ - // Setting the theme. - ("local-storage", {"rustdoc-theme": |theme|, "rustdoc-use-system-theme": "false"}), - // We reload the page so the local storage settings are being used. - ("reload"), - - ("assert-css", ("details.rustdoc-toggle > summary::before", { - "opacity": "0.5", - "filter": |filter|, - }, ALL)), - ("move-cursor-to", "details.rustdoc-toggle summary"), - ("assert-css", ("details.rustdoc-toggle > summary:hover::before", { - "opacity": "1", - "filter": |filter|, - })), - // moving the cursor somewhere else to not mess with next function calls. - ("move-cursor-to", ".search-input"), - ] -) - -call-function: ("check-color", {"theme": "ayu", "filter": "invert(1)"}) -call-function: ("check-color", {"theme": "dark", "filter": "invert(1)"}) -call-function: ("check-color", {"theme": "light", "filter": "none"}) diff --git a/src/test/rustdoc-gui/toggle-implementors.goml b/src/test/rustdoc-gui/toggle-implementors.goml deleted file mode 100644 index 8ff5b91af..000000000 --- a/src/test/rustdoc-gui/toggle-implementors.goml +++ /dev/null @@ -1,4 +0,0 @@ -// This test ensures that the implementors toggle are not open by default. -goto: "file://" + |DOC_PATH| + "/implementors/trait.Whatever.html" - -assert-attribute-false: ("#implementors-list > details", {"open": ""}, ALL) diff --git a/src/test/rustdoc-gui/toggled-open-implementations.goml b/src/test/rustdoc-gui/toggled-open-implementations.goml deleted file mode 100644 index e4d59b5d7..000000000 --- a/src/test/rustdoc-gui/toggled-open-implementations.goml +++ /dev/null @@ -1,5 +0,0 @@ -// This tests that the "implementations" section on struct/enum pages -// has all the implementations toggled open by default, so users can -// find method names in those implementations with Ctrl-F. -goto: "file://" + |DOC_PATH| + "/test_docs/struct.Foo.html" -assert-attribute: (".rustdoc-toggle.implementors-toggle", {"open": ""}) diff --git a/src/test/rustdoc-gui/trait-sidebar-item-order.goml b/src/test/rustdoc-gui/trait-sidebar-item-order.goml deleted file mode 100644 index e5d023544..000000000 --- a/src/test/rustdoc-gui/trait-sidebar-item-order.goml +++ /dev/null @@ -1,13 +0,0 @@ -// Checks that the elements in the sidebar are alphabetically sorted. - -// We need to disable this check because `implementors/test_docs/trait.AnotherOne.js` -// doesn't exist. -fail-on-request-error: false - -goto: "file://" + |DOC_PATH| + "/test_docs/trait.AnotherOne.html" -assert-text: (".sidebar-elems section .block li:nth-of-type(1) > a", "another") -assert-text: (".sidebar-elems section .block li:nth-of-type(2) > a", "func1") -assert-text: (".sidebar-elems section .block li:nth-of-type(3) > a", "func2") -assert-text: (".sidebar-elems section .block li:nth-of-type(4) > a", "func3") -assert-text: (".sidebar-elems section .block li:nth-of-type(5) > a", "hello") -assert-text: (".sidebar-elems section .block li:nth-of-type(6) > a", "why_not") diff --git a/src/test/rustdoc-gui/type-declation-overflow.goml b/src/test/rustdoc-gui/type-declation-overflow.goml deleted file mode 100644 index c014eb52e..000000000 --- a/src/test/rustdoc-gui/type-declation-overflow.goml +++ /dev/null @@ -1,60 +0,0 @@ -// This test ensures that the items declaration content overflow is handled inside the <pre> directly. - -// We need to disable this check because -// `implementors/test_docs/trait.ALongNameBecauseItHelpsTestingTheCurrentProblem.js` -// doesn't exist. -fail-on-request-error: false - -goto: "file://" + |DOC_PATH| + "/lib2/long_trait/trait.ALongNameBecauseItHelpsTestingTheCurrentProblem.html" -// We set a fixed size so there is no chance of "random" resize. -size: (1100, 800) -// Logically, the <body> scroll width should be the width of the window. -assert-property: ("body", {"scrollWidth": "1100"}) -// However, since there is overflow in the type declaration, its scroll width is bigger. -assert-property: (".item-decl pre", {"scrollWidth": "1324"}) - -// In the table-ish view on the module index, the name should not be wrapped more than necessary. -goto: "file://" + |DOC_PATH| + "/lib2/too_long/index.html" -assert-property: (".item-table .struct", {"offsetWidth": "684"}) - -// We now make the same check on type declaration... -goto: "file://" + |DOC_PATH| + "/lib2/too_long/type.ReallyLongTypeNameLongLongLong.html" -assert-property: ("body", {"scrollWidth": "1100"}) -// We now check that the section width hasn't grown because of it. -assert-property: ("#main-content", {"scrollWidth": "840"}) -// And now checking that it has scrollable content. -assert-property: (".item-decl pre", {"scrollWidth": "1103"}) - -// ... and constant. -// On a sidenote, it also checks that the (very) long title isn't changing the docblock width. -goto: "file://" + |DOC_PATH| + "/lib2/too_long/constant.ReallyLongTypeNameLongLongLongConstBecauseWhyNotAConstRightGigaGigaSupraLong.html" -assert-property: ("body", {"scrollWidth": "1100"}) -// We now check that the section width hasn't grown because of it. -assert-property: ("#main-content", {"scrollWidth": "840"}) -// And now checking that it has scrollable content. -assert-property: (".item-decl pre", {"scrollWidth": "950"}) - -// On mobile: -size: (600, 600) -goto: "file://" + |DOC_PATH| + "/lib2/too_long/struct.SuperIncrediblyLongLongLongLongLongLongLongGigaGigaGigaMegaLongLongLongStructName.html" -// It shouldn't have an overflow in the topbar either. -store-property: (scrollWidth, ".mobile-topbar h2", "scrollWidth") -assert-property: (".mobile-topbar h2", {"clientWidth": |scrollWidth|}) -assert-css: (".mobile-topbar h2", {"overflow-x": "hidden"}) - -// Check wrapping for top main-heading h1 and out-of-band. -// On desktop, they wrap when too big. -size: (1100, 800) -goto: "file://" + |DOC_PATH| + "/lib2/too_long/struct.SuperIncrediblyLongLongLongLongLongLongLongGigaGigaGigaMegaLongLongLongStructName.html" -compare-elements-position-false: (".main-heading h1", ".main-heading .out-of-band", ("y")) -goto: "file://" + |DOC_PATH| + "/lib2/index.html" -compare-elements-position: (".main-heading h1", ".main-heading .out-of-band", ("y")) -// make sure there is a gap between them -compare-elements-position-near-false: (".main-heading h1", ".main-heading .out-of-band", {"x": 550}) - -// On mobile, they always wrap. -size: (600, 600) -goto: "file://" + |DOC_PATH| + "/lib2/too_long/struct.SuperIncrediblyLongLongLongLongLongLongLongGigaGigaGigaMegaLongLongLongStructName.html" -compare-elements-position-false: (".main-heading h1", ".main-heading .out-of-band", ("y")) -goto: "file://" + |DOC_PATH| + "/lib2/index.html" -compare-elements-position-false: (".main-heading h1", ".main-heading .out-of-band", ("y")) diff --git a/src/test/rustdoc-gui/unsafe-fn.goml b/src/test/rustdoc-gui/unsafe-fn.goml deleted file mode 100644 index 5e43b85fc..000000000 --- a/src/test/rustdoc-gui/unsafe-fn.goml +++ /dev/null @@ -1,28 +0,0 @@ -// Check position and color of the `<sup>` for unsafe elements. -goto: "file://" + |DOC_PATH| + "/test_docs/index.html" -// If the text isn't displayed, the browser doesn't compute color style correctly... -show-text: true - -compare-elements-property: ( - "//a[@title='test_docs::safe_fn fn']/..", - "//a[@title='test_docs::unsafe_fn fn']/..", - ["clientHeight"] -) - -define-function: ( - "sup-check", - // `theme` is the theme being tested. - // `color` is the expected color of the `<sup>` element. - (theme, color), - [ - // Set the theme. - ("local-storage", {"rustdoc-theme": |theme|, "rustdoc-use-system-theme": "false"}), - // We reload the page so the local storage settings are being used. - ("reload"), - ("assert-css", (".item-left sup", {"color": |color|})), - ], -) - -call-function: ("sup-check", ("dark", "rgb(221, 221, 221)")) -call-function: ("sup-check", ("ayu", "rgb(197, 197, 197)")) -call-function: ("sup-check", ("light", "rgb(0, 0, 0)")) diff --git a/src/test/rustdoc-gui/where-whitespace.goml b/src/test/rustdoc-gui/where-whitespace.goml deleted file mode 100644 index 41596a9bc..000000000 --- a/src/test/rustdoc-gui/where-whitespace.goml +++ /dev/null @@ -1,27 +0,0 @@ -// This test ensures that the where conditions are correctly displayed. -goto: "file://" + |DOC_PATH| + "/lib2/trait.Whitespace.html" -show-text: true -// First, we check in the trait definition if the where clause is "on its own" (not on the same -// line than "pub trait Whitespace<Idx>"). -compare-elements-position-false: (".item-decl code", ".where.fmt-newline", ("y")) -// And that the code following it isn't on the same line either. -compare-elements-position-false: (".item-decl .fn", ".where.fmt-newline", ("y")) - -goto: "file://" + |DOC_PATH| + "/lib2/struct.WhereWhitespace.html" -// We make the screen a bit wider to ensure that the trait impl is on one line. -size: (915, 915) - -compare-elements-position-false: ("#method\.new .fn", "#method\.new .where.fmt-newline", ("y")) -// We ensure that both the trait name and the struct name are on the same line in -// "impl<K, T> Whitespace<&K> for WhereWhitespace<T>". -compare-elements-position: ( - "#trait-implementations-list .impl h3 .trait", - "#trait-implementations-list .impl h3 .struct", - ("y"), -) -// And we now check that the where condition isn't on the same line. -compare-elements-position-false: ( - "#trait-implementations-list .impl h3 .trait", - "#trait-implementations-list .impl h3 .where.fmt-newline", - ("y"), -) |