fix test compile errors

This commit is contained in:
appflowy 2021-09-02 17:43:10 +08:00
parent b8332d28c1
commit 6b7557314c
16 changed files with 38 additions and 115 deletions

View file

@ -4,4 +4,4 @@ pub const HEARTBEAT_INTERVAL: Duration = Duration::from_secs(8);
pub const PING_TIMEOUT: Duration = Duration::from_secs(60); pub const PING_TIMEOUT: Duration = Duration::from_secs(60);
pub const MAX_PAYLOAD_SIZE: usize = 262_144; // max payload size is 256k pub const MAX_PAYLOAD_SIZE: usize = 262_144; // max payload size is 256k
pub const IGNORE_ROUTES: [&str; 2] = ["/api/register", "/api/auth/"]; pub const IGNORE_ROUTES: [&str; 2] = ["/api/register", "/api/auth"];

View file

@ -2,8 +2,6 @@ use crate::user_service::{LoggedUser, AUTHORIZED_USERS};
use actix_service::{Service, Transform}; use actix_service::{Service, Transform};
use actix_web::{ use actix_web::{
dev::{ServiceRequest, ServiceResponse}, dev::{ServiceRequest, ServiceResponse},
http::{HeaderName, HeaderValue, Method},
web::Data,
Error, Error,
HttpResponse, HttpResponse,
ResponseError, ResponseError,
@ -11,15 +9,11 @@ use actix_web::{
use crate::config::IGNORE_ROUTES; use crate::config::IGNORE_ROUTES;
use actix_web::{body::AnyBody, dev::MessageBody}; use actix_web::{body::AnyBody, dev::MessageBody};
use flowy_net::{config::HEADER_TOKEN, errors::ServerError, response::FlowyResponse}; use flowy_net::{config::HEADER_TOKEN, errors::ServerError};
use futures::{ use futures::future::{ok, LocalBoxFuture, Ready};
future::{ok, LocalBoxFuture, Ready},
Future,
};
use std::{ use std::{
convert::TryInto, convert::TryInto,
error::Error as StdError, error::Error as StdError,
pin::Pin,
task::{Context, Poll}, task::{Context, Poll},
}; };
@ -59,7 +53,7 @@ where
self.service.poll_ready(cx) self.service.poll_ready(cx)
} }
fn call(&self, mut req: ServiceRequest) -> Self::Future { fn call(&self, req: ServiceRequest) -> Self::Future {
let mut authenticate_pass: bool = false; let mut authenticate_pass: bool = false;
for ignore_route in IGNORE_ROUTES.iter() { for ignore_route in IGNORE_ROUTES.iter() {
if req.path().starts_with(ignore_route) { if req.path().starts_with(ignore_route) {

View file

@ -12,7 +12,7 @@ use crate::{
use anyhow::Context; use anyhow::Context;
use chrono::Utc; use chrono::Utc;
use flowy_net::errors::invalid_params; use flowy_net::errors::invalid_params;
use flowy_user::entities::parser::UserId;
use flowy_workspace::{ use flowy_workspace::{
entities::{ entities::{
app::parser::{AppDesc, AppName}, app::parser::{AppDesc, AppName},

View file

@ -10,7 +10,7 @@ use crate::{
use crate::user_service::LoggedUser; use crate::user_service::LoggedUser;
use actix_web::{ use actix_web::{
web::{Data, Path, Payload}, web::{Data, Payload},
HttpResponse, HttpResponse,
}; };
use flowy_net::errors::ServerError; use flowy_net::errors::ServerError;

View file

@ -10,7 +10,6 @@ use flowy_net::{
errors::{invalid_params, ServerError}, errors::{invalid_params, ServerError},
response::FlowyResponse, response::FlowyResponse,
}; };
use flowy_user::entities::parser::UserId;
use crate::{ use crate::{
user_service::LoggedUser, user_service::LoggedUser,

View file

@ -18,7 +18,7 @@ impl std::convert::Into<AnyBody> for FlowyResponse {
fn into(self) -> AnyBody { fn into(self) -> AnyBody {
match serde_json::to_string(&self) { match serde_json::to_string(&self) {
Ok(body) => AnyBody::from(body), Ok(body) => AnyBody::from(body),
Err(err) => AnyBody::Empty, Err(_) => AnyBody::Empty,
} }
} }
} }

View file

@ -44,7 +44,6 @@ pub(crate) fn create_default_workspace_if_need(user_id: &str) -> Result<(), User
let payload: Bytes = CreateWorkspaceRequest { let payload: Bytes = CreateWorkspaceRequest {
name: DEFAULT_WORKSPACE_NAME.to_string(), name: DEFAULT_WORKSPACE_NAME.to_string(),
desc: DEFAULT_WORKSPACE_DESC.to_string(), desc: DEFAULT_WORKSPACE_DESC.to_string(),
user_id: user_id.to_string(),
} }
.into_bytes() .into_bytes()
.unwrap(); .unwrap();
@ -52,21 +51,12 @@ pub(crate) fn create_default_workspace_if_need(user_id: &str) -> Result<(), User
let request = ModuleRequest::new(CreateWorkspace).payload(payload); let request = ModuleRequest::new(CreateWorkspace).payload(payload);
let result = EventDispatch::sync_send(request) let result = EventDispatch::sync_send(request)
.parse::<Workspace, DispatchError>() .parse::<Workspace, DispatchError>()
.map_err(|e| { .map_err(|e| ErrorBuilder::new(ErrorCode::CreateDefaultWorkspaceFailed).error(e).build())?;
ErrorBuilder::new(ErrorCode::CreateDefaultWorkspaceFailed)
.error(e)
.build()
})?;
let workspace = result.map_err(|e| { let workspace = result.map_err(|e| ErrorBuilder::new(ErrorCode::CreateDefaultWorkspaceFailed).error(e).build())?;
ErrorBuilder::new(ErrorCode::CreateDefaultWorkspaceFailed)
.error(e)
.build()
})?;
let query: Bytes = QueryWorkspaceRequest { let query: Bytes = QueryWorkspaceRequest {
workspace_id: Some(workspace.id.clone()), workspace_id: Some(workspace.id.clone()),
user_id: user_id.to_string(),
} }
.into_bytes() .into_bytes()
.unwrap(); .unwrap();

View file

@ -6,7 +6,6 @@ use crate::{
use crate::{entities::UpdateUserParams, services::server::UserServerAPI}; use crate::{entities::UpdateUserParams, services::server::UserServerAPI};
use flowy_infra::future::ResultFuture; use flowy_infra::future::ResultFuture;
use flowy_net::{config::*, request::HttpRequestBuilder}; use flowy_net::{config::*, request::HttpRequestBuilder};
use std::sync::Arc;
pub struct UserServer {} pub struct UserServer {}
impl UserServer { impl UserServer {

View file

@ -2,6 +2,6 @@ mod app_handler;
mod view_handler; mod view_handler;
mod workspace_handler; mod workspace_handler;
pub use app_handler::*; pub(crate) use app_handler::*;
pub use view_handler::*; pub(crate) use view_handler::*;
pub use workspace_handler::*; pub(crate) use workspace_handler::*;

View file

@ -7,7 +7,7 @@ use crate::{
sql_tables::app::{AppTable, AppTableChangeset, AppTableSql}, sql_tables::app::{AppTable, AppTableChangeset, AppTableSql},
}; };
use flowy_dispatch::prelude::DispatchFuture; use flowy_dispatch::prelude::DispatchFuture;
use flowy_net::request::HttpRequestBuilder;
use std::sync::Arc; use std::sync::Arc;
pub(crate) struct AppController { pub(crate) struct AppController {

View file

@ -1,6 +1,6 @@
pub use app_controller::*; pub(crate) use app_controller::*;
pub use view_controller::*; pub(crate) use view_controller::*;
pub use workspace_controller::*; pub(crate) use workspace_controller::*;
mod app_controller; mod app_controller;
mod database; mod database;

View file

@ -59,7 +59,7 @@ impl WorkspaceServerAPI for WorkspaceServerMock {
} }
fn read_view(&self, _token: &str, _params: QueryViewParams) -> ResultFuture<Option<View>, WorkspaceError> { fn read_view(&self, _token: &str, _params: QueryViewParams) -> ResultFuture<Option<View>, WorkspaceError> {
ResultFuture::new(async { Ok((None)) }) ResultFuture::new(async { Ok(None) })
} }
fn delete_view(&self, _token: &str, _params: DeleteViewParams) -> ResultFuture<(), WorkspaceError> { fn delete_view(&self, _token: &str, _params: DeleteViewParams) -> ResultFuture<(), WorkspaceError> {

View file

@ -1,12 +1,12 @@
use crate::{ use crate::{
entities::view::{CreateViewParams, DeleteViewParams, QueryViewParams, UpdateViewParams, View}, entities::view::{CreateViewParams, UpdateViewParams, View},
errors::WorkspaceError, errors::WorkspaceError,
module::WorkspaceDatabase, module::WorkspaceDatabase,
observable::{send_observable, WorkspaceObservable}, observable::{send_observable, WorkspaceObservable},
services::server::Server, services::server::Server,
sql_tables::view::{ViewTable, ViewTableChangeset, ViewTableSql}, sql_tables::view::{ViewTable, ViewTableChangeset, ViewTableSql},
}; };
use flowy_net::request::HttpRequestBuilder;
use std::sync::Arc; use std::sync::Arc;
pub(crate) struct ViewController { pub(crate) struct ViewController {

View file

@ -8,8 +8,8 @@ use crate::{
}; };
use flowy_dispatch::prelude::DispatchFuture; use flowy_dispatch::prelude::DispatchFuture;
use flowy_infra::kv::KVStore; use flowy_infra::kv::KVStore;
use flowy_net::request::HttpRequestBuilder;
use std::{future::Future, sync::Arc}; use std::sync::Arc;
pub(crate) struct WorkspaceController { pub(crate) struct WorkspaceController {
pub user: Arc<dyn WorkspaceUser>, pub user: Arc<dyn WorkspaceUser>,

View file

@ -18,14 +18,9 @@ pub fn create_workspace(name: &str, desc: &str) -> (String, Workspace) {
let request = CreateWorkspaceRequest { let request = CreateWorkspaceRequest {
name: name.to_owned(), name: name.to_owned(),
desc: desc.to_owned(), desc: desc.to_owned(),
user_id: user_id.clone(),
}; };
let workspace = builder let workspace = builder.event(CreateWorkspace).request(request).sync_send().parse::<Workspace>();
.event(CreateWorkspace)
.request(request)
.sync_send()
.parse::<Workspace>();
(user_id, workspace) (user_id, workspace)
} }
@ -38,10 +33,7 @@ pub fn read_workspaces(request: QueryWorkspaceRequest) -> Option<Workspace> {
.parse::<RepeatedWorkspace>(); .parse::<RepeatedWorkspace>();
debug_assert_eq!(repeated_workspace.len(), 1); debug_assert_eq!(repeated_workspace.len(), 1);
repeated_workspace repeated_workspace.drain(..1).collect::<Vec<Workspace>>().pop()
.drain(..1)
.collect::<Vec<Workspace>>()
.pop()
} }
pub fn create_app(name: &str, desc: &str, workspace_id: &str) -> App { pub fn create_app(name: &str, desc: &str, workspace_id: &str) -> App {
@ -65,25 +57,13 @@ pub fn delete_app(app_id: &str) {
app_id: app_id.to_string(), app_id: app_id.to_string(),
}; };
AnnieTestBuilder::new() AnnieTestBuilder::new().event(DeleteApp).request(delete_app_request).sync_send();
.event(DeleteApp)
.request(delete_app_request)
.sync_send();
} }
pub fn update_app(request: UpdateAppRequest) { pub fn update_app(request: UpdateAppRequest) { AnnieTestBuilder::new().event(UpdateApp).request(request).sync_send(); }
AnnieTestBuilder::new()
.event(UpdateApp)
.request(request)
.sync_send();
}
pub fn read_app(request: QueryAppRequest) -> App { pub fn read_app(request: QueryAppRequest) -> App {
let app = AnnieTestBuilder::new() let app = AnnieTestBuilder::new().event(ReadApp).request(request).sync_send().parse::<App>();
.event(ReadApp)
.request(request)
.sync_send()
.parse::<App>();
app app
} }
@ -112,17 +92,6 @@ pub fn create_view() -> View {
create_view_with_request(request) create_view_with_request(request)
} }
pub fn update_view(request: UpdateViewRequest) { pub fn update_view(request: UpdateViewRequest) { AnnieTestBuilder::new().event(UpdateView).request(request).sync_send(); }
AnnieTestBuilder::new()
.event(UpdateView)
.request(request)
.sync_send();
}
pub fn read_view(request: QueryViewRequest) -> View { pub fn read_view(request: QueryViewRequest) -> View { AnnieTestBuilder::new().event(ReadView).request(request).sync_send().parse::<View>() }
AnnieTestBuilder::new()
.event(ReadView)
.request(request)
.sync_send()
.parse::<View>()
}

View file

@ -10,11 +10,8 @@ fn workspace_create_success() { let _ = create_workspace("First workspace", "");
#[test] #[test]
fn workspace_read_all() { fn workspace_read_all() {
let (user_id, _) = create_workspace( let (_, _) = create_workspace("Workspace A", "workspace_create_and_then_get_workspace_success");
"Workspace A", let request = QueryWorkspaceRequest::new();
"workspace_create_and_then_get_workspace_success",
);
let request = QueryWorkspaceRequest::new(&user_id);
let workspaces = AnnieTestBuilder::new() let workspaces = AnnieTestBuilder::new()
.event(ReadWorkspaces) .event(ReadWorkspaces)
.request(request) .request(request)
@ -26,21 +23,18 @@ fn workspace_read_all() {
#[test] #[test]
fn workspace_create_and_then_get_workspace() { fn workspace_create_and_then_get_workspace() {
let (user_id, workspace) = create_workspace( let (_user_id, workspace) = create_workspace("Workspace A", "workspace_create_and_then_get_workspace_success");
"Workspace A", let request = QueryWorkspaceRequest::new().workspace_id(&workspace.id);
"workspace_create_and_then_get_workspace_success",
);
let request = QueryWorkspaceRequest::new(&user_id).workspace_id(&workspace.id);
let workspace_from_db = read_workspaces(request).unwrap(); let workspace_from_db = read_workspaces(request).unwrap();
assert_eq!(workspace.name, workspace_from_db.name); assert_eq!(workspace.name, workspace_from_db.name);
} }
#[test] #[test]
fn workspace_create_with_apps() { fn workspace_create_with_apps() {
let (user_id, workspace) = create_workspace("Workspace", ""); let (_user_id, workspace) = create_workspace("Workspace", "");
let app = create_app("App A", "AppFlowy Github Project", &workspace.id); let app = create_app("App A", "AppFlowy Github Project", &workspace.id);
let request = QueryWorkspaceRequest::new(&user_id).workspace_id(&workspace.id); let request = QueryWorkspaceRequest::new().workspace_id(&workspace.id);
let workspace_from_db = read_workspaces(request).unwrap(); let workspace_from_db = read_workspaces(request).unwrap();
assert_eq!(&app, workspace_from_db.apps.first_or_crash()); assert_eq!(&app, workspace_from_db.apps.first_or_crash());
} }
@ -49,21 +43,10 @@ fn workspace_create_with_apps() {
fn workspace_create_with_invalid_name() { fn workspace_create_with_invalid_name() {
for name in invalid_workspace_name_test_case() { for name in invalid_workspace_name_test_case() {
let builder = AnnieTestBuilder::new(); let builder = AnnieTestBuilder::new();
let user_id = builder.user_detail.as_ref().unwrap().id.clone(); let request = CreateWorkspaceRequest { name, desc: "".to_owned() };
let request = CreateWorkspaceRequest {
name,
desc: "".to_owned(),
user_id: user_id.clone(),
};
assert_eq!( assert_eq!(
builder builder.event(CreateWorkspace).request(request).sync_send().error().code,
.event(CreateWorkspace)
.request(request)
.sync_send()
.error()
.code,
ErrorCode::WorkspaceNameInvalid ErrorCode::WorkspaceNameInvalid
) )
} }
@ -73,21 +56,10 @@ fn workspace_create_with_invalid_name() {
fn workspace_update_with_invalid_name() { fn workspace_update_with_invalid_name() {
for name in invalid_workspace_name_test_case() { for name in invalid_workspace_name_test_case() {
let builder = AnnieTestBuilder::new(); let builder = AnnieTestBuilder::new();
let user_id = builder.user_detail.as_ref().unwrap().id.clone(); let request = CreateWorkspaceRequest { name, desc: "".to_owned() };
let request = CreateWorkspaceRequest {
name,
desc: "".to_owned(),
user_id: user_id.clone(),
};
assert_eq!( assert_eq!(
builder builder.event(CreateWorkspace).request(request).sync_send().error().code,
.event(CreateWorkspace)
.request(request)
.sync_send()
.error()
.code,
ErrorCode::WorkspaceNameInvalid ErrorCode::WorkspaceNameInvalid
) )
} }