Skip to content

Commit

Permalink
[sqlite] Rename getAllOutboundP2PMessages() to getUnsentOutboundP2PMe…
Browse files Browse the repository at this point in the history
…ssages()

Summary:
https://linear.app/comm/issue/ENG-9291/read-outbound-messages-with-status-different-that-sent

getAllOutboundP2PMessages() no longer returns all messages, but only unsent messages. As this name
may be misleading, maybe it'd be nice to rename it.

Depends on D13908

Test Plan: Run the app and send some messages on web and native.

Reviewers: tomek, kamil

Reviewed By: kamil

Subscribers: ashoat

Differential Revision: https://phab.comm.dev/D13909
  • Loading branch information
graszka22 committed Nov 13, 2024
1 parent 825e943 commit 6c66ce0
Show file tree
Hide file tree
Showing 18 changed files with 35 additions and 34 deletions.
2 changes: 1 addition & 1 deletion lib/tunnelbroker/peer-to-peer-context.js
Original file line number Diff line number Diff line change
Expand Up @@ -160,7 +160,7 @@ async function processOutboundP2PMessages(
}
}
} else {
const allMessages = await sqliteAPI.getAllOutboundP2PMessages();
const allMessages = await sqliteAPI.getUnsentOutboundP2PMessages();
messages = allMessages.filter(message => message.supportsAutoRetry);
}

Expand Down
2 changes: 1 addition & 1 deletion lib/types/sqlite-types.js
Original file line number Diff line number Diff line change
Expand Up @@ -45,7 +45,7 @@ export type SQLiteAPI = {
+getInboundP2PMessagesByID: (
ids: $ReadOnlyArray<string>,
) => Promise<Array<InboundP2PMessage>>,
+getAllOutboundP2PMessages: () => Promise<Array<OutboundP2PMessage>>,
+getUnsentOutboundP2PMessages: () => Promise<Array<OutboundP2PMessage>>,
+getRelatedMessages: (
messageID: string,
) => Promise<Array<ClientDBMessageInfo>>,
Expand Down
2 changes: 1 addition & 1 deletion lib/utils/__mocks__/config.js
Original file line number Diff line number Diff line change
Expand Up @@ -38,7 +38,7 @@ const getConfig = (): Config => ({
getInboundP2PMessagesByID: jest.fn(),
removeInboundP2PMessages: jest.fn(),
processDBStoreOperations: jest.fn(),
getAllOutboundP2PMessages: jest.fn(),
getUnsentOutboundP2PMessages: jest.fn(),
markOutboundP2PMessageAsSent: jest.fn(),
removeOutboundP2PMessage: jest.fn(),
resetOutboundP2PMessagesForDevice: jest.fn(),
Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -155,7 +155,8 @@ class DatabaseQueryExecutor {
const std::vector<OutboundP2PMessage> &messages) const = 0;
virtual std::vector<OutboundP2PMessage>
getOutboundP2PMessagesByID(const std::vector<std::string> &ids) const = 0;
virtual std::vector<OutboundP2PMessage> getAllOutboundP2PMessages() const = 0;
virtual std::vector<OutboundP2PMessage>
getUnsentOutboundP2PMessages() const = 0;
virtual void removeOutboundP2PMessage(
std::string confirmedMessageID,
std::string deviceID) const = 0;
Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -2547,7 +2547,7 @@ std::vector<OutboundP2PMessage> SQLiteQueryExecutor::getOutboundP2PMessagesByID(
}

std::vector<OutboundP2PMessage>
SQLiteQueryExecutor::getAllOutboundP2PMessages() const {
SQLiteQueryExecutor::getUnsentOutboundP2PMessages() const {
std::string query =
"SELECT * FROM outbound_p2p_messages "
"WHERE status != 'sent' "
Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -174,7 +174,7 @@ class SQLiteQueryExecutor : public DatabaseQueryExecutor {
const std::vector<OutboundP2PMessage> &messages) const override;
std::vector<OutboundP2PMessage> getOutboundP2PMessagesByID(
const std::vector<std::string> &ids) const override;
std::vector<OutboundP2PMessage> getAllOutboundP2PMessages() const override;
std::vector<OutboundP2PMessage> getUnsentOutboundP2PMessages() const override;
void removeOutboundP2PMessage(
std::string confirmedMessageID,
std::string deviceID) const override;
Expand Down
6 changes: 3 additions & 3 deletions native/cpp/CommonCpp/NativeModules/CommCoreModule.cpp
Original file line number Diff line number Diff line change
Expand Up @@ -2888,16 +2888,16 @@ CommCoreModule::getOutboundP2PMessagesByID(jsi::Runtime &rt, jsi::Array ids) {
});
}

jsi::Value CommCoreModule::getAllOutboundP2PMessages(jsi::Runtime &rt) {
jsi::Value CommCoreModule::getUnsentOutboundP2PMessages(jsi::Runtime &rt) {
return createPromiseAsJSIValue(
rt, [=](jsi::Runtime &innerRt, std::shared_ptr<Promise> promise) {
taskType job = [=, &innerRt]() {
std::string error;
std::vector<OutboundP2PMessage> messages;

try {
messages =
DatabaseManager::getQueryExecutor().getAllOutboundP2PMessages();
messages = DatabaseManager::getQueryExecutor()
.getUnsentOutboundP2PMessages();

} catch (std::system_error &e) {
error = e.what();
Expand Down
6 changes: 3 additions & 3 deletions native/cpp/CommonCpp/NativeModules/CommCoreModule.h
Original file line number Diff line number Diff line change
Expand Up @@ -246,10 +246,10 @@ class CommCoreModule : public facebook::react::CommCoreModuleSchemaCxxSpecJSI {
virtual jsi::Value
removeInboundP2PMessages(jsi::Runtime &rt, jsi::Array ids) override;
virtual jsi::Value
getOutboundP2PMessagesByID(jsi::Runtime &rt, jsi::Array ids) override;
virtual jsi::Value getAllOutboundP2PMessages(jsi::Runtime &rt) override;
virtual jsi::Value
getInboundP2PMessagesByID(jsi::Runtime &rt, jsi::Array ids) override;
virtual jsi::Value
getOutboundP2PMessagesByID(jsi::Runtime &rt, jsi::Array ids) override;
virtual jsi::Value getUnsentOutboundP2PMessages(jsi::Runtime &rt) override;
virtual jsi::Value markOutboundP2PMessageAsSent(
jsi::Runtime &rt,
jsi::String messageID,
Expand Down
6 changes: 3 additions & 3 deletions native/cpp/CommonCpp/_generated/commJSI-generated.cpp
Original file line number Diff line number Diff line change
Expand Up @@ -217,8 +217,8 @@ static jsi::Value __hostFunction_CommCoreModuleSchemaCxxSpecJSI_getInboundP2PMes
static jsi::Value __hostFunction_CommCoreModuleSchemaCxxSpecJSI_getOutboundP2PMessagesByID(jsi::Runtime &rt, TurboModule &turboModule, const jsi::Value* args, size_t count) {
return static_cast<CommCoreModuleSchemaCxxSpecJSI *>(&turboModule)->getOutboundP2PMessagesByID(rt, args[0].asObject(rt).asArray(rt));
}
static jsi::Value __hostFunction_CommCoreModuleSchemaCxxSpecJSI_getAllOutboundP2PMessages(jsi::Runtime &rt, TurboModule &turboModule, const jsi::Value* args, size_t count) {
return static_cast<CommCoreModuleSchemaCxxSpecJSI *>(&turboModule)->getAllOutboundP2PMessages(rt);
static jsi::Value __hostFunction_CommCoreModuleSchemaCxxSpecJSI_getUnsentOutboundP2PMessages(jsi::Runtime &rt, TurboModule &turboModule, const jsi::Value* args, size_t count) {
return static_cast<CommCoreModuleSchemaCxxSpecJSI *>(&turboModule)->getUnsentOutboundP2PMessages(rt);
}
static jsi::Value __hostFunction_CommCoreModuleSchemaCxxSpecJSI_markOutboundP2PMessageAsSent(jsi::Runtime &rt, TurboModule &turboModule, const jsi::Value* args, size_t count) {
return static_cast<CommCoreModuleSchemaCxxSpecJSI *>(&turboModule)->markOutboundP2PMessageAsSent(rt, args[0].asString(rt), args[1].asString(rt));
Expand Down Expand Up @@ -313,7 +313,7 @@ CommCoreModuleSchemaCxxSpecJSI::CommCoreModuleSchemaCxxSpecJSI(std::shared_ptr<C
methodMap_["removeInboundP2PMessages"] = MethodMetadata {1, __hostFunction_CommCoreModuleSchemaCxxSpecJSI_removeInboundP2PMessages};
methodMap_["getInboundP2PMessagesByID"] = MethodMetadata {1, __hostFunction_CommCoreModuleSchemaCxxSpecJSI_getInboundP2PMessagesByID};
methodMap_["getOutboundP2PMessagesByID"] = MethodMetadata {1, __hostFunction_CommCoreModuleSchemaCxxSpecJSI_getOutboundP2PMessagesByID};
methodMap_["getAllOutboundP2PMessages"] = MethodMetadata {0, __hostFunction_CommCoreModuleSchemaCxxSpecJSI_getAllOutboundP2PMessages};
methodMap_["getUnsentOutboundP2PMessages"] = MethodMetadata {0, __hostFunction_CommCoreModuleSchemaCxxSpecJSI_getUnsentOutboundP2PMessages};
methodMap_["markOutboundP2PMessageAsSent"] = MethodMetadata {2, __hostFunction_CommCoreModuleSchemaCxxSpecJSI_markOutboundP2PMessageAsSent};
methodMap_["removeOutboundP2PMessage"] = MethodMetadata {2, __hostFunction_CommCoreModuleSchemaCxxSpecJSI_removeOutboundP2PMessage};
methodMap_["resetOutboundP2PMessagesForDevice"] = MethodMetadata {1, __hostFunction_CommCoreModuleSchemaCxxSpecJSI_resetOutboundP2PMessagesForDevice};
Expand Down
10 changes: 5 additions & 5 deletions native/cpp/CommonCpp/_generated/commJSI.h
Original file line number Diff line number Diff line change
Expand Up @@ -86,7 +86,7 @@ class JSI_EXPORT CommCoreModuleSchemaCxxSpecJSI : public TurboModule {
virtual jsi::Value removeInboundP2PMessages(jsi::Runtime &rt, jsi::Array ids) = 0;
virtual jsi::Value getInboundP2PMessagesByID(jsi::Runtime &rt, jsi::Array ids) = 0;
virtual jsi::Value getOutboundP2PMessagesByID(jsi::Runtime &rt, jsi::Array ids) = 0;
virtual jsi::Value getAllOutboundP2PMessages(jsi::Runtime &rt) = 0;
virtual jsi::Value getUnsentOutboundP2PMessages(jsi::Runtime &rt) = 0;
virtual jsi::Value markOutboundP2PMessageAsSent(jsi::Runtime &rt, jsi::String messageID, jsi::String deviceID) = 0;
virtual jsi::Value removeOutboundP2PMessage(jsi::Runtime &rt, jsi::String messageID, jsi::String deviceID) = 0;
virtual jsi::Value resetOutboundP2PMessagesForDevice(jsi::Runtime &rt, jsi::String deviceID) = 0;
Expand Down Expand Up @@ -644,13 +644,13 @@ class JSI_EXPORT CommCoreModuleSchemaCxxSpec : public TurboModule {
return bridging::callFromJs<jsi::Value>(
rt, &T::getOutboundP2PMessagesByID, jsInvoker_, instance_, std::move(ids));
}
jsi::Value getAllOutboundP2PMessages(jsi::Runtime &rt) override {
jsi::Value getUnsentOutboundP2PMessages(jsi::Runtime &rt) override {
static_assert(
bridging::getParameterCount(&T::getAllOutboundP2PMessages) == 1,
"Expected getAllOutboundP2PMessages(...) to have 1 parameters");
bridging::getParameterCount(&T::getUnsentOutboundP2PMessages) == 1,
"Expected getUnsentOutboundP2PMessages(...) to have 1 parameters");

return bridging::callFromJs<jsi::Value>(
rt, &T::getAllOutboundP2PMessages, jsInvoker_, instance_);
rt, &T::getUnsentOutboundP2PMessages, jsInvoker_, instance_);
}
jsi::Value markOutboundP2PMessageAsSent(jsi::Runtime &rt, jsi::String messageID, jsi::String deviceID) override {
static_assert(
Expand Down
2 changes: 1 addition & 1 deletion native/database/sqlite-api.js
Original file line number Diff line number Diff line change
Expand Up @@ -13,7 +13,7 @@ const sqliteAPI: SQLiteAPI = {
// read operations
getAllInboundP2PMessages: commCoreModule.getAllInboundP2PMessages,
getInboundP2PMessagesByID: commCoreModule.getInboundP2PMessagesByID,
getAllOutboundP2PMessages: commCoreModule.getAllOutboundP2PMessages,
getUnsentOutboundP2PMessages: commCoreModule.getUnsentOutboundP2PMessages,
getRelatedMessages: commCoreModule.getRelatedMessages,
getOutboundP2PMessagesByID: commCoreModule.getOutboundP2PMessagesByID,
searchMessages: commCoreModule.searchMessages,
Expand Down
2 changes: 1 addition & 1 deletion native/schema/CommCoreModuleSchema.js
Original file line number Diff line number Diff line change
Expand Up @@ -187,7 +187,7 @@ interface Spec extends TurboModule {
+getOutboundP2PMessagesByID: (
ids: $ReadOnlyArray<string>,
) => Promise<Array<OutboundP2PMessage>>;
+getAllOutboundP2PMessages: () => Promise<Array<OutboundP2PMessage>>;
+getUnsentOutboundP2PMessages: () => Promise<Array<OutboundP2PMessage>>;
+markOutboundP2PMessageAsSent: (
messageID: string,
deviceID: string,
Expand Down
4 changes: 2 additions & 2 deletions web/cpp/SQLiteQueryExecutorBindings.cpp
Original file line number Diff line number Diff line change
Expand Up @@ -302,8 +302,8 @@ EMSCRIPTEN_BINDINGS(SQLiteQueryExecutor) {
"getOutboundP2PMessagesByID",
&SQLiteQueryExecutor::getOutboundP2PMessagesByID)
.function(
"getAllOutboundP2PMessages",
&SQLiteQueryExecutor::getAllOutboundP2PMessages)
"getUnsentOutboundP2PMessages",
&SQLiteQueryExecutor::getUnsentOutboundP2PMessages)
.function(
"setCiphertextForOutboundP2PMessage",
&SQLiteQueryExecutor::setCiphertextForOutboundP2PMessage)
Expand Down
2 changes: 1 addition & 1 deletion web/database/sqlite-api.js
Original file line number Diff line number Diff line change
Expand Up @@ -40,7 +40,7 @@ const sqliteAPI: SQLiteAPI = {
return messages ? [...messages] : [];
},

async getAllOutboundP2PMessages(): Promise<OutboundP2PMessage[]> {
async getUnsentOutboundP2PMessages(): Promise<OutboundP2PMessage[]> {
const sharedWorker = await getCommSharedWorker();

const data = await sharedWorker.schedule({
Expand Down
Binary file modified web/shared-worker/_generated/comm_query_executor.wasm
Binary file not shown.
14 changes: 7 additions & 7 deletions web/shared-worker/queries/outbound-p2p-message-queries.test.js
Original file line number Diff line number Diff line change
Expand Up @@ -97,11 +97,11 @@ describe('Outbound P2P messages queries', () => {
});

it('should return all messages', () => {
expect(queryExecutor?.getAllOutboundP2PMessages().length).toBe(4);
expect(queryExecutor?.getUnsentOutboundP2PMessages().length).toBe(4);
});

it('should return messages in correct order', () => {
const messages = queryExecutor?.getAllOutboundP2PMessages();
const messages = queryExecutor?.getUnsentOutboundP2PMessages();
expect(messages).toStrictEqual(messagesOrdered);
});

Expand All @@ -111,8 +111,8 @@ describe('Outbound P2P messages queries', () => {
TEST_MSG_4.deviceID,
);

expect(queryExecutor?.getAllOutboundP2PMessages().length).toBe(3);
expect(queryExecutor?.getAllOutboundP2PMessages()).toStrictEqual([
expect(queryExecutor?.getUnsentOutboundP2PMessages().length).toBe(3);
expect(queryExecutor?.getUnsentOutboundP2PMessages()).toStrictEqual([
TEST_MSG_3,
TEST_MSG_1,
TEST_MSG_2,
Expand All @@ -122,7 +122,7 @@ describe('Outbound P2P messages queries', () => {
it('should remove all messages for given device', () => {
queryExecutor?.removeAllOutboundP2PMessages(device1);
queryExecutor?.removeAllOutboundP2PMessages(device2);
expect(queryExecutor?.getAllOutboundP2PMessages().length).toBe(0);
expect(queryExecutor?.getUnsentOutboundP2PMessages().length).toBe(0);
});

it('should set ciphertext for given message', () => {
Expand All @@ -134,7 +134,7 @@ describe('Outbound P2P messages queries', () => {
ciphertext,
);

const messages = queryExecutor?.getAllOutboundP2PMessages() ?? [];
const messages = queryExecutor?.getUnsentOutboundP2PMessages() ?? [];
expect(messages.length).toBe(4);
expect(
messages.find(msg => msg.messageID === TEST_MSG_4.messageID)?.ciphertext,
Expand All @@ -147,7 +147,7 @@ describe('Outbound P2P messages queries', () => {
TEST_MSG_4.deviceID,
);

const messages = queryExecutor?.getAllOutboundP2PMessages() ?? [];
const messages = queryExecutor?.getUnsentOutboundP2PMessages() ?? [];
expect(messages.length).toBe(3);
expect(
messages.find(msg => msg.messageID === TEST_MSG_4.messageID),
Expand Down
2 changes: 1 addition & 1 deletion web/shared-worker/types/sqlite-query-executor.js
Original file line number Diff line number Diff line change
Expand Up @@ -185,7 +185,7 @@ declare export class SQLiteQueryExecutor {
getOutboundP2PMessagesByID(
ids: $ReadOnlyArray<string>,
): $ReadOnlyArray<OutboundP2PMessage>;
getAllOutboundP2PMessages(): $ReadOnlyArray<OutboundP2PMessage>;
getUnsentOutboundP2PMessages(): $ReadOnlyArray<OutboundP2PMessage>;
setCiphertextForOutboundP2PMessage(
messageID: string,
deviceID: string,
Expand Down
2 changes: 1 addition & 1 deletion web/shared-worker/worker/shared-worker.js
Original file line number Diff line number Diff line change
Expand Up @@ -251,7 +251,7 @@ async function processAppRequest(
) {
return {
type: workerResponseMessageTypes.GET_OUTBOUND_P2P_MESSAGES,
outboundP2PMessages: sqliteQueryExecutor.getAllOutboundP2PMessages(),
outboundP2PMessages: sqliteQueryExecutor.getUnsentOutboundP2PMessages(),
};
} else if (message.type === workerRequestMessageTypes.GET_RELATED_MESSAGES) {
const webMessageEntities = sqliteQueryExecutor.getRelatedMessagesWeb(
Expand Down

0 comments on commit 6c66ce0

Please sign in to comment.