summaryrefslogtreecommitdiffstats
path: root/tests/rustdoc/issue-110422-inner-private.rs
diff options
context:
space:
mode:
authorDaniel Baumann <daniel.baumann@progress-linux.org>2024-05-18 02:49:42 +0000
committerDaniel Baumann <daniel.baumann@progress-linux.org>2024-05-18 02:49:42 +0000
commit837b550238aa671a591ccf282dddeab29cadb206 (patch)
tree914b6b8862bace72bd3245ca184d374b08d8a672 /tests/rustdoc/issue-110422-inner-private.rs
parentAdding debian version 1.70.0+dfsg2-1. (diff)
downloadrustc-837b550238aa671a591ccf282dddeab29cadb206.tar.xz
rustc-837b550238aa671a591ccf282dddeab29cadb206.zip
Merging upstream version 1.71.1+dfsg1.
Signed-off-by: Daniel Baumann <daniel.baumann@progress-linux.org>
Diffstat (limited to 'tests/rustdoc/issue-110422-inner-private.rs')
-rw-r--r--tests/rustdoc/issue-110422-inner-private.rs64
1 files changed, 64 insertions, 0 deletions
diff --git a/tests/rustdoc/issue-110422-inner-private.rs b/tests/rustdoc/issue-110422-inner-private.rs
new file mode 100644
index 000000000..ee8ed5cc6
--- /dev/null
+++ b/tests/rustdoc/issue-110422-inner-private.rs
@@ -0,0 +1,64 @@
+// Regression test for <https://github.com/rust-lang/rust/issues/110422>.
+// This test ensures that inner items (except for implementations and macros)
+// don't appear in documentation.
+
+// compile-flags: --document-private-items
+
+#![crate_name = "foo"]
+
+// @has 'foo/index.html'
+// Checking there is no "trait" entry.
+// @count - '//*[@id="main-content"]/*[@class="small-section-header"]' 4
+// @has - '//*[@id="main-content"]/*[@class="small-section-header"]' 'Structs'
+// @has - '//*[@id="main-content"]/*[@class="small-section-header"]' 'Constants'
+// @has - '//*[@id="main-content"]/*[@class="small-section-header"]' 'Functions'
+// @has - '//*[@id="main-content"]/*[@class="small-section-header"]' 'Macros'
+
+// @has - '//a[@href="fn.foo.html"]' 'foo'
+fn foo() {
+ fn bar() {}
+
+ // @has - '//a[@class="macro"]' 'visible_macro'
+ // @!has - '//a[@class="macro"]' 'non_visible_macro'
+ // @has 'foo/macro.visible_macro.html'
+ // @!has 'foo/macro.non_visible_macro.html'
+ #[macro_export]
+ macro_rules! visible_macro {
+ () => {}
+ }
+
+ macro_rules! non_visible_macro {
+ () => {}
+ }
+}
+
+// @has 'foo/index.html'
+// @has - '//a[@href="struct.Bar.html"]' 'Bar'
+struct Bar;
+
+const BAR: i32 = {
+ // @!has - '//a[@href="fn.yo.html"]' 'yo'
+ // @!has 'foo/fn.yo.html'
+ fn yo() {}
+
+ // @!has 'foo/index.html' '//a[@href="trait.Foo.html"]' 'Foo'
+ // @!has 'foo/trait.Foo.html'
+ trait Foo {
+ fn babar() {}
+ }
+ impl Foo for Bar {}
+
+ // @has 'foo/struct.Bar.html'
+ // @has - '//*[@id="method.foo"]/*[@class="code-header"]' 'pub(crate) fn foo()'
+ // @count - '//*[@id="main-content"]/*[@class="small-section-header"]' 3
+ // We now check that the `Foo` trait is not documented nor visible on `Bar` page.
+ // @has - '//*[@id="main-content"]/*[@class="small-section-header"]' 'Implementations'
+ // @has - '//*[@id="main-content"]/*[@class="small-section-header"]' 'Auto Trait Implementations'
+ // @has - '//*[@id="main-content"]/*[@class="small-section-header"]' 'Blanket Implementations'
+ // @!has - '//*[@href="trait.Foo.html#method.babar"]/*[@class="code-header"]' 'fn babar()'
+ impl Bar {
+ fn foo() {}
+ }
+
+ 1
+};