more tests

This commit is contained in:
2023-08-29 21:34:00 +02:00
parent d22ca255e1
commit 16028ba4df

View File

@@ -54,6 +54,10 @@ fn random_name() -> String {
s s
} }
fn random_number(range: std::ops::Range<usize>) -> usize {
range.choose(&mut rand::thread_rng()).unwrap()
}
async fn run_test<T, R>(inner: T) -> Result<(), TestError> async fn run_test<T, R>(inner: T) -> Result<(), TestError>
where where
T: FnOnce(WebDriver) -> R, T: FnOnce(WebDriver) -> R,
@@ -72,8 +76,8 @@ where
println!("[sub] starting prepare script {script}"); println!("[sub] starting prepare script {script}");
let handle_prepare = Command::new(script) let handle_prepare = Command::new(script)
.stdin(Stdio::null()) .stdin(Stdio::null())
// .stdout(Stdio::null()) .stdout(Stdio::null())
// .stderr(Stdio::null()) .stderr(Stdio::null())
.output()?; .output()?;
assert!(handle_prepare.status.success()); assert!(handle_prepare.status.success());
@@ -86,8 +90,8 @@ where
println!("[sub] starting script {script}"); println!("[sub] starting script {script}");
let handle = Command::new("geckodriver") let handle = Command::new("geckodriver")
.stdin(Stdio::null()) .stdin(Stdio::null())
// .stdout(Stdio::null()) .stdout(Stdio::null())
// .stderr(Stdio::null()) .stderr(Stdio::null())
.spawn()?; .spawn()?;
println!("[sub] geckodriver started"); println!("[sub] geckodriver started");
handle handle
@@ -109,8 +113,8 @@ where
let handle = Command::new(script) let handle = Command::new(script)
.arg(PORT.to_string()) .arg(PORT.to_string())
.stdin(Stdio::null()) .stdin(Stdio::null())
// .stdout(Stdio::null()) .stdout(Stdio::null())
// .stderr(Stdio::null()) .stderr(Stdio::null())
.spawn()?; .spawn()?;
println!("[sub] app started"); println!("[sub] app started");
handle handle
@@ -171,6 +175,13 @@ where
// call the actual function // call the actual function
println!("calling test function"); println!("calling test function");
let result = inner(driver).await; let result = inner(driver).await;
if let Err(ref e) = result {
println!("test failed, leaving browser open");
println!("test error: {:?}", e);
println!("[hit enter to finish]");
std::io::stdin().read_line(&mut String::new())?;
}
// let result: Result<(), TestError> = Ok(()); // let result: Result<(), TestError> = Ok(());
println!("test function done"); println!("test function done");
@@ -204,7 +215,7 @@ macro_rules! check_eq {
($left:expr, $right:expr) => { ($left:expr, $right:expr) => {
if ($left != $right) { if ($left != $right) {
return Err(TestError::CheckError { return Err(TestError::CheckError {
message: format!("line {}: {:?} != {:?}", line!(), $right, $left), message: format!("line {}: {:?} != {:?}", line!(), $left, $right),
}); });
} }
}; };
@@ -212,8 +223,8 @@ macro_rules! check_eq {
async fn check_table( async fn check_table(
table: &WebElement, table: &WebElement,
head: &Vec<impl AsRef<str>>, head: &Vec<Option<impl AsRef<str>>>,
body: &Vec<Vec<impl AsRef<str>>>, body: &Vec<Vec<Option<impl AsRef<str>>>>,
) -> Result<(), TestError> { ) -> Result<(), TestError> {
let table_head = table let table_head = table
.find(By::Tag("thead")) .find(By::Tag("thead"))
@@ -224,7 +235,9 @@ async fn check_table(
check_eq!(table_head.len(), head.len()); check_eq!(table_head.len(), head.len());
for (i, h) in table_head.iter().enumerate() { for (i, h) in table_head.iter().enumerate() {
check_eq!(h.text().await?, head[i].as_ref()); if let Some(e) = &head[i] {
check_eq!(h.text().await?, e.as_ref());
}
} }
let table_rows = table let table_rows = table
@@ -241,7 +254,9 @@ async fn check_table(
check_eq!(columns.len(), body[row_i].len()); check_eq!(columns.len(), body[row_i].len());
for (column_i, column) in columns.iter().enumerate() { for (column_i, column) in columns.iter().enumerate() {
check_eq!(column.text().await?, body[row_i][column_i].as_ref()); if let Some(e) = &body[row_i][column_i] {
check_eq!(column.text().await?, e.as_ref());
}
} }
} }
Ok(()) Ok(())
@@ -292,8 +307,8 @@ async fn test() -> Result<(), TestError> {
check_table( check_table(
&category_list, &category_list,
&vec!["Name", "Weight"], &vec![Some("Name"), Some("Weight")],
&vec![vec!["Sum", "0"]], &vec![vec![Some("Sum"), Some("0")]],
) )
.await?; .await?;
@@ -307,9 +322,9 @@ async fn test() -> Result<(), TestError> {
// insert a few categories // insert a few categories
let mut rows = vec![vec!["Sum".to_string(), "0".to_string()]]; let mut rows = vec![vec![Some("Sum".to_string()), Some("0".to_string())]];
let iterations = 3; let iterations = random_number(1..5);
for i in 0..iterations { for i in 0..iterations {
let new_category_form = driver.find(By::Id("new-category")).await?; let new_category_form = driver.find(By::Id("new-category")).await?;
@@ -333,9 +348,9 @@ async fn test() -> Result<(), TestError> {
let category_list = driver.find(By::Id("category-list")).await?; let category_list = driver.find(By::Id("category-list")).await?;
rows.insert(i, vec![category_name, "0".to_string()]); rows.insert(i, vec![Some(category_name), Some("0".to_string())]);
check_table(&category_list, &vec!["Name", "Weight"], &rows).await?; check_table(&category_list, &vec![Some("Name"), Some("Weight")], &rows).await?;
} }
// select one of the new categories and check that it's empty // select one of the new categories and check that it's empty
@@ -347,10 +362,14 @@ async fn test() -> Result<(), TestError> {
.find_all(By::Tag("tr")) .find_all(By::Tag("tr"))
.await?; .await?;
let id = { 0..iterations }.choose(&mut rand::thread_rng()).unwrap(); let id = random_number(0..iterations);
let category_link = &table_rows[id].find_all(By::Tag("td")).await?[0]; let category_link = &table_rows[id].find_all(By::Tag("td")).await?[0];
let category_name = category_link.text().await?;
println!("==================================== name of new category: {category_name}");
check_eq!(category_link.is_clickable().await?, true); check_eq!(category_link.is_clickable().await?, true);
category_link.click().await?; category_link.click().await?;
@@ -363,7 +382,124 @@ async fn test() -> Result<(), TestError> {
.to_lowercase() .to_lowercase()
.contains("empty"), .contains("empty"),
true true
) );
// now, add an item to the category.
// check that the preselected category is ours
let new_item_form = driver.find(By::Id("new-item")).await?;
let new_item_input_name = new_item_form
.find(By::Css("input[name='new-item-name']"))
.await?;
check_eq!(new_item_input_name.value().await?, Some(String::new()));
let new_item_input_weight = new_item_form
.find(By::Css("input[name='new-item-weight']"))
.await?;
check_eq!(new_item_input_weight.value().await?, Some(String::new()));
let new_item_input_category = new_item_form
.find(By::Css("select[name='new-item-category-id']"))
.await?;
check_eq!(
thirtyfour::components::SelectElement::new(&new_item_input_category)
.await?
.first_selected_option()
.await?
.text()
.await?,
category_name.clone()
);
let new_item_form_submit = new_item_form.find(By::Css("input[type='submit']")).await?;
check_eq!(new_item_form_submit.is_clickable().await?, !js_enabled);
// add a few items
let iterations = random_number(1..5);
let mut rows = vec![];
let mut weights = vec![];
for _i in 0..iterations {
let new_item_form = driver.find(By::Id("new-item")).await?;
let item_name = random_name();
let item_weight = random_number(0..1500);
weights.push(item_weight);
let new_item_name_input = new_item_form
.find(By::Css("input[name='new-item-name']"))
.await?;
check_eq!(new_item_name_input.value().await?, Some(String::new()));
new_item_name_input.send_keys(&item_name).await?;
let new_item_weight_input = new_item_form
.find(By::Css("input[name='new-item-weight']"))
.await?;
check_eq!(new_item_weight_input.value().await?, Some(String::new()));
new_item_weight_input
.send_keys(item_weight.to_string())
.await?;
let new_item_form_submit =
new_item_form.find(By::Css("input[type='submit']")).await?;
check_eq!(new_item_form_submit.is_clickable().await?, true);
new_item_form_submit.click().await?;
let item_list = driver.find(By::Id("items")).await?;
rows.push(vec![
Some(item_name),
Some(item_weight.to_string()),
None,
None,
]);
check_table(
&item_list,
&vec![Some("Name"), Some("Weight"), None, None],
&rows,
)
.await?;
// check that the sum of weights is still correct
let category_list = driver.find(By::Id("category-list")).await?;
let table_rows = category_list
.find(By::Tag("tbody"))
.await?
.find_all(By::Tag("tr"))
.await?;
let mut found = false;
for row in &table_rows {
let cols = row.find_all(By::Tag("td")).await?;
if cols[0].text().await? == category_name {
check_eq!(
cols[1].text().await?,
weights.iter().sum::<usize>().to_string()
)
}
found = true;
}
if !found {
return Err(TestError::CheckError {
message: "did not find a (formerly existing?) category".to_string(),
});
}
}
} }
Ok(()) Ok(())