2021-03-13 06:14:02 -05:00
|
|
|
// Structs contain data, but can also have logic. In this exercise we have
|
2024-06-21 16:54:00 -04:00
|
|
|
// defined the `Package` struct and we want to test some logic attached to it.
|
2020-04-27 14:17:26 -04:00
|
|
|
|
|
|
|
#[derive(Debug)]
|
|
|
|
struct Package {
|
2020-06-11 12:44:47 -04:00
|
|
|
sender_country: String,
|
|
|
|
recipient_country: String,
|
2023-08-28 18:52:11 -04:00
|
|
|
weight_in_grams: u32,
|
2020-04-27 14:17:26 -04:00
|
|
|
}
|
|
|
|
|
|
|
|
impl Package {
|
2024-06-21 16:54:00 -04:00
|
|
|
fn new(sender_country: String, recipient_country: String, weight_in_grams: u32) -> Self {
|
2023-08-28 18:52:11 -04:00
|
|
|
if weight_in_grams < 10 {
|
2024-06-21 16:54:00 -04:00
|
|
|
// This isn't how you should handle errors in Rust, but we will
|
|
|
|
// learn about error handling later.
|
|
|
|
panic!("Can't ship a package with weight below 10 grams");
|
|
|
|
}
|
|
|
|
|
|
|
|
Self {
|
|
|
|
sender_country,
|
|
|
|
recipient_country,
|
|
|
|
weight_in_grams,
|
2020-04-27 14:17:26 -04:00
|
|
|
}
|
|
|
|
}
|
|
|
|
|
2024-06-21 16:54:00 -04:00
|
|
|
// TODO: Add the correct return type to the function signature.
|
|
|
|
fn is_international(&self) {
|
|
|
|
// TODO: Read the tests that use this method to find out when a package is concidered international.
|
2020-04-27 14:17:26 -04:00
|
|
|
}
|
|
|
|
|
2024-06-21 16:54:00 -04:00
|
|
|
// TODO: Add the correct return type to the function signature.
|
|
|
|
fn get_fees(&self, cents_per_gram: u32) {
|
|
|
|
// TODO: Calculate the package's fees.
|
2020-04-27 14:17:26 -04:00
|
|
|
}
|
|
|
|
}
|
|
|
|
|
2024-04-17 16:46:21 -04:00
|
|
|
fn main() {
|
|
|
|
// You can optionally experiment here.
|
|
|
|
}
|
|
|
|
|
2020-04-27 14:17:26 -04:00
|
|
|
#[cfg(test)]
|
|
|
|
mod tests {
|
|
|
|
use super::*;
|
|
|
|
|
|
|
|
#[test]
|
|
|
|
#[should_panic]
|
|
|
|
fn fail_creating_weightless_package() {
|
2020-06-11 12:44:47 -04:00
|
|
|
let sender_country = String::from("Spain");
|
|
|
|
let recipient_country = String::from("Austria");
|
2020-04-27 14:17:26 -04:00
|
|
|
|
2023-08-28 18:52:11 -04:00
|
|
|
Package::new(sender_country, recipient_country, 5);
|
2020-04-27 14:17:26 -04:00
|
|
|
}
|
|
|
|
|
|
|
|
#[test]
|
|
|
|
fn create_international_package() {
|
2020-06-11 12:44:47 -04:00
|
|
|
let sender_country = String::from("Spain");
|
|
|
|
let recipient_country = String::from("Russia");
|
2020-07-10 22:01:38 -04:00
|
|
|
|
2020-06-11 12:44:47 -04:00
|
|
|
let package = Package::new(sender_country, recipient_country, 1200);
|
2020-04-27 14:17:26 -04:00
|
|
|
|
|
|
|
assert!(package.is_international());
|
|
|
|
}
|
|
|
|
|
2021-03-12 12:36:35 -05:00
|
|
|
#[test]
|
|
|
|
fn create_local_package() {
|
|
|
|
let sender_country = String::from("Canada");
|
|
|
|
let recipient_country = sender_country.clone();
|
|
|
|
|
|
|
|
let package = Package::new(sender_country, recipient_country, 1200);
|
|
|
|
|
|
|
|
assert!(!package.is_international());
|
|
|
|
}
|
|
|
|
|
2020-04-27 14:17:26 -04:00
|
|
|
#[test]
|
|
|
|
fn calculate_transport_fees() {
|
2020-06-11 12:44:47 -04:00
|
|
|
let sender_country = String::from("Spain");
|
|
|
|
let recipient_country = String::from("Spain");
|
2020-04-27 14:17:26 -04:00
|
|
|
|
2021-10-30 18:55:58 -04:00
|
|
|
let cents_per_gram = 3;
|
2020-07-10 22:01:38 -04:00
|
|
|
|
2020-06-11 12:44:47 -04:00
|
|
|
let package = Package::new(sender_country, recipient_country, 1500);
|
2020-07-10 22:01:38 -04:00
|
|
|
|
2020-09-19 15:22:56 -04:00
|
|
|
assert_eq!(package.get_fees(cents_per_gram), 4500);
|
2022-10-04 05:43:23 -04:00
|
|
|
assert_eq!(package.get_fees(cents_per_gram * 2), 9000);
|
2020-04-27 14:17:26 -04:00
|
|
|
}
|
|
|
|
}
|