|
@@ -1,6 +1,6 @@
|
|
|
use crate::{
|
|
|
- helper::{valid_email, valid_password},
|
|
|
- init_sdk,
|
|
|
+ helper::{random_valid_email, valid_password},
|
|
|
+ init_test_sdk,
|
|
|
};
|
|
|
use flowy_dispatch::prelude::*;
|
|
|
pub use flowy_sdk::*;
|
|
@@ -13,101 +13,34 @@ use std::{
|
|
|
convert::TryFrom,
|
|
|
fmt::{Debug, Display},
|
|
|
hash::Hash,
|
|
|
- marker::PhantomData,
|
|
|
+ sync::Arc,
|
|
|
thread,
|
|
|
};
|
|
|
|
|
|
-pub struct Tester<Error> {
|
|
|
- inner_request: Option<ModuleRequest>,
|
|
|
- assert_status_code: Option<StatusCode>,
|
|
|
+pub struct TesterContext {
|
|
|
+ request: Option<ModuleRequest>,
|
|
|
response: Option<EventResponse>,
|
|
|
- err_phantom: PhantomData<Error>,
|
|
|
- user_detail: Option<UserDetail>,
|
|
|
+ status_code: StatusCode,
|
|
|
+ server: ArcFlowyServer,
|
|
|
+ user_email: String,
|
|
|
}
|
|
|
|
|
|
-impl<Error> Tester<Error>
|
|
|
-where
|
|
|
- Error: FromBytes + Debug,
|
|
|
-{
|
|
|
- pub fn new<E>(event: E) -> Self
|
|
|
- where
|
|
|
- E: Eq + Hash + Debug + Clone + Display,
|
|
|
- {
|
|
|
- init_sdk();
|
|
|
- log::trace!(
|
|
|
- "{:?} thread started: thread_id= {}",
|
|
|
- thread::current(),
|
|
|
- thread_id::get()
|
|
|
- );
|
|
|
-
|
|
|
- Self {
|
|
|
- inner_request: Some(ModuleRequest::new(event)),
|
|
|
- assert_status_code: None,
|
|
|
- response: None,
|
|
|
- err_phantom: PhantomData,
|
|
|
- user_detail: None,
|
|
|
- }
|
|
|
- }
|
|
|
-
|
|
|
- pub fn set_request<P>(&mut self, request: P)
|
|
|
- where
|
|
|
- P: ToBytes,
|
|
|
- {
|
|
|
- let mut inner_request = self.inner_request.take().unwrap();
|
|
|
- let bytes = request.into_bytes().unwrap();
|
|
|
- inner_request = inner_request.payload(bytes);
|
|
|
- self.inner_request = Some(inner_request);
|
|
|
- }
|
|
|
-
|
|
|
- pub fn assert_error(&mut self) { self.assert_status_code = Some(StatusCode::Err); }
|
|
|
-
|
|
|
- pub fn assert_success(&mut self) { self.assert_status_code = Some(StatusCode::Ok); }
|
|
|
-
|
|
|
- pub async fn async_send(&mut self) {
|
|
|
- assert_eq!(self.inner_request.is_some(), true, "must set event");
|
|
|
-
|
|
|
- let resp = EventDispatch::async_send(self.inner_request.take().unwrap()).await;
|
|
|
- self.response = Some(resp);
|
|
|
- }
|
|
|
-
|
|
|
- pub fn sync_send(&mut self) {
|
|
|
- let resp = EventDispatch::sync_send(self.inner_request.take().unwrap());
|
|
|
- self.response = Some(resp);
|
|
|
- }
|
|
|
-
|
|
|
- pub fn parse<R>(self) -> R
|
|
|
- where
|
|
|
- R: FromBytes,
|
|
|
- {
|
|
|
- let response = self.response.unwrap();
|
|
|
- match response.parse::<R, Error>() {
|
|
|
- Ok(Ok(data)) => data,
|
|
|
- Ok(Err(e)) => panic!("parse failed: {:?}", e),
|
|
|
- Err(e) => panic!("Internal error: {:?}", e),
|
|
|
- }
|
|
|
- }
|
|
|
-
|
|
|
- pub fn error(self) -> Error {
|
|
|
- let response = self.response.unwrap();
|
|
|
- assert_eq!(response.status_code, StatusCode::Err);
|
|
|
- <Data<Error>>::try_from(response.payload)
|
|
|
- .unwrap()
|
|
|
- .into_inner()
|
|
|
+impl TesterContext {
|
|
|
+ pub fn new(email: String) -> Self {
|
|
|
+ let mut ctx = TesterContext::default();
|
|
|
+ ctx.user_email = email;
|
|
|
+ ctx
|
|
|
}
|
|
|
}
|
|
|
|
|
|
-pub struct TesterContext {
|
|
|
- request: Option<ModuleRequest>,
|
|
|
- status_code: StatusCode,
|
|
|
- response: Option<EventResponse>,
|
|
|
-}
|
|
|
-
|
|
|
impl std::default::Default for TesterContext {
|
|
|
fn default() -> Self {
|
|
|
Self {
|
|
|
request: None,
|
|
|
status_code: StatusCode::Ok,
|
|
|
response: None,
|
|
|
+ server: Arc::new(FlowyServerMocker {}),
|
|
|
+ user_email: random_valid_email(),
|
|
|
}
|
|
|
}
|
|
|
}
|
|
@@ -115,18 +48,20 @@ impl std::default::Default for TesterContext {
|
|
|
pub trait TesterTrait {
|
|
|
type Error: FromBytes + Debug;
|
|
|
|
|
|
- fn context(&mut self) -> &mut TesterContext;
|
|
|
+ fn mut_context(&mut self) -> &mut TesterContext;
|
|
|
|
|
|
- fn assert_error(&mut self) { self.context().status_code = StatusCode::Err; }
|
|
|
+ fn context(&self) -> &TesterContext;
|
|
|
|
|
|
- fn assert_success(&mut self) { self.context().status_code = StatusCode::Ok; }
|
|
|
+ fn assert_error(&mut self) { self.mut_context().status_code = StatusCode::Err; }
|
|
|
+
|
|
|
+ fn assert_success(&mut self) { self.mut_context().status_code = StatusCode::Ok; }
|
|
|
|
|
|
fn set_event<E>(&mut self, event: E)
|
|
|
where
|
|
|
E: Eq + Hash + Debug + Clone + Display,
|
|
|
{
|
|
|
- init_sdk();
|
|
|
- self.context().request = Some(ModuleRequest::new(event));
|
|
|
+ init_test_sdk(self.context().server.clone());
|
|
|
+ self.mut_context().request = Some(ModuleRequest::new(event));
|
|
|
}
|
|
|
|
|
|
fn set_payload<P>(&mut self, payload: P)
|
|
@@ -134,20 +69,20 @@ pub trait TesterTrait {
|
|
|
P: ToBytes,
|
|
|
{
|
|
|
let bytes = payload.into_bytes().unwrap();
|
|
|
- let module_request = self.context().request.take().unwrap();
|
|
|
- self.context().request = Some(module_request.payload(bytes));
|
|
|
+ let module_request = self.mut_context().request.take().unwrap();
|
|
|
+ self.mut_context().request = Some(module_request.payload(bytes));
|
|
|
}
|
|
|
|
|
|
fn sync_send(&mut self) {
|
|
|
- let resp = EventDispatch::sync_send(self.context().request.take().unwrap());
|
|
|
- self.context().response = Some(resp);
|
|
|
+ let resp = EventDispatch::sync_send(self.mut_context().request.take().unwrap());
|
|
|
+ self.mut_context().response = Some(resp);
|
|
|
}
|
|
|
|
|
|
fn parse<R>(&mut self) -> R
|
|
|
where
|
|
|
R: FromBytes,
|
|
|
{
|
|
|
- let response = self.context().response.clone().unwrap();
|
|
|
+ let response = self.mut_context().response.clone().unwrap();
|
|
|
match response.parse::<R, Self::Error>() {
|
|
|
Ok(Ok(data)) => data,
|
|
|
Ok(Err(e)) => panic!("parse failed: {:?}", e),
|
|
@@ -156,7 +91,7 @@ pub trait TesterTrait {
|
|
|
}
|
|
|
|
|
|
fn error(&mut self) -> Self::Error {
|
|
|
- let response = self.context().response.clone().unwrap();
|
|
|
+ let response = self.mut_context().response.clone().unwrap();
|
|
|
assert_eq!(response.status_code, StatusCode::Err);
|
|
|
<Data<Self::Error>>::try_from(response.payload)
|
|
|
.unwrap()
|
|
@@ -164,21 +99,26 @@ pub trait TesterTrait {
|
|
|
}
|
|
|
|
|
|
fn login(&self) -> UserDetail {
|
|
|
- init_sdk();
|
|
|
- let _ = EventDispatch::sync_send(ModuleRequest::new(SignOut));
|
|
|
- let request = SignInRequest {
|
|
|
- email: valid_email(),
|
|
|
+ init_test_sdk(self.context().server.clone());
|
|
|
+ self.logout();
|
|
|
+ let payload = SignInRequest {
|
|
|
+ email: self.context().user_email.clone(),
|
|
|
password: valid_password(),
|
|
|
- };
|
|
|
+ }
|
|
|
+ .into_bytes()
|
|
|
+ .unwrap();
|
|
|
+
|
|
|
+ let request = ModuleRequest::new(SignIn).payload(payload);
|
|
|
+ let user_detail = EventDispatch::sync_send(request)
|
|
|
+ .parse::<UserDetail, UserError>()
|
|
|
+ .unwrap()
|
|
|
+ .unwrap();
|
|
|
|
|
|
- let mut tester = Tester::<UserError>::new(SignIn);
|
|
|
- tester.set_request(request);
|
|
|
- tester.sync_send();
|
|
|
- tester.parse::<UserDetail>()
|
|
|
+ user_detail
|
|
|
}
|
|
|
|
|
|
fn logout(&self) {
|
|
|
- init_sdk();
|
|
|
+ init_test_sdk(self.context().server.clone());
|
|
|
let _ = EventDispatch::sync_send(ModuleRequest::new(SignOut));
|
|
|
}
|
|
|
}
|