Merge pull request 'chore: clippy lints' (#44) from chore-clippy into master
All checks were successful
ci/woodpecker/push/woodpecker Pipeline was successful

Reviewed-on: #44
This commit is contained in:
Aravinth Manivannan 2024-07-16 13:20:06 +05:30
commit 89d43f281f
38 changed files with 187 additions and 261 deletions

View file

@ -42,7 +42,7 @@ mod tests {
let msg = CreateSecretMsgBuilder::default() let msg = CreateSecretMsgBuilder::default()
.secret("secret".into()) .secret("secret".into())
.user_id(UUID.clone()) .user_id(UUID)
.build() .build()
.unwrap(); .unwrap();

View file

@ -49,7 +49,7 @@ mod tests {
.unwrap(), .unwrap(),
); );
let msg = VerifySecretExistsMsgBuilder::default() let msg = VerifySecretExistsMsgBuilder::default()
.user_id(user_id.clone()) .user_id(user_id)
.secret(secret.into()) .secret(secret.into())
.build() .build()
.unwrap(); .unwrap();
@ -59,7 +59,7 @@ mod tests {
let create_msg = CreateSecretMsgBuilder::default() let create_msg = CreateSecretMsgBuilder::default()
.secret(secret.into()) .secret(secret.into())
.user_id(user_id.clone()) .user_id(user_id)
.build() .build()
.unwrap(); .unwrap();
db.create_verification_secret(create_msg).await.unwrap(); db.create_verification_secret(create_msg).await.unwrap();

View file

@ -60,7 +60,7 @@ mod tests {
let create_msg = CreateSecretMsgBuilder::default() let create_msg = CreateSecretMsgBuilder::default()
.secret(secret.into()) .secret(secret.into())
.user_id(user_id.clone()) .user_id(user_id)
.build() .build()
.unwrap(); .unwrap();

View file

@ -45,7 +45,7 @@ impl View<User> for UserView {
self.deleted = false; self.deleted = false;
self.first_name = val.first_name().into(); self.first_name = val.first_name().into();
self.last_name = val.last_name().into(); self.last_name = val.last_name().into();
self.user_id = val.user_id().clone(); self.user_id = *val.user_id();
} }
UserEvent::UserDeleted => self.deleted = true, UserEvent::UserDeleted => self.deleted = true,
UserEvent::Loggedin(_) => (), UserEvent::Loggedin(_) => (),

View file

@ -56,7 +56,7 @@ mod tests {
.unwrap(), .unwrap(),
); );
let msg = VerifySecretExistsMsgBuilder::default() let msg = VerifySecretExistsMsgBuilder::default()
.user_id(user_id.clone()) .user_id(user_id)
.secret(secret.into()) .secret(secret.into())
.build() .build()
.unwrap(); .unwrap();
@ -66,7 +66,7 @@ mod tests {
let create_msg = CreateSecretMsgBuilder::default() let create_msg = CreateSecretMsgBuilder::default()
.secret(secret.into()) .secret(secret.into())
.user_id(user_id.clone()) .user_id(user_id)
.build() .build()
.unwrap(); .unwrap();
db.create_verification_secret(create_msg).await.unwrap(); db.create_verification_secret(create_msg).await.unwrap();

View file

@ -29,7 +29,7 @@ mod tests {
fn test_cmd() { fn test_cmd() {
let user_id = UUID; let user_id = UUID;
let secret = "asdfasdf"; let secret = "asdfasdf";
let cmd = MarkUserVerifiedCommand::new(user_id.clone(), secret.into()).unwrap(); let cmd = MarkUserVerifiedCommand::new(user_id, secret.into()).unwrap();
assert_eq!(cmd.user_id(), &user_id); assert_eq!(cmd.user_id(), &user_id);
assert_eq!(cmd.secret(), secret); assert_eq!(cmd.secret(), secret);
} }

View file

@ -22,7 +22,7 @@ impl MarkUserVerifiedUseCase for MarkUserVerifiedService {
cmd: command::MarkUserVerifiedCommand, cmd: command::MarkUserVerifiedCommand,
) -> IdentityResult<()> { ) -> IdentityResult<()> {
let msg = VerifySecretExistsMsgBuilder::default() let msg = VerifySecretExistsMsgBuilder::default()
.user_id(cmd.user_id().clone()) .user_id(*cmd.user_id())
.secret(cmd.secret().into()) .secret(cmd.secret().into())
.build() .build()
.unwrap(); .unwrap();
@ -54,7 +54,7 @@ mod tests {
async fn test_service() { async fn test_service() {
let user_id = UUID; let user_id = UUID;
let secret = "password"; let secret = "password";
let cmd = command::MarkUserVerifiedCommand::new(user_id.clone(), secret.into()).unwrap(); let cmd = command::MarkUserVerifiedCommand::new(user_id, secret.into()).unwrap();
// happy case // happy case
{ {

View file

@ -60,7 +60,7 @@ impl RegisterUserUseCase for RegisterUserService {
.create_verification_secret( .create_verification_secret(
CreateSecretMsgBuilder::default() CreateSecretMsgBuilder::default()
.secret(secret.clone()) .secret(secret.clone())
.user_id(user_id.clone()) .user_id(user_id)
.build() .build()
.unwrap(), .unwrap(),
) )
@ -103,7 +103,7 @@ mod tests {
let cmd = command::UnvalidatedRegisterUserCommandBuilder::default() let cmd = command::UnvalidatedRegisterUserCommandBuilder::default()
.first_name(username.into()) .first_name(username.into())
.last_name(username.into()) .last_name(username.into())
.email(email.into()) .email(email)
.password(password.into()) .password(password.into())
.confirm_password(password.into()) .confirm_password(password.into())
.build() .build()
@ -151,7 +151,7 @@ mod tests {
let cmd = command::UnvalidatedRegisterUserCommandBuilder::default() let cmd = command::UnvalidatedRegisterUserCommandBuilder::default()
.first_name(username.into()) .first_name(username.into())
.last_name(username.into()) .last_name(username.into())
.email(email.into()) .email(email)
.password(password.into()) .password(password.into())
.confirm_password(password.into()) .confirm_password(password.into())
.build() .build()

View file

@ -41,7 +41,7 @@ mod tests {
fn test_cmd() { fn test_cmd() {
let config = argon2_creds::Config::default(); let config = argon2_creds::Config::default();
ResendVerificationEmailCommand::new( ResendVerificationEmailCommand::new(
UUID.clone(), UUID,
"john".into(), "john".into(),
"realaravinth@example.com".into(), "realaravinth@example.com".into(),
&config, &config,
@ -49,13 +49,7 @@ mod tests {
.unwrap(); .unwrap();
assert_eq!( assert_eq!(
ResendVerificationEmailCommand::new( ResendVerificationEmailCommand::new(UUID, "john".into(), "john".into(), &config).err(),
UUID.clone(),
"john".into(),
"john".into(),
&config
)
.err(),
Some(IdentityCommandError::BadEmail) Some(IdentityCommandError::BadEmail)
); );
} }

View file

@ -57,11 +57,11 @@ mod tests {
#[actix_rt::test] #[actix_rt::test]
async fn test_service() { async fn test_service() {
let user_id = UUID; let user_id = UUID;
let email = format!("john@example.com"); let email = "john@example.com".to_string();
let secret = "asdfasdf"; let secret = "asdfasdf";
let config = argon2_creds::Config::default(); let config = argon2_creds::Config::default();
let cmd = command::ResendVerificationEmailCommand::new( let cmd = command::ResendVerificationEmailCommand::new(
UUID.clone(), UUID,
"john".into(), "john".into(),
email.clone(), email.clone(),
&config, &config,
@ -88,11 +88,11 @@ mod tests {
#[actix_rt::test] #[actix_rt::test]
async fn test_service_email_exists() { async fn test_service_email_exists() {
let user_id = UUID; let user_id = UUID;
let email = format!("john@example.com"); let email = "john@example.com".to_string();
let secret = "asdfasdf"; let secret = "asdfasdf";
let config = argon2_creds::Config::default(); let config = argon2_creds::Config::default();
let cmd = command::ResendVerificationEmailCommand::new( let cmd = command::ResendVerificationEmailCommand::new(
UUID.clone(), UUID,
"john".into(), "john".into(),
email.clone(), email.clone(),
&config, &config,

View file

@ -44,7 +44,7 @@ mod tests {
.email_verified(false) .email_verified(false)
.is_admin(true) .is_admin(true)
.deleted(false) .deleted(false)
.user_id(UUID.clone()) .user_id(UUID)
.build() .build()
.unwrap(), .unwrap(),
) )
@ -61,7 +61,7 @@ mod tests {
.is_admin(false) .is_admin(false)
.email_verified(false) .email_verified(false)
.deleted(false) .deleted(false)
.user_id(UUID.clone()) .user_id(UUID)
.build() .build()
.unwrap(), .unwrap(),
) )

View file

@ -38,7 +38,7 @@ mod tests {
.email_verified(false) .email_verified(false)
.is_admin(true) .is_admin(true)
.deleted(false) .deleted(false)
.user_id(UUID.clone()) .user_id(UUID)
.build() .build()
.unwrap(); .unwrap();

View file

@ -49,12 +49,12 @@ mod tests {
let password = "adsfasdfasd"; let password = "adsfasdfasd";
let first_name = "john"; let first_name = "john";
let user_id = UUID; let user_id = UUID;
let new_email = format!("newemail@example.com"); let new_email = "newemail@example.com".to_string();
let hashed_password = config.password(password).unwrap(); let hashed_password = config.password(password).unwrap();
assert_eq!( assert_eq!(
UpdateEmailCommand::new( UpdateEmailCommand::new(
new_email.clone(), new_email.clone(),
user_id.clone(), user_id,
first_name.into(), first_name.into(),
password.into(), password.into(),
&hashed_password, &hashed_password,
@ -69,7 +69,7 @@ mod tests {
assert_eq!( assert_eq!(
UpdateEmailCommand::new( UpdateEmailCommand::new(
user_id.to_string(), user_id.to_string(),
user_id.clone(), user_id,
first_name.into(), first_name.into(),
password.into(), password.into(),
&hashed_password, &hashed_password,
@ -83,7 +83,7 @@ mod tests {
assert_eq!( assert_eq!(
UpdateEmailCommand::new( UpdateEmailCommand::new(
new_email.to_string(), new_email.to_string(),
user_id.clone(), user_id,
first_name.into(), first_name.into(),
first_name.into(), first_name.into(),
&hashed_password, &hashed_password,

View file

@ -44,7 +44,7 @@ impl UpdateEmailUseCase for UpdateEmailService {
.create_verification_secret( .create_verification_secret(
CreateSecretMsgBuilder::default() CreateSecretMsgBuilder::default()
.secret(secret.clone()) .secret(secret.clone())
.user_id(cmd.user_id().clone()) .user_id(*cmd.user_id())
.build() .build()
.unwrap(), .unwrap(),
) )
@ -71,14 +71,14 @@ mod tests {
#[actix_rt::test] #[actix_rt::test]
async fn test_service() { async fn test_service() {
let user_id = UUID; let user_id = UUID;
let new_email = format!("john@example.com"); let new_email = "john@example.com".to_string();
let password = "password"; let password = "password";
let config = argon2_creds::Config::default(); let config = argon2_creds::Config::default();
let hashed_password = config.password(password).unwrap(); let hashed_password = config.password(password).unwrap();
let cmd = command::UpdateEmailCommand::new( let cmd = command::UpdateEmailCommand::new(
new_email.clone(), new_email.clone(),
user_id.clone(), user_id,
"john".into(), "john".into(),
password.into(), password.into(),
&hashed_password, &hashed_password,

View file

@ -55,7 +55,7 @@ mod tests {
) )
.unwrap() .unwrap()
.hashed_new_passowrd, .hashed_new_passowrd,
new_password.into(), new_password,
) )
.unwrap(); .unwrap();

View file

@ -33,7 +33,7 @@ mod tests {
username.into(), username.into(),
password.into(), password.into(),
new_password.clone(), new_password.clone(),
new_password.into(), new_password,
&hashed_password, &hashed_password,
&config, &config,
) )

View file

@ -142,12 +142,12 @@ impl Aggregate for User {
UserEvent::UserRegistered(e) => { UserEvent::UserRegistered(e) => {
self.first_name = e.first_name().into(); self.first_name = e.first_name().into();
self.last_name = e.last_name().into(); self.last_name = e.last_name().into();
self.user_id = e.user_id().clone(); self.user_id = *e.user_id();
self.email = e.email().into(); self.email = e.email().into();
self.hashed_password = e.hashed_password().into(); self.hashed_password = e.hashed_password().into();
self.is_admin = e.is_admin().clone(); self.is_admin = *e.is_admin();
self.email_verified = e.email_verified().clone(); self.email_verified = *e.email_verified();
self.is_verified = e.is_verified().clone(); self.is_verified = *e.is_verified();
self.deleted = false; self.deleted = false;
} }
UserEvent::UserDeleted => { UserEvent::UserDeleted => {

View file

@ -32,15 +32,12 @@ pub struct CategoryView {
// design the events to carry the balance information instead. // design the events to carry the balance information instead.
impl View<Category> for CategoryView { impl View<Category> for CategoryView {
fn update(&mut self, event: &EventEnvelope<Category>) { fn update(&mut self, event: &EventEnvelope<Category>) {
match &event.payload { if let InventoryEvent::CategoryAdded(val) = &event.payload {
InventoryEvent::CategoryAdded(val) => { self.name = val.name().into();
self.name = val.name().into(); self.description = val.description().clone();
self.description = val.description().clone(); self.category_id = *val.category_id();
self.category_id = val.category_id().clone(); self.store_id = *val.store_id();
self.store_id = val.store_id().clone(); self.deleted = false;
self.deleted = false;
}
_ => (),
} }
} }
} }
@ -187,7 +184,7 @@ impl Query<Category> for SimpleLoggingQuery {
impl Query<Category> for InventoryDBPostgresAdapter { impl Query<Category> for InventoryDBPostgresAdapter {
async fn dispatch(&self, category_id: &str, events: &[EventEnvelope<Category>]) { async fn dispatch(&self, category_id: &str, events: &[EventEnvelope<Category>]) {
let res = self let res = self
.load_with_context(&category_id) .load_with_context(category_id)
.await .await
.unwrap_or_else(|_| { .unwrap_or_else(|_| {
Some(( Some((

View file

@ -63,10 +63,10 @@ pub mod tests {
.name(cmd.name().into()) .name(cmd.name().into())
.description(cmd.description().as_ref().map(|s| s.to_string())) .description(cmd.description().as_ref().map(|s| s.to_string()))
.image(cmd.image().as_ref().map(|s| s.to_string())) .image(cmd.image().as_ref().map(|s| s.to_string()))
.sku_able(cmd.sku_able().clone()) .sku_able(*cmd.sku_able())
.category_id(cmd.category_id().clone()) .category_id(*cmd.category_id())
.quantity(cmd.quantity().clone()) .quantity(cmd.quantity().clone())
.product_id(UUID.clone()) .product_id(UUID)
.customizations(customizations) .customizations(customizations)
.price(cmd.price().clone()) .price(cmd.price().clone())
.build() .build()

View file

@ -60,10 +60,10 @@ mod tests {
.name(product_name.into()) .name(product_name.into())
.description(cmd.description().as_ref().map(|s| s.to_string())) .description(cmd.description().as_ref().map(|s| s.to_string()))
.image(cmd.image().as_ref().map(|s| s.to_string())) .image(cmd.image().as_ref().map(|s| s.to_string()))
.sku_able(cmd.sku_able().clone()) .sku_able(*cmd.sku_able())
.category_id(cmd.category_id().clone()) .category_id(*cmd.category_id())
.customizations(Vec::default()) .customizations(Vec::default())
.product_id(UUID.clone()) .product_id(UUID)
.price(cmd.price().clone()) .price(cmd.price().clone())
.quantity(cmd.quantity().clone()) .quantity(cmd.quantity().clone())
.build() .build()

View file

@ -10,8 +10,8 @@ use cqrs_es::{EventEnvelope, Query, View};
use serde::{Deserialize, Serialize}; use serde::{Deserialize, Serialize};
use uuid::Uuid; use uuid::Uuid;
use super::errors::*;
use super::InventoryDBPostgresAdapter; use super::InventoryDBPostgresAdapter;
use super::{errors::*, product_id_exists};
use crate::inventory::domain::events::InventoryEvent; use crate::inventory::domain::events::InventoryEvent;
use crate::inventory::domain::product_aggregate::{ use crate::inventory::domain::product_aggregate::{
Currency, Customization, CustomizationBuilder, PriceBuilder, Product, ProductBuilder, Currency, Customization, CustomizationBuilder, PriceBuilder, Product, ProductBuilder,
@ -122,27 +122,24 @@ impl From<ProductView> for Product {
// design the events to carry the balance information instead. // design the events to carry the balance information instead.
impl View<Product> for ProductView { impl View<Product> for ProductView {
fn update(&mut self, event: &EventEnvelope<Product>) { fn update(&mut self, event: &EventEnvelope<Product>) {
match &event.payload { if let InventoryEvent::ProductAdded(val) = &event.payload {
InventoryEvent::ProductAdded(val) => { self.name = val.name().into();
self.name = val.name().into(); self.description = val.description().clone();
self.description = val.description().clone(); self.image = val.image().clone();
self.image = val.image().clone(); self.product_id = *val.product_id();
self.product_id = val.product_id().clone(); self.category_id = *val.category_id();
self.category_id = val.category_id().clone();
self.sku_able = val.sku_able().clone(); self.sku_able = *val.sku_able();
self.price_minor = val.price().minor().clone() as i32; self.price_minor = *val.price().minor() as i32;
self.price_major = val.price().major().clone() as i32; self.price_major = *val.price().major() as i32;
self.price_currency = val.price().currency().to_string(); self.price_currency = val.price().currency().to_string();
self.quantity_number = val.quantity().number().clone() as i32; self.quantity_number = *val.quantity().number() as i32;
self.quantity_unit = val.quantity().unit().to_string(); self.quantity_unit = val.quantity().unit().to_string();
self.deleted = false; self.deleted = false;
self.customizations = val.customizations().clone(); self.customizations = val.customizations().clone();
}
_ => (),
} }
} }
} }
@ -234,7 +231,7 @@ impl ViewRepository<ProductView, Product> for InventoryDBPostgresAdapter {
.await .await
.map_err(PostgresAggregateError::from)?; .map_err(PostgresAggregateError::from)?;
let customizations = res.get_customizations(&self).await?; let customizations = res.get_customizations(self).await?;
Ok(Some(res.to_product_view(customizations))) Ok(Some(res.to_product_view(customizations)))
} }
@ -273,7 +270,7 @@ impl ViewRepository<ProductView, Product> for InventoryDBPostgresAdapter {
.await .await
.map_err(PostgresAggregateError::from)?; .map_err(PostgresAggregateError::from)?;
let customizations = res.get_customizations(&self).await?; let customizations = res.get_customizations(self).await?;
struct Context { struct Context {
version: i64, version: i64,
@ -436,7 +433,7 @@ impl ViewRepository<ProductView, Product> for InventoryDBPostgresAdapter {
impl Query<Product> for InventoryDBPostgresAdapter { impl Query<Product> for InventoryDBPostgresAdapter {
async fn dispatch(&self, product_id: &str, events: &[EventEnvelope<Product>]) { async fn dispatch(&self, product_id: &str, events: &[EventEnvelope<Product>]) {
let res = self let res = self
.load_with_context(&product_id) .load_with_context(product_id)
.await .await
.unwrap_or_else(|_| { .unwrap_or_else(|_| {
Some(( Some((

View file

@ -66,7 +66,7 @@ pub mod tests {
let store = StoreBuilder::default() let store = StoreBuilder::default()
.name("store_name".into()) .name("store_name".into())
.owner(UUID.clone()) .owner(UUID)
.address(Some("store_address".into())) .address(Some("store_address".into()))
.store_id(store_id) .store_id(store_id)
.build() .build()

View file

@ -52,7 +52,7 @@ mod tests {
let store = StoreBuilder::default() let store = StoreBuilder::default()
.name("store_name".into()) .name("store_name".into())
.owner(UUID.clone()) .owner(UUID)
.address(Some("store_address".into())) .address(Some("store_address".into()))
.store_id(store_id) .store_id(store_id)
.build() .build()

View file

@ -32,15 +32,12 @@ pub struct StoreView {
// design the events to carry the balance information instead. // design the events to carry the balance information instead.
impl View<Store> for StoreView { impl View<Store> for StoreView {
fn update(&mut self, event: &EventEnvelope<Store>) { fn update(&mut self, event: &EventEnvelope<Store>) {
match &event.payload { if let InventoryEvent::StoreAdded(val) = &event.payload {
InventoryEvent::StoreAdded(val) => { self.name = val.name().into();
self.name = val.name().into(); self.address = val.address().clone();
self.address = val.address().clone(); self.store_id = *val.store_id();
self.store_id = val.store_id().clone(); self.owner = *val.owner();
self.owner = val.owner().clone(); self.deleted = false;
self.deleted = false;
}
_ => (),
} }
} }
} }
@ -187,7 +184,7 @@ impl Query<Store> for SimpleLoggingQuery {
impl Query<Store> for InventoryDBPostgresAdapter { impl Query<Store> for InventoryDBPostgresAdapter {
async fn dispatch(&self, store_id: &str, events: &[EventEnvelope<Store>]) { async fn dispatch(&self, store_id: &str, events: &[EventEnvelope<Store>]) {
let res = self let res = self
.load_with_context(&store_id) .load_with_context(store_id)
.await .await
.unwrap_or_else(|_| Some((StoreView::default(), ViewContext::new(store_id.into(), 0)))); .unwrap_or_else(|_| Some((StoreView::default(), ViewContext::new(store_id.into(), 0))));
let (mut view, view_context): (StoreView, ViewContext) = res.unwrap(); let (mut view, view_context): (StoreView, ViewContext) = res.unwrap();
@ -254,7 +251,7 @@ mod tests {
)) ))
.add_category(mock_add_category_service( .add_category(mock_add_category_service(
IS_NEVER_CALLED, IS_NEVER_CALLED,
AddCategoryCommand::new("foo".into(), None, UUID.clone(), UUID.clone()).unwrap(), AddCategoryCommand::new("foo".into(), None, UUID, UUID).unwrap(),
)) ))
.add_product(mock_add_product_service(IS_NEVER_CALLED, get_command())) .add_product(mock_add_product_service(IS_NEVER_CALLED, get_command()))
.build() .build()
@ -273,7 +270,7 @@ mod tests {
); );
let rand = crate::utils::random_string::GenerateRandomString {}; let rand = crate::utils::random_string::GenerateRandomString {};
let cmd = AddStoreCommand::new(rand.get_random(10), None, UUID.clone()).unwrap(); let cmd = AddStoreCommand::new(rand.get_random(10), None, UUID).unwrap();
cqrs.execute("", InventoryCommand::AddStore(cmd.clone())) cqrs.execute("", InventoryCommand::AddStore(cmd.clone()))
.await .await
.unwrap(); .unwrap();

View file

@ -41,7 +41,7 @@ impl AddCategoryUseCase for AddCategoryService {
let mut category = CategoryBuilder::default() let mut category = CategoryBuilder::default()
.name(cmd.name().into()) .name(cmd.name().into())
.description(cmd.description().as_ref().map(|s| s.to_string())) .description(cmd.description().as_ref().map(|s| s.to_string()))
.store_id(cmd.store_id().clone()) .store_id(*cmd.store_id())
.category_id(category_id) .category_id(category_id)
.build() .build()
.unwrap(); .unwrap();
@ -64,7 +64,7 @@ impl AddCategoryUseCase for AddCategoryService {
category = CategoryBuilder::default() category = CategoryBuilder::default()
.name(cmd.name().into()) .name(cmd.name().into())
.description(cmd.description().as_ref().map(|s| s.to_string())) .description(cmd.description().as_ref().map(|s| s.to_string()))
.store_id(cmd.store_id().clone()) .store_id(*cmd.store_id())
.category_id(category_id) .category_id(category_id)
.build() .build()
.unwrap(); .unwrap();
@ -78,9 +78,9 @@ impl AddCategoryUseCase for AddCategoryService {
Ok(CategoryAddedEventBuilder::default() Ok(CategoryAddedEventBuilder::default()
.name(category.name().into()) .name(category.name().into())
.description(category.description().as_ref().map(|s| s.to_string())) .description(category.description().as_ref().map(|s| s.to_string()))
.added_by_user(cmd.adding_by().clone()) .added_by_user(*cmd.adding_by())
.store_id(category.store_id().clone()) .store_id(*category.store_id())
.category_id(category.category_id().clone()) .category_id(*category.category_id())
.build() .build()
.unwrap()) .unwrap())
} }
@ -104,9 +104,9 @@ pub mod tests {
let res = CategoryAddedEventBuilder::default() let res = CategoryAddedEventBuilder::default()
.name(cmd.name().into()) .name(cmd.name().into())
.description(cmd.description().as_ref().map(|s| s.to_string())) .description(cmd.description().as_ref().map(|s| s.to_string()))
.added_by_user(cmd.adding_by().clone()) .added_by_user(*cmd.adding_by())
.store_id(cmd.store_id().clone()) .store_id(*cmd.store_id())
.category_id(UUID.clone()) .category_id(UUID)
.build() .build()
.unwrap(); .unwrap();
@ -129,13 +129,8 @@ pub mod tests {
let store_id = Uuid::new_v4(); let store_id = Uuid::new_v4();
// description = None // description = None
let cmd = AddCategoryCommand::new( let cmd = AddCategoryCommand::new(name.into(), Some(description.into()), store_id, user_id)
name.into(), .unwrap();
Some(description.into()),
store_id.clone(),
user_id.clone(),
)
.unwrap();
let s = AddCategoryServiceBuilder::default() let s = AddCategoryServiceBuilder::default()
.db_category_name_exists_for_store(mock_category_name_exists_for_store_db_port_false( .db_category_name_exists_for_store(mock_category_name_exists_for_store_db_port_false(
@ -162,13 +157,8 @@ pub mod tests {
let store_id = Uuid::new_v4(); let store_id = Uuid::new_v4();
// description = None // description = None
let cmd = AddCategoryCommand::new( let cmd = AddCategoryCommand::new(name.into(), Some(description.into()), store_id, user_id)
name.into(), .unwrap();
Some(description.into()),
store_id.clone(),
user_id.clone(),
)
.unwrap();
let s = AddCategoryServiceBuilder::default() let s = AddCategoryServiceBuilder::default()
.db_category_name_exists_for_store(mock_category_name_exists_for_store_db_port_true( .db_category_name_exists_for_store(mock_category_name_exists_for_store_db_port_true(

View file

@ -11,9 +11,7 @@ use mockall::*;
use super::errors::*; use super::errors::*;
use crate::inventory::{ use crate::inventory::{
application::port::output::db::{ application::port::output::db::{
customization_id_exists::{self, *}, customization_id_exists::*, customization_name_exists_for_product::*, product_id_exists::*,
customization_name_exists_for_product::*,
product_id_exists::*,
product_name_exists_for_category::*, product_name_exists_for_category::*,
}, },
domain::{ domain::{
@ -97,9 +95,9 @@ impl AddProductUseCase for AddProductService {
.name(cmd.name().into()) .name(cmd.name().into())
.description(cmd.description().as_ref().map(|s| s.to_string())) .description(cmd.description().as_ref().map(|s| s.to_string()))
.image(cmd.image().clone()) .image(cmd.image().clone())
.sku_able(cmd.sku_able().clone()) .sku_able(*cmd.sku_able())
.price(cmd.price().clone()) .price(cmd.price().clone())
.category_id(cmd.category_id().clone()) .category_id(*cmd.category_id())
.quantity(cmd.quantity().clone()) .quantity(cmd.quantity().clone())
.customizations(customizations) .customizations(customizations)
.product_id(product_id) .product_id(product_id)
@ -115,14 +113,14 @@ impl AddProductUseCase for AddProductService {
} }
Ok(ProductAddedEventBuilder::default() Ok(ProductAddedEventBuilder::default()
.added_by_user(cmd.adding_by().clone()) .added_by_user(*cmd.adding_by())
.name(product.name().into()) .name(product.name().into())
.description(product.description().as_ref().map(|s| s.to_string())) .description(product.description().as_ref().map(|s| s.to_string()))
.image(product.image().clone()) .image(product.image().clone())
.sku_able(product.sku_able().clone()) .sku_able(*product.sku_able())
.price(product.price().clone()) .price(product.price().clone())
.category_id(product.category_id().clone()) .category_id(*product.category_id())
.product_id(product.product_id().clone()) .product_id(*product.product_id())
.customizations(product.customizations().clone()) .customizations(product.customizations().clone())
.quantity(product.quantity().clone()) .quantity(product.quantity().clone())
.build() .build()
@ -134,8 +132,6 @@ impl AddProductUseCase for AddProductService {
pub mod tests { pub mod tests {
use super::*; use super::*;
use uuid::Uuid;
use crate::inventory::domain::add_product_command::tests::get_command; use crate::inventory::domain::add_product_command::tests::get_command;
use crate::utils::uuid::tests::UUID; use crate::utils::uuid::tests::UUID;
use crate::{tests::bdd::*, utils::uuid::tests::mock_get_uuid}; use crate::{tests::bdd::*, utils::uuid::tests::mock_get_uuid};
@ -162,13 +158,13 @@ pub mod tests {
.name(cmd.name().into()) .name(cmd.name().into())
.description(cmd.description().as_ref().map(|s| s.to_string())) .description(cmd.description().as_ref().map(|s| s.to_string()))
.image(cmd.image().as_ref().map(|s| s.to_string())) .image(cmd.image().as_ref().map(|s| s.to_string()))
.sku_able(cmd.sku_able().clone()) .sku_able(*cmd.sku_able())
.category_id(cmd.category_id().clone()) .category_id(*cmd.category_id())
.product_id(UUID.clone()) .product_id(UUID)
.price(cmd.price().clone()) .price(cmd.price().clone())
.quantity(cmd.quantity().clone()) .quantity(cmd.quantity().clone())
.customizations(customizations) .customizations(customizations)
.added_by_user(cmd.adding_by().clone()) .added_by_user(*cmd.adding_by())
.build() .build()
.unwrap(); .unwrap();

View file

@ -10,9 +10,7 @@ use mockall::*;
use super::errors::*; use super::errors::*;
use crate::inventory::{ use crate::inventory::{
application::port::output::db::{ application::port::output::db::{store_id_exists::*, store_name_exists::*},
errors::InventoryDBError, store_id_exists::*, store_name_exists::*,
},
domain::{ domain::{
add_store_command::AddStoreCommand, add_store_command::AddStoreCommand,
store_added_event::{StoreAddedEvent, StoreAddedEventBuilder}, store_added_event::{StoreAddedEvent, StoreAddedEventBuilder},
@ -43,8 +41,8 @@ impl AddStoreUseCase for AddStoreService {
let mut store = StoreBuilder::default() let mut store = StoreBuilder::default()
.name(cmd.name().into()) .name(cmd.name().into())
.address(cmd.address().as_ref().map(|s| s.to_string())) .address(cmd.address().as_ref().map(|s| s.to_string()))
.owner(cmd.owner().clone()) .owner(*cmd.owner())
.store_id(store_id.clone()) .store_id(store_id)
.build() .build()
.unwrap(); .unwrap();
@ -58,8 +56,8 @@ impl AddStoreUseCase for AddStoreService {
store = StoreBuilder::default() store = StoreBuilder::default()
.name(cmd.name().into()) .name(cmd.name().into())
.address(cmd.address().as_ref().map(|s| s.to_string())) .address(cmd.address().as_ref().map(|s| s.to_string()))
.owner(cmd.owner().clone()) .owner(*cmd.owner())
.store_id(store_id.clone()) .store_id(store_id)
.build() .build()
.unwrap(); .unwrap();
continue; continue;
@ -71,8 +69,8 @@ impl AddStoreUseCase for AddStoreService {
Ok(StoreAddedEventBuilder::default() Ok(StoreAddedEventBuilder::default()
.name(store.name().into()) .name(store.name().into())
.address(store.address().as_ref().map(|s| s.to_string())) .address(store.address().as_ref().map(|s| s.to_string()))
.owner(cmd.owner().clone()) .owner(*cmd.owner())
.store_id(store_id.clone()) .store_id(store_id)
.build() .build()
.unwrap()) .unwrap())
} }
@ -94,8 +92,8 @@ pub mod tests {
let res = StoreAddedEventBuilder::default() let res = StoreAddedEventBuilder::default()
.name(cmd.name().into()) .name(cmd.name().into())
.address(cmd.address().as_ref().map(|s| s.to_string())) .address(cmd.address().as_ref().map(|s| s.to_string()))
.owner(cmd.owner().clone()) .owner(*cmd.owner())
.store_id(UUID.clone()) .store_id(UUID)
.build() .build()
.unwrap(); .unwrap();
@ -117,7 +115,7 @@ pub mod tests {
let owner = UUID; let owner = UUID;
// address = None // address = None
let cmd = AddStoreCommand::new(name.into(), Some(address.into()), owner.clone()).unwrap(); let cmd = AddStoreCommand::new(name.into(), Some(address.into()), owner).unwrap();
let s = AddStoreServiceBuilder::default() let s = AddStoreServiceBuilder::default()
.db_store_id_exists(mock_store_id_exists_db_port_false(IS_CALLED_ONLY_ONCE)) .db_store_id_exists(mock_store_id_exists_db_port_false(IS_CALLED_ONLY_ONCE))
@ -140,7 +138,7 @@ pub mod tests {
let owner = UUID; let owner = UUID;
// address = None // address = None
let cmd = AddStoreCommand::new(name.into(), Some(address.into()), owner.clone()).unwrap(); let cmd = AddStoreCommand::new(name.into(), Some(address.into()), owner).unwrap();
let s = AddStoreServiceBuilder::default() let s = AddStoreServiceBuilder::default()
.db_store_id_exists(mock_store_id_exists_db_port_false(IS_NEVER_CALLED)) .db_store_id_exists(mock_store_id_exists_db_port_false(IS_NEVER_CALLED))

View file

@ -66,21 +66,16 @@ mod tests {
let store_id = Uuid::new_v4(); let store_id = Uuid::new_v4();
// description = None // description = None
let cmd = AddCategoryCommand::new(name.into(), None, store_id.clone(), adding_by.clone()) let cmd = AddCategoryCommand::new(name.into(), None, store_id, adding_by).unwrap();
.unwrap();
assert_eq!(cmd.name(), name); assert_eq!(cmd.name(), name);
assert_eq!(cmd.description(), &None); assert_eq!(cmd.description(), &None);
assert_eq!(cmd.adding_by(), &adding_by); assert_eq!(cmd.adding_by(), &adding_by);
assert_eq!(cmd.store_id(), &store_id); assert_eq!(cmd.store_id(), &store_id);
// description = Some // description = Some
let cmd = AddCategoryCommand::new( let cmd =
name.into(), AddCategoryCommand::new(name.into(), Some(description.into()), store_id, adding_by)
Some(description.into()), .unwrap();
store_id.clone(),
adding_by.clone(),
)
.unwrap();
assert_eq!(cmd.name(), name); assert_eq!(cmd.name(), name);
assert_eq!(cmd.description(), &Some(description.to_owned())); assert_eq!(cmd.description(), &Some(description.to_owned()));
assert_eq!(cmd.adding_by(), &adding_by); assert_eq!(cmd.adding_by(), &adding_by);
@ -88,12 +83,7 @@ mod tests {
// AddCategoryCommandError::NameIsEmpty // AddCategoryCommandError::NameIsEmpty
assert_eq!( assert_eq!(
AddCategoryCommand::new( AddCategoryCommand::new("".into(), Some(description.into()), store_id, adding_by,),
"".into(),
Some(description.into()),
store_id.clone(),
adding_by.clone(),
),
Err(AddCategoryCommandError::NameIsEmpty) Err(AddCategoryCommandError::NameIsEmpty)
) )
} }

View file

@ -181,8 +181,8 @@ pub mod tests {
.name(name.into()) .name(name.into())
.description(description.clone()) .description(description.clone())
.image(image.clone()) .image(image.clone())
.category_id(category_id.clone()) .category_id(category_id)
.adding_by(adding_by.clone()) .adding_by(adding_by)
.quantity(quantity) .quantity(quantity)
.sku_able(sku_able) .sku_able(sku_able)
.price(price.clone()) .price(price.clone())
@ -218,8 +218,8 @@ pub mod tests {
.name(name.into()) .name(name.into())
.description(None) .description(None)
.image(None) .image(None)
.category_id(category_id.clone()) .category_id(category_id)
.adding_by(adding_by.clone()) .adding_by(adding_by)
.quantity(quantity.clone()) .quantity(quantity.clone())
.sku_able(sku_able) .sku_able(sku_able)
.price(price.clone()) .price(price.clone())
@ -265,9 +265,9 @@ pub mod tests {
.name(name.into()) .name(name.into())
.description(description.clone()) .description(description.clone())
.image(image.clone()) .image(image.clone())
.category_id(category_id.clone()) .category_id(category_id)
.quantity(quantity.clone()) .quantity(quantity.clone())
.adding_by(adding_by.clone()) .adding_by(adding_by)
.sku_able(sku_able) .sku_able(sku_able)
.price(price.clone()) .price(price.clone())
.customizations(customizations.clone()) .customizations(customizations.clone())
@ -312,8 +312,8 @@ pub mod tests {
.name("".into()) .name("".into())
.description(description.clone()) .description(description.clone())
.image(image.clone()) .image(image.clone())
.category_id(category_id.clone()) .category_id(category_id)
.adding_by(adding_by.clone()) .adding_by(adding_by)
.quantity(quantity) .quantity(quantity)
.sku_able(sku_able) .sku_able(sku_able)
.customizations(customizations) .customizations(customizations)
@ -365,8 +365,8 @@ pub mod tests {
.name(name.into()) .name(name.into())
.description(description.clone()) .description(description.clone())
.image(image.clone()) .image(image.clone())
.category_id(category_id.clone()) .category_id(category_id)
.adding_by(adding_by.clone()) .adding_by(adding_by)
.quantity(quantity) .quantity(quantity)
.sku_able(sku_able) .sku_able(sku_able)
.customizations(customizations) .customizations(customizations)

View file

@ -59,23 +59,23 @@ mod tests {
fn test_cmd() { fn test_cmd() {
let name = "foo"; let name = "foo";
let address = "bar"; let address = "bar";
let owner = UUID.clone(); let owner = UUID;
// address = None // address = None
let cmd = AddStoreCommand::new(name.into(), None, owner.clone()).unwrap(); let cmd = AddStoreCommand::new(name.into(), None, owner).unwrap();
assert_eq!(cmd.name(), name); assert_eq!(cmd.name(), name);
assert_eq!(cmd.address(), &None); assert_eq!(cmd.address(), &None);
assert_eq!(cmd.owner(), &owner); assert_eq!(cmd.owner(), &owner);
// address = Some // address = Some
let cmd = AddStoreCommand::new(name.into(), Some(address.into()), owner.clone()).unwrap(); let cmd = AddStoreCommand::new(name.into(), Some(address.into()), owner).unwrap();
assert_eq!(cmd.name(), name); assert_eq!(cmd.name(), name);
assert_eq!(cmd.address(), &Some(address.to_owned())); assert_eq!(cmd.address(), &Some(address.to_owned()));
assert_eq!(cmd.owner(), &owner); assert_eq!(cmd.owner(), &owner);
// AddStoreCommandError::NameIsEmpty // AddStoreCommandError::NameIsEmpty
assert_eq!( assert_eq!(
AddStoreCommand::new("".into(), Some(address.into()), owner.clone()), AddStoreCommand::new("".into(), Some(address.into()), owner),
Err(AddStoreCommandError::NameIsEmpty) Err(AddStoreCommandError::NameIsEmpty)
) )
} }

View file

@ -55,17 +55,14 @@ impl Aggregate for Category {
} }
fn apply(&mut self, event: Self::Event) { fn apply(&mut self, event: Self::Event) {
match event { if let InventoryEvent::CategoryAdded(e) = event {
InventoryEvent::CategoryAdded(e) => { *self = CategoryBuilder::default()
*self = CategoryBuilder::default() .name(e.name().into())
.name(e.name().into()) .category_id(*e.category_id())
.category_id(e.category_id().clone()) .description(e.description().clone())
.description(e.description().clone()) .store_id(*e.store_id())
.store_id(e.store_id().clone()) .build()
.build() .unwrap();
.unwrap();
}
_ => (),
} }
} }
} }
@ -96,22 +93,17 @@ mod aggregate_tests {
let description = Some("category_description".to_string()); let description = Some("category_description".to_string());
let adding_by = UUID; let adding_by = UUID;
let store_id = Uuid::new_v4(); let store_id = Uuid::new_v4();
let category_id = UUID.clone(); let category_id = UUID;
let cmd = AddCategoryCommand::new( let cmd =
name.into(), AddCategoryCommand::new(name.into(), description.clone(), store_id, adding_by).unwrap();
description.clone(),
store_id.clone(),
adding_by.clone(),
)
.unwrap();
let expected = CategoryAddedEventBuilder::default() let expected = CategoryAddedEventBuilder::default()
.name(cmd.name().into()) .name(cmd.name().into())
.description(cmd.description().as_ref().map(|s| s.to_string())) .description(cmd.description().as_ref().map(|s| s.to_string()))
.added_by_user(cmd.adding_by().clone()) .added_by_user(*cmd.adding_by())
.store_id(cmd.store_id().clone()) .store_id(*cmd.store_id())
.category_id(category_id.clone()) .category_id(category_id)
.build() .build()
.unwrap(); .unwrap();
let expected = InventoryEvent::CategoryAdded(expected); let expected = InventoryEvent::CategoryAdded(expected);

View file

@ -53,13 +53,13 @@ pub mod tests {
.name(cmd.name().into()) .name(cmd.name().into())
.description(cmd.description().as_ref().map(|s| s.to_string())) .description(cmd.description().as_ref().map(|s| s.to_string()))
.image(cmd.image().as_ref().map(|s| s.to_string())) .image(cmd.image().as_ref().map(|s| s.to_string()))
.sku_able(cmd.sku_able().clone()) .sku_able(*cmd.sku_able())
.category_id(cmd.category_id().clone()) .category_id(*cmd.category_id())
.product_id(UUID.clone()) .product_id(UUID)
.price(cmd.price().clone()) .price(cmd.price().clone())
.customizations(customizations) .customizations(customizations)
.quantity(cmd.quantity().clone()) .quantity(cmd.quantity().clone())
.added_by_user(cmd.adding_by().clone()) .added_by_user(*cmd.adding_by())
.build() .build()
.unwrap() .unwrap()
} }

View file

@ -5,10 +5,10 @@
use std::str::FromStr; use std::str::FromStr;
use async_trait::async_trait; use async_trait::async_trait;
use config::builder;
use cqrs_es::Aggregate; use cqrs_es::Aggregate;
use derive_builder::Builder; use derive_builder::Builder;
use derive_getters::Getters; use derive_getters::Getters;
use derive_more::Display;
use serde::{Deserialize, Serialize}; use serde::{Deserialize, Serialize};
use uuid::Uuid; use uuid::Uuid;
@ -16,12 +16,17 @@ use super::{commands::InventoryCommand, events::InventoryEvent};
use crate::inventory::application::services::errors::*; use crate::inventory::application::services::errors::*;
use crate::inventory::application::services::InventoryServicesInterface; use crate::inventory::application::services::InventoryServicesInterface;
#[derive(Clone, Debug, Serialize, Deserialize, Eq, PartialEq, Ord, PartialOrd)] #[derive(Clone, Display, Debug, Serialize, Deserialize, Eq, PartialEq, Ord, PartialOrd)]
pub enum QuantityUnit { pub enum QuantityUnit {
#[display(fmt = "{}", KILO_GRAM)]
Kilogram, Kilogram,
#[display(fmt = "{}", GRAM)]
Gram, Gram,
#[display(fmt = "{}", DISCRETE_NUMBER)]
DiscreteNumber, // example: 1 sofa, 2 bed, etc. DiscreteNumber, // example: 1 sofa, 2 bed, etc.
#[display(fmt = "{}", MILLI_LITER)]
MilliLiter, MilliLiter,
#[display(fmt = "{}", LITER)]
Liter, Liter,
} }
@ -37,19 +42,6 @@ const DISCRETE_NUMBER: &str = "discrete_number";
const MILLI_LITER: &str = "ml"; const MILLI_LITER: &str = "ml";
const LITER: &str = "l"; const LITER: &str = "l";
impl ToString for QuantityUnit {
fn to_string(&self) -> String {
match self {
Self::Kilogram => KILO_GRAM,
Self::Gram => GRAM,
Self::DiscreteNumber => DISCRETE_NUMBER,
Self::MilliLiter => MILLI_LITER,
Self::Liter => LITER,
}
.into()
}
}
impl FromStr for QuantityUnit { impl FromStr for QuantityUnit {
type Err = String; type Err = String;
fn from_str(s: &str) -> Result<Self, Self::Err> { fn from_str(s: &str) -> Result<Self, Self::Err> {
@ -72,22 +64,14 @@ pub struct Quantity {
unit: QuantityUnit, unit: QuantityUnit,
} }
#[derive(Clone, Debug, Serialize, Deserialize, Eq, PartialEq, Ord, PartialOrd)] #[derive(Clone, Display, Debug, Serialize, Deserialize, Eq, PartialEq, Ord, PartialOrd)]
pub enum Currency { pub enum Currency {
#[display(fmt = "{}", INR)]
INR, INR,
} }
const INR: &str = "INR"; const INR: &str = "INR";
impl ToString for Currency {
fn to_string(&self) -> String {
match self {
Self::INR => INR,
}
.into()
}
}
impl FromStr for Currency { impl FromStr for Currency {
type Err = String; type Err = String;
fn from_str(s: &str) -> Result<Self, Self::Err> { fn from_str(s: &str) -> Result<Self, Self::Err> {
@ -172,23 +156,20 @@ impl Aggregate for Product {
} }
fn apply(&mut self, event: Self::Event) { fn apply(&mut self, event: Self::Event) {
match event { if let InventoryEvent::ProductAdded(e) = event {
InventoryEvent::ProductAdded(e) => { *self = ProductBuilder::default()
*self = ProductBuilder::default() .name(e.name().into())
.name(e.name().into()) .description(e.description().clone())
.description(e.description().clone()) .image(e.image().clone())
.image(e.image().clone()) .price(e.price().clone())
.price(e.price().clone()) .category_id(*e.category_id())
.category_id(e.category_id().clone()) .sku_able(*e.sku_able())
.sku_able(e.sku_able().clone()) .product_id(*e.product_id())
.product_id(e.product_id().clone()) .quantity(e.quantity().clone())
.quantity(e.quantity().clone()) .customizations(e.customizations().clone())
.customizations(e.customizations().clone()) .deleted(false)
.deleted(false) .build()
.build() .unwrap();
.unwrap();
}
_ => (),
} }
} }
} }

View file

@ -55,15 +55,12 @@ impl Aggregate for Store {
} }
fn apply(&mut self, event: Self::Event) { fn apply(&mut self, event: Self::Event) {
match event { if let InventoryEvent::StoreAdded(e) = event {
InventoryEvent::StoreAdded(e) => { self.name = e.name().into();
self.name = e.name().into(); self.address = e.address().as_ref().map(|s| s.to_string());
self.address = e.address().as_ref().map(|s| s.to_string()); self.owner = *e.owner();
self.owner = e.owner().clone(); self.store_id = *e.store_id();
self.store_id = e.store_id().clone(); self.deleted = false;
self.deleted = false;
}
_ => (),
} }
} }
} }
@ -99,13 +96,13 @@ mod tests {
let expected = StoreAddedEventBuilder::default() let expected = StoreAddedEventBuilder::default()
.name(name.into()) .name(name.into())
.address(address.clone()) .address(address.clone())
.store_id(store_id.clone()) .store_id(store_id)
.owner(owner.into()) .owner(owner)
.build() .build()
.unwrap(); .unwrap();
let expected = InventoryEvent::StoreAdded(expected); let expected = InventoryEvent::StoreAdded(expected);
let cmd = AddStoreCommand::new(name.into(), address.clone(), owner.clone()).unwrap(); let cmd = AddStoreCommand::new(name.into(), address.clone(), owner).unwrap();
let mut services = MockInventoryServicesInterface::new(); let mut services = MockInventoryServicesInterface::new();
services services

View file

@ -75,8 +75,6 @@ mod tests {
"postgres://test_db_env_override", "postgres://test_db_env_override",
database.url database.url
); );
assert!(true);
}) })
.join() .join()
.unwrap(); .unwrap();

View file

@ -65,7 +65,6 @@ mod tests {
"asdfasdflkjhasdlkfhalksdf", "asdfasdflkjhasdlkfhalksdf",
server.cookie_secret server.cookie_secret
); );
assert!(true);
}) })
.join() .join()
.unwrap(); .unwrap();

View file

@ -10,18 +10,18 @@ pub fn parse_aggregate_id<T: Default>(
non_id: &str, non_id: &str,
) -> Result<Option<(T, ViewContext)>, PersistenceError> { ) -> Result<Option<(T, ViewContext)>, PersistenceError> {
match Uuid::parse_str(aggregate_id) { match Uuid::parse_str(aggregate_id) {
Ok(_) => return Ok(None), Ok(_) => Ok(None),
Err(e) => { Err(e) => {
if aggregate_id == non_id { if aggregate_id == non_id {
// if store_id is unbearable, then store isn't created yet. Use cleaner, robust method // if store_id is unbearable, then store isn't created yet. Use cleaner, robust method
// later. // later.
return Ok(Some(( Ok(Some((
T::default(), T::default(),
ViewContext::new(aggregate_id.into(), 0), ViewContext::new(aggregate_id.into(), 0),
))); )))
} else { } else {
return Err(PersistenceError::UnknownError(Box::new(e))); Err(PersistenceError::UnknownError(Box::new(e)))
} }
} }
}; }
} }

View file

@ -50,9 +50,9 @@ pub mod tests {
let mut m = MockGetUUID::new(); let mut m = MockGetUUID::new();
if let Some(times) = times { if let Some(times) = times {
m.expect_get_uuid().times(times).return_const(UUID.clone()); m.expect_get_uuid().times(times).return_const(UUID);
} else { } else {
m.expect_get_uuid().return_const(UUID.clone()); m.expect_get_uuid().return_const(UUID);
} }
Arc::new(m) Arc::new(m)