Skip to content

Commit

Permalink
doc: fix rustdoc for docs.rs with features, add CI
Browse files Browse the repository at this point in the history
Signed-off-by: MrCroxx <[email protected]>
  • Loading branch information
MrCroxx committed Dec 3, 2024
1 parent 8e329ab commit 2eb507c
Show file tree
Hide file tree
Showing 11 changed files with 71 additions and 22 deletions.
46 changes: 46 additions & 0 deletions .github/workflows/ci.yml
Original file line number Diff line number Diff line change
Expand Up @@ -216,6 +216,52 @@ jobs:
CODECOV_TOKEN: ${{ secrets.CODECOV_TOKEN }}
with:
verbose: true
rustdoc-test:
name: rust doc test
strategy:
fail-fast: false
matrix:
os: [ubuntu-latest, macos-latest, windows-latest]
runs-on: ${{ matrix.os }}
steps:
- name: Checkout
uses: actions/checkout@v4
- name: Install rust toolchain
uses: dtolnay/rust-toolchain@master
with:
toolchain: nightly
- name: Cache Cargo home
uses: actions/cache@v4
id: cache
with:
path: |
~/.cargo/bin/
~/.cargo/registry/index/
~/.cargo/registry/cache/
~/.cargo/git/db/
key: ${{ runner.os }}-cargo-${{ hashFiles('**/Cargo.toml') }}-${{ env.CACHE_KEY_SUFFIX }}-rustdoc-test
- name: Install NASM for aws-lc-rs on Windows
if: runner.os == 'Windows'
uses: ilammy/setup-nasm@v1
- name: Install ninja-build tool for aws-lc-fips-sys on Windows
if: runner.os == 'Windows'
uses: seanmiddleditch/gha-setup-ninja@v5
- name: Run rustdoc test
run: |
cargo test --features "nightly,prometheus,prometheus-client,prometheus-client_0_22,opentelemetry,opentelemetry_0_26,opentelemetry_0_27" --doc
- name: Test docs build with docs.rs
env:
RUSTDOCFLAGS: --cfg docsrs -D warnings
run: |
cargo doc --features "nightly,prometheus,prometheus-client,prometheus-client_0_22,opentelemetry,opentelemetry_0_26,opentelemetry_0_27"
- name: Upload docs.rs docs as artifacts
uses: actions/upload-artifact@v4
with:
name: docs
path: target/doc
if-no-files-found: error
retention-days: 7

deadlock:
name: run with single worker thread and deadlock detection
runs-on: ubuntu-latest
Expand Down
3 changes: 0 additions & 3 deletions foyer-bench/Cargo.toml
Original file line number Diff line number Diff line change
Expand Up @@ -12,9 +12,6 @@ license = { workspace = true }
readme = { workspace = true }
# See more keys and their definitions at https://doc.rust-lang.org/cargo/reference/manifest.html

[package.metadata.docs.rs]
all-features = true

[dependencies]
anyhow = "1"
bytesize = { workspace = true }
Expand Down
4 changes: 0 additions & 4 deletions foyer-cli/Cargo.toml
Original file line number Diff line number Diff line change
Expand Up @@ -21,9 +21,5 @@ thiserror = { workspace = true }

[dev-dependencies]

[[bin]]
name = "foyer"
path = "src/main.rs"

[lints]
workspace = true
3 changes: 0 additions & 3 deletions foyer-common/Cargo.toml
Original file line number Diff line number Diff line change
Expand Up @@ -12,9 +12,6 @@ license = { workspace = true }
readme = { workspace = true }
# See more keys and their definitions at https://doc.rust-lang.org/cargo/reference/manifest.html

[package.metadata.docs.rs]
all-features = true

[dependencies]
ahash = { workspace = true }
bytes = "1"
Expand Down
3 changes: 0 additions & 3 deletions foyer-memory/Cargo.toml
Original file line number Diff line number Diff line change
Expand Up @@ -12,9 +12,6 @@ license = { workspace = true }
readme = { workspace = true }
# See more keys and their definitions at https://doc.rust-lang.org/cargo/reference/manifest.html

[package.metadata.docs.rs]
all-features = true

[dependencies]
ahash = { workspace = true }
bitflags = "2"
Expand Down
2 changes: 1 addition & 1 deletion foyer-memory/src/eviction/lru.rs
Original file line number Diff line number Diff line change
Expand Up @@ -32,7 +32,7 @@ use crate::{
pub struct LruConfig {
/// The ratio of the high priority pool occupied.
///
/// [`Lru`] guarantees that the high priority weight are always as larger as
/// `Lru` guarantees that the high priority weight are always as larger as
/// but no larger that the capacity * high priority pool ratio.
///
/// # Panic
Expand Down
4 changes: 0 additions & 4 deletions foyer-memory/src/eviction/mod.rs
Original file line number Diff line number Diff line change
Expand Up @@ -81,10 +81,6 @@ where
///
/// [`Eviction`] is needs to be implemented to support a new cache eviction algorithm.
///
/// For performance considerations, most APIs pass parameters via [`NonNull`] pointers to implement intrusive data
/// structures. It is not required to implement the cache eviction algorithm using the [`NonNull`] pointers. They can
/// also be used as a token for the target entry.
///
/// # Safety
///
/// The pointer can be dereferenced as a mutable reference ***iff*** the `self` reference is also mutable.
Expand Down
3 changes: 0 additions & 3 deletions foyer-storage/Cargo.toml
Original file line number Diff line number Diff line change
Expand Up @@ -12,9 +12,6 @@ license = { workspace = true }
readme = { workspace = true }
# See more keys and their definitions at https://doc.rust-lang.org/cargo/reference/manifest.html

[package.metadata.docs.rs]
all-features = true

[dependencies]
ahash = { workspace = true }
# TODO(MrCroxx): Remove this after `allocator_api` is stable.
Expand Down
12 changes: 11 additions & 1 deletion foyer/Cargo.toml
Original file line number Diff line number Diff line change
Expand Up @@ -13,7 +13,17 @@ readme = { workspace = true }
# See more keys and their definitions at https://doc.rust-lang.org/cargo/reference/manifest.html

[package.metadata.docs.rs]
all-features = true
features = [
"nightly",
# build docs for exporters
"prometheus",
"prometheus-client",
"prometheus-client_0_22",
"opentelemetry",
"opentelemetry_0_26",
"opentelemetry_0_27",
]
rustdoc-args = ["--cfg", "docsrs"]

[dependencies]
ahash = { workspace = true }
Expand Down
1 change: 1 addition & 0 deletions foyer/src/lib.rs
Original file line number Diff line number Diff line change
Expand Up @@ -13,6 +13,7 @@
// limitations under the License.

#![cfg_attr(feature = "nightly", feature(allocator_api))]
#![cfg_attr(docsrs, feature(doc_cfg))]

//! A hybrid cache library that supports plug-and-play cache algorithms, in-memory cache and disk cache.
//!
Expand Down
12 changes: 12 additions & 0 deletions foyer/src/prelude.rs
Original file line number Diff line number Diff line change
Expand Up @@ -13,17 +13,29 @@
// limitations under the License.

#[cfg(feature = "opentelemetry")]
#[cfg_attr(docsrs, doc(cfg(feature = "opentelemetry")))]
pub use crate::common::metrics::registry::opentelemetry;

#[cfg(feature = "opentelemetry_0_26")]
#[cfg_attr(docsrs, doc(cfg(feature = "opentelemetry_0_26")))]
pub use crate::common::metrics::registry::opentelemetry_0_26;

#[cfg(feature = "opentelemetry_0_27")]
#[cfg_attr(docsrs, doc(cfg(feature = "opentelemetry_0_27")))]
pub use crate::common::metrics::registry::opentelemetry_0_27;

#[cfg(feature = "prometheus")]
#[cfg_attr(docsrs, doc(cfg(feature = "prometheus")))]
pub use crate::common::metrics::registry::prometheus;

#[cfg(feature = "prometheus-client")]
#[cfg_attr(docsrs, doc(cfg(feature = "prometheus-client")))]
pub use crate::common::metrics::registry::prometheus_client;

#[cfg(feature = "prometheus-client_0_22")]
#[cfg_attr(docsrs, doc(cfg(feature = "prometheus-client_0_22")))]
pub use crate::common::metrics::registry::prometheus_client_0_22;

pub use crate::{
common::{
buf::{BufExt, BufMutExt},
Expand Down

0 comments on commit 2eb507c

Please sign in to comment.