Skip to content

Commit

Permalink
Test README.md urls in the container annotations (Fixes #427)
Browse files Browse the repository at this point in the history
  • Loading branch information
dirkmueller committed Apr 4, 2024
1 parent 517671e commit de1a75f
Show file tree
Hide file tree
Showing 2 changed files with 54 additions and 0 deletions.
53 changes: 53 additions & 0 deletions tests/test_metadata.py
Original file line number Diff line number Diff line change
Expand Up @@ -13,10 +13,13 @@
offer the labels under the ``com.suse.bci`` prefix but ``com.suse.sle``.
"""
import urllib.parse as urlparse
from subprocess import check_output
from typing import List

import markdown2
import pytest
import requests
from _pytest.mark.structures import ParameterSet
from pytest_container import OciRuntimeBase
from pytest_container.container import ContainerData
Expand Down Expand Up @@ -375,6 +378,56 @@ def test_disturl(
)


@pytest.mark.parametrize(
"container,container_name,container_type",
IMAGES_AND_NAMES_WITH_BASE_XFAIL,
indirect=["container"],
)
def test_readme_md_content(
container: ContainerData,
container_name: str,
container_type: ImageType,
):
"""General check of the ``io.artifacthub.package.readme-url`` label:
verify that if it exists, it is reachable and the content is valid
markdown.
"""
labels = container.inspect.config.labels

readme_url = urlparse.urlparse(labels["io.artifacthub.package.readme-url"])

assert readme_url.scheme == "https"
assert readme_url.netloc in (
"api.opensuse.org",
"build.suse.de",
"build.opensuse.org",
"sources.suse.com",
)
assert readme_url.port is None
assert readme_url.path.endswith(".md") or readme_url.query.endswith(".md")

body = requests.get(
readme_url.geturl(),
timeout=30,
headers={"User-Agent": "SLE BCI tests"},
)
assert readme_url.geturl() is None

body.raise_for_status()

# TODO(dmllr): the urls pointing to build.opensuse.org or build.suse.de are not
# actually pointing at the raw markdown file, but at a html page that contains
# the markdown. So we can't do the markdown conversion test on those until these
# references are fixed.
if readme_url.netloc == "sources.suse.com":
assert not body.headers["content-type"].startswith("text/html")
# Doesn't look like html?
assert not body.text.strip().startswith("<")
# can be converted to html?
assert markdown2.markdown(body.text).startswith("<html>")


@pytest.mark.skipif(
not LOCALHOST.exists("osc"),
reason="osc needs to be installed for this test",
Expand Down
1 change: 1 addition & 0 deletions tox.ini
Original file line number Diff line number Diff line change
Expand Up @@ -10,6 +10,7 @@ deps =
pytest-xdist ; python_version >= "3.6"
dataclasses ; python_version < "3.7"
pytest-rerunfailures
markdown2
typing_extensions
requests
tenacity
Expand Down

0 comments on commit de1a75f

Please sign in to comment.