-
Notifications
You must be signed in to change notification settings - Fork 27
Commit
This commit does not belong to any branch on this repository, and may belong to a fork outside of the repository.
Merge pull request #310 from sneakers-the-rat/bugfix-windows-paths
Fix `linkml_files`
- Loading branch information
Showing
3 changed files
with
234 additions
and
56 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
Empty file.
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,129 @@ | ||
import pytest | ||
import requests | ||
from pathlib import Path | ||
from itertools import product | ||
from urllib.parse import urlparse | ||
|
||
try: | ||
import requests_cache | ||
HAVE_REQUESTS_CACHE = True | ||
except ImportError: | ||
HAVE_REQUESTS_CACHE = False | ||
|
||
from linkml_runtime.linkml_model.linkml_files import ( | ||
Source, | ||
Format, | ||
_Path, | ||
URL_FOR, | ||
LOCAL_PATH_FOR, | ||
LOCAL_BASE, | ||
GITHUB_IO_PATH_FOR, | ||
GITHUB_PATH_FOR, | ||
META_ONLY, | ||
ReleaseTag | ||
) | ||
|
||
EXPECTED_FORMATS = [ | ||
(source, fmt) for source, fmt in product(Source, Format) | ||
if (fmt not in META_ONLY or source == Source.META) | ||
] | ||
|
||
@pytest.mark.parametrize( | ||
'source,fmt', | ||
EXPECTED_FORMATS | ||
) | ||
def test_local_paths(source, fmt): | ||
a_path = Path(LOCAL_PATH_FOR(source, fmt)) | ||
assert a_path.exists() | ||
assert a_path.is_absolute() | ||
|
||
@pytest.mark.parametrize( | ||
'fmt', | ||
Format.__iter__() | ||
) | ||
def test_format_paths(fmt): | ||
"""Every format should have an entry in _Path""" | ||
assert fmt.name in _Path.items() | ||
|
||
def test_no_unmapped_dirs(): | ||
""" | ||
There should be no additional directories that don't have a mapping for Format. | ||
""" | ||
EXCLUDES = ('__pycache__',) | ||
|
||
expected = {LOCAL_BASE / _Path.get(fmt.name).path for fmt in Format} | ||
expected.add(LOCAL_BASE / 'model') | ||
|
||
actual = {a_dir for a_dir in LOCAL_BASE.iterdir() if a_dir.is_dir() and a_dir.name not in EXCLUDES} | ||
# Special case the root directory | ||
actual.add(LOCAL_BASE) | ||
# Special case YAML which is in a subdirectory - we've checked for existence above | ||
actual.add(LOCAL_BASE / _Path.get('YAML').path) | ||
assert expected == actual | ||
|
||
|
||
# -------------------------------------------------- | ||
# URLs | ||
# -------------------------------------------------- | ||
|
||
@pytest.mark.skipif(not HAVE_REQUESTS_CACHE, reason='We need to cache this...') | ||
@pytest.mark.parametrize( | ||
'release_type', | ||
ReleaseTag.__iter__() | ||
) | ||
@pytest.mark.parametrize( | ||
'source,fmt', | ||
EXPECTED_FORMATS | ||
) | ||
def test_github_path_exists(source,fmt, release_type): | ||
url = GITHUB_PATH_FOR(source, fmt, release_type) | ||
res = requests.get(url) | ||
assert res.status_code != 404 | ||
|
||
|
||
@pytest.mark.parametrize( | ||
'release_type', | ||
ReleaseTag.__iter__() | ||
) | ||
@pytest.mark.parametrize( | ||
'source,fmt', | ||
EXPECTED_FORMATS | ||
) | ||
def test_github_path_format(source,fmt, release_type): | ||
if release_type == ReleaseTag.CURRENT: | ||
pytest.skip("Need to cache network requests for this") | ||
|
||
url = GITHUB_PATH_FOR(source, fmt, release_type) | ||
# ensure it parses | ||
assert urlparse(url) | ||
# for windows... | ||
assert '\\' not in url | ||
|
||
|
||
@pytest.mark.skipif(not HAVE_REQUESTS_CACHE,reason= "Need to cache this") | ||
@pytest.mark.parametrize( | ||
'source,fmt', | ||
EXPECTED_FORMATS | ||
) | ||
def test_github_io_path(source,fmt): | ||
url = GITHUB_IO_PATH_FOR(source, fmt) | ||
res = requests.get(url) | ||
assert res.status_code != 404 | ||
|
||
|
||
@pytest.mark.skipif(not HAVE_REQUESTS_CACHE,reason= 'Need to cache this') | ||
@pytest.mark.parametrize( | ||
'source,fmt', | ||
EXPECTED_FORMATS | ||
) | ||
def test_url_for_format(source,fmt): | ||
url = URL_FOR(source, fmt) | ||
res = requests.get(url) | ||
assert res.status_code != 404 | ||
|
||
|
||
|
||
|
||
|
||
|
||
|