2022-08-23 09:24:42 +03:00
|
|
|
use indexmap::IndexSet;
|
2022-06-12 03:43:50 +03:00
|
|
|
use serde_json::Value;
|
|
|
|
|
|
|
|
#[macro_export]
|
2022-06-25 03:15:16 +03:00
|
|
|
macro_rules! assert_resp_paths {
|
2022-06-12 03:43:50 +03:00
|
|
|
($resp:ident) => {
|
2022-06-25 03:15:16 +03:00
|
|
|
assert_resp_paths!($resp, self::fixtures::FILES)
|
2022-06-12 03:43:50 +03:00
|
|
|
};
|
|
|
|
($resp:ident, $files:expr) => {
|
|
|
|
assert_eq!($resp.status(), 200);
|
|
|
|
let body = $resp.text()?;
|
2022-08-03 03:51:12 +03:00
|
|
|
let paths = self::utils::retrieve_index_paths(&body);
|
2022-06-12 03:43:50 +03:00
|
|
|
assert!(!paths.is_empty());
|
|
|
|
for file in $files {
|
|
|
|
assert!(paths.contains(&file.to_string()));
|
|
|
|
}
|
|
|
|
};
|
|
|
|
}
|
|
|
|
|
|
|
|
#[macro_export]
|
|
|
|
macro_rules! fetch {
|
|
|
|
($method:literal, $url:expr) => {
|
2023-12-21 09:24:20 +03:00
|
|
|
reqwest::blocking::Client::new().request(reqwest::Method::from_bytes($method)?, $url)
|
2022-06-12 03:43:50 +03:00
|
|
|
};
|
|
|
|
}
|
|
|
|
|
|
|
|
#[allow(dead_code)]
|
2023-02-20 17:50:24 +03:00
|
|
|
pub fn retrieve_index_paths(content: &str) -> IndexSet<String> {
|
2024-05-05 01:23:18 +03:00
|
|
|
let value = retrieve_json(content).unwrap();
|
2022-06-12 03:43:50 +03:00
|
|
|
let paths = value
|
2023-02-20 17:50:24 +03:00
|
|
|
.get("paths")
|
|
|
|
.unwrap()
|
|
|
|
.as_array()
|
|
|
|
.unwrap()
|
2022-06-12 03:43:50 +03:00
|
|
|
.iter()
|
|
|
|
.flat_map(|v| {
|
|
|
|
let name = v.get("name")?.as_str()?;
|
|
|
|
let path_type = v.get("path_type")?.as_str()?;
|
|
|
|
if path_type.ends_with("Dir") {
|
2023-02-20 06:05:53 +03:00
|
|
|
Some(format!("{name}/"))
|
2022-06-12 03:43:50 +03:00
|
|
|
} else {
|
|
|
|
Some(name.to_owned())
|
|
|
|
}
|
|
|
|
})
|
|
|
|
.collect();
|
2023-02-20 17:50:24 +03:00
|
|
|
paths
|
|
|
|
}
|
|
|
|
|
|
|
|
#[allow(dead_code)]
|
2024-05-05 01:23:18 +03:00
|
|
|
pub fn retrieve_edit_file(content: &str) -> Option<bool> {
|
|
|
|
let value = retrieve_json(content)?;
|
2023-02-20 17:50:24 +03:00
|
|
|
let value = value.get("editable").unwrap();
|
|
|
|
Some(value.as_bool().unwrap())
|
|
|
|
}
|
|
|
|
|
|
|
|
#[allow(dead_code)]
|
|
|
|
pub fn encode_uri(v: &str) -> String {
|
|
|
|
let parts: Vec<_> = v.split('/').map(urlencoding::encode).collect();
|
|
|
|
parts.join("/")
|
|
|
|
}
|
|
|
|
|
2023-08-24 13:32:34 +03:00
|
|
|
#[allow(dead_code)]
|
2024-05-05 01:23:18 +03:00
|
|
|
pub fn retrieve_json(content: &str) -> Option<Value> {
|
2023-02-20 17:50:24 +03:00
|
|
|
let lines: Vec<&str> = content.lines().collect();
|
|
|
|
let line = lines.iter().find(|v| v.contains("DATA ="))?;
|
|
|
|
let line_col = line.find("DATA =").unwrap() + 6;
|
|
|
|
let value: Value = line[line_col..].parse().unwrap();
|
|
|
|
Some(value)
|
2022-06-12 03:43:50 +03:00
|
|
|
}
|