1
0
mirror of https://github.com/GNS3/gns3-server synced 2025-01-28 00:41:01 +00:00

Merge pull request #2204 from GNS3/fix/2203

Allow ':' in project name when using Docker containers
This commit is contained in:
Jeremy Grossmann 2023-03-19 16:00:04 +08:00 committed by GitHub
commit 2bb71838ac
No known key found for this signature in database
GPG Key ID: 4AEE18F83AFDEB23
2 changed files with 272 additions and 65 deletions

View File

@ -303,7 +303,12 @@ class DockerVM(BaseNode):
resources = get_resource("compute/docker/resources") resources = get_resource("compute/docker/resources")
if not os.path.exists(resources): if not os.path.exists(resources):
raise DockerError(f"{resources} is missing, can't start Docker container") raise DockerError(f"{resources} is missing, can't start Docker container")
binds = [f"{resources}:/gns3:ro"] binds = [{
"Type": "bind",
"Source": resources,
"Target": "/gns3",
"ReadOnly": True
}]
# We mount our own etc/network # We mount our own etc/network
try: try:
@ -334,7 +339,11 @@ class DockerVM(BaseNode):
for volume in self._volumes: for volume in self._volumes:
source = os.path.join(self.working_dir, os.path.relpath(volume, "/")) source = os.path.join(self.working_dir, os.path.relpath(volume, "/"))
os.makedirs(source, exist_ok=True) os.makedirs(source, exist_ok=True)
binds.append(f"{source}:/gns3volumes{volume}") binds.append({
"Type": "bind",
"Source": source,
"Target": "/gns3volumes{}".format(volume)
})
return binds return binds
@ -410,7 +419,7 @@ class DockerVM(BaseNode):
"HostConfig": { "HostConfig": {
"CapAdd": ["ALL"], "CapAdd": ["ALL"],
"Privileged": True, "Privileged": True,
"Binds": self._mount_binds(image_infos), "Mounts": self._mount_binds(image_infos),
"Memory": self._memory * (1024 * 1024), # convert memory to bytes "Memory": self._memory * (1024 * 1024), # convert memory to bytes
"NanoCpus": int(self._cpus * 1e9), # convert cpus to nano cpus "NanoCpus": int(self._cpus * 1e9), # convert cpus to nano cpus
}, },
@ -475,7 +484,11 @@ class DockerVM(BaseNode):
"QT_GRAPHICSSYSTEM=native" "QT_GRAPHICSSYSTEM=native"
) # To fix a Qt issue: https://github.com/GNS3/gns3-server/issues/556 ) # To fix a Qt issue: https://github.com/GNS3/gns3-server/issues/556
params["Env"].append(f"DISPLAY=:{self._display}") params["Env"].append(f"DISPLAY=:{self._display}")
params["HostConfig"]["Binds"].append("/tmp/.X11-unix/:/tmp/.X11-unix/") params["HostConfig"]["Mounts"].append({
"Type": "bind",
"Source": "/tmp/.X11-unix/",
"Target": "/tmp/.X11-unix/"
})
if self._extra_hosts: if self._extra_hosts:
extra_hosts = self._format_extra_hosts(self._extra_hosts) extra_hosts = self._format_extra_hosts(self._extra_hosts)

View File

@ -103,9 +103,18 @@ async def test_create(compute_project, manager):
"HostConfig": "HostConfig":
{ {
"CapAdd": ["ALL"], "CapAdd": ["ALL"],
"Binds": [ "Mounts": [
"{}:/gns3:ro".format(get_resource("compute/docker/resources")), {
"{}:/gns3volumes/etc/network".format(os.path.join(vm.working_dir, "etc", "network")) "Type": "bind",
"Source": get_resource("compute/docker/resources"),
"Target": "/gns3",
"ReadOnly": True
},
{
"Type": "bind",
"Source": os.path.join(vm.working_dir, "etc", "network"),
"Target": "/gns3volumes/etc/network"
}
], ],
"Privileged": True, "Privileged": True,
"Memory": 0, "Memory": 0,
@ -144,9 +153,18 @@ async def test_create_with_tag(compute_project, manager):
"HostConfig": "HostConfig":
{ {
"CapAdd": ["ALL"], "CapAdd": ["ALL"],
"Binds": [ "Mounts": [
"{}:/gns3:ro".format(get_resource("compute/docker/resources")), {
"{}:/gns3volumes/etc/network".format(os.path.join(vm.working_dir, "etc", "network")) "Type": "bind",
"Source": get_resource("compute/docker/resources"),
"Target": "/gns3",
"ReadOnly": True
},
{
"Type": "bind",
"Source": os.path.join(vm.working_dir, "etc", "network"),
"Target": "/gns3volumes/etc/network"
}
], ],
"Privileged": True, "Privileged": True,
"Memory": 0, "Memory": 0,
@ -188,10 +206,23 @@ async def test_create_vnc(compute_project, manager):
"HostConfig": "HostConfig":
{ {
"CapAdd": ["ALL"], "CapAdd": ["ALL"],
"Binds": [ "Mounts": [
"{}:/gns3:ro".format(get_resource("compute/docker/resources")), {
"{}:/gns3volumes/etc/network".format(os.path.join(vm.working_dir, "etc", "network")), "Type": "bind",
'/tmp/.X11-unix/:/tmp/.X11-unix/' "Source": get_resource("compute/docker/resources"),
"Target": "/gns3",
"ReadOnly": True
},
{
"Type": "bind",
"Source": os.path.join(vm.working_dir, "etc", "network"),
"Target": "/gns3volumes/etc/network"
},
{
"Type": "bind",
"Source": "/tmp/.X11-unix/",
"Target": "/tmp/.X11-unix/"
}
], ],
"Privileged": True, "Privileged": True,
"Memory": 0, "Memory": 0,
@ -310,9 +341,18 @@ async def test_create_start_cmd(compute_project, manager):
"HostConfig": "HostConfig":
{ {
"CapAdd": ["ALL"], "CapAdd": ["ALL"],
"Binds": [ "Mounts": [
"{}:/gns3:ro".format(get_resource("compute/docker/resources")), {
"{}:/gns3volumes/etc/network".format(os.path.join(vm.working_dir, "etc", "network")) "Type": "bind",
"Source": get_resource("compute/docker/resources"),
"Target": "/gns3",
"ReadOnly": True
},
{
"Type": "bind",
"Source": os.path.join(vm.working_dir, "etc", "network"),
"Target": "/gns3volumes/etc/network"
}
], ],
"Privileged": True, "Privileged": True,
"Memory": 0, "Memory": 0,
@ -413,9 +453,18 @@ async def test_create_image_not_available(compute_project, manager):
"HostConfig": "HostConfig":
{ {
"CapAdd": ["ALL"], "CapAdd": ["ALL"],
"Binds": [ "Mounts": [
"{}:/gns3:ro".format(get_resource("compute/docker/resources")), {
"{}:/gns3volumes/etc/network".format(os.path.join(vm.working_dir, "etc", "network")) "Type": "bind",
"Source": get_resource("compute/docker/resources"),
"Target": "/gns3",
"ReadOnly": True
},
{
"Type": "bind",
"Source": os.path.join(vm.working_dir, "etc", "network"),
"Target": "/gns3volumes/etc/network"
}
], ],
"Privileged": True, "Privileged": True,
"Memory": 0, "Memory": 0,
@ -459,9 +508,18 @@ async def test_create_with_user(compute_project, manager):
"HostConfig": "HostConfig":
{ {
"CapAdd": ["ALL"], "CapAdd": ["ALL"],
"Binds": [ "Mounts": [
"{}:/gns3:ro".format(get_resource("compute/docker/resources")), {
"{}:/gns3volumes/etc/network".format(os.path.join(vm.working_dir, "etc", "network")) "Type": "bind",
"Source": get_resource("compute/docker/resources"),
"Target": "/gns3",
"ReadOnly": True
},
{
"Type": "bind",
"Source": os.path.join(vm.working_dir, "etc", "network"),
"Target": "/gns3volumes/etc/network"
}
], ],
"Privileged": True, "Privileged": True,
"Memory": 0, "Memory": 0,
@ -548,10 +606,23 @@ async def test_create_with_extra_volumes_duplicate_1_image(compute_project, mana
"HostConfig": "HostConfig":
{ {
"CapAdd": ["ALL"], "CapAdd": ["ALL"],
"Binds": [ "Mounts": [
"{}:/gns3:ro".format(get_resource("compute/docker/resources")), {
"{}:/gns3volumes/etc/network".format(os.path.join(vm.working_dir, "etc", "network")), "Type": "bind",
"{}:/gns3volumes/vol/1".format(os.path.join(vm.working_dir, "vol", "1")), "Source": get_resource("compute/docker/resources"),
"Target": "/gns3",
"ReadOnly": True
},
{
"Type": "bind",
"Source": os.path.join(vm.working_dir, "etc", "network"),
"Target": "/gns3volumes/etc/network"
},
{
"Type": "bind",
"Source": os.path.join(vm.working_dir, "vol", "1"),
"Target": "/gns3volumes/vol/1"
}
], ],
"Privileged": True, "Privileged": True,
"Memory": 0, "Memory": 0,
@ -590,10 +661,23 @@ async def test_create_with_extra_volumes_duplicate_2_user(compute_project, manag
"HostConfig": "HostConfig":
{ {
"CapAdd": ["ALL"], "CapAdd": ["ALL"],
"Binds": [ "Mounts": [
"{}:/gns3:ro".format(get_resource("compute/docker/resources")), {
"{}:/gns3volumes/etc/network".format(os.path.join(vm.working_dir, "etc", "network")), "Type": "bind",
"{}:/gns3volumes/vol/1".format(os.path.join(vm.working_dir, "vol", "1")), "Source": get_resource("compute/docker/resources"),
"Target": "/gns3",
"ReadOnly": True
},
{
"Type": "bind",
"Source": os.path.join(vm.working_dir, "etc", "network"),
"Target": "/gns3volumes/etc/network"
},
{
"Type": "bind",
"Source": os.path.join(vm.working_dir, "vol", "1"),
"Target": "/gns3volumes/vol/1"
}
], ],
"Privileged": True, "Privileged": True,
"Memory": 0, "Memory": 0,
@ -632,10 +716,23 @@ async def test_create_with_extra_volumes_duplicate_3_subdir(compute_project, man
"HostConfig": "HostConfig":
{ {
"CapAdd": ["ALL"], "CapAdd": ["ALL"],
"Binds": [ "Mounts": [
"{}:/gns3:ro".format(get_resource("compute/docker/resources")), {
"{}:/gns3volumes/etc/network".format(os.path.join(vm.working_dir, "etc", "network")), "Type": "bind",
"{}:/gns3volumes/vol".format(os.path.join(vm.working_dir, "vol")), "Source": get_resource("compute/docker/resources"),
"Target": "/gns3",
"ReadOnly": True
},
{
"Type": "bind",
"Source": os.path.join(vm.working_dir, "etc", "network"),
"Target": "/gns3volumes/etc/network"
},
{
"Type": "bind",
"Source": os.path.join(vm.working_dir, "vol"),
"Target": "/gns3volumes/vol"
}
], ],
"Privileged": True, "Privileged": True,
"Memory": 0, "Memory": 0,
@ -674,10 +771,23 @@ async def test_create_with_extra_volumes_duplicate_4_backslash(compute_project,
"HostConfig": "HostConfig":
{ {
"CapAdd": ["ALL"], "CapAdd": ["ALL"],
"Binds": [ "Mounts": [
"{}:/gns3:ro".format(get_resource("compute/docker/resources")), {
"{}:/gns3volumes/etc/network".format(os.path.join(vm.working_dir, "etc", "network")), "Type": "bind",
"{}:/gns3volumes/vol".format(os.path.join(vm.working_dir, "vol")), "Source": get_resource("compute/docker/resources"),
"Target": "/gns3",
"ReadOnly": True
},
{
"Type": "bind",
"Source": os.path.join(vm.working_dir, "etc", "network"),
"Target": "/gns3volumes/etc/network"
},
{
"Type": "bind",
"Source": os.path.join(vm.working_dir, "vol"),
"Target": "/gns3volumes/vol"
}
], ],
"Privileged": True, "Privileged": True,
"Memory": 0, "Memory": 0,
@ -716,9 +826,18 @@ async def test_create_with_extra_volumes_duplicate_5_subdir_issue_1595(compute_p
"HostConfig": "HostConfig":
{ {
"CapAdd": ["ALL"], "CapAdd": ["ALL"],
"Binds": [ "Mounts": [
"{}:/gns3:ro".format(get_resource("compute/docker/resources")), {
"{}:/gns3volumes/etc".format(os.path.join(vm.working_dir, "etc")), "Type": "bind",
"Source": get_resource("compute/docker/resources"),
"Target": "/gns3",
"ReadOnly": True
},
{
"Type": "bind",
"Source": os.path.join(vm.working_dir, "etc"),
"Target": "/gns3volumes/etc"
}
], ],
"Privileged": True, "Privileged": True,
"Memory": 0, "Memory": 0,
@ -757,9 +876,18 @@ async def test_create_with_extra_volumes_duplicate_6_subdir_issue_1595(compute_p
"HostConfig": "HostConfig":
{ {
"CapAdd": ["ALL"], "CapAdd": ["ALL"],
"Binds": [ "Mounts": [
"{}:/gns3:ro".format(get_resource("compute/docker/resources")), {
"{}:/gns3volumes/etc".format(os.path.join(vm.working_dir, "etc")), "Type": "bind",
"Source": get_resource("compute/docker/resources"),
"Target": "/gns3",
"ReadOnly": True
},
{
"Type": "bind",
"Source": os.path.join(vm.working_dir, "etc"),
"Target": "/gns3volumes/etc"
}
], ],
"Privileged": True, "Privileged": True,
"Memory": 0, "Memory": 0,
@ -804,11 +932,28 @@ async def test_create_with_extra_volumes(compute_project, manager):
"HostConfig": "HostConfig":
{ {
"CapAdd": ["ALL"], "CapAdd": ["ALL"],
"Binds": [ "Mounts": [
"{}:/gns3:ro".format(get_resource("compute/docker/resources")), {
"{}:/gns3volumes/etc/network".format(os.path.join(vm.working_dir, "etc", "network")), "Type": "bind",
"{}:/gns3volumes/vol/1".format(os.path.join(vm.working_dir, "vol", "1")), "Source": get_resource("compute/docker/resources"),
"{}:/gns3volumes/vol/2".format(os.path.join(vm.working_dir, "vol", "2")), "Target": "/gns3",
"ReadOnly": True
},
{
"Type": "bind",
"Source": os.path.join(vm.working_dir, "etc", "network"),
"Target": "/gns3volumes/etc/network"
},
{
"Type": "bind",
"Source": os.path.join(vm.working_dir, "vol", "1"),
"Target": "/gns3volumes/vol/1"
},
{
"Type": "bind",
"Source": os.path.join(vm.working_dir, "vol", "2"),
"Target": "/gns3volumes/vol/2"
}
], ],
"Privileged": True, "Privileged": True,
"Memory": 0, "Memory": 0,
@ -1043,9 +1188,18 @@ async def test_update(vm):
"HostConfig": "HostConfig":
{ {
"CapAdd": ["ALL"], "CapAdd": ["ALL"],
"Binds": [ "Mounts": [
"{}:/gns3:ro".format(get_resource("compute/docker/resources")), {
"{}:/gns3volumes/etc/network".format(os.path.join(vm.working_dir, "etc", "network")) "Type": "bind",
"Source": get_resource("compute/docker/resources"),
"Target": "/gns3",
"ReadOnly": True
},
{
"Type": "bind",
"Source": os.path.join(vm.working_dir, "etc", "network"),
"Target": "/gns3volumes/etc/network"
}
], ],
"Privileged": True, "Privileged": True,
"Memory": 0, "Memory": 0,
@ -1115,9 +1269,18 @@ async def test_update_running(vm):
"HostConfig": "HostConfig":
{ {
"CapAdd": ["ALL"], "CapAdd": ["ALL"],
"Binds": [ "Mounts": [
"{}:/gns3:ro".format(get_resource("compute/docker/resources")), {
"{}:/gns3volumes/etc/network".format(os.path.join(vm.working_dir, "etc", "network")) "Type": "bind",
"Source": get_resource("compute/docker/resources"),
"Target": "/gns3",
"ReadOnly": True
},
{
"Type": "bind",
"Source": os.path.join(vm.working_dir, "etc", "network"),
"Target": "/gns3volumes/etc/network"
}
], ],
"Privileged": True, "Privileged": True,
"Memory": 0, "Memory": 0,
@ -1397,9 +1560,22 @@ async def test_mount_binds(vm):
dst = os.path.join(vm.working_dir, "test/experimental") dst = os.path.join(vm.working_dir, "test/experimental")
assert vm._mount_binds(image_infos) == [ assert vm._mount_binds(image_infos) == [
"{}:/gns3:ro".format(get_resource("compute/docker/resources")), {
"{}:/gns3volumes/etc/network".format(os.path.join(vm.working_dir, "etc", "network")), "Type": "bind",
"{}:/gns3volumes{}".format(dst, "/test/experimental") "Source": get_resource("compute/docker/resources"),
"Target": "/gns3",
"ReadOnly": True
},
{
"Type": "bind",
"Source": os.path.join(vm.working_dir, "etc", "network"),
"Target": "/gns3volumes/etc/network"
},
{
"Type": "bind",
"Source": dst,
"Target": "/gns3volumes/test/experimental"
}
] ]
assert vm._volumes == ["/etc/network", "/test/experimental"] assert vm._volumes == ["/etc/network", "/test/experimental"]
@ -1527,9 +1703,18 @@ async def test_cpus(compute_project, manager):
"HostConfig": "HostConfig":
{ {
"CapAdd": ["ALL"], "CapAdd": ["ALL"],
"Binds": [ "Mounts": [
"{}:/gns3:ro".format(get_resource("compute/docker/resources")), {
"{}:/gns3volumes/etc/network".format(os.path.join(vm.working_dir, "etc", "network")) "Type": "bind",
"Source": get_resource("compute/docker/resources"),
"Target": "/gns3",
"ReadOnly": True
},
{
"Type": "bind",
"Source": os.path.join(vm.working_dir, "etc", "network"),
"Target": "/gns3volumes/etc/network"
}
], ],
"Privileged": True, "Privileged": True,
"Memory": 0, "Memory": 0,
@ -1568,9 +1753,18 @@ async def test_memory(compute_project, manager):
"HostConfig": "HostConfig":
{ {
"CapAdd": ["ALL"], "CapAdd": ["ALL"],
"Binds": [ "Mounts": [
"{}:/gns3:ro".format(get_resource("compute/docker/resources")), {
"{}:/gns3volumes/etc/network".format(os.path.join(vm.working_dir, "etc", "network")) "Type": "bind",
"Source": get_resource("compute/docker/resources"),
"Target": "/gns3",
"ReadOnly": True
},
{
"Type": "bind",
"Source": os.path.join(vm.working_dir, "etc", "network"),
"Target": "/gns3volumes/etc/network"
}
], ],
"Privileged": True, "Privileged": True,
"Memory": 33554432, # 32MB in bytes "Memory": 33554432, # 32MB in bytes