diff options
| author | mo8it <mo8it@proton.me> | 2024-06-26 14:35:05 +0200 |
|---|---|---|
| committer | mo8it <mo8it@proton.me> | 2024-06-26 14:35:05 +0200 |
| commit | a91888e79e69e04e57c2049cdf940a70201e1d6e (patch) | |
| tree | f757f0790d5176b9a5f96b5c38c0f0636a2efca1 /solutions | |
| parent | c31e15c4cf5085adcf544a33ac256364fc2bcfbf (diff) | |
option2 solution
Diffstat (limited to 'solutions')
| -rw-r--r-- | solutions/12_options/options2.rs | 38 |
1 files changed, 37 insertions, 1 deletions
diff --git a/solutions/12_options/options2.rs b/solutions/12_options/options2.rs index 4e18198..0f24665 100644 --- a/solutions/12_options/options2.rs +++ b/solutions/12_options/options2.rs @@ -1 +1,37 @@ -// Solutions will be available before the stable release. Thank you for testing the beta version 🥰 +fn main() { + // You can optionally experiment here. +} + +#[cfg(test)] +mod tests { + #[test] + fn simple_option() { + let target = "rustlings"; + let optional_target = Some(target); + + // if-let + if let Some(word) = optional_target { + assert_eq!(word, target); + } + } + + #[test] + fn layered_option() { + let range = 10; + let mut optional_integers: Vec<Option<i8>> = vec![None]; + + for i in 1..=range { + optional_integers.push(Some(i)); + } + + let mut cursor = range; + + // while-let with nested pattern matching + while let Some(Some(integer)) = optional_integers.pop() { + assert_eq!(integer, cursor); + cursor -= 1; + } + + assert_eq!(cursor, 0); + } +} |
