Merge branch 'advisory-fix-1' of github.com:onionshare/onionshare-ghsa-jh82-c5jw-pxpc into ros-fixes

This commit is contained in:
Micah Lee 2021-11-18 19:16:00 -08:00
commit 627f44c423
No known key found for this signature in database
GPG key ID: 403C2657CD994F73
2 changed files with 18 additions and 16 deletions

View file

@ -378,7 +378,7 @@ class ReceiveModeRequest(Request):
# Figure out what files should be saved # Figure out what files should be saved
now = datetime.now() now = datetime.now()
date_dir = now.strftime("%Y-%m-%d") date_dir = now.strftime("%Y-%m-%d")
time_dir = now.strftime("%H%M%S") time_dir = now.strftime("%H%M%S%f")
self.receive_mode_dir = os.path.join( self.receive_mode_dir = os.path.join(
self.web.settings.get("receive", "data_dir"), date_dir, time_dir self.web.settings.get("receive", "data_dir"), date_dir, time_dir
) )

View file

@ -1,3 +1,4 @@
import glob
import pytest import pytest
import os import os
import requests import requests
@ -35,17 +36,17 @@ class TestReceive(GuiBaseTest):
now = datetime.now() now = datetime.now()
for _ in range(10): for _ in range(10):
date_dir = now.strftime("%Y-%m-%d") date_dir = now.strftime("%Y-%m-%d")
if identical_files_at_once: time_dir = now.strftime("%H%M%S")
time_dir = now.strftime("%H%M%S-1")
else:
time_dir = now.strftime("%H%M%S")
receive_mode_dir = os.path.join( receive_mode_dir = os.path.join(
tab.settings.get("receive", "data_dir"), date_dir, time_dir tab.settings.get("receive", "data_dir"), date_dir, time_dir
) )
expected_filename = os.path.join(receive_mode_dir, expected_basename) # The directories have microseconds in the name, so we need
if os.path.exists(expected_filename): # to use globbing against directory names containing the same
exists = True # second in order to try to find the file.
break for path in glob.glob(receive_mode_dir + "*"):
if os.path.exists(os.path.join(path, expected_basename)):
exists = True
break
now = now - timedelta(seconds=1) now = now - timedelta(seconds=1)
self.assertTrue(exists) self.assertTrue(exists)
@ -83,17 +84,18 @@ class TestReceive(GuiBaseTest):
for _ in range(10): for _ in range(10):
date_dir = now.strftime("%Y-%m-%d") date_dir = now.strftime("%Y-%m-%d")
time_dir = now.strftime("%H%M%S") time_dir = now.strftime("%H%M%S")
expected_filename = os.path.join( expected_estimated_filename = os.path.join(
tab.settings.get("receive", "data_dir"), tab.settings.get("receive", "data_dir"),
date_dir, date_dir,
f"{time_dir}-message.txt", f"{time_dir}*-message.txt",
) )
if os.path.exists(expected_filename): for path in glob.glob(expected_estimated_filename):
with open(expected_filename) as f: if os.path.exists(path):
assert f.read() == message with open(path) as f:
assert f.read() == message
exists = True exists = True
break break
now = now - timedelta(seconds=1) now = now - timedelta(seconds=1)
self.assertTrue(exists) self.assertTrue(exists)