mirror of
https://github.com/rust-lang/rustlings.git
synced 2025-01-15 00:56:31 +00:00
b540c6df25
Some people would get stuck on this exercise, trying to understand the meaning behind foo, fuzz, baz etc. Making the theme of the code make a little more sense to humans should hopefully prevent people from getting confused by abstract and non-sensical tests.
37 lines
926 B
Rust
37 lines
926 B
Rust
// TODO: Fix the compiler error on this function.
|
|
fn picky_eater(food: &str) -> &str {
|
|
if food == "strawberry" {
|
|
"Yummy!"
|
|
} else {
|
|
1
|
|
}
|
|
}
|
|
|
|
fn main() {
|
|
// You can optionally experiment here.
|
|
}
|
|
|
|
// TODO: Read the tests to understand the desired behavior.
|
|
// Make all tests pass without changing them.
|
|
#[cfg(test)]
|
|
mod tests {
|
|
use super::*;
|
|
|
|
#[test]
|
|
fn yummy_food() {
|
|
// This means that calling `picky_eater` with the argument "food" should return "Yummy!".
|
|
assert_eq!(picky_eater("strawberry"), "Yummy!");
|
|
}
|
|
|
|
#[test]
|
|
fn neutral_food() {
|
|
assert_eq!(picky_eater("potato"), "I guess I can eat that.");
|
|
}
|
|
|
|
#[test]
|
|
fn default_disliked_food() {
|
|
assert_eq!(picky_eater("broccoli"), "No thanks!");
|
|
assert_eq!(picky_eater("gummy bears"), "No thanks!");
|
|
assert_eq!(picky_eater("literally anything"), "No thanks!");
|
|
}
|
|
}
|