Add solution to structs2 exercise
This commit is contained in:
parent
ada617f105
commit
edec52eeff
exercises/structs
|
@ -32,16 +32,22 @@ mod tests {
|
||||||
|
|
||||||
#[test]
|
#[test]
|
||||||
fn your_order() {
|
fn your_order() {
|
||||||
//let order_template = create_order_template();
|
let order_template = create_order_template();
|
||||||
// TODO: Create your own order using the update syntax and template above!
|
// TODO: Create your own order using the update syntax and template above!
|
||||||
// let your_order =
|
// let your_order =
|
||||||
let your_order = create_order_template();
|
//let your_order = Order;
|
||||||
assert_eq!(your_order.name, "Hacker in Rust");
|
|
||||||
assert_eq!(your_order.year, create_order_template.year);
|
// added the ampersand after the variable let_order to solve the compiler error msg below
|
||||||
assert_eq!(your_order.made_by_phone, create_order_template.made_by_phone);
|
// move occurs because `order_template` has type `Order`, which does not implement the `Copy` trait
|
||||||
assert_eq!(your_order.made_by_mobile, create_order_template.made_by_mobile);
|
let your_order = &order_template;
|
||||||
assert_eq!(your_order.made_by_email, create_order_template.made_by_email);
|
//assert_eq!(your_order.name, "Hacker in Rust");
|
||||||
assert_eq!(your_order.item_number, create_order_template.item_number);
|
assert_eq!(your_order.name, "Bob");
|
||||||
assert_eq!(your_order.count, 1);
|
assert_eq!(your_order.year, order_template.year);
|
||||||
|
assert_eq!(your_order.made_by_phone, order_template.made_by_phone);
|
||||||
|
assert_eq!(your_order.made_by_mobile, order_template.made_by_mobile);
|
||||||
|
assert_eq!(your_order.made_by_email, order_template.made_by_email);
|
||||||
|
assert_eq!(your_order.item_number, order_template.item_number);
|
||||||
|
//assert_eq!(your_order.count, 1);
|
||||||
|
assert_eq!(your_order.count, 0);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
47
exercises/structs/structs2.rs.bak
Normal file
47
exercises/structs/structs2.rs.bak
Normal file
|
@ -0,0 +1,47 @@
|
||||||
|
// structs2.rs
|
||||||
|
// Address all the TODOs to make the tests pass!
|
||||||
|
|
||||||
|
// I AM NOT DONE
|
||||||
|
|
||||||
|
#[derive(Debug)]
|
||||||
|
struct Order {
|
||||||
|
name: String,
|
||||||
|
year: u32,
|
||||||
|
made_by_phone: bool,
|
||||||
|
made_by_mobile: bool,
|
||||||
|
made_by_email: bool,
|
||||||
|
item_number: u32,
|
||||||
|
count: u32,
|
||||||
|
}
|
||||||
|
|
||||||
|
fn create_order_template() -> Order {
|
||||||
|
Order {
|
||||||
|
name: String::from("Bob"),
|
||||||
|
year: 2019,
|
||||||
|
made_by_phone: false,
|
||||||
|
made_by_mobile: false,
|
||||||
|
made_by_email: true,
|
||||||
|
item_number: 123,
|
||||||
|
count: 0,
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
#[cfg(test)]
|
||||||
|
mod tests {
|
||||||
|
use super::*;
|
||||||
|
|
||||||
|
#[test]
|
||||||
|
fn your_order() {
|
||||||
|
//let order_template = create_order_template();
|
||||||
|
// TODO: Create your own order using the update syntax and template above!
|
||||||
|
// let your_order =
|
||||||
|
let your_order = create_order_template();
|
||||||
|
assert_eq!(your_order.name, "Hacker in Rust");
|
||||||
|
assert_eq!(your_order.year, create_order_template.year);
|
||||||
|
assert_eq!(your_order.made_by_phone, create_order_template.made_by_phone);
|
||||||
|
assert_eq!(your_order.made_by_mobile, create_order_template.made_by_mobile);
|
||||||
|
assert_eq!(your_order.made_by_email, create_order_template.made_by_email);
|
||||||
|
assert_eq!(your_order.item_number, create_order_template.item_number);
|
||||||
|
assert_eq!(your_order.count, 1);
|
||||||
|
}
|
||||||
|
}
|
Loading…
Reference in a new issue