Add share to docker config issue (#4322)

This commit is contained in:
Mike Degatano 2023-05-30 15:36:06 -04:00 committed by GitHub
parent 841f68c175
commit e449205863
No known key found for this signature in database
GPG Key ID: 4AEE18F83AFDEB23
6 changed files with 35 additions and 17 deletions

View File

@ -387,6 +387,7 @@ class DockerAddon(DockerInterface):
source=self.sys_config.path_extern_share.as_posix(),
target="/share",
read_only=addon_mapping[MAP_SHARE],
propagation=PropagationMode.SLAVE.value,
)
)

View File

@ -97,6 +97,7 @@ class DockerHomeAssistant(DockerInterface):
source=self.sys_config.path_extern_share.as_posix(),
target="/share",
read_only=False,
propagation=PropagationMode.SLAVE.value,
),
Mount(
type=MountType.BIND.value,

View File

@ -14,7 +14,7 @@ def _check_container(container: DockerInterface) -> bool:
return any(
mount.get("Propagation") != PropagationMode.SLAVE.value
for mount in container.meta_mounts
if mount.get("Destination") == "/media"
if mount.get("Destination") in ["/media", "/share"]
)

View File

@ -126,8 +126,20 @@ def test_addon_map_folder_defaults(
in docker_addon.mounts
)
# Share not mapped
assert "/share" not in [mount["Target"] for mount in docker_addon.mounts]
# Share added and propagation set
assert (
Mount(
type="bind",
source=coresys.config.path_extern_share.as_posix(),
target="/share",
read_only=True,
propagation="slave",
)
in docker_addon.mounts
)
# Backup not added
assert "/backup" not in [mount["Target"] for mount in docker_addon.mounts]
def test_journald_addon(

View File

@ -7,7 +7,7 @@
"url": "https://www.home-assistant.io/",
"startup": "application",
"boot": "auto",
"map": ["config:rw", "ssl", "media"],
"map": ["config:rw", "ssl", "media", "share"],
"options": {},
"schema": {},
"image": "test/{arch}-my-custom-addon"

View File

@ -2,6 +2,8 @@
from unittest.mock import MagicMock, patch
import pytest
from supervisor.addons.addon import Addon
from supervisor.const import CoreState
from supervisor.coresys import CoreSys
@ -14,24 +16,23 @@ from supervisor.resolution.data import Issue, Suggestion
from tests.conftest import mock_async_return_true
def _make_mock_container_get(bad_config_names: list[str]):
def _make_mock_container_get(bad_config_names: list[str], folder: str = "media"):
"""Make mock of container get."""
mount = {
"Type": "bind",
"Source": f"/mnt/data/supervisor/{folder}",
"Destination": f"/{folder}",
"Mode": "rw",
"RW": True,
"Propagation": "rprivate",
}
def mock_container_get(name):
out = MagicMock()
out.status = "running"
out.attrs = {"State": {}, "Mounts": []}
if name in bad_config_names:
out.attrs["Mounts"].append(
{
"Type": "bind",
"Source": "/mnt/data/supervisor/media",
"Destination": "/media",
"Mode": "rw",
"RW": True,
"Propagation": "rprivate",
}
)
out.attrs["Mounts"].append(mount)
return out
@ -45,10 +46,13 @@ async def test_base(coresys: CoreSys):
assert docker_config.enabled
async def test_check(docker: DockerAPI, coresys: CoreSys, install_addon_ssh: Addon):
@pytest.mark.parametrize("folder", ["media", "share"])
async def test_check(
docker: DockerAPI, coresys: CoreSys, install_addon_ssh: Addon, folder: str
):
"""Test check reports issue when containers have incorrect config."""
docker.containers.get = _make_mock_container_get(
["homeassistant", "hassio_audio", "addon_local_ssh"]
["homeassistant", "hassio_audio", "addon_local_ssh"], folder
)
with patch.object(DockerInterface, "is_running", new=mock_async_return_true):
await coresys.plugins.load()