summaryrefslogtreecommitdiff
path: root/exercises/17_tests/tests3.rs
diff options
context:
space:
mode:
authormo8it <mo8it@proton.me>2024-06-27 17:29:33 +0200
committermo8it <mo8it@proton.me>2024-06-27 17:29:33 +0200
commit746cf6863dee8f676596b07e74bad1a19fa2579e (patch)
tree87390c289ebde7ff3298efa1da359b4d379db7c1 /exercises/17_tests/tests3.rs
parent803e32dad2395d309b74b9fde6b9e08577cf8a0a (diff)
Remove tests3 and add solution to tests4
Diffstat (limited to 'exercises/17_tests/tests3.rs')
-rw-r--r--exercises/17_tests/tests3.rs41
1 files changed, 32 insertions, 9 deletions
diff --git a/exercises/17_tests/tests3.rs b/exercises/17_tests/tests3.rs
index d1cb489..9fc9318 100644
--- a/exercises/17_tests/tests3.rs
+++ b/exercises/17_tests/tests3.rs
@@ -1,9 +1,19 @@
-// This test isn't testing our function -- make it do that in such a way that
-// the test passes. Then write a second test that tests whether we get the
-// result we expect to get when we call `is_even(5)`.
+struct Rectangle {
+ width: i32,
+ height: i32,
+}
+
+impl Rectangle {
+ // Don't change this function.
+ fn new(width: i32, height: i32) -> Self {
+ if width <= 0 || height <= 0 {
+ // Returning a `Result` would be better here. But we want to learn
+ // how to test functions that can panic.
+ panic!("Rectangle width and height can't be negative");
+ }
-fn is_even(num: i32) -> bool {
- num % 2 == 0
+ Rectangle { width, height }
+ }
}
fn main() {
@@ -15,12 +25,25 @@ mod tests {
use super::*;
#[test]
- fn is_true_when_even() {
- assert!();
+ fn correct_width_and_height() {
+ // TODO: This test should check if the rectangle has the size that we
+ // pass to its constructor.
+ let rect = Rectangle::new(10, 20);
+ assert_eq!(???, 10); // Check width
+ assert_eq!(???, 20); // Check height
+ }
+
+ // TODO: This test should check if the program panics when we try to create
+ // a rectangle with negative width.
+ #[test]
+ fn negative_width() {
+ let _rect = Rectangle::new(-10, 10);
}
+ // TODO: This test should check if the program panics when we try to create
+ // a rectangle with negative height.
#[test]
- fn is_false_when_odd() {
- assert!();
+ fn negative_height() {
+ let _rect = Rectangle::new(10, -10);
}
}