2018-02-22 13:09:53 +07:00
|
|
|
// result1.rs
|
2015-09-19 07:27:25 +06:00
|
|
|
// Make this test pass! Scroll down for hints :)
|
|
|
|
|
2019-05-22 18:48:32 +07:00
|
|
|
#[derive(PartialEq, Debug)]
|
2015-09-19 07:27:25 +06:00
|
|
|
struct PositiveNonzeroInteger(u64);
|
|
|
|
|
2019-05-22 18:48:32 +07:00
|
|
|
#[derive(PartialEq, Debug)]
|
2015-09-19 07:27:25 +06:00
|
|
|
enum CreationError {
|
|
|
|
Negative,
|
|
|
|
Zero,
|
|
|
|
}
|
|
|
|
|
|
|
|
impl PositiveNonzeroInteger {
|
|
|
|
fn new(value: i64) -> Result<PositiveNonzeroInteger, CreationError> {
|
|
|
|
Ok(PositiveNonzeroInteger(value as u64))
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
#[test]
|
|
|
|
fn test_creation() {
|
|
|
|
assert!(PositiveNonzeroInteger::new(10).is_ok());
|
2019-05-22 18:48:32 +07:00
|
|
|
assert_eq!(
|
|
|
|
Err(CreationError::Negative),
|
|
|
|
PositiveNonzeroInteger::new(-10)
|
|
|
|
);
|
2015-09-19 07:27:25 +06:00
|
|
|
assert_eq!(Err(CreationError::Zero), PositiveNonzeroInteger::new(0));
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
// `PositiveNonzeroInteger::new` is always creating a new instance and returning an `Ok` result.
|
|
|
|
// It should be doing some checking, returning an `Err` result if those checks fail, and only
|
|
|
|
// returning an `Ok` result if those checks determine that everything is... okay :)
|