-
Notifications
You must be signed in to change notification settings - Fork 9
Commit
This commit does not belong to any branch on this repository, and may belong to a fork outside of the repository.
Fix file metadata incomplete return bug
If a file is listed or checked for existence and an UPA is added to the file before the file is completely uploaded, the metadata will never be fully created.
- Loading branch information
1 parent
acc6048
commit bc09575
Showing
4 changed files
with
91 additions
and
5 deletions.
There are no files selected for viewing
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,80 @@ | ||
""" Unit tests for the metadata handling routines. """ | ||
|
||
import json | ||
import uuid | ||
|
||
from collections.abc import Callable, Generator | ||
from pathlib import Path as PyPath | ||
from pytest import fixture | ||
|
||
from staging_service.utils import Path | ||
from staging_service.metadata import some_metadata | ||
|
||
from tests.test_app import FileUtil | ||
|
||
# TODO TEST add more unit tests here. | ||
|
||
|
||
@fixture(scope="module") | ||
def temp_dir() -> Generator[PyPath, None, None]: | ||
with FileUtil() as fu: | ||
childdir = PyPath(fu.make_dir(str(uuid.uuid4()))).resolve() | ||
|
||
yield childdir | ||
|
||
# FileUtil will auto delete after exiting | ||
|
||
|
||
async def test_incomplete_metadata_file_update(temp_dir: Path): | ||
""" | ||
Tests the case where a file is listed or checked for existance prior to completing | ||
upload, and then an UPA is added to the file. This previously caused incomplete metadata | ||
to be returned as the logic for whether to run the metadata regeneration code based on | ||
the contents of the current metadata file was incorrect. | ||
See https://kbase-jira.atlassian.net/browse/PTV-1767 | ||
""" | ||
await _incomplete_metadata_file_update( | ||
temp_dir, | ||
{"source": "some place", "UPA": "1/2/3"}, | ||
"some place" | ||
) | ||
|
||
await _incomplete_metadata_file_update( | ||
temp_dir, | ||
{"UPA": "1/2/3"}, | ||
"Unknown" | ||
) | ||
|
||
async def _incomplete_metadata_file_update(temp_dir, metadict, source): | ||
target = Path( | ||
str(temp_dir / "full"), | ||
str(temp_dir / "meta"), | ||
"user_path", | ||
"myfilename", | ||
"super_fake_jgi_path") | ||
|
||
with open(target.full_path, "w") as p: | ||
p.writelines(make_test_lines(1, 6)) | ||
with open(target.metadata_path, "w") as p: | ||
p.write(json.dumps(metadict)) | ||
|
||
res = await some_metadata(target) | ||
|
||
assert "mtime" in res # just check the file time is there | ||
del res["mtime"] | ||
|
||
assert res == { | ||
"source": source, | ||
"md5": "9f07da9655223b777121141ff7735f25", | ||
"head": "".join(make_test_lines(1, 5)), | ||
"tail": "".join(make_test_lines(2, 6)), | ||
"UPA": "1/2/3", | ||
"isFolder": False, | ||
"lineCount": "5", | ||
"name": "myfilename", | ||
"path": "user_path", | ||
"size": 1280 | ||
} | ||
|
||
def make_test_lines(start, stop): | ||
return [str(i) + "a" * (256 - len(str(i)) - 1) + "\n" for i in range(start, stop)] |