Skip to content

Commit

Permalink
Make some commits optional in storage.py
Browse files Browse the repository at this point in the history
Add boolean "commit" argument to find_or_create_user and
update_draft_replies.

Also make utils.chronometer log at INFO, so you don't have to run at
DEBUG to time things. Debug logging is significantly slower in
intensive loops like storage.update_replies, which can take up to a
couple of seconds longer with debug enabled, given 1000 sources with
two replies each.
  • Loading branch information
rmol authored and sssoleileraaa committed Apr 3, 2020
1 parent 77bbb4b commit 56e0981
Show file tree
Hide file tree
Showing 4 changed files with 24 additions and 8 deletions.
4 changes: 3 additions & 1 deletion securedrop_client/api_jobs/uploads.py
Original file line number Diff line number Diff line change
Expand Up @@ -75,7 +75,9 @@ def call_api(self, api_client: API, session: Session) -> str:
draft_file_counter = draft_reply_db_object.file_counter
draft_timestamp = draft_reply_db_object.timestamp
update_draft_replies(
session, source.id, draft_timestamp, draft_file_counter, new_file_counter)
session, source.id, draft_timestamp, draft_file_counter, new_file_counter,
commit=False
)

# Add reply to replies table and increase the source interaction count by 1 and delete
# the draft reply.
Expand Down
10 changes: 5 additions & 5 deletions securedrop_client/storage.py
Original file line number Diff line number Diff line change
Expand Up @@ -329,9 +329,7 @@ def update_replies(remote_replies: List[SDKReply], local_replies: List[Reply],
session.commit()


def find_or_create_user(uuid: str,
username: str,
session: Session) -> User:
def find_or_create_user(uuid: str, username: str, session: Session, commit: bool = True) -> User:
"""
Returns a user object representing the referenced journalist UUID.
If the user does not already exist in the data, a new instance is created.
Expand All @@ -343,12 +341,14 @@ def find_or_create_user(uuid: str,
new_user = User(username=username)
new_user.uuid = uuid
session.add(new_user)
session.commit()
if commit:
session.commit()
return new_user

if user.username != username:
user.username = username
session.commit()
if commit:
session.commit()

return user

Expand Down
2 changes: 1 addition & 1 deletion securedrop_client/utils.py
Original file line number Diff line number Diff line change
Expand Up @@ -88,7 +88,7 @@ def chronometer(logger: logging.Logger, description: str) -> Generator:
yield
finally:
elapsed = time.perf_counter() - start
logger.debug(f"{description} duration: {elapsed:.4f}s")
logger.info(f"{description} duration: {elapsed:.4f}s")


class SourceCache(object):
Expand Down
16 changes: 15 additions & 1 deletion tests/test_storage.py
Original file line number Diff line number Diff line change
Expand Up @@ -20,7 +20,8 @@
delete_single_submission_or_reply_on_disk, get_local_files, find_new_files, \
source_exists, set_message_or_reply_content, mark_as_downloaded, mark_as_decrypted, get_file, \
get_message, get_reply, update_and_get_user, update_missing_files, mark_as_not_downloaded, \
mark_all_pending_drafts_as_failed, delete_local_source_by_uuid, update_file_size
mark_all_pending_drafts_as_failed, delete_local_source_by_uuid, update_file_size, \
update_draft_replies

from securedrop_client import db
from tests import factory
Expand Down Expand Up @@ -1206,3 +1207,16 @@ def test_update_file_size(homedir, session):
update_file_size(f.uuid, data_dir, session)

assert f.size == real_size


def test_update_draft_replies_commit(mocker, session):
"""
Tests the commit argument of storage.update_draft_replies.
"""
session.commit = mocker.MagicMock()

update_draft_replies(session, "notreal", datetime.datetime.now(), 1, 2, commit=False)
assert session.commit.call_count == 0

update_draft_replies(session, "notreal", datetime.datetime.now(), 1, 2)
assert session.commit.call_count == 1

0 comments on commit 56e0981

Please sign in to comment.