properly test get_files
This commit is contained in:
parent
5c6eec62ee
commit
c2961cb1cf
1 changed files with 47 additions and 3 deletions
|
@ -26,6 +26,48 @@ def test_single_file():
|
||||||
)
|
)
|
||||||
|
|
||||||
|
|
||||||
|
def test_multiple_files():
|
||||||
|
'''
|
||||||
|
If you pass a directory/multiple directories, it flattens the contents
|
||||||
|
'''
|
||||||
|
create('/tmp/hpi_test/dir1/')
|
||||||
|
create('/tmp/hpi_test/dir1/zzz')
|
||||||
|
create('/tmp/hpi_test/dir1/yyy')
|
||||||
|
# create('/tmp/hpi_test/dir1/whatever/') # TODO not sure about this... should really allow extra dirs
|
||||||
|
create('/tmp/hpi_test/dir2/')
|
||||||
|
create('/tmp/hpi_test/dir2/mmm')
|
||||||
|
create('/tmp/hpi_test/dir2/nnn')
|
||||||
|
create('/tmp/hpi_test/dir3/')
|
||||||
|
create('/tmp/hpi_test/dir3/ttt')
|
||||||
|
|
||||||
|
assert get_files([
|
||||||
|
Path('/tmp/hpi_test/dir3'), # it takes in Path as well as str
|
||||||
|
'/tmp/hpi_test/dir1',
|
||||||
|
]) == (
|
||||||
|
# the paths are always returned in sorted order (unless you pass sort=False)
|
||||||
|
Path('/tmp/hpi_test/dir1/yyy'),
|
||||||
|
Path('/tmp/hpi_test/dir1/zzz'),
|
||||||
|
Path('/tmp/hpi_test/dir3/ttt'),
|
||||||
|
)
|
||||||
|
|
||||||
|
|
||||||
|
def test_glob():
|
||||||
|
'''
|
||||||
|
You can pass a blog to restrict the extensions
|
||||||
|
'''
|
||||||
|
|
||||||
|
create('/tmp/hpi_test/file_3.zip')
|
||||||
|
create('/tmp/hpi_test/file_2.zip')
|
||||||
|
create('/tmp/hpi_test/ignoreme')
|
||||||
|
create('/tmp/hpi_test/file.zip')
|
||||||
|
|
||||||
|
assert get_files('/tmp/hpi_test', 'file_*.zip') == (
|
||||||
|
Path('/tmp/hpi_test/file_2.zip'),
|
||||||
|
Path('/tmp/hpi_test/file_3.zip'),
|
||||||
|
)
|
||||||
|
|
||||||
|
# named argument should work too
|
||||||
|
assert len(get_files('/tmp/hpi_test', glob='file_*.zip')) > 0
|
||||||
|
|
||||||
|
|
||||||
test_path = Path('/tmp/hpi_test')
|
test_path = Path('/tmp/hpi_test')
|
||||||
|
@ -40,6 +82,8 @@ def teardown():
|
||||||
shutil.rmtree(test_path)
|
shutil.rmtree(test_path)
|
||||||
|
|
||||||
|
|
||||||
from my.common import PathIsh
|
def create(f: str) -> None:
|
||||||
def create(f: PathIsh) -> None:
|
if f.endswith('/'):
|
||||||
Path(f).touch()
|
Path(f).mkdir()
|
||||||
|
else:
|
||||||
|
Path(f).touch()
|
||||||
|
|
Loading…
Add table
Reference in a new issue