Added ElementUpdateStrategy to DbElement, performed necessary code changes

This commit is contained in:
Philip (a-0) 2024-02-13 17:57:40 +01:00
parent 605c2b7856
commit 1b1f1dfffa
5 changed files with 44 additions and 24 deletions

View file

@ -1,7 +1,7 @@
use tracing::debug;
use ubisync_lib::peer::Peer;
use ubisync_lib::types::PeerId;
use ubisync_lib::types::{ElementUpdateStrategy, PeerId};
use ubisync_lib::messages::{Message, MessageContent};
@ -20,6 +20,7 @@ pub fn handle(state: &CommState, peer: &PeerId, message: Message) {
.add_received_element(
id.to_owned(),
content.to_owned(),
ElementUpdateStrategy::Overwrite,
Some(message.id().to_owned()),
pot.to_owned(),
)

View file

@ -6,7 +6,7 @@ use tracing::debug;
use ubisync_lib::{
api::events::AppEvent,
messages::MessageContent,
types::{AppId, Element, ElementContent, ElementId, Pot, PotId},
types::{AppId, Element, ElementContent, ElementId, ElementUpdateStrategy, Pot, PotId},
};
use crate::api::v0::app::App;
@ -60,7 +60,7 @@ impl ApiState {
pub fn create_element(&self, content: ElementContent, pot: PotId) -> anyhow::Result<ElementId> {
let id = ElementId::new();
self.db()
.add_element(id.clone(), content.clone(), None, false, pot.clone())?;
.add_element(id.clone(), content.clone(), ElementUpdateStrategy::Overwrite, None, false, pot.clone())?;
debug!("Added element {{{}}}", id.to_string());
self.state.send_to_peers(

View file

@ -5,7 +5,7 @@ use tracing::debug;
use ubisync_lib::{
api::events::AppEvent,
peer::Peer,
types::{Element, ElementContent, ElementId, MessageId, PotId},
types::{Element, ElementContent, ElementId, ElementUpdateStrategy, MessageId, PotId},
};
use crate::node_events::UbisyncNodeEvent;
@ -25,11 +25,19 @@ impl CommState {
&self,
id: ElementId,
content: ElementContent,
update_strategy: ElementUpdateStrategy,
latest_message: Option<MessageId>,
pot_id: PotId,
) -> anyhow::Result<()> {
self.db()
.add_element(id.clone(), content, latest_message, false, pot_id)
.add_element(
id.clone(),
content,
update_strategy,
latest_message,
false,
pot_id,
)
.inspect(|_| debug!("Added element {{{}}}", id.to_string()))
}
@ -102,7 +110,7 @@ mod tests {
use super::CommState;
use tracing::Level;
use ubisync_lib::types::{ElementContent, ElementId, MessageId, PotId};
use ubisync_lib::types::{ElementContent, ElementId, ElementUpdateStrategy, MessageId, PotId};
#[tokio::test]
#[serial_test::serial]
@ -119,6 +127,7 @@ mod tests {
.add_received_element(
id.clone(),
ElementContent::Text("Test-text".to_string()),
ElementUpdateStrategy::Overwrite,
Some(MessageId::new()),
pot_id,
)
@ -145,6 +154,7 @@ mod tests {
.add_received_element(
id.clone(),
ElementContent::Text("Test-text".to_string()),
ElementUpdateStrategy::Overwrite,
Some(MessageId::new()),
pot_id,
)

View file

@ -113,7 +113,7 @@ impl StateDB {
#[cfg(test)]
mod tests {
use ubisync_lib::types::{AppId, ElementContent, ElementId, Pot, PotId};
use ubisync_lib::types::{AppId, ElementContent, ElementId, ElementUpdateStrategy, Pot, PotId};
use crate::{api::v0::app::App, state::database::StateDB};
@ -259,6 +259,7 @@ mod tests {
db.add_element(
element_id.clone(),
ElementContent::Text("Text".to_string()),
ElementUpdateStrategy::Overwrite,
None,
false,
pot_id.clone(),

View file

@ -1,7 +1,7 @@
use anyhow::{anyhow, Error};
use bonsaidb::core::schema::{Collection, SerializedCollection};
use serde::{Deserialize, Serialize};
use ubisync_lib::types::{Element, ElementContent, ElementId, MessageId, PotId};
use ubisync_lib::types::{Element, ElementContent, ElementId, ElementUpdateStrategy, MessageId, PotId};
use crate::state::database::{as_key::AsKey, StateDB};
@ -11,6 +11,7 @@ pub(super) struct DbElement {
#[natural_id]
pub(super) id: AsKey<ElementId>,
pub(super) content: ElementContent,
pub(super) update_strategy: ElementUpdateStrategy,
pub(super) latest_message: Option<MessageId>,
pub(super) local_changes: bool,
pub(super) pot: PotId,
@ -18,13 +19,14 @@ pub(super) struct DbElement {
impl From<DbElement> for Element {
fn from(value: DbElement) -> Self {
Element::from((
(*value.id).clone(),
Some(value.pot),
value.content,
value.latest_message,
value.local_changes,
))
Element {
id: (*value.id).clone(),
content: value.content,
update_strategy: value.update_strategy,
latest_message: value.latest_message,
local_changes: value.local_changes,
pot: Some(value.pot),
}
}
}
@ -33,6 +35,7 @@ impl StateDB {
&self,
id: ElementId,
content: ElementContent,
update_strategy: ElementUpdateStrategy,
latest_message: Option<MessageId>,
local_changes: bool,
pot: PotId,
@ -41,6 +44,7 @@ impl StateDB {
DbElement {
id: AsKey::new(id),
content,
update_strategy,
latest_message,
local_changes,
pot,
@ -104,7 +108,7 @@ impl StateDB {
#[cfg(test)]
mod tests {
use ubisync_lib::types::{ElementContent, ElementId, MessageId, PotId};
use ubisync_lib::types::{Element, ElementContent, ElementId, ElementUpdateStrategy, MessageId, PotId};
use crate::state::database::StateDB;
@ -116,6 +120,7 @@ mod tests {
db.add_element(
element_id.clone(),
ElementContent::Text("Content!!!".to_string()),
ElementUpdateStrategy::default(),
None,
false,
pot_id.clone(),
@ -126,14 +131,14 @@ mod tests {
assert_eq!(
Some(
(
element_id,
Some(pot_id),
ElementContent::Text("Content!!!".to_string()),
None,
false
)
.into()
Element {
id: element_id,
content: ElementContent::Text("Content!!!".to_string()),
update_strategy: ElementUpdateStrategy::default(),
latest_message: None,
local_changes: false,
pot: Some(pot_id),
}
),
retrieved_element
)
@ -146,6 +151,7 @@ mod tests {
db.add_element(
element_id.clone(),
ElementContent::Text("Content!!!".to_string()),
ElementUpdateStrategy::default(),
None,
false,
PotId::new(),
@ -171,6 +177,7 @@ mod tests {
db.add_element(
element_id.clone(),
ElementContent::Text("Content!!!".to_string()),
ElementUpdateStrategy::default(),
None,
false,
PotId::new(),
@ -206,6 +213,7 @@ mod tests {
db.add_element(
element_id.clone(),
ElementContent::Text("Content!!!".to_string()),
ElementUpdateStrategy::default(),
None,
false,
PotId::new(),