2024-06-26 09:06:29 -04:00
|
|
|
// TODO: This function refuses to generate text to be printed on a nametag if
|
|
|
|
// you pass it an empty string. It'd be nicer if it explained what the problem
|
|
|
|
// was instead of just returning `None`. Thankfully, Rust has a similar
|
|
|
|
// construct to `Option` that can be used to express error conditions. Change
|
|
|
|
// the function signature and body to return `Result<String, String>` instead
|
|
|
|
// of `Option<String>`.
|
2024-05-22 09:04:12 -04:00
|
|
|
fn generate_nametag_text(name: String) -> Option<String> {
|
2022-02-08 18:46:22 -05:00
|
|
|
if name.is_empty() {
|
2016-02-16 18:14:20 -05:00
|
|
|
// Empty names aren't allowed.
|
|
|
|
None
|
2022-02-08 18:46:22 -05:00
|
|
|
} else {
|
2024-06-26 09:06:29 -04:00
|
|
|
Some(format!("Hi! My name is {name}"))
|
2016-02-16 18:14:20 -05:00
|
|
|
}
|
|
|
|
}
|
|
|
|
|
2024-06-26 09:06:29 -04:00
|
|
|
fn main() {
|
|
|
|
// You can optionally experiment here.
|
|
|
|
}
|
|
|
|
|
2016-02-16 18:14:20 -05:00
|
|
|
#[cfg(test)]
|
|
|
|
mod tests {
|
|
|
|
use super::*;
|
|
|
|
|
|
|
|
#[test]
|
|
|
|
fn generates_nametag_text_for_a_nonempty_name() {
|
|
|
|
assert_eq!(
|
2024-06-26 09:06:29 -04:00
|
|
|
generate_nametag_text("Beyoncé".to_string()).as_deref(),
|
|
|
|
Ok("Hi! My name is Beyoncé"),
|
2016-02-16 18:14:20 -05:00
|
|
|
);
|
|
|
|
}
|
|
|
|
|
|
|
|
#[test]
|
|
|
|
fn explains_why_generating_nametag_text_fails() {
|
|
|
|
assert_eq!(
|
2024-06-26 09:06:29 -04:00
|
|
|
generate_nametag_text(String::new()).as_deref(),
|
2022-02-04 09:00:24 -05:00
|
|
|
// Don't change this line
|
2024-06-26 09:06:29 -04:00
|
|
|
Err("`name` was empty; it must be nonempty."),
|
2016-02-16 18:14:20 -05:00
|
|
|
);
|
|
|
|
}
|
|
|
|
}
|