mirror of
https://github.com/notohh/rustlings.git
synced 2024-11-25 14:57:32 -05:00
created task
This commit is contained in:
parent
01fa21f160
commit
27b7579566
2 changed files with 50 additions and 0 deletions
40
exercises/tests/tests4.rs
Normal file
40
exercises/tests/tests4.rs
Normal file
|
@ -0,0 +1,40 @@
|
|||
// tests4.rs
|
||||
// Correct the tests to
|
||||
// Do not change Rectangle::new body
|
||||
// Execute `rustlings hint tests4` or use the `hint` watch subcommand for a hint.
|
||||
|
||||
// I AM NOT DONE
|
||||
|
||||
struct Rectangle {
|
||||
width: i32,
|
||||
height: i32
|
||||
}
|
||||
|
||||
impl Rectangle {
|
||||
pub fn new(width: i32, height: i32) -> Self {
|
||||
if width < 0 || height < 0 {
|
||||
panic!("Rectangle width and height cannot be negative!")
|
||||
}
|
||||
Rectangle {width, height}
|
||||
}
|
||||
}
|
||||
|
||||
#[cfg(test)]
|
||||
mod tests {
|
||||
use super::*;
|
||||
|
||||
#[test]
|
||||
fn correct_width_and_height() {
|
||||
let _rect = Rectangle::new(10, 10);
|
||||
}
|
||||
|
||||
#[test]
|
||||
fn negative_width() {
|
||||
let _rect = Rectangle::new(-10, 10);
|
||||
}
|
||||
|
||||
#[test]
|
||||
fn negative_height() {
|
||||
let _rect = Rectangle::new(10, -10);
|
||||
}
|
||||
}
|
10
info.toml
10
info.toml
|
@ -807,6 +807,16 @@ You can call a function right where you're passing arguments to `assert!` -- so
|
|||
something like `assert!(having_fun())`. If you want to check that you indeed get false, you
|
||||
can negate the result of what you're doing using `!`, like `assert!(!having_fun())`."""
|
||||
|
||||
[[exercises]]
|
||||
name = "tests4"
|
||||
path = "exercises/tests/tests4.rs"
|
||||
mode = "test"
|
||||
hint = """
|
||||
We expect method `Rectangle::new()` to panic for negative values.
|
||||
To handle that you need to add special attribute to test function.
|
||||
You can refer to the docs: https://doc.rust-lang.org/stable/book/ch11-01-writing-tests.html"""
|
||||
|
||||
|
||||
# STANDARD LIBRARY TYPES
|
||||
|
||||
[[exercises]]
|
||||
|
|
Loading…
Reference in a new issue