extract poll_match_until_complete function
This commit is contained in:
parent
45d6172814
commit
df44ef055e
1 changed files with 49 additions and 28 deletions
|
@ -1,6 +1,7 @@
|
||||||
use axum::{
|
use axum::{
|
||||||
body::Body,
|
body::Body,
|
||||||
http::{self, Request, StatusCode},
|
http::{self, Request, StatusCode},
|
||||||
|
Router,
|
||||||
};
|
};
|
||||||
use diesel::{PgConnection, RunQueryDsl};
|
use diesel::{PgConnection, RunQueryDsl};
|
||||||
use planetwars_server::{create_db_pool, create_pw_api, db, modules, DbPool, GlobalConfig};
|
use planetwars_server::{create_db_pool, create_pw_api, db, modules, DbPool, GlobalConfig};
|
||||||
|
@ -9,6 +10,7 @@ use std::{
|
||||||
io,
|
io,
|
||||||
path::{Path, PathBuf},
|
path::{Path, PathBuf},
|
||||||
sync::Arc,
|
sync::Arc,
|
||||||
|
task::Poll,
|
||||||
time::Duration,
|
time::Duration,
|
||||||
};
|
};
|
||||||
use tempfile::TempDir;
|
use tempfile::TempDir;
|
||||||
|
@ -128,6 +130,44 @@ impl<'a> TestApp<'a> {
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
async fn poll_match(app: &mut Router, match_id: &str) -> io::Result<Poll<JsonValue>> {
|
||||||
|
let response = app
|
||||||
|
.call(
|
||||||
|
Request::builder()
|
||||||
|
.method(http::Method::GET)
|
||||||
|
.header("Content-Type", "application/json")
|
||||||
|
.uri(format!("/api/matches/{}", match_id))
|
||||||
|
.body(Body::empty())
|
||||||
|
.unwrap(),
|
||||||
|
)
|
||||||
|
.await
|
||||||
|
.unwrap();
|
||||||
|
|
||||||
|
assert_eq!(response.status(), StatusCode::OK);
|
||||||
|
let body = hyper::body::to_bytes(response.into_body()).await.unwrap();
|
||||||
|
let resp: JsonValue = serde_json::from_slice(&body).unwrap();
|
||||||
|
|
||||||
|
match resp["state"].as_str() {
|
||||||
|
Some("Playing") => Ok(Poll::Pending),
|
||||||
|
Some("Finished") => Ok(Poll::Ready(resp)),
|
||||||
|
// TODO: replace with err
|
||||||
|
value => panic!("got unexpected match state {:?}", value),
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
async fn poll_match_until_complete(app: &mut Router, match_id: &str) -> io::Result<JsonValue> {
|
||||||
|
let poll_interval = Duration::from_millis(100);
|
||||||
|
let mut interval = tokio::time::interval(poll_interval);
|
||||||
|
loop {
|
||||||
|
interval.tick().await;
|
||||||
|
match poll_match(app, match_id).await {
|
||||||
|
Ok(Poll::Ready(result)) => return Ok(result),
|
||||||
|
Ok(Poll::Pending) => (),
|
||||||
|
Err(err) => return Err(err),
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
#[tokio::test(flavor = "multi_thread")]
|
#[tokio::test(flavor = "multi_thread")]
|
||||||
async fn test_submit_bot() -> io::Result<()> {
|
async fn test_submit_bot() -> io::Result<()> {
|
||||||
let test_app = TestApp::create().await.unwrap();
|
let test_app = TestApp::create().await.unwrap();
|
||||||
|
@ -162,32 +202,13 @@ async fn test_submit_bot() -> io::Result<()> {
|
||||||
let body = hyper::body::to_bytes(response.into_body()).await.unwrap();
|
let body = hyper::body::to_bytes(response.into_body()).await.unwrap();
|
||||||
let resp: JsonValue = serde_json::from_slice(&body).unwrap();
|
let resp: JsonValue = serde_json::from_slice(&body).unwrap();
|
||||||
|
|
||||||
let match_id = &resp["match"]["id"];
|
let match_id = &resp["match"]["id"].as_i64().unwrap();
|
||||||
let mut num_tries = 0;
|
let _match_result = tokio::time::timeout(
|
||||||
loop {
|
Duration::from_secs(10),
|
||||||
num_tries += 1;
|
poll_match_until_complete(&mut app, &match_id.to_string()),
|
||||||
assert!(num_tries <= 100, "time limit exceeded");
|
|
||||||
tokio::time::sleep(Duration::from_millis(100)).await;
|
|
||||||
|
|
||||||
let response = app
|
|
||||||
.call(
|
|
||||||
Request::builder()
|
|
||||||
.method(http::Method::GET)
|
|
||||||
.header("Content-Type", "application/json")
|
|
||||||
.uri(format!("/api/matches/{}", match_id))
|
|
||||||
.body(Body::empty())
|
|
||||||
.unwrap(),
|
|
||||||
)
|
)
|
||||||
.await
|
.await
|
||||||
.unwrap();
|
.expect("fetching match result timed out")
|
||||||
|
.expect("failed to get match result");
|
||||||
assert_eq!(response.status(), StatusCode::OK);
|
Ok(())
|
||||||
let body = hyper::body::to_bytes(response.into_body()).await.unwrap();
|
|
||||||
let resp: JsonValue = serde_json::from_slice(&body).unwrap();
|
|
||||||
match resp["state"].as_str() {
|
|
||||||
Some("Playing") => (), // continue,
|
|
||||||
Some("Finished") => return Ok(()), // success
|
|
||||||
value => panic!("got unexpected match state {:?}", value),
|
|
||||||
}
|
|
||||||
}
|
|
||||||
}
|
}
|
||||||
|
|
Loading…
Reference in a new issue