Use microseconds for Receive Mode dir/file names

This commit is contained in:
Miguel Jacq 2021-11-09 12:30:48 +11:00
parent 1b259a208d
commit 096178a9e6
No known key found for this signature in database
GPG key ID: EEA4341C6D97A0B6
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
now = datetime.now()
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.web.settings.get("receive", "data_dir"), date_dir, time_dir
)

View file

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