2022-07-14 11:34:50 -04:00
|
|
|
// options1.rs
|
|
|
|
// Execute `rustlings hint options1` or use the `hint` watch subcommand for a hint.
|
2020-03-05 15:52:54 -05:00
|
|
|
|
2020-04-02 08:40:59 -04:00
|
|
|
// I AM NOT DONE
|
2020-03-05 15:52:54 -05:00
|
|
|
|
2022-07-14 11:53:27 -04:00
|
|
|
// This function returns how much icecream there is left in the fridge.
|
|
|
|
// If it's before 10PM, there's 5 pieces left. At 10PM, someone eats them
|
|
|
|
// all, so there'll be no more left :(
|
|
|
|
// TODO: Return an Option!
|
|
|
|
fn maybe_icecream(time_of_day: u16) -> Option<u16> {
|
2022-10-11 13:05:37 -04:00
|
|
|
// We use the 24-hour system here, so 10PM is a value of 22 and 12AM is a value of 0
|
|
|
|
// The Option output should gracefully handle cases where time_of_day > 23.
|
2022-07-14 11:53:27 -04:00
|
|
|
???
|
|
|
|
}
|
|
|
|
|
|
|
|
#[cfg(test)]
|
|
|
|
mod tests {
|
|
|
|
use super::*;
|
2020-03-05 15:52:54 -05:00
|
|
|
|
2022-07-14 11:53:27 -04:00
|
|
|
#[test]
|
|
|
|
fn check_icecream() {
|
2022-08-15 04:05:50 -04:00
|
|
|
assert_eq!(maybe_icecream(9), Some(5));
|
2022-08-17 00:51:17 -04:00
|
|
|
assert_eq!(maybe_icecream(10), Some(5));
|
2022-07-26 15:01:09 -04:00
|
|
|
assert_eq!(maybe_icecream(23), Some(0));
|
|
|
|
assert_eq!(maybe_icecream(22), Some(0));
|
|
|
|
assert_eq!(maybe_icecream(25), None);
|
2022-07-14 11:53:27 -04:00
|
|
|
}
|
2020-03-05 15:52:54 -05:00
|
|
|
|
2022-07-14 11:53:27 -04:00
|
|
|
#[test]
|
|
|
|
fn raw_value() {
|
|
|
|
// TODO: Fix this test. How do you get at the value contained in the Option?
|
|
|
|
let icecreams = maybe_icecream(12);
|
2022-08-17 00:51:17 -04:00
|
|
|
assert_eq!(icecreams, 5);
|
2020-03-05 15:52:54 -05:00
|
|
|
}
|
2020-03-11 13:44:10 -04:00
|
|
|
}
|