mod simulation;
use simulation::factory::FactoryType;
works fine in main.rs
, but not in a doctest inside simulation/factory.rs
:
impl product_type::ProductType for FactoryType {
/// Lorem Ipsum
///
/// # Examples
///
/// ```
/// use simulation::factory::FactoryType;
///
/// ...
/// ```
fn human_id(&self) -> &String {
...
}
}
cargo test
gives me the error
---- simulation::factory::human_id_0 stdout ----
<anon>:2:9: 2:19 error: unresolved import `simulation::factory::FactoryType`. Maybe a missing `extern crate simulation`?
<anon>:2 use simulation::factory::FactoryType;
^~~~~~~~~~
error: aborting due to previous error
thread 'simulation::factory::human_id_0' panicked at 'Box<Any>', /home/rustbuild/src/rust-buildbot/slave/stable-dist-rustc-linux/build/src/libsyntax/diagnostic.rs:192
How can I get doctests to work?
When you write a doc test, you have to act as the user of your code would. Given these files:
src/lib.rs
pub mod simulation {
pub mod factory {
pub struct FactoryType;
impl FactoryType {
/// ```
/// use foo::simulation::factory::FactoryType;
///
/// let f = FactoryType;
/// assert_eq!(42, f.human_id())
/// ```
pub fn human_id(&self) -> u8 { 41 }
}
}
}
src/main.rs
use foo::simulation::factory::FactoryType;
fn main() {
let f = FactoryType;
println!("{}", f.human_id());
}
Everything works.