mirror of
				https://github.com/rust-lang/rust.git
				synced 2025-10-30 20:44:34 +00:00 
			
		
		
		
	
		
			
				
	
	
		
			184 lines
		
	
	
		
			5.6 KiB
		
	
	
	
		
			Plaintext
		
	
	
	
	
	
			
		
		
	
	
			184 lines
		
	
	
		
			5.6 KiB
		
	
	
	
		
			Plaintext
		
	
	
	
	
	
| // Checks that the setting "line numbers" is working as expected.
 | |
| include: "utils.goml"
 | |
| go-to: "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"
 | |
| 
 | |
| // All corners should be rounded.
 | |
| assert-css: (
 | |
|     ".example-wrap .rust",
 | |
|     {
 | |
|         "border-top-left-radius": "6px",
 | |
|         "border-bottom-left-radius": "6px",
 | |
|         "border-top-right-radius": "6px",
 | |
|         "border-bottom-right-radius": "6px",
 | |
|     },
 | |
|     ALL,
 | |
| )
 | |
| 
 | |
| // We set the setting to show the line numbers on code examples.
 | |
| set-local-storage: {"rustdoc-line-numbers": "true"}
 | |
| reload:
 | |
| // We wait for the line numbers to be added into the DOM by the JS...
 | |
| wait-for: ".digits-1 pre"
 | |
| 
 | |
| // Otherwise, we can't check text color
 | |
| show-text: true
 | |
| 
 | |
| // Let's now check some CSS properties...
 | |
| define-function: (
 | |
|     "check-colors",
 | |
|     [theme, color],
 | |
|     block {
 | |
|         // Page will be reloaded in "switch-theme".
 | |
|         call-function: ("switch-theme", {"theme": |theme|})
 | |
|         // If the test didn't fail, it means that it was found!
 | |
|         assert-css: (
 | |
|             ".digits-1 pre [data-nosnippet]",
 | |
|             {
 | |
|                 "color": |color|,
 | |
|                 "margin-top": "0px",
 | |
|                 "margin-bottom": "0px",
 | |
|                 "margin-left": "0px",
 | |
|                 "margin-right": "20px",
 | |
|                 "padding-top": "0px",
 | |
|                 "padding-bottom": "0px",
 | |
|                 "padding-left": "4px",
 | |
|                 "padding-right": "4px",
 | |
|                 "text-align": "right",
 | |
|             },
 | |
|             ALL,
 | |
|         )
 | |
|     },
 | |
| )
 | |
| call-function: ("check-colors", {
 | |
|     "theme": "ayu",
 | |
|     "color": "#5c6773",
 | |
| })
 | |
| call-function: ("check-colors", {
 | |
|     "theme": "dark",
 | |
|     "color": "#3b91e2",
 | |
| })
 | |
| call-function: ("check-colors", {
 | |
|     "theme": "light",
 | |
|     "color": "#c67e2d",
 | |
| })
 | |
| 
 | |
| // 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: ".digits-1.hide-lines"
 | |
| assert-local-storage: {"rustdoc-line-numbers": "false" }
 | |
| 
 | |
| // Finally, turn it on again.
 | |
| click: "input#line-numbers"
 | |
| wait-for: ".digits-1:not(.hide-lines)"
 | |
| assert-local-storage: {"rustdoc-line-numbers": "true" }
 | |
| 
 | |
| // Same check with scraped examples line numbers.
 | |
| go-to: "file://" + |DOC_PATH| + "/scrape_examples/fn.test_many.html"
 | |
| 
 | |
| define-function: (
 | |
|     "check-padding",
 | |
|     [path, padding_bottom],
 | |
|     block {
 | |
|         assert-css: (|path| + " span[data-nosnippet]", {
 | |
|             "padding-top": "0px",
 | |
|             "padding-bottom": "0px",
 | |
|             "padding-left": "4px",
 | |
|             "padding-right": "4px",
 | |
|             "margin-right": "20px",
 | |
|             "margin-left": "0px",
 | |
|             "margin-top": "0px",
 | |
|             "margin-bottom": "0px",
 | |
|         }, ALL)
 | |
|     },
 | |
| )
 | |
| 
 | |
| call-function: ("check-padding", {
 | |
|     "path": ".scraped-example .example-wrap",
 | |
|     "padding_bottom": "0px",
 | |
| })
 | |
| 
 | |
| move-cursor-to: ".scraped-example .example-wrap .rust"
 | |
| wait-for: ".scraped-example .example-wrap .button-holder .expand"
 | |
| click: ".scraped-example .example-wrap .button-holder .expand"
 | |
| wait-for: ".scraped-example.expanded"
 | |
| 
 | |
| call-function: ("check-padding", {
 | |
|     "path": ".scraped-example.expanded .example-wrap",
 | |
|     "padding_bottom": "14px",
 | |
| })
 | |
| 
 | |
| define-function: ("check-line-numbers-existence", [], block {
 | |
|     assert-local-storage: {"rustdoc-line-numbers": "true" }
 | |
|     assert-false: ".example-line-numbers"
 | |
|     click: "#settings-menu"
 | |
|     wait-for: "#settings"
 | |
| 
 | |
|     // Then, click the toggle button.
 | |
|     click: "input#line-numbers"
 | |
|     wait-for-local-storage-false: {"rustdoc-line-numbers": "true" }
 | |
|     assert-false: ".example-line-numbers"
 | |
|     // Line numbers should still be there.
 | |
|     assert-css: ("[data-nosnippet]", { "display": "inline-block"})
 | |
|     // Now disabling the setting.
 | |
|     click: "input#line-numbers"
 | |
|     wait-for-local-storage: {"rustdoc-line-numbers": "true" }
 | |
|     assert-false: ".example-line-numbers"
 | |
|     // Line numbers should still be there.
 | |
|     assert-css: ("[data-nosnippet]", { "display": "inline-block"})
 | |
|     // Closing settings menu.
 | |
|     click: "#settings-menu"
 | |
|     wait-for-css: ("#settings", {"display": "none"})
 | |
| })
 | |
| 
 | |
| // Checking that turning off the line numbers setting won't remove line numbers from scraped
 | |
| // examples.
 | |
| call-function: ("check-line-numbers-existence", {})
 | |
| 
 | |
| // Now checking the line numbers in the source code page.
 | |
| click: ".src"
 | |
| assert-css: ("a[data-nosnippet]", {
 | |
|     "padding-top": "0px",
 | |
|     "padding-bottom": "0px",
 | |
|     "padding-left": "4px",
 | |
|     "padding-right": "4px",
 | |
|     "margin-top": "0px",
 | |
|     "margin-bottom": "0px",
 | |
|     "margin-left": "0px",
 | |
|     "margin-right": "20px",
 | |
| }, ALL)
 | |
| // Checking that turning off the line numbers setting won't remove line numbers.
 | |
| call-function: ("check-line-numbers-existence", {})
 | |
| 
 | |
| // Now checking that even non-rust code blocks have line numbers generated.
 | |
| go-to: "file://" + |DOC_PATH| + "/lib2/sub_mod/struct.Foo.html"
 | |
| assert-local-storage: {"rustdoc-line-numbers": "true" }
 | |
| assert: ".example-wrap > pre.language-txt"
 | |
| assert: ".example-wrap > pre.rust"
 | |
| assert-count: (".example-wrap", 2)
 | |
| assert-count: (".example-wrap.digits-1", 2)
 | |
| 
 | |
| click: "#settings-menu"
 | |
| wait-for: "#settings"
 | |
| 
 | |
| // Then, click the toggle button.
 | |
| click: "input#line-numbers"
 | |
| wait-for-count: (".example-wrap.digits-1.hide-lines", 2)
 | |
| assert-local-storage-false: {"rustdoc-line-numbers": "true" }
 | |
| 
 | |
| // Now turning off the setting.
 | |
| click: "input#line-numbers"
 | |
| wait-for-count: (".example-wrap.digits-1", 2)
 | |
| wait-for-count: (".example-wrap.digits-1.hide-lines", 0)
 | |
| assert-local-storage: {"rustdoc-line-numbers": "true" }
 | 
