feat: Initial task runner functionality
This commit is contained in:
parent
713994d848
commit
43bea77392
6 changed files with 244 additions and 35 deletions
|
|
@ -1,14 +1,93 @@
|
|||
use crate::utils::parse::Testcases;
|
||||
use std::{
|
||||
collections::HashMap,
|
||||
fmt::format,
|
||||
io::{self, Error, ErrorKind},
|
||||
};
|
||||
|
||||
use crate::utils::parse::{Responses, Testcase, Testcases};
|
||||
use tasks01::poly2block::{self, poly2block};
|
||||
|
||||
use serde::{Deserialize, Serialize};
|
||||
use serde_json::{json, Value};
|
||||
|
||||
mod tasks01;
|
||||
|
||||
pub fn task_distrubute(testcases: Testcases) {
|
||||
for testcase in testcases.testcases {
|
||||
//match testcase {}
|
||||
todo!();
|
||||
pub fn task_deploy(testcase: &Testcase) -> Result<Value, String> {
|
||||
/*
|
||||
* Function to automatially distribute task workloads
|
||||
* TODO: Add functionality to also pass semantics
|
||||
*
|
||||
* */
|
||||
|
||||
let args = &testcase.arguments;
|
||||
|
||||
match testcase.action.as_str() {
|
||||
"poly2block" => {
|
||||
let coefficients: Vec<u8> = args["coefficients"]
|
||||
.as_array()
|
||||
.unwrap()
|
||||
.into_iter()
|
||||
.map(|x| x.as_u64().unwrap() as u8)
|
||||
.collect();
|
||||
//eprintln!("{:?}", &args["coefficients"]);
|
||||
//eprintln!("{:?}", testcase);
|
||||
//eprintln!("{:?}", coefficients);
|
||||
let result = poly2block(coefficients);
|
||||
let json = json!({"block" : result});
|
||||
Ok(json)
|
||||
}
|
||||
_ => Err(format!(
|
||||
"Fatal error in task distribution. Data was: {:?}",
|
||||
args
|
||||
)),
|
||||
}
|
||||
}
|
||||
|
||||
pub fn task_deploy() {
|
||||
todo!();
|
||||
// TODO: Is this obsolete? Might delete later.
|
||||
pub fn task_distrubute(testcases: &Testcases) -> Responses {
|
||||
let mut responses: HashMap<String, Value> = HashMap::new();
|
||||
|
||||
for (id, testcase) in &testcases.testcases {
|
||||
responses.insert(id.to_owned(), task_deploy(testcase).unwrap());
|
||||
}
|
||||
|
||||
Responses {
|
||||
responses: responses,
|
||||
}
|
||||
}
|
||||
|
||||
#[cfg(test)]
|
||||
mod tests {
|
||||
use super::*;
|
||||
use crate::utils::parse::parse_json;
|
||||
use std::fs;
|
||||
|
||||
#[test]
|
||||
fn test_task_deploy() {
|
||||
let json = fs::read_to_string("src/test_json/poly2block_example.json").unwrap();
|
||||
let parsed = parse_json(json).unwrap();
|
||||
let testcase = parsed
|
||||
.testcases
|
||||
.get("b856d760-023d-4b00-bad2-15d2b6da22fe")
|
||||
.unwrap();
|
||||
|
||||
assert!(
|
||||
task_deploy(&testcase).is_ok(),
|
||||
"Error: Function result was: {:?}",
|
||||
task_deploy(&testcase)
|
||||
);
|
||||
}
|
||||
|
||||
#[test]
|
||||
fn test_task_distribution() {
|
||||
let json = fs::read_to_string("src/test_json/poly2block_example.json").unwrap();
|
||||
let parsed = parse_json(json).unwrap();
|
||||
|
||||
let expected = json!({ "responses": { "b856d760-023d-4b00-bad2-15d2b6da22fe": {"block": "ARIAAAAAAAAAAAAAAAAAgA=="}}});
|
||||
|
||||
assert_eq!(
|
||||
serde_json::to_value(task_distrubute(&parsed)).unwrap(),
|
||||
serde_json::to_value(expected).unwrap()
|
||||
);
|
||||
}
|
||||
}
|
||||
|
|
|
|||
|
|
@ -1,2 +1,3 @@
|
|||
mod poly2block;
|
||||
mod block2poly;
|
||||
pub mod block2poly;
|
||||
pub mod poly2block;
|
||||
|
||||
|
|
|
|||
|
|
@ -4,4 +4,5 @@ use serde_json::Value;
|
|||
|
||||
pub fn poly2block(coefficients: Vec<u8>) -> String {
|
||||
BASE64_STANDARD.encode(poly::coefficient_to_binary(coefficients).to_ne_bytes())
|
||||
}
|
||||
}
|
||||
|
||||
|
|
|
|||
Loading…
Add table
Add a link
Reference in a new issue