Skip to content

Commit

Permalink
dont err if intent was already published
Browse files Browse the repository at this point in the history
  • Loading branch information
insipx committed Dec 16, 2024
1 parent 2debcf2 commit 38d9eeb
Show file tree
Hide file tree
Showing 2 changed files with 29 additions and 13 deletions.
20 changes: 12 additions & 8 deletions xmtp_mls/src/groups/mls_sync.rs
Original file line number Diff line number Diff line change
Expand Up @@ -1633,16 +1633,20 @@ pub(crate) mod tests {
let amal_group_a: Arc<MlsGroup<_>> =
Arc::new(amal_a.create_group(None, Default::default()).unwrap());

for _ in 0..500 {
let conn = amal_a.context().store().conn().unwrap();
let provider: Arc<XmtpOpenMlsProvider> = Arc::new(conn.into());

// create group intent
amal_group_a.sync().await.unwrap();
assert_eq!(provider.conn_ref().intents_deleted(), 1);

for _ in 0..100 {
let s = xmtp_common::rand_string::<100>();
amal_group_a.send_message_optimistic(s.as_bytes()).unwrap();
}

let conn = amal_a.context().store().conn().unwrap();
let provider: Arc<XmtpOpenMlsProvider> = Arc::new(conn.into());

let mut set = tokio::task::JoinSet::new();
for _ in 0..100 {
for _ in 0..50 {
let g = amal_group_a.clone();
let p = provider.clone();
set.spawn(async move { g.publish_intents(&p).await });
Expand All @@ -1655,9 +1659,9 @@ pub(crate) mod tests {
});

let published = provider.conn_ref().intents_published();
assert_eq!(published, 501);
// let created = provider.conn_ref().intents_created();
// assert_eq!(created, 501);
assert_eq!(published, 101);
let created = provider.conn_ref().intents_created();
assert_eq!(created, 101);
if !errs.is_empty() {
panic!("Errors during publish");
}
Expand Down
22 changes: 17 additions & 5 deletions xmtp_mls/src/storage/encrypted_store/group_intent.rs
Original file line number Diff line number Diff line change
Expand Up @@ -205,7 +205,7 @@ impl DbConnection {
.filter(dsl::state.eq(IntentState::ToPublish))
.set((
dsl::state.eq(IntentState::Published),
dsl::payload_hash.eq(payload_hash),
dsl::payload_hash.eq(&payload_hash),
dsl::post_commit_data.eq(post_commit_data),
dsl::staged_commit.eq(staged_commit),
dsl::published_in_epoch.eq(published_in_epoch),
Expand All @@ -214,10 +214,22 @@ impl DbConnection {
})?;

match res {
// If nothing matched the query, return an error. Either ID or state was wrong
0 => Err(StorageError::NotFound(format!(
"ToPublish intent {intent_id} for publish"
))),
// If nothing matched the query, check if its already published, otherwise return an error. Either ID or state was wrong
0 => {
let already_published = self.raw_query(|conn| {
dsl::group_intents
.filter(dsl::id.eq(intent_id))
.first::<StoredGroupIntent>(conn)
});

if already_published.is_ok() {
return Ok(());
} else {
return Err(StorageError::NotFound(format!(
"Published intent {intent_id} for commit"
)));
}
}
_ => Ok(()),
}
}
Expand Down

0 comments on commit 38d9eeb

Please sign in to comment.