list and delete campaign endpoints
This commit is contained in:
parent
a287f2d31c
commit
33a7a1882c
3 changed files with 364 additions and 56 deletions
|
@ -1,5 +1,18 @@
|
||||||
{
|
{
|
||||||
"db": "PostgreSQL",
|
"db": "PostgreSQL",
|
||||||
|
"03c9789e83a398bed96354924a0e63ccaa97bec667fda1b8277bb9afda9a6fcd": {
|
||||||
|
"query": "DELETE \n FROM survey_campaigns \n WHERE \n user_id = (\n SELECT \n ID \n FROM \n survey_admins \n WHERE \n name = $1\n )\n AND\n id = ($2)",
|
||||||
|
"describe": {
|
||||||
|
"columns": [],
|
||||||
|
"parameters": {
|
||||||
|
"Left": [
|
||||||
|
"Text",
|
||||||
|
"Uuid"
|
||||||
|
]
|
||||||
|
},
|
||||||
|
"nullable": []
|
||||||
|
}
|
||||||
|
},
|
||||||
"0d22134cc5076304b7895827f006ee8269cc500f400114a7472b83f0f1c568b5": {
|
"0d22134cc5076304b7895827f006ee8269cc500f400114a7472b83f0f1c568b5": {
|
||||||
"query": "INSERT INTO survey_admins \n (name , password, secret) VALUES ($1, $2, $3)",
|
"query": "INSERT INTO survey_admins \n (name , password, secret) VALUES ($1, $2, $3)",
|
||||||
"describe": {
|
"describe": {
|
||||||
|
@ -133,6 +146,27 @@
|
||||||
"nullable": []
|
"nullable": []
|
||||||
}
|
}
|
||||||
},
|
},
|
||||||
|
"58ec3b8f98c27e13ec2732f8ee23f6eb9845ac5d9fd97b1e5c9f2eed4b1f5693": {
|
||||||
|
"query": "SELECT name \n FROM survey_campaigns\n WHERE \n id = $1\n AND\n user_id = (SELECT ID from survey_admins WHERE name = $2)",
|
||||||
|
"describe": {
|
||||||
|
"columns": [
|
||||||
|
{
|
||||||
|
"ordinal": 0,
|
||||||
|
"name": "name",
|
||||||
|
"type_info": "Varchar"
|
||||||
|
}
|
||||||
|
],
|
||||||
|
"parameters": {
|
||||||
|
"Left": [
|
||||||
|
"Uuid",
|
||||||
|
"Text"
|
||||||
|
]
|
||||||
|
},
|
||||||
|
"nullable": [
|
||||||
|
false
|
||||||
|
]
|
||||||
|
}
|
||||||
|
},
|
||||||
"683707dbc847b37c58c29aaad0d1a978c9fe0657da13af99796e4461134b5a43": {
|
"683707dbc847b37c58c29aaad0d1a978c9fe0657da13af99796e4461134b5a43": {
|
||||||
"query": "UPDATE survey_admins set email = $1\n WHERE name = $2",
|
"query": "UPDATE survey_admins set email = $1\n WHERE name = $2",
|
||||||
"describe": {
|
"describe": {
|
||||||
|
@ -166,6 +200,32 @@
|
||||||
]
|
]
|
||||||
}
|
}
|
||||||
},
|
},
|
||||||
|
"70cc7bfc9b6ff5b68db70c069c0947d51bfc4a53cedc020016ee25ff98586c93": {
|
||||||
|
"query": "SELECT \n name, id\n FROM \n survey_campaigns \n WHERE\n user_id = (\n SELECT \n ID\n FROM \n survey_admins\n WHERE\n name = $1\n )",
|
||||||
|
"describe": {
|
||||||
|
"columns": [
|
||||||
|
{
|
||||||
|
"ordinal": 0,
|
||||||
|
"name": "name",
|
||||||
|
"type_info": "Varchar"
|
||||||
|
},
|
||||||
|
{
|
||||||
|
"ordinal": 1,
|
||||||
|
"name": "id",
|
||||||
|
"type_info": "Uuid"
|
||||||
|
}
|
||||||
|
],
|
||||||
|
"parameters": {
|
||||||
|
"Left": [
|
||||||
|
"Text"
|
||||||
|
]
|
||||||
|
},
|
||||||
|
"nullable": [
|
||||||
|
false,
|
||||||
|
false
|
||||||
|
]
|
||||||
|
}
|
||||||
|
},
|
||||||
"82feafc36533144e49ba374c8c47ca4aa0d6558a9803778ad28cfa7b62382c3e": {
|
"82feafc36533144e49ba374c8c47ca4aa0d6558a9803778ad28cfa7b62382c3e": {
|
||||||
"query": "\n INSERT INTO survey_campaigns (\n user_id, ID, name, difficulties, created_at\n ) VALUES(\n (SELECT id FROM survey_admins WHERE name = $1),\n $2, $3, $4, $5\n );",
|
"query": "\n INSERT INTO survey_campaigns (\n user_id, ID, name, difficulties, created_at\n ) VALUES(\n (SELECT id FROM survey_admins WHERE name = $1),\n $2, $3, $4, $5\n );",
|
||||||
"describe": {
|
"describe": {
|
||||||
|
|
|
@ -20,27 +20,40 @@ use actix_identity::Identity;
|
||||||
use actix_web::{web, HttpResponse, Responder};
|
use actix_web::{web, HttpResponse, Responder};
|
||||||
use serde::{Deserialize, Serialize};
|
use serde::{Deserialize, Serialize};
|
||||||
use sqlx::types::time::OffsetDateTime;
|
use sqlx::types::time::OffsetDateTime;
|
||||||
|
use uuid::Uuid;
|
||||||
|
|
||||||
use super::get_uuid;
|
use super::{get_admin_check_login, get_uuid};
|
||||||
use crate::errors::*;
|
use crate::errors::*;
|
||||||
use crate::AppData;
|
use crate::AppData;
|
||||||
|
|
||||||
pub mod routes {
|
pub mod routes {
|
||||||
pub struct Campaign {
|
pub struct Campaign {
|
||||||
pub add: &'static str,
|
pub add: &'static str,
|
||||||
|
pub delete: &'static str,
|
||||||
|
// pub get_feedback: &'static str,
|
||||||
|
pub list: &'static str,
|
||||||
}
|
}
|
||||||
|
|
||||||
impl Campaign {
|
impl Campaign {
|
||||||
pub const fn new() -> Campaign {
|
pub const fn new() -> Campaign {
|
||||||
let add = "/api/v1/admin/campaign/add";
|
let add = "/api/v1/admin/campaign/add";
|
||||||
Campaign { add }
|
let delete = "/api/v1/admin/campaign/{uuid}/delete";
|
||||||
|
// let get_feedback = "/api/v1/campaign/{uuid}/feedback";
|
||||||
|
let list = "/api/v1/admin/campaign/list";
|
||||||
|
|
||||||
|
Campaign { add, delete, list }
|
||||||
|
}
|
||||||
|
// pub fn get_benches_route(&self, campaign_id: &str) -> String {
|
||||||
|
// self.get_feedback.replace("{uuid}", &campaign_id)
|
||||||
|
// }
|
||||||
|
|
||||||
|
pub fn get_delete_route(&self, campaign_id: &str) -> String {
|
||||||
|
self.delete.replace("{uuid}", &campaign_id)
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
pub mod runners {
|
pub mod runners {
|
||||||
// use std::borrow::Cow;
|
|
||||||
|
|
||||||
use super::*;
|
use super::*;
|
||||||
|
|
||||||
pub async fn add_runner(
|
pub async fn add_runner(
|
||||||
|
@ -87,6 +100,218 @@ pub mod runners {
|
||||||
}
|
}
|
||||||
Ok(uuid)
|
Ok(uuid)
|
||||||
}
|
}
|
||||||
|
|
||||||
|
pub async fn list_campaign_runner(
|
||||||
|
username: &str,
|
||||||
|
data: &AppData,
|
||||||
|
) -> ServiceResult<Vec<ListCampaignResp>> {
|
||||||
|
struct ListCampaign {
|
||||||
|
name: String,
|
||||||
|
id: Uuid,
|
||||||
|
}
|
||||||
|
|
||||||
|
let mut campaigns = sqlx::query_as!(
|
||||||
|
ListCampaign,
|
||||||
|
"SELECT
|
||||||
|
name, id
|
||||||
|
FROM
|
||||||
|
survey_campaigns
|
||||||
|
WHERE
|
||||||
|
user_id = (
|
||||||
|
SELECT
|
||||||
|
ID
|
||||||
|
FROM
|
||||||
|
survey_admins
|
||||||
|
WHERE
|
||||||
|
name = $1
|
||||||
|
)",
|
||||||
|
username
|
||||||
|
)
|
||||||
|
.fetch_all(&data.db)
|
||||||
|
.await?;
|
||||||
|
|
||||||
|
let mut list_resp = Vec::with_capacity(campaigns.len());
|
||||||
|
campaigns.drain(0..).for_each(|c| {
|
||||||
|
list_resp.push(ListCampaignResp {
|
||||||
|
name: c.name,
|
||||||
|
uuid: c.id.to_string(),
|
||||||
|
});
|
||||||
|
});
|
||||||
|
|
||||||
|
Ok(list_resp)
|
||||||
|
}
|
||||||
|
|
||||||
|
// pub async fn get_benches(
|
||||||
|
// username: &str,
|
||||||
|
// uuid: &str,
|
||||||
|
// data: &AppData,
|
||||||
|
// ) -> ServiceResult<GetFeedbackResp> {
|
||||||
|
// let uuid = Uuid::parse_str(uuid).map_err(|_| ServiceError::NotAnId)?;
|
||||||
|
//
|
||||||
|
// struct FeedbackInternal {
|
||||||
|
// time: OffsetDateTime,
|
||||||
|
// description: String,
|
||||||
|
// helpful: bool,
|
||||||
|
// }
|
||||||
|
//
|
||||||
|
// struct Name {
|
||||||
|
// name: String,
|
||||||
|
// }
|
||||||
|
//
|
||||||
|
// let name_fut = sqlx::query_as!(
|
||||||
|
// Name,
|
||||||
|
// "SELECT name
|
||||||
|
// FROM survey_campaigns
|
||||||
|
// WHERE uuid = $1
|
||||||
|
// AND
|
||||||
|
// user_id = (
|
||||||
|
// SELECT
|
||||||
|
// ID
|
||||||
|
// FROM
|
||||||
|
// kaizen_users
|
||||||
|
// WHERE
|
||||||
|
// name = $2
|
||||||
|
// )
|
||||||
|
// ",
|
||||||
|
// uuid,
|
||||||
|
// username
|
||||||
|
// )
|
||||||
|
// .fetch_one(&data.db); //.await?;
|
||||||
|
//
|
||||||
|
// let feedback_fut = sqlx::query_as!(
|
||||||
|
// FeedbackInternal,
|
||||||
|
// "SELECT
|
||||||
|
// time, description, helpful
|
||||||
|
// FROM
|
||||||
|
// kaizen_feedbacks
|
||||||
|
// WHERE campaign_id = (
|
||||||
|
// SELECT uuid
|
||||||
|
// FROM
|
||||||
|
// survey_campaigns
|
||||||
|
// WHERE
|
||||||
|
// uuid = $1
|
||||||
|
// AND
|
||||||
|
// user_id = (
|
||||||
|
// SELECT
|
||||||
|
// ID
|
||||||
|
// FROM
|
||||||
|
// kaizen_users
|
||||||
|
// WHERE
|
||||||
|
// name = $2
|
||||||
|
// )
|
||||||
|
// )",
|
||||||
|
// uuid,
|
||||||
|
// username
|
||||||
|
// )
|
||||||
|
// .fetch_all(&data.db);
|
||||||
|
// let (name, mut feedbacks) = try_join!(name_fut, feedback_fut)?;
|
||||||
|
// //.await?;
|
||||||
|
//
|
||||||
|
// let mut feedback_resp = Vec::with_capacity(feedbacks.len());
|
||||||
|
// feedbacks.drain(0..).for_each(|f| {
|
||||||
|
// feedback_resp.push(Feedback {
|
||||||
|
// time: f.time.unix_timestamp() as u64,
|
||||||
|
// description: f.description,
|
||||||
|
// helpful: f.helpful,
|
||||||
|
// });
|
||||||
|
// });
|
||||||
|
//
|
||||||
|
// Ok(GetFeedbackResp {
|
||||||
|
// feedbacks: feedback_resp,
|
||||||
|
// name: name.name,
|
||||||
|
// })
|
||||||
|
// }
|
||||||
|
|
||||||
|
pub async fn delete(
|
||||||
|
uuid: &Uuid,
|
||||||
|
username: &str,
|
||||||
|
data: &AppData,
|
||||||
|
) -> ServiceResult<()> {
|
||||||
|
sqlx::query!(
|
||||||
|
"DELETE
|
||||||
|
FROM survey_campaigns
|
||||||
|
WHERE
|
||||||
|
user_id = (
|
||||||
|
SELECT
|
||||||
|
ID
|
||||||
|
FROM
|
||||||
|
survey_admins
|
||||||
|
WHERE
|
||||||
|
name = $1
|
||||||
|
)
|
||||||
|
AND
|
||||||
|
id = ($2)",
|
||||||
|
username,
|
||||||
|
uuid
|
||||||
|
)
|
||||||
|
.execute(&data.db)
|
||||||
|
.await?;
|
||||||
|
Ok(())
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
#[my_codegen::post(
|
||||||
|
path = "crate::V1_API_ROUTES.admin.campaign.delete",
|
||||||
|
wrap = "get_admin_check_login()"
|
||||||
|
)]
|
||||||
|
pub async fn delete(
|
||||||
|
id: Identity,
|
||||||
|
data: AppData,
|
||||||
|
path: web::Path<String>,
|
||||||
|
) -> ServiceResult<impl Responder> {
|
||||||
|
let username = id.identity().unwrap();
|
||||||
|
let path = path.into_inner();
|
||||||
|
let uuid = Uuid::parse_str(&path).map_err(|_| ServiceError::NotAnId)?;
|
||||||
|
runners::delete(&uuid, &username, &data).await?;
|
||||||
|
Ok(HttpResponse::Ok())
|
||||||
|
}
|
||||||
|
|
||||||
|
//#[derive(Serialize, Deserialize)]
|
||||||
|
//pub struct Feedback {
|
||||||
|
// pub time: u64,
|
||||||
|
// pub description: String,
|
||||||
|
// pub helpful: bool,
|
||||||
|
//}
|
||||||
|
//
|
||||||
|
//#[derive(Serialize, Deserialize)]
|
||||||
|
//pub struct GetFeedbackResp {
|
||||||
|
// pub name: String,
|
||||||
|
// pub feedbacks: Vec<Feedback>,
|
||||||
|
//}
|
||||||
|
//
|
||||||
|
//#[my_codegen::post(
|
||||||
|
// path = "crate::V1_API_ROUTES.campaign.get_feedback",
|
||||||
|
// wrap = "crate::CheckLogin"
|
||||||
|
//)]
|
||||||
|
//pub async fn get_feedback(
|
||||||
|
// id: Identity,
|
||||||
|
// data: AppData,
|
||||||
|
// path: web::Path<String>,
|
||||||
|
//) -> ServiceResult<impl Responder> {
|
||||||
|
// let username = id.identity().unwrap();
|
||||||
|
// let path = path.into_inner();
|
||||||
|
// let feedback_resp = runners::get_feedback(&username, &path, &data).await?;
|
||||||
|
// Ok(HttpResponse::Ok().json(feedback_resp))
|
||||||
|
//}
|
||||||
|
|
||||||
|
#[derive(Serialize, Deserialize)]
|
||||||
|
pub struct ListCampaignResp {
|
||||||
|
pub name: String,
|
||||||
|
pub uuid: String,
|
||||||
|
}
|
||||||
|
|
||||||
|
#[my_codegen::post(
|
||||||
|
path = "crate::V1_API_ROUTES.admin.campaign.list",
|
||||||
|
wrap = "get_admin_check_login()"
|
||||||
|
)]
|
||||||
|
pub async fn list_campaign(
|
||||||
|
id: Identity,
|
||||||
|
data: AppData,
|
||||||
|
) -> ServiceResult<impl Responder> {
|
||||||
|
let username = id.identity().unwrap();
|
||||||
|
let list_resp = runners::list_campaign_runner(&username, &data).await?;
|
||||||
|
|
||||||
|
Ok(HttpResponse::Ok().json(list_resp))
|
||||||
}
|
}
|
||||||
|
|
||||||
#[derive(Serialize, Deserialize)]
|
#[derive(Serialize, Deserialize)]
|
||||||
|
@ -102,6 +327,9 @@ pub struct AddCapmaignResp {
|
||||||
|
|
||||||
pub fn services(cfg: &mut web::ServiceConfig) {
|
pub fn services(cfg: &mut web::ServiceConfig) {
|
||||||
cfg.service(add);
|
cfg.service(add);
|
||||||
|
cfg.service(delete);
|
||||||
|
cfg.service(list_campaign);
|
||||||
|
//cfg.service(get_feedback);
|
||||||
}
|
}
|
||||||
|
|
||||||
#[my_codegen::post(path = "crate::V1_API_ROUTES.admin.campaign.add")]
|
#[my_codegen::post(path = "crate::V1_API_ROUTES.admin.campaign.add")]
|
||||||
|
@ -123,6 +351,7 @@ async fn add(
|
||||||
mod tests {
|
mod tests {
|
||||||
use crate::api::v1::bench::Submission;
|
use crate::api::v1::bench::Submission;
|
||||||
use crate::data::Data;
|
use crate::data::Data;
|
||||||
|
use crate::errors::*;
|
||||||
use crate::middleware::auth::GetLoginRoute;
|
use crate::middleware::auth::GetLoginRoute;
|
||||||
use crate::tests::*;
|
use crate::tests::*;
|
||||||
use crate::*;
|
use crate::*;
|
||||||
|
@ -197,5 +426,21 @@ mod tests {
|
||||||
|
|
||||||
let _proof =
|
let _proof =
|
||||||
submit_bench(&submit_payload, &campaign, survey_cookie, data.clone()).await;
|
submit_bench(&submit_payload, &campaign, survey_cookie, data.clone()).await;
|
||||||
|
|
||||||
|
let list = list_campaings(data.clone(), cookies.clone()).await;
|
||||||
|
assert!(list.iter().any(|c| c.name == NAME));
|
||||||
|
|
||||||
|
bad_post_req_test_witout_payload(
|
||||||
|
NAME,
|
||||||
|
PASSWORD,
|
||||||
|
&V1_API_ROUTES.admin.campaign.delete.replace("{uuid}", NAME),
|
||||||
|
ServiceError::NotAnId,
|
||||||
|
)
|
||||||
|
.await;
|
||||||
|
|
||||||
|
delete_campaign(&campaign, data.clone(), cookies.clone()).await;
|
||||||
|
|
||||||
|
let list = list_campaings(data.clone(), cookies.clone()).await;
|
||||||
|
assert!(!list.iter().any(|c| c.name == NAME));
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
107
src/tests.rs
107
src/tests.rs
|
@ -27,7 +27,7 @@ use uuid::Uuid;
|
||||||
use super::*;
|
use super::*;
|
||||||
use crate::api::v1::admin::{
|
use crate::api::v1::admin::{
|
||||||
auth::runners::{Login, Register},
|
auth::runners::{Login, Register},
|
||||||
campaigns::{AddCapmaign, AddCapmaignResp},
|
campaigns::{AddCapmaign, AddCapmaignResp, ListCampaignResp},
|
||||||
};
|
};
|
||||||
use crate::api::v1::bench::{Bench, BenchConfig, Submission, SubmissionProof};
|
use crate::api::v1::bench::{Bench, BenchConfig, Submission, SubmissionProof};
|
||||||
use crate::data::Data;
|
use crate::data::Data;
|
||||||
|
@ -177,28 +177,28 @@ pub async fn bad_post_req_test<T: Serialize>(
|
||||||
//println!("{}", txt.error);
|
//println!("{}", txt.error);
|
||||||
assert_eq!(resp_err.error, format!("{}", err));
|
assert_eq!(resp_err.error, format!("{}", err));
|
||||||
}
|
}
|
||||||
//
|
|
||||||
///// bad post req test without payload
|
/// bad post req test without payload
|
||||||
//pub async fn bad_post_req_test_witout_payload(
|
pub async fn bad_post_req_test_witout_payload(
|
||||||
// name: &str,
|
name: &str,
|
||||||
// password: &str,
|
password: &str,
|
||||||
// url: &str,
|
url: &str,
|
||||||
// err: ServiceError,
|
err: ServiceError,
|
||||||
//) {
|
) {
|
||||||
// let (data, _, signin_resp) = signin(name, password).await;
|
let (data, _, signin_resp) = signin(name, password).await;
|
||||||
// let cookies = get_cookie!(signin_resp);
|
let cookies = get_cookie!(signin_resp);
|
||||||
// let app = get_app!(data).await;
|
let app = get_app!(data).await;
|
||||||
//
|
|
||||||
// let resp = test::call_service(
|
let resp = test::call_service(
|
||||||
// &app,
|
&app,
|
||||||
// post_request!(url).cookie(cookies.clone()).to_request(),
|
post_request!(url).cookie(cookies.clone()).to_request(),
|
||||||
// )
|
)
|
||||||
// .await;
|
.await;
|
||||||
// assert_eq!(resp.status(), err.status_code());
|
assert_eq!(resp.status(), err.status_code());
|
||||||
// let resp_err: ErrorToResponse = test::read_body_json(resp).await;
|
let resp_err: ErrorToResponse = test::read_body_json(resp).await;
|
||||||
// //println!("{}", txt.error);
|
//println!("{}", txt.error);
|
||||||
// assert_eq!(resp_err.error, format!("{}", err));
|
assert_eq!(resp_err.error, format!("{}", err));
|
||||||
//}
|
}
|
||||||
|
|
||||||
pub const DIFFICULTIES: [i32; 5] = [1, 2, 3, 4, 5];
|
pub const DIFFICULTIES: [i32; 5] = [1, 2, 3, 4, 5];
|
||||||
|
|
||||||
|
@ -255,35 +255,38 @@ pub async fn get_campaign_config(
|
||||||
test::read_body_json(new_resp).await
|
test::read_body_json(new_resp).await
|
||||||
}
|
}
|
||||||
|
|
||||||
//pub async fn delete_campaign(
|
pub async fn delete_campaign(
|
||||||
// camapign: &CreateResp,
|
camapign: &AddCapmaignResp,
|
||||||
// data: Arc<Data>,
|
data: Arc<Data>,
|
||||||
// cookies: Cookie<'_>,
|
cookies: Cookie<'_>,
|
||||||
//) {
|
) {
|
||||||
// let del_route = V1_API_ROUTES.campaign.get_delete_route(&camapign.uuid);
|
let del_route = V1_API_ROUTES
|
||||||
// let app = get_app!(data).await;
|
.admin
|
||||||
// let del_resp =
|
.campaign
|
||||||
// test::call_service(&app, post_request!(&del_route).cookie(cookies).to_request())
|
.get_delete_route(&camapign.campaign_id);
|
||||||
// .await;
|
let app = get_app!(data).await;
|
||||||
// assert_eq!(del_resp.status(), StatusCode::OK);
|
let del_resp =
|
||||||
//}
|
test::call_service(&app, post_request!(&del_route).cookie(cookies).to_request())
|
||||||
//
|
.await;
|
||||||
//pub async fn list_campaings(
|
assert_eq!(del_resp.status(), StatusCode::OK);
|
||||||
// data: Arc<Data>,
|
}
|
||||||
// cookies: Cookie<'_>,
|
|
||||||
//) -> Vec<ListCampaignResp> {
|
pub async fn list_campaings(
|
||||||
// let app = get_app!(data).await;
|
data: Arc<Data>,
|
||||||
// let list_resp = test::call_service(
|
cookies: Cookie<'_>,
|
||||||
// &app,
|
) -> Vec<ListCampaignResp> {
|
||||||
// post_request!(crate::V1_API_ROUTES.campaign.list)
|
let app = get_app!(data).await;
|
||||||
// .cookie(cookies)
|
let list_resp = test::call_service(
|
||||||
// .to_request(),
|
&app,
|
||||||
// )
|
post_request!(crate::V1_API_ROUTES.admin.campaign.list)
|
||||||
// .await;
|
.cookie(cookies)
|
||||||
// assert_eq!(list_resp.status(), StatusCode::OK);
|
.to_request(),
|
||||||
// test::read_body_json(list_resp).await
|
)
|
||||||
//}
|
.await;
|
||||||
//
|
assert_eq!(list_resp.status(), StatusCode::OK);
|
||||||
|
test::read_body_json(list_resp).await
|
||||||
|
}
|
||||||
|
|
||||||
pub async fn submit_bench(
|
pub async fn submit_bench(
|
||||||
payload: &Submission,
|
payload: &Submission,
|
||||||
campaign: &AddCapmaignResp,
|
campaign: &AddCapmaignResp,
|
||||||
|
|
Loading…
Reference in a new issue