// structs2.rs
// Address all the TODOs to make the tests pass!

// 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,
    }
}

// let your_order = Order{ 
// 	name: String::from("Hacker in Rust"),
// 	count: 1,
// 	..order_template	//dot dot operator meaning the rest of struct fields remains the same
// };

#[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!

        // this struct is moved from above to inside this function.
		// create own struct version changing the name and count while the remaining fields remain the same
		let your_order = Order{ 
			name: String::from("Hacker in Rust"),
			count: 1,
			..order_template	//dot dot operator meaning the rest of struct fields remain the same
		};
        assert_eq!(your_order.name, "Hacker in Rust");
        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);
    }
}