2015-10-14 18:10:05 +02:00
|
|
|
# -*- coding: utf-8 -*-
|
|
|
|
#
|
2020-06-16 13:59:03 +09:30
|
|
|
# Copyright (C) 2020 GNS3 Technologies Inc.
|
2015-10-14 18:10:05 +02:00
|
|
|
#
|
|
|
|
# This program is free software: you can redistribute it and/or modify
|
|
|
|
# it under the terms of the GNU General Public License as published by
|
|
|
|
# the Free Software Foundation, either version 3 of the License, or
|
|
|
|
# (at your option) any later version.
|
|
|
|
#
|
|
|
|
# This program is distributed in the hope that it will be useful,
|
|
|
|
# but WITHOUT ANY WARRANTY; without even the implied warranty of
|
|
|
|
# MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
|
|
|
|
# GNU General Public License for more details.
|
|
|
|
#
|
|
|
|
# You should have received a copy of the GNU General Public License
|
|
|
|
# along with this program. If not, see <http://www.gnu.org/licenses/>.
|
|
|
|
|
2017-07-11 18:05:11 +02:00
|
|
|
import aiohttp
|
2016-09-27 18:01:50 +02:00
|
|
|
import asyncio
|
2015-10-14 18:10:05 +02:00
|
|
|
import pytest
|
2022-08-24 21:03:16 +02:00
|
|
|
import pytest_asyncio
|
2015-10-14 18:10:05 +02:00
|
|
|
import uuid
|
2016-02-12 11:57:56 +01:00
|
|
|
import os
|
2023-08-18 12:20:54 +10:00
|
|
|
|
|
|
|
from unittest.mock import patch
|
2016-03-01 14:53:43 +01:00
|
|
|
from tests.utils import asyncio_patch, AsyncioMagicMock
|
2015-10-14 18:10:05 +02:00
|
|
|
|
2020-11-19 15:21:03 +10:30
|
|
|
from gns3server.compute.ubridge.ubridge_error import UbridgeNamespaceError
|
2016-04-15 17:57:06 +02:00
|
|
|
from gns3server.compute.docker.docker_vm import DockerVM
|
2020-11-19 15:21:03 +10:30
|
|
|
from gns3server.compute.docker.docker_error import DockerError, DockerHttp404Error
|
2016-04-15 17:57:06 +02:00
|
|
|
from gns3server.compute.docker import Docker
|
2016-03-01 18:38:03 +01:00
|
|
|
from gns3server.utils.get_resource import get_resource
|
2015-10-14 18:10:05 +02:00
|
|
|
|
2016-02-11 15:49:28 +01:00
|
|
|
|
2017-07-20 15:37:56 +02:00
|
|
|
from unittest.mock import patch, MagicMock, call
|
2015-10-14 18:10:05 +02:00
|
|
|
|
|
|
|
|
2022-08-24 21:03:16 +02:00
|
|
|
@pytest_asyncio.fixture
|
2020-10-02 16:07:50 +09:30
|
|
|
async def manager(port_manager):
|
2020-06-16 13:59:03 +09:30
|
|
|
|
2015-10-14 18:10:05 +02:00
|
|
|
m = Docker.instance()
|
|
|
|
m.port_manager = port_manager
|
|
|
|
return m
|
|
|
|
|
|
|
|
|
2022-08-24 21:03:16 +02:00
|
|
|
@pytest_asyncio.fixture(scope="function")
|
2020-10-02 16:07:50 +09:30
|
|
|
async def vm(compute_project, manager):
|
2020-06-16 13:59:03 +09:30
|
|
|
|
2020-07-29 16:32:45 +09:30
|
|
|
vm = DockerVM("test", str(uuid.uuid4()), compute_project, manager, "ubuntu:latest", aux_type="none")
|
2015-10-14 18:10:05 +02:00
|
|
|
vm._cid = "e90e34656842"
|
|
|
|
return vm
|
|
|
|
|
|
|
|
|
2020-06-16 13:59:03 +09:30
|
|
|
def test_json(vm, compute_project):
|
|
|
|
|
2021-04-17 23:34:28 +09:30
|
|
|
assert vm.asdict() == {
|
2015-10-14 18:10:05 +02:00
|
|
|
'container_id': 'e90e34656842',
|
2016-05-19 13:09:07 +02:00
|
|
|
'image': 'ubuntu:latest',
|
2015-10-14 18:10:05 +02:00
|
|
|
'name': 'test',
|
2020-06-16 13:59:03 +09:30
|
|
|
'project_id': compute_project.id,
|
2016-05-11 11:35:36 -06:00
|
|
|
'node_id': vm.id,
|
2015-10-14 18:10:05 +02:00
|
|
|
'adapters': 1,
|
|
|
|
'console': vm.console,
|
2016-02-29 21:08:25 +01:00
|
|
|
'console_type': 'telnet',
|
2020-07-29 16:32:45 +09:30
|
|
|
'aux_type': 'none',
|
2016-04-07 13:29:11 +02:00
|
|
|
'console_resolution': '1024x768',
|
2016-05-03 16:49:33 +02:00
|
|
|
'console_http_port': 80,
|
|
|
|
'console_http_path': '/',
|
2018-04-27 14:33:07 +02:00
|
|
|
'extra_hosts': None,
|
2019-04-22 09:53:38 +01:00
|
|
|
'extra_volumes': [],
|
2020-07-18 21:03:55 +09:30
|
|
|
'memory': 0,
|
|
|
|
'cpus': 0,
|
2016-02-29 10:38:30 +01:00
|
|
|
'aux': vm.aux,
|
2015-10-14 18:10:05 +02:00
|
|
|
'start_command': vm.start_command,
|
2016-02-12 11:57:56 +01:00
|
|
|
'environment': vm.environment,
|
2016-05-17 19:51:06 +02:00
|
|
|
'node_directory': vm.working_dir,
|
2018-12-30 21:50:47 +07:00
|
|
|
'status': 'stopped',
|
|
|
|
'usage': ''
|
2015-10-14 18:10:05 +02:00
|
|
|
}
|
|
|
|
|
|
|
|
|
2016-02-19 17:01:28 +01:00
|
|
|
def test_start_command(vm):
|
|
|
|
|
|
|
|
vm.start_command = "hello"
|
|
|
|
assert vm.start_command == "hello"
|
|
|
|
vm.start_command = " "
|
|
|
|
assert vm.start_command is None
|
|
|
|
|
|
|
|
|
2020-10-02 16:07:50 +09:30
|
|
|
@pytest.mark.asyncio
|
2020-06-16 13:59:03 +09:30
|
|
|
async def test_create(compute_project, manager):
|
2015-10-14 18:10:05 +02:00
|
|
|
|
|
|
|
response = {
|
|
|
|
"Id": "e90e34656806",
|
|
|
|
"Warnings": []
|
|
|
|
}
|
2020-06-16 13:59:03 +09:30
|
|
|
with asyncio_patch("gns3server.compute.docker.Docker.list_images", return_value=[{"image": "ubuntu"}]):
|
2016-04-15 17:57:06 +02:00
|
|
|
with asyncio_patch("gns3server.compute.docker.Docker.query", return_value=response) as mock:
|
2020-06-16 13:59:03 +09:30
|
|
|
vm = DockerVM("test", str(uuid.uuid4()), compute_project, manager, "ubuntu:latest")
|
|
|
|
await vm.create()
|
2015-10-14 18:10:05 +02:00
|
|
|
mock.assert_called_with("POST", "containers/create", data={
|
|
|
|
"Tty": True,
|
|
|
|
"OpenStdin": True,
|
|
|
|
"StdinOnce": False,
|
|
|
|
"HostConfig":
|
|
|
|
{
|
|
|
|
"CapAdd": ["ALL"],
|
2023-03-19 17:56:07 +10:00
|
|
|
"Mounts": [
|
|
|
|
{
|
|
|
|
"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"
|
|
|
|
}
|
2016-03-24 17:08:16 +01:00
|
|
|
],
|
2020-07-18 21:03:55 +09:30
|
|
|
"Privileged": True,
|
|
|
|
"Memory": 0,
|
|
|
|
"NanoCpus": 0
|
2015-10-14 18:10:05 +02:00
|
|
|
},
|
2016-02-12 11:57:56 +01:00
|
|
|
"Volumes": {},
|
2015-10-14 18:10:05 +02:00
|
|
|
"NetworkDisabled": True,
|
2016-02-23 19:22:35 +01:00
|
|
|
"Hostname": "test",
|
2016-05-19 13:09:07 +02:00
|
|
|
"Image": "ubuntu:latest",
|
2016-05-06 19:07:18 +02:00
|
|
|
"Env": [
|
2016-06-15 10:12:32 +02:00
|
|
|
"container=docker",
|
2016-06-01 11:39:42 +02:00
|
|
|
"GNS3_MAX_ETHERNET=eth0",
|
|
|
|
"GNS3_VOLUMES=/etc/network"
|
2016-10-24 12:21:57 +02:00
|
|
|
],
|
2016-05-19 13:09:07 +02:00
|
|
|
"Entrypoint": ["/gns3/init.sh"],
|
|
|
|
"Cmd": ["/bin/sh"]
|
|
|
|
})
|
|
|
|
assert vm._cid == "e90e34656806"
|
|
|
|
|
|
|
|
|
2020-10-02 16:07:50 +09:30
|
|
|
@pytest.mark.asyncio
|
2020-06-16 13:59:03 +09:30
|
|
|
async def test_create_with_tag(compute_project, manager):
|
2016-05-19 13:09:07 +02:00
|
|
|
|
|
|
|
response = {
|
|
|
|
"Id": "e90e34656806",
|
|
|
|
"Warnings": []
|
|
|
|
}
|
2020-06-16 13:59:03 +09:30
|
|
|
with asyncio_patch("gns3server.compute.docker.Docker.list_images", return_value=[{"image": "ubuntu"}]):
|
2016-05-19 13:32:30 +02:00
|
|
|
with asyncio_patch("gns3server.compute.docker.Docker.query", return_value=response) as mock:
|
2020-06-16 13:59:03 +09:30
|
|
|
vm = DockerVM("test", str(uuid.uuid4()), compute_project, manager, "ubuntu:16.04")
|
|
|
|
await vm.create()
|
2015-10-14 18:10:05 +02:00
|
|
|
mock.assert_called_with("POST", "containers/create", data={
|
|
|
|
"Tty": True,
|
|
|
|
"OpenStdin": True,
|
|
|
|
"StdinOnce": False,
|
|
|
|
"HostConfig":
|
|
|
|
{
|
|
|
|
"CapAdd": ["ALL"],
|
2023-03-19 17:56:07 +10:00
|
|
|
"Mounts": [
|
|
|
|
{
|
|
|
|
"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"
|
|
|
|
}
|
2016-03-24 17:08:16 +01:00
|
|
|
],
|
2020-07-18 21:03:55 +09:30
|
|
|
"Privileged": True,
|
|
|
|
"Memory": 0,
|
|
|
|
"NanoCpus": 0
|
2015-10-14 18:10:05 +02:00
|
|
|
},
|
2016-02-12 11:57:56 +01:00
|
|
|
"Volumes": {},
|
2015-10-14 18:10:05 +02:00
|
|
|
"NetworkDisabled": True,
|
2016-02-23 19:22:35 +01:00
|
|
|
"Hostname": "test",
|
2016-05-19 13:32:30 +02:00
|
|
|
"Image": "ubuntu:16.04",
|
2016-05-06 19:07:18 +02:00
|
|
|
"Env": [
|
2016-06-15 10:12:32 +02:00
|
|
|
"container=docker",
|
2016-06-01 11:39:42 +02:00
|
|
|
"GNS3_MAX_ETHERNET=eth0",
|
|
|
|
"GNS3_VOLUMES=/etc/network"
|
2016-10-24 12:21:57 +02:00
|
|
|
],
|
2016-03-04 09:08:40 +01:00
|
|
|
"Entrypoint": ["/gns3/init.sh"],
|
|
|
|
"Cmd": ["/bin/sh"]
|
2016-02-29 21:08:25 +01:00
|
|
|
})
|
|
|
|
assert vm._cid == "e90e34656806"
|
|
|
|
|
|
|
|
|
2020-10-02 16:07:50 +09:30
|
|
|
@pytest.mark.asyncio
|
2020-06-16 13:59:03 +09:30
|
|
|
async def test_create_vnc(compute_project, manager):
|
2016-02-29 21:08:25 +01:00
|
|
|
|
|
|
|
response = {
|
|
|
|
"Id": "e90e34656806",
|
|
|
|
"Warnings": []
|
|
|
|
}
|
|
|
|
|
2020-06-16 13:59:03 +09:30
|
|
|
with asyncio_patch("gns3server.compute.docker.Docker.list_images", return_value=[{"image": "ubuntu"}]):
|
2016-04-15 17:57:06 +02:00
|
|
|
with asyncio_patch("gns3server.compute.docker.Docker.query", return_value=response) as mock:
|
2020-06-16 13:59:03 +09:30
|
|
|
vm = DockerVM("test", str(uuid.uuid4()), compute_project, manager, "ubuntu", console_type="vnc", console=5900)
|
2016-02-29 21:08:25 +01:00
|
|
|
vm._start_vnc = MagicMock()
|
|
|
|
vm._display = 42
|
2020-06-16 13:59:03 +09:30
|
|
|
await vm.create()
|
2016-02-29 21:08:25 +01:00
|
|
|
mock.assert_called_with("POST", "containers/create", data={
|
|
|
|
"Tty": True,
|
|
|
|
"OpenStdin": True,
|
|
|
|
"StdinOnce": False,
|
|
|
|
"HostConfig":
|
|
|
|
{
|
|
|
|
"CapAdd": ["ALL"],
|
2023-03-19 17:56:07 +10:00
|
|
|
"Mounts": [
|
|
|
|
{
|
|
|
|
"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"
|
|
|
|
},
|
|
|
|
{
|
|
|
|
"Type": "bind",
|
2023-09-06 23:30:00 +07:00
|
|
|
"Source": f"/tmp/.X11-unix/X{vm._display}",
|
|
|
|
"Target": f"/tmp/.X11-unix/X{vm._display}",
|
|
|
|
"ReadOnly": True
|
2023-03-19 17:56:07 +10:00
|
|
|
}
|
2016-03-01 18:38:03 +01:00
|
|
|
],
|
2020-07-18 21:03:55 +09:30
|
|
|
"Privileged": True,
|
|
|
|
"Memory": 0,
|
|
|
|
"NanoCpus": 0
|
2016-02-29 21:08:25 +01:00
|
|
|
},
|
|
|
|
"Volumes": {},
|
|
|
|
"NetworkDisabled": True,
|
|
|
|
"Hostname": "test",
|
2016-05-19 13:09:07 +02:00
|
|
|
"Image": "ubuntu:latest",
|
2016-05-06 19:07:18 +02:00
|
|
|
"Env": [
|
2016-06-15 10:12:32 +02:00
|
|
|
"container=docker",
|
2016-05-06 19:07:18 +02:00
|
|
|
"GNS3_MAX_ETHERNET=eth0",
|
2016-06-01 11:39:42 +02:00
|
|
|
"GNS3_VOLUMES=/etc/network",
|
2016-06-15 11:01:03 +02:00
|
|
|
"QT_GRAPHICSSYSTEM=native",
|
2016-05-06 19:07:18 +02:00
|
|
|
"DISPLAY=:42"
|
2016-10-24 12:21:57 +02:00
|
|
|
],
|
2016-03-04 09:08:40 +01:00
|
|
|
"Entrypoint": ["/gns3/init.sh"],
|
|
|
|
"Cmd": ["/bin/sh"]
|
2015-10-14 18:10:05 +02:00
|
|
|
})
|
2016-02-29 21:08:25 +01:00
|
|
|
assert vm._start_vnc.called
|
2015-10-14 18:10:05 +02:00
|
|
|
assert vm._cid == "e90e34656806"
|
2016-04-06 14:57:52 +02:00
|
|
|
assert vm._console_type == "vnc"
|
2015-10-14 18:10:05 +02:00
|
|
|
|
|
|
|
|
2020-10-02 16:07:50 +09:30
|
|
|
@pytest.mark.asyncio
|
2020-06-16 13:59:03 +09:30
|
|
|
async def test_create_with_extra_hosts(compute_project, manager):
|
2018-04-25 16:03:01 +02:00
|
|
|
|
2020-06-16 13:59:03 +09:30
|
|
|
extra_hosts = "test:199.199.199.1\ntest2:199.199.199.1"
|
2018-04-25 16:03:01 +02:00
|
|
|
response = {
|
|
|
|
"Id": "e90e34656806",
|
|
|
|
"Warnings": []
|
|
|
|
}
|
|
|
|
|
2018-04-27 14:33:07 +02:00
|
|
|
with asyncio_patch("gns3server.compute.docker.Docker.list_images", return_value=[{"image": "ubuntu"}]):
|
2018-04-25 16:03:01 +02:00
|
|
|
with asyncio_patch("gns3server.compute.docker.Docker.query", return_value=response) as mock:
|
2020-06-16 13:59:03 +09:30
|
|
|
vm = DockerVM("test", str(uuid.uuid4()), compute_project, manager, "ubuntu", extra_hosts=extra_hosts)
|
|
|
|
await vm.create()
|
2018-04-25 16:03:01 +02:00
|
|
|
called_kwargs = mock.call_args[1]
|
2018-04-27 14:33:07 +02:00
|
|
|
assert "GNS3_EXTRA_HOSTS=199.199.199.1\ttest\n199.199.199.1\ttest2" in called_kwargs["data"]["Env"]
|
2018-04-25 16:03:01 +02:00
|
|
|
assert vm._extra_hosts == extra_hosts
|
|
|
|
|
2023-05-22 15:11:17 +08:00
|
|
|
@pytest.mark.asyncio
|
2023-03-19 18:26:26 +10:00
|
|
|
async def test_create_with_colon_in_project_name(compute_project, manager):
|
|
|
|
|
|
|
|
response = {
|
|
|
|
"Id": "e90e34656806",
|
|
|
|
"Warnings": []
|
|
|
|
}
|
|
|
|
|
|
|
|
with asyncio_patch("gns3server.compute.docker.Docker.list_images", return_value=[{"image": "ubuntu"}]):
|
|
|
|
with asyncio_patch("gns3server.compute.docker.Docker.query", return_value=response):
|
|
|
|
with patch("gns3server.compute.project.Project.node_working_directory", return_value="/tmp/test_:_/"):
|
|
|
|
vm = DockerVM("test", str(uuid.uuid4()), compute_project, manager, "ubuntu")
|
|
|
|
with pytest.raises(DockerError):
|
|
|
|
await vm.create()
|
|
|
|
|
2018-04-25 16:03:01 +02:00
|
|
|
|
2020-10-02 16:07:50 +09:30
|
|
|
@pytest.mark.asyncio
|
2020-06-16 13:59:03 +09:30
|
|
|
async def test_create_with_extra_hosts_wrong_format(compute_project, manager):
|
2018-04-27 14:33:07 +02:00
|
|
|
extra_hosts = "test"
|
|
|
|
|
|
|
|
response = {
|
|
|
|
"Id": "e90e34656806",
|
|
|
|
"Warnings": []
|
|
|
|
}
|
|
|
|
|
|
|
|
with asyncio_patch("gns3server.compute.docker.Docker.list_images", return_value=[{"image": "ubuntu"}]):
|
|
|
|
with asyncio_patch("gns3server.compute.docker.Docker.query", return_value=response):
|
2020-06-16 13:59:03 +09:30
|
|
|
vm = DockerVM("test", str(uuid.uuid4()), compute_project, manager, "ubuntu", extra_hosts=extra_hosts)
|
2018-04-27 14:33:07 +02:00
|
|
|
with pytest.raises(DockerError):
|
2020-06-16 13:59:03 +09:30
|
|
|
await vm.create()
|
2018-04-27 14:33:07 +02:00
|
|
|
|
|
|
|
|
2020-10-02 16:07:50 +09:30
|
|
|
@pytest.mark.asyncio
|
2020-06-16 13:59:03 +09:30
|
|
|
async def test_create_with_empty_extra_hosts(compute_project, manager):
|
2018-04-27 14:33:07 +02:00
|
|
|
extra_hosts = "test:\n"
|
|
|
|
|
|
|
|
response = {
|
|
|
|
"Id": "e90e34656806",
|
|
|
|
"Warnings": []
|
|
|
|
}
|
|
|
|
|
|
|
|
with asyncio_patch("gns3server.compute.docker.Docker.list_images", return_value=[{"image": "ubuntu"}]):
|
|
|
|
with asyncio_patch("gns3server.compute.docker.Docker.query", return_value=response) as mock:
|
2020-06-16 13:59:03 +09:30
|
|
|
vm = DockerVM("test", str(uuid.uuid4()), compute_project, manager, "ubuntu", extra_hosts=extra_hosts)
|
|
|
|
await vm.create()
|
2018-04-27 14:33:07 +02:00
|
|
|
called_kwargs = mock.call_args[1]
|
|
|
|
assert len([ e for e in called_kwargs["data"]["Env"] if "GNS3_EXTRA_HOSTS" in e]) == 0
|
|
|
|
|
|
|
|
|
2020-10-02 16:07:50 +09:30
|
|
|
@pytest.mark.asyncio
|
2020-06-16 13:59:03 +09:30
|
|
|
async def test_create_with_project_variables(compute_project, manager):
|
2018-05-04 14:34:44 +02:00
|
|
|
response = {
|
|
|
|
"Id": "e90e34656806",
|
|
|
|
"Warnings": []
|
|
|
|
}
|
|
|
|
|
2020-06-16 13:59:03 +09:30
|
|
|
compute_project.variables = [
|
2018-05-04 14:34:44 +02:00
|
|
|
{"name": "VAR1"},
|
2018-05-09 11:25:55 +02:00
|
|
|
{"name": "VAR2", "value": "VAL1"},
|
|
|
|
{"name": "VAR3", "value": "2x${VAR2}"}
|
2018-05-04 14:34:44 +02:00
|
|
|
]
|
|
|
|
|
|
|
|
with asyncio_patch("gns3server.compute.docker.Docker.list_images", return_value=[{"image": "ubuntu"}]):
|
|
|
|
with asyncio_patch("gns3server.compute.docker.Docker.query", return_value=response) as mock:
|
2020-06-16 13:59:03 +09:30
|
|
|
vm = DockerVM("test", str(uuid.uuid4()), compute_project, manager, "ubuntu")
|
|
|
|
await vm.create()
|
2018-05-04 14:34:44 +02:00
|
|
|
called_kwargs = mock.call_args[1]
|
|
|
|
assert "VAR1=" in called_kwargs["data"]["Env"]
|
|
|
|
assert "VAR2=VAL1" in called_kwargs["data"]["Env"]
|
2018-05-09 11:25:55 +02:00
|
|
|
assert "VAR3=2xVAL1" in called_kwargs["data"]["Env"]
|
2020-06-16 13:59:03 +09:30
|
|
|
compute_project.variables = None
|
2018-05-04 14:34:44 +02:00
|
|
|
|
2018-05-07 15:18:19 +02:00
|
|
|
|
2020-10-02 16:07:50 +09:30
|
|
|
@pytest.mark.asyncio
|
2020-06-16 13:59:03 +09:30
|
|
|
async def test_create_start_cmd(compute_project, manager):
|
2015-10-14 18:10:05 +02:00
|
|
|
|
|
|
|
response = {
|
|
|
|
"Id": "e90e34656806",
|
|
|
|
"Warnings": []
|
|
|
|
}
|
2020-06-16 13:59:03 +09:30
|
|
|
with asyncio_patch("gns3server.compute.docker.Docker.list_images", return_value=[{"image": "ubuntu"}]):
|
2016-04-15 17:57:06 +02:00
|
|
|
with asyncio_patch("gns3server.compute.docker.Docker.query", return_value=response) as mock:
|
2020-06-16 13:59:03 +09:30
|
|
|
vm = DockerVM("test", str(uuid.uuid4()), compute_project, manager, "ubuntu:latest")
|
2015-10-14 18:10:05 +02:00
|
|
|
vm._start_command = "/bin/ls"
|
2020-06-16 13:59:03 +09:30
|
|
|
await vm.create()
|
2015-10-14 18:10:05 +02:00
|
|
|
mock.assert_called_with("POST", "containers/create", data={
|
|
|
|
"Tty": True,
|
|
|
|
"OpenStdin": True,
|
|
|
|
"StdinOnce": False,
|
|
|
|
"HostConfig":
|
|
|
|
{
|
|
|
|
"CapAdd": ["ALL"],
|
2023-03-19 17:56:07 +10:00
|
|
|
"Mounts": [
|
|
|
|
{
|
|
|
|
"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"
|
|
|
|
}
|
2016-03-24 17:08:16 +01:00
|
|
|
],
|
2020-07-18 21:03:55 +09:30
|
|
|
"Privileged": True,
|
|
|
|
"Memory": 0,
|
|
|
|
"NanoCpus": 0
|
2015-10-14 18:10:05 +02:00
|
|
|
},
|
2016-02-12 11:57:56 +01:00
|
|
|
"Volumes": {},
|
2016-03-04 09:08:40 +01:00
|
|
|
"Entrypoint": ["/gns3/init.sh"],
|
|
|
|
"Cmd": ["/bin/ls"],
|
2015-10-14 18:10:05 +02:00
|
|
|
"NetworkDisabled": True,
|
2016-02-23 19:22:35 +01:00
|
|
|
"Hostname": "test",
|
2016-05-19 13:09:07 +02:00
|
|
|
"Image": "ubuntu:latest",
|
2016-05-06 19:07:18 +02:00
|
|
|
"Env": [
|
2016-06-15 10:12:32 +02:00
|
|
|
"container=docker",
|
2016-06-01 11:39:42 +02:00
|
|
|
"GNS3_MAX_ETHERNET=eth0",
|
|
|
|
"GNS3_VOLUMES=/etc/network"
|
2016-10-24 12:21:57 +02:00
|
|
|
]
|
2015-10-14 18:10:05 +02:00
|
|
|
})
|
|
|
|
assert vm._cid == "e90e34656806"
|
|
|
|
|
|
|
|
|
2020-10-02 16:07:50 +09:30
|
|
|
@pytest.mark.asyncio
|
2020-06-16 13:59:03 +09:30
|
|
|
async def test_create_environment(compute_project, manager):
|
2017-07-20 15:37:56 +02:00
|
|
|
"""
|
2020-06-16 13:59:03 +09:30
|
|
|
Allow user to pass an environment. User can't override our
|
2017-07-20 15:37:56 +02:00
|
|
|
internal variables
|
|
|
|
"""
|
2015-10-14 18:10:05 +02:00
|
|
|
|
|
|
|
response = {
|
|
|
|
"Id": "e90e34656806",
|
|
|
|
"Warnings": []
|
|
|
|
}
|
2017-07-20 15:37:56 +02:00
|
|
|
with asyncio_patch("gns3server.compute.docker.Docker.list_images", return_value=[{"image": "ubuntu"}]):
|
2016-04-15 17:57:06 +02:00
|
|
|
with asyncio_patch("gns3server.compute.docker.Docker.query", return_value=response) as mock:
|
2020-06-16 13:59:03 +09:30
|
|
|
vm = DockerVM("test", str(uuid.uuid4()), compute_project, manager, "ubuntu")
|
2017-07-20 15:37:56 +02:00
|
|
|
vm.environment = "YES=1\nNO=0\nGNS3_MAX_ETHERNET=eth2"
|
2020-06-16 13:59:03 +09:30
|
|
|
await vm.create()
|
2018-02-27 16:33:55 +01:00
|
|
|
assert mock.call_args[1]['data']['Env'] == [
|
|
|
|
"container=docker",
|
|
|
|
"GNS3_MAX_ETHERNET=eth0",
|
|
|
|
"GNS3_VOLUMES=/etc/network",
|
|
|
|
"YES=1",
|
|
|
|
"NO=0"
|
|
|
|
]
|
|
|
|
|
|
|
|
|
2020-10-02 16:07:50 +09:30
|
|
|
@pytest.mark.asyncio
|
2020-06-16 13:59:03 +09:30
|
|
|
async def test_create_environment_with_last_new_line_character(compute_project, manager):
|
2018-02-27 16:33:55 +01:00
|
|
|
"""
|
2020-06-16 13:59:03 +09:30
|
|
|
Allow user to pass an environment. User can't override our
|
2018-02-27 16:33:55 +01:00
|
|
|
internal variables
|
|
|
|
"""
|
|
|
|
|
|
|
|
response = {
|
|
|
|
"Id": "e90e34656806",
|
|
|
|
"Warnings": []
|
|
|
|
}
|
|
|
|
with asyncio_patch("gns3server.compute.docker.Docker.list_images", return_value=[{"image": "ubuntu"}]):
|
|
|
|
with asyncio_patch("gns3server.compute.docker.Docker.query", return_value=response) as mock:
|
2020-06-16 13:59:03 +09:30
|
|
|
vm = DockerVM("test", str(uuid.uuid4()), compute_project, manager, "ubuntu")
|
2018-02-27 16:33:55 +01:00
|
|
|
vm.environment = "YES=1\nNO=0\nGNS3_MAX_ETHERNET=eth2\n"
|
2020-06-16 13:59:03 +09:30
|
|
|
await vm.create()
|
2018-02-27 16:33:55 +01:00
|
|
|
assert mock.call_args[1]['data']['Env'] == [
|
|
|
|
"container=docker",
|
|
|
|
"GNS3_MAX_ETHERNET=eth0",
|
|
|
|
"GNS3_VOLUMES=/etc/network",
|
|
|
|
"YES=1",
|
|
|
|
"NO=0"
|
|
|
|
]
|
2015-10-14 18:10:05 +02:00
|
|
|
|
|
|
|
|
2020-10-02 16:07:50 +09:30
|
|
|
@pytest.mark.asyncio
|
2020-06-16 13:59:03 +09:30
|
|
|
async def test_create_image_not_available(compute_project, manager):
|
2015-10-14 18:10:05 +02:00
|
|
|
|
2016-02-24 17:08:28 +01:00
|
|
|
call = 0
|
2018-10-15 17:05:49 +07:00
|
|
|
async def information():
|
2016-02-24 17:08:28 +01:00
|
|
|
nonlocal call
|
|
|
|
if call == 0:
|
|
|
|
call += 1
|
|
|
|
raise DockerHttp404Error("missing")
|
|
|
|
else:
|
|
|
|
return {}
|
|
|
|
|
2015-10-14 18:10:05 +02:00
|
|
|
response = {
|
|
|
|
"Id": "e90e34656806",
|
|
|
|
"Warnings": []
|
|
|
|
}
|
2016-02-24 17:08:28 +01:00
|
|
|
|
2020-06-16 13:59:03 +09:30
|
|
|
vm = DockerVM("test", str(uuid.uuid4()), compute_project, manager, "ubuntu")
|
2016-05-13 19:28:53 -06:00
|
|
|
vm._get_image_information = MagicMock()
|
|
|
|
vm._get_image_information.side_effect = information
|
2016-04-15 17:57:06 +02:00
|
|
|
with asyncio_patch("gns3server.compute.docker.DockerVM.pull_image", return_value=True) as mock_pull:
|
|
|
|
with asyncio_patch("gns3server.compute.docker.Docker.query", return_value=response) as mock:
|
2020-06-16 13:59:03 +09:30
|
|
|
await vm.create()
|
2016-02-24 17:08:28 +01:00
|
|
|
mock.assert_called_with("POST", "containers/create", data={
|
|
|
|
"Tty": True,
|
|
|
|
"OpenStdin": True,
|
|
|
|
"StdinOnce": False,
|
|
|
|
"HostConfig":
|
|
|
|
{
|
|
|
|
"CapAdd": ["ALL"],
|
2023-03-19 17:56:07 +10:00
|
|
|
"Mounts": [
|
|
|
|
{
|
|
|
|
"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"
|
|
|
|
}
|
2016-03-24 17:08:16 +01:00
|
|
|
],
|
2020-07-18 21:03:55 +09:30
|
|
|
"Privileged": True,
|
|
|
|
"Memory": 0,
|
|
|
|
"NanoCpus": 0
|
2016-02-24 17:08:28 +01:00
|
|
|
},
|
|
|
|
"Volumes": {},
|
|
|
|
"NetworkDisabled": True,
|
|
|
|
"Hostname": "test",
|
2016-05-19 13:09:07 +02:00
|
|
|
"Image": "ubuntu:latest",
|
2016-05-06 19:07:18 +02:00
|
|
|
"Env": [
|
2016-06-15 10:12:32 +02:00
|
|
|
"container=docker",
|
2016-06-01 11:39:42 +02:00
|
|
|
"GNS3_MAX_ETHERNET=eth0",
|
|
|
|
"GNS3_VOLUMES=/etc/network"
|
2016-10-24 12:21:57 +02:00
|
|
|
],
|
2016-03-04 09:08:40 +01:00
|
|
|
"Entrypoint": ["/gns3/init.sh"],
|
|
|
|
"Cmd": ["/bin/sh"]
|
2016-02-24 17:08:28 +01:00
|
|
|
})
|
|
|
|
assert vm._cid == "e90e34656806"
|
2016-05-19 13:09:07 +02:00
|
|
|
mock_pull.assert_called_with("ubuntu:latest")
|
2015-10-14 18:10:05 +02:00
|
|
|
|
2020-06-16 13:59:03 +09:30
|
|
|
|
2020-10-02 16:07:50 +09:30
|
|
|
@pytest.mark.asyncio
|
2020-06-16 13:59:03 +09:30
|
|
|
async def test_create_with_user(compute_project, manager):
|
2019-04-05 11:06:35 +01:00
|
|
|
|
|
|
|
response = {
|
|
|
|
"Id": "e90e34656806",
|
|
|
|
"Warnings": [],
|
|
|
|
"Config" : {
|
|
|
|
"User" : "test",
|
|
|
|
},
|
|
|
|
}
|
2020-06-16 13:59:03 +09:30
|
|
|
with asyncio_patch("gns3server.compute.docker.Docker.list_images", return_value=[{"image": "ubuntu"}]):
|
2019-04-05 11:06:35 +01:00
|
|
|
with asyncio_patch("gns3server.compute.docker.Docker.query", return_value=response) as mock:
|
2020-06-16 13:59:03 +09:30
|
|
|
vm = DockerVM("test", str(uuid.uuid4()), compute_project, manager, "ubuntu:latest")
|
|
|
|
await vm.create()
|
2019-04-05 11:06:35 +01:00
|
|
|
mock.assert_called_with("POST", "containers/create", data={
|
|
|
|
"Tty": True,
|
|
|
|
"OpenStdin": True,
|
|
|
|
"StdinOnce": False,
|
|
|
|
"User": "root",
|
|
|
|
"HostConfig":
|
|
|
|
{
|
|
|
|
"CapAdd": ["ALL"],
|
2023-03-19 17:56:07 +10:00
|
|
|
"Mounts": [
|
|
|
|
{
|
|
|
|
"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"
|
|
|
|
}
|
2019-04-05 11:06:35 +01:00
|
|
|
],
|
2020-07-18 21:03:55 +09:30
|
|
|
"Privileged": True,
|
|
|
|
"Memory": 0,
|
|
|
|
"NanoCpus": 0
|
2019-04-05 11:06:35 +01:00
|
|
|
},
|
|
|
|
"Volumes": {},
|
|
|
|
"NetworkDisabled": True,
|
|
|
|
"Hostname": "test",
|
|
|
|
"Image": "ubuntu:latest",
|
|
|
|
"Env": [
|
|
|
|
"container=docker",
|
|
|
|
"GNS3_MAX_ETHERNET=eth0",
|
|
|
|
"GNS3_VOLUMES=/etc/network",
|
|
|
|
"GNS3_USER=test"
|
|
|
|
],
|
|
|
|
"Entrypoint": ["/gns3/init.sh"],
|
|
|
|
"Cmd": ["/bin/sh"]
|
|
|
|
})
|
|
|
|
assert vm._cid == "e90e34656806"
|
2015-10-14 18:10:05 +02:00
|
|
|
|
2020-10-02 16:07:50 +09:30
|
|
|
|
|
|
|
@pytest.mark.asyncio
|
2020-06-16 13:59:03 +09:30
|
|
|
async def test_create_with_extra_volumes_invalid_format_1(compute_project, manager):
|
2019-04-22 09:53:38 +01:00
|
|
|
|
|
|
|
response = {
|
|
|
|
"Id": "e90e34656806",
|
|
|
|
"Warnings": []
|
|
|
|
}
|
2020-06-16 13:59:03 +09:30
|
|
|
with asyncio_patch("gns3server.compute.docker.Docker.list_images", return_value=[{"image": "ubuntu"}]):
|
|
|
|
with asyncio_patch("gns3server.compute.docker.Docker.query", return_value=response):
|
|
|
|
vm = DockerVM("test", str(uuid.uuid4()), compute_project, manager, "ubuntu:latest", extra_volumes=["vol1"])
|
2019-04-22 09:53:38 +01:00
|
|
|
with pytest.raises(DockerError):
|
2020-06-16 13:59:03 +09:30
|
|
|
await vm.create()
|
2019-04-22 09:53:38 +01:00
|
|
|
|
2020-06-16 13:59:03 +09:30
|
|
|
|
2020-10-02 16:07:50 +09:30
|
|
|
@pytest.mark.asyncio
|
2020-06-16 13:59:03 +09:30
|
|
|
async def test_create_with_extra_volumes_invalid_format_2(compute_project, manager):
|
2019-04-22 09:53:38 +01:00
|
|
|
|
|
|
|
response = {
|
|
|
|
"Id": "e90e34656806",
|
|
|
|
"Warnings": []
|
|
|
|
}
|
2020-06-16 13:59:03 +09:30
|
|
|
with asyncio_patch("gns3server.compute.docker.Docker.list_images", return_value=[{"image": "ubuntu"}]):
|
2019-04-22 09:53:38 +01:00
|
|
|
with asyncio_patch("gns3server.compute.docker.Docker.query", return_value=response) as mock:
|
2020-06-16 13:59:03 +09:30
|
|
|
vm = DockerVM("test", str(uuid.uuid4()), compute_project, manager, "ubuntu:latest", extra_volumes=["/vol1", ""])
|
2019-04-22 09:53:38 +01:00
|
|
|
with pytest.raises(DockerError):
|
2020-06-16 13:59:03 +09:30
|
|
|
await vm.create()
|
2019-04-22 09:53:38 +01:00
|
|
|
|
2020-06-16 13:59:03 +09:30
|
|
|
|
2020-10-02 16:07:50 +09:30
|
|
|
@pytest.mark.asyncio
|
2020-06-16 13:59:03 +09:30
|
|
|
async def test_create_with_extra_volumes_invalid_format_3(compute_project, manager):
|
2019-04-22 12:46:28 +01:00
|
|
|
|
|
|
|
response = {
|
|
|
|
"Id": "e90e34656806",
|
|
|
|
"Warnings": []
|
|
|
|
}
|
2020-06-16 13:59:03 +09:30
|
|
|
with asyncio_patch("gns3server.compute.docker.Docker.list_images", return_value=[{"image": "ubuntu"}]):
|
|
|
|
with asyncio_patch("gns3server.compute.docker.Docker.query", return_value=response):
|
|
|
|
vm = DockerVM("test", str(uuid.uuid4()), compute_project, manager, "ubuntu:latest", extra_volumes=["/vol1/.."])
|
2019-04-22 12:46:28 +01:00
|
|
|
with pytest.raises(DockerError):
|
2020-06-16 13:59:03 +09:30
|
|
|
await vm.create()
|
|
|
|
|
2019-04-22 12:46:28 +01:00
|
|
|
|
2020-10-02 16:07:50 +09:30
|
|
|
@pytest.mark.asyncio
|
2020-06-16 13:59:03 +09:30
|
|
|
async def test_create_with_extra_volumes_duplicate_1_image(compute_project, manager):
|
2019-04-22 09:53:38 +01:00
|
|
|
|
|
|
|
response = {
|
|
|
|
"Id": "e90e34656806",
|
|
|
|
"Warnings": [],
|
|
|
|
"Config" : {
|
|
|
|
"Volumes" : {
|
|
|
|
"/vol/1": None
|
|
|
|
},
|
|
|
|
},
|
|
|
|
}
|
2020-06-16 13:59:03 +09:30
|
|
|
with asyncio_patch("gns3server.compute.docker.Docker.list_images", return_value=[{"image": "ubuntu"}]):
|
2019-04-22 09:53:38 +01:00
|
|
|
with asyncio_patch("gns3server.compute.docker.Docker.query", return_value=response) as mock:
|
2020-06-16 13:59:03 +09:30
|
|
|
vm = DockerVM("test", str(uuid.uuid4()), compute_project, manager, "ubuntu:latest", extra_volumes=["/vol/1"])
|
|
|
|
await vm.create()
|
2019-06-05 09:39:44 +01:00
|
|
|
mock.assert_called_with("POST", "containers/create", data={
|
|
|
|
"Tty": True,
|
|
|
|
"OpenStdin": True,
|
|
|
|
"StdinOnce": False,
|
|
|
|
"HostConfig":
|
|
|
|
{
|
|
|
|
"CapAdd": ["ALL"],
|
2023-03-19 17:56:07 +10:00
|
|
|
"Mounts": [
|
|
|
|
{
|
|
|
|
"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"
|
|
|
|
},
|
|
|
|
{
|
|
|
|
"Type": "bind",
|
|
|
|
"Source": os.path.join(vm.working_dir, "vol", "1"),
|
|
|
|
"Target": "/gns3volumes/vol/1"
|
|
|
|
}
|
2019-06-05 09:39:44 +01:00
|
|
|
],
|
2020-07-18 21:03:55 +09:30
|
|
|
"Privileged": True,
|
|
|
|
"Memory": 0,
|
|
|
|
"NanoCpus": 0
|
2019-06-05 09:39:44 +01:00
|
|
|
},
|
|
|
|
"Volumes": {},
|
|
|
|
"NetworkDisabled": True,
|
|
|
|
"Hostname": "test",
|
|
|
|
"Image": "ubuntu:latest",
|
|
|
|
"Env": [
|
|
|
|
"container=docker",
|
|
|
|
"GNS3_MAX_ETHERNET=eth0",
|
|
|
|
"GNS3_VOLUMES=/etc/network:/vol/1"
|
|
|
|
],
|
|
|
|
"Entrypoint": ["/gns3/init.sh"],
|
|
|
|
"Cmd": ["/bin/sh"]
|
|
|
|
})
|
|
|
|
assert vm._cid == "e90e34656806"
|
2019-04-22 09:53:38 +01:00
|
|
|
|
2020-06-16 13:59:03 +09:30
|
|
|
|
2020-10-02 16:07:50 +09:30
|
|
|
@pytest.mark.asyncio
|
2020-06-16 13:59:03 +09:30
|
|
|
async def test_create_with_extra_volumes_duplicate_2_user(compute_project, manager):
|
2019-04-22 09:53:38 +01:00
|
|
|
|
|
|
|
response = {
|
|
|
|
"Id": "e90e34656806",
|
|
|
|
"Warnings": [],
|
|
|
|
}
|
2020-06-16 13:59:03 +09:30
|
|
|
with asyncio_patch("gns3server.compute.docker.Docker.list_images", return_value=[{"image": "ubuntu"}]):
|
2019-04-22 09:53:38 +01:00
|
|
|
with asyncio_patch("gns3server.compute.docker.Docker.query", return_value=response) as mock:
|
2020-06-16 13:59:03 +09:30
|
|
|
vm = DockerVM("test", str(uuid.uuid4()), compute_project, manager, "ubuntu:latest", extra_volumes=["/vol/1", "/vol/1"])
|
|
|
|
await vm.create()
|
2019-06-05 09:39:44 +01:00
|
|
|
mock.assert_called_with("POST", "containers/create", data={
|
|
|
|
"Tty": True,
|
|
|
|
"OpenStdin": True,
|
|
|
|
"StdinOnce": False,
|
|
|
|
"HostConfig":
|
|
|
|
{
|
|
|
|
"CapAdd": ["ALL"],
|
2023-03-19 17:56:07 +10:00
|
|
|
"Mounts": [
|
|
|
|
{
|
|
|
|
"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"
|
|
|
|
},
|
|
|
|
{
|
|
|
|
"Type": "bind",
|
|
|
|
"Source": os.path.join(vm.working_dir, "vol", "1"),
|
|
|
|
"Target": "/gns3volumes/vol/1"
|
|
|
|
}
|
2019-06-05 09:39:44 +01:00
|
|
|
],
|
2020-07-18 21:03:55 +09:30
|
|
|
"Privileged": True,
|
|
|
|
"Memory": 0,
|
|
|
|
"NanoCpus": 0
|
2019-06-05 09:39:44 +01:00
|
|
|
},
|
|
|
|
"Volumes": {},
|
|
|
|
"NetworkDisabled": True,
|
|
|
|
"Hostname": "test",
|
|
|
|
"Image": "ubuntu:latest",
|
|
|
|
"Env": [
|
|
|
|
"container=docker",
|
|
|
|
"GNS3_MAX_ETHERNET=eth0",
|
|
|
|
"GNS3_VOLUMES=/etc/network:/vol/1"
|
|
|
|
],
|
|
|
|
"Entrypoint": ["/gns3/init.sh"],
|
|
|
|
"Cmd": ["/bin/sh"]
|
|
|
|
})
|
|
|
|
assert vm._cid == "e90e34656806"
|
2019-04-22 09:53:38 +01:00
|
|
|
|
2020-06-16 13:59:03 +09:30
|
|
|
|
2020-10-02 16:07:50 +09:30
|
|
|
@pytest.mark.asyncio
|
2020-06-16 13:59:03 +09:30
|
|
|
async def test_create_with_extra_volumes_duplicate_3_subdir(compute_project, manager):
|
2019-04-22 12:46:28 +01:00
|
|
|
|
|
|
|
response = {
|
|
|
|
"Id": "e90e34656806",
|
|
|
|
"Warnings": [],
|
|
|
|
}
|
2020-06-16 13:59:03 +09:30
|
|
|
with asyncio_patch("gns3server.compute.docker.Docker.list_images", return_value=[{"image": "ubuntu"}]):
|
2019-04-22 12:46:28 +01:00
|
|
|
with asyncio_patch("gns3server.compute.docker.Docker.query", return_value=response) as mock:
|
2020-06-16 13:59:03 +09:30
|
|
|
vm = DockerVM("test", str(uuid.uuid4()), compute_project, manager, "ubuntu:latest", extra_volumes=["/vol/1/", "/vol"])
|
|
|
|
await vm.create()
|
2019-06-05 09:39:44 +01:00
|
|
|
mock.assert_called_with("POST", "containers/create", data={
|
|
|
|
"Tty": True,
|
|
|
|
"OpenStdin": True,
|
|
|
|
"StdinOnce": False,
|
|
|
|
"HostConfig":
|
|
|
|
{
|
|
|
|
"CapAdd": ["ALL"],
|
2023-03-19 17:56:07 +10:00
|
|
|
"Mounts": [
|
|
|
|
{
|
|
|
|
"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"
|
|
|
|
},
|
|
|
|
{
|
|
|
|
"Type": "bind",
|
|
|
|
"Source": os.path.join(vm.working_dir, "vol"),
|
|
|
|
"Target": "/gns3volumes/vol"
|
|
|
|
}
|
2019-06-05 09:39:44 +01:00
|
|
|
],
|
2020-07-18 21:03:55 +09:30
|
|
|
"Privileged": True,
|
|
|
|
"Memory": 0,
|
|
|
|
"NanoCpus": 0
|
2019-06-05 09:39:44 +01:00
|
|
|
},
|
|
|
|
"Volumes": {},
|
|
|
|
"NetworkDisabled": True,
|
|
|
|
"Hostname": "test",
|
|
|
|
"Image": "ubuntu:latest",
|
|
|
|
"Env": [
|
|
|
|
"container=docker",
|
|
|
|
"GNS3_MAX_ETHERNET=eth0",
|
|
|
|
"GNS3_VOLUMES=/etc/network:/vol"
|
|
|
|
],
|
|
|
|
"Entrypoint": ["/gns3/init.sh"],
|
|
|
|
"Cmd": ["/bin/sh"]
|
|
|
|
})
|
|
|
|
assert vm._cid == "e90e34656806"
|
2019-04-22 12:46:28 +01:00
|
|
|
|
2020-06-16 13:59:03 +09:30
|
|
|
|
2020-10-02 16:07:50 +09:30
|
|
|
@pytest.mark.asyncio
|
2020-06-16 13:59:03 +09:30
|
|
|
async def test_create_with_extra_volumes_duplicate_4_backslash(compute_project, manager):
|
2019-04-22 12:46:28 +01:00
|
|
|
|
|
|
|
response = {
|
|
|
|
"Id": "e90e34656806",
|
|
|
|
"Warnings": [],
|
|
|
|
}
|
2020-06-16 13:59:03 +09:30
|
|
|
with asyncio_patch("gns3server.compute.docker.Docker.list_images", return_value=[{"image": "ubuntu"}]):
|
2019-04-22 12:46:28 +01:00
|
|
|
with asyncio_patch("gns3server.compute.docker.Docker.query", return_value=response) as mock:
|
2020-06-16 13:59:03 +09:30
|
|
|
vm = DockerVM("test", str(uuid.uuid4()), compute_project, manager, "ubuntu:latest", extra_volumes=["/vol//", "/vol"])
|
|
|
|
await vm.create()
|
2019-06-05 09:39:44 +01:00
|
|
|
mock.assert_called_with("POST", "containers/create", data={
|
|
|
|
"Tty": True,
|
|
|
|
"OpenStdin": True,
|
|
|
|
"StdinOnce": False,
|
|
|
|
"HostConfig":
|
|
|
|
{
|
|
|
|
"CapAdd": ["ALL"],
|
2023-03-19 17:56:07 +10:00
|
|
|
"Mounts": [
|
|
|
|
{
|
|
|
|
"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"
|
|
|
|
},
|
|
|
|
{
|
|
|
|
"Type": "bind",
|
|
|
|
"Source": os.path.join(vm.working_dir, "vol"),
|
|
|
|
"Target": "/gns3volumes/vol"
|
|
|
|
}
|
2019-06-05 09:39:44 +01:00
|
|
|
],
|
2020-07-18 21:03:55 +09:30
|
|
|
"Privileged": True,
|
|
|
|
"Memory": 0,
|
|
|
|
"NanoCpus": 0
|
2019-06-05 09:39:44 +01:00
|
|
|
},
|
|
|
|
"Volumes": {},
|
|
|
|
"NetworkDisabled": True,
|
|
|
|
"Hostname": "test",
|
|
|
|
"Image": "ubuntu:latest",
|
|
|
|
"Env": [
|
|
|
|
"container=docker",
|
|
|
|
"GNS3_MAX_ETHERNET=eth0",
|
|
|
|
"GNS3_VOLUMES=/etc/network:/vol"
|
|
|
|
],
|
|
|
|
"Entrypoint": ["/gns3/init.sh"],
|
|
|
|
"Cmd": ["/bin/sh"]
|
|
|
|
})
|
|
|
|
assert vm._cid == "e90e34656806"
|
|
|
|
|
2020-06-16 13:59:03 +09:30
|
|
|
|
2020-10-02 16:07:50 +09:30
|
|
|
@pytest.mark.asyncio
|
2020-06-16 13:59:03 +09:30
|
|
|
async def test_create_with_extra_volumes_duplicate_5_subdir_issue_1595(compute_project, manager):
|
2019-06-05 09:39:44 +01:00
|
|
|
|
|
|
|
response = {
|
|
|
|
"Id": "e90e34656806",
|
|
|
|
"Warnings": [],
|
|
|
|
}
|
2020-06-16 13:59:03 +09:30
|
|
|
with asyncio_patch("gns3server.compute.docker.Docker.list_images", return_value=[{"image": "ubuntu"}]):
|
2019-06-05 09:39:44 +01:00
|
|
|
with asyncio_patch("gns3server.compute.docker.Docker.query", return_value=response) as mock:
|
2020-06-16 13:59:03 +09:30
|
|
|
vm = DockerVM("test", str(uuid.uuid4()), compute_project, manager, "ubuntu:latest", extra_volumes=["/etc"])
|
|
|
|
await vm.create()
|
2019-06-05 09:39:44 +01:00
|
|
|
mock.assert_called_with("POST", "containers/create", data={
|
|
|
|
"Tty": True,
|
|
|
|
"OpenStdin": True,
|
|
|
|
"StdinOnce": False,
|
|
|
|
"HostConfig":
|
|
|
|
{
|
|
|
|
"CapAdd": ["ALL"],
|
2023-03-19 17:56:07 +10:00
|
|
|
"Mounts": [
|
|
|
|
{
|
|
|
|
"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"
|
|
|
|
}
|
2019-06-05 09:39:44 +01:00
|
|
|
],
|
2020-07-18 21:03:55 +09:30
|
|
|
"Privileged": True,
|
|
|
|
"Memory": 0,
|
|
|
|
"NanoCpus": 0
|
2019-06-05 09:39:44 +01:00
|
|
|
},
|
|
|
|
"Volumes": {},
|
|
|
|
"NetworkDisabled": True,
|
|
|
|
"Hostname": "test",
|
|
|
|
"Image": "ubuntu:latest",
|
|
|
|
"Env": [
|
|
|
|
"container=docker",
|
|
|
|
"GNS3_MAX_ETHERNET=eth0",
|
|
|
|
"GNS3_VOLUMES=/etc"
|
|
|
|
],
|
|
|
|
"Entrypoint": ["/gns3/init.sh"],
|
|
|
|
"Cmd": ["/bin/sh"]
|
|
|
|
})
|
|
|
|
assert vm._cid == "e90e34656806"
|
|
|
|
|
2020-06-16 13:59:03 +09:30
|
|
|
|
2020-10-02 16:07:50 +09:30
|
|
|
@pytest.mark.asyncio
|
2020-06-16 13:59:03 +09:30
|
|
|
async def test_create_with_extra_volumes_duplicate_6_subdir_issue_1595(compute_project, manager):
|
2019-06-05 09:39:44 +01:00
|
|
|
|
|
|
|
response = {
|
|
|
|
"Id": "e90e34656806",
|
|
|
|
"Warnings": [],
|
|
|
|
}
|
2020-06-16 13:59:03 +09:30
|
|
|
with asyncio_patch("gns3server.compute.docker.Docker.list_images", return_value=[{"image": "ubuntu"}]):
|
2019-06-05 09:39:44 +01:00
|
|
|
with asyncio_patch("gns3server.compute.docker.Docker.query", return_value=response) as mock:
|
2020-06-16 13:59:03 +09:30
|
|
|
vm = DockerVM("test", str(uuid.uuid4()), compute_project, manager, "ubuntu:latest", extra_volumes=["/etc/test", "/etc"])
|
|
|
|
await vm.create()
|
2019-06-05 09:39:44 +01:00
|
|
|
mock.assert_called_with("POST", "containers/create", data={
|
|
|
|
"Tty": True,
|
|
|
|
"OpenStdin": True,
|
|
|
|
"StdinOnce": False,
|
|
|
|
"HostConfig":
|
|
|
|
{
|
|
|
|
"CapAdd": ["ALL"],
|
2023-03-19 17:56:07 +10:00
|
|
|
"Mounts": [
|
|
|
|
{
|
|
|
|
"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"
|
|
|
|
}
|
2019-06-05 09:39:44 +01:00
|
|
|
],
|
2020-07-18 21:03:55 +09:30
|
|
|
"Privileged": True,
|
|
|
|
"Memory": 0,
|
|
|
|
"NanoCpus": 0
|
2019-06-05 09:39:44 +01:00
|
|
|
},
|
|
|
|
"Volumes": {},
|
|
|
|
"NetworkDisabled": True,
|
|
|
|
"Hostname": "test",
|
|
|
|
"Image": "ubuntu:latest",
|
|
|
|
"Env": [
|
|
|
|
"container=docker",
|
|
|
|
"GNS3_MAX_ETHERNET=eth0",
|
|
|
|
"GNS3_VOLUMES=/etc"
|
|
|
|
],
|
|
|
|
"Entrypoint": ["/gns3/init.sh"],
|
|
|
|
"Cmd": ["/bin/sh"]
|
|
|
|
})
|
|
|
|
assert vm._cid == "e90e34656806"
|
2019-04-22 12:46:28 +01:00
|
|
|
|
2020-06-16 13:59:03 +09:30
|
|
|
|
2020-10-02 16:07:50 +09:30
|
|
|
@pytest.mark.asyncio
|
2020-06-16 13:59:03 +09:30
|
|
|
async def test_create_with_extra_volumes(compute_project, manager):
|
2019-04-22 09:53:38 +01:00
|
|
|
|
|
|
|
response = {
|
|
|
|
"Id": "e90e34656806",
|
|
|
|
"Warnings": [],
|
|
|
|
"Config" : {
|
|
|
|
"Volumes" : {
|
|
|
|
"/vol/1": None
|
|
|
|
},
|
|
|
|
},
|
|
|
|
}
|
2020-06-16 13:59:03 +09:30
|
|
|
|
|
|
|
with asyncio_patch("gns3server.compute.docker.Docker.list_images", return_value=[{"image": "ubuntu"}]):
|
2019-04-22 09:53:38 +01:00
|
|
|
with asyncio_patch("gns3server.compute.docker.Docker.query", return_value=response) as mock:
|
2020-06-16 13:59:03 +09:30
|
|
|
vm = DockerVM("test", str(uuid.uuid4()), compute_project, manager, "ubuntu:latest", extra_volumes=["/vol/2"])
|
|
|
|
await vm.create()
|
2019-04-22 09:53:38 +01:00
|
|
|
mock.assert_called_with("POST", "containers/create", data={
|
|
|
|
"Tty": True,
|
|
|
|
"OpenStdin": True,
|
|
|
|
"StdinOnce": False,
|
|
|
|
"HostConfig":
|
|
|
|
{
|
|
|
|
"CapAdd": ["ALL"],
|
2023-03-19 17:56:07 +10:00
|
|
|
"Mounts": [
|
|
|
|
{
|
|
|
|
"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"
|
|
|
|
},
|
|
|
|
{
|
|
|
|
"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"
|
|
|
|
}
|
2019-04-22 09:53:38 +01:00
|
|
|
],
|
2020-07-18 21:03:55 +09:30
|
|
|
"Privileged": True,
|
|
|
|
"Memory": 0,
|
|
|
|
"NanoCpus": 0
|
2019-04-22 09:53:38 +01:00
|
|
|
},
|
|
|
|
"Volumes": {},
|
|
|
|
"NetworkDisabled": True,
|
|
|
|
"Hostname": "test",
|
|
|
|
"Image": "ubuntu:latest",
|
|
|
|
"Env": [
|
|
|
|
"container=docker",
|
|
|
|
"GNS3_MAX_ETHERNET=eth0",
|
|
|
|
"GNS3_VOLUMES=/etc/network:/vol/1:/vol/2"
|
|
|
|
],
|
|
|
|
"Entrypoint": ["/gns3/init.sh"],
|
|
|
|
"Cmd": ["/bin/sh"]
|
|
|
|
})
|
|
|
|
assert vm._cid == "e90e34656806"
|
|
|
|
|
2020-06-16 13:59:03 +09:30
|
|
|
|
2020-10-02 16:07:50 +09:30
|
|
|
@pytest.mark.asyncio
|
2020-06-16 13:59:03 +09:30
|
|
|
async def test_get_container_state(vm):
|
|
|
|
|
2015-10-14 18:10:05 +02:00
|
|
|
response = {
|
|
|
|
"State": {
|
|
|
|
"Error": "",
|
|
|
|
"ExitCode": 9,
|
|
|
|
"FinishedAt": "2015-01-06T15:47:32.080254511Z",
|
|
|
|
"OOMKilled": False,
|
|
|
|
"Paused": False,
|
|
|
|
"Pid": 0,
|
|
|
|
"Restarting": False,
|
|
|
|
"Running": True,
|
|
|
|
"StartedAt": "2015-01-06T15:47:32.072697474Z"
|
|
|
|
}
|
|
|
|
}
|
2020-06-16 13:59:03 +09:30
|
|
|
with asyncio_patch("gns3server.compute.docker.Docker.query", return_value=response):
|
|
|
|
assert await vm._get_container_state() == "running"
|
2015-10-14 18:10:05 +02:00
|
|
|
|
|
|
|
response["State"]["Running"] = False
|
|
|
|
response["State"]["Paused"] = True
|
2020-06-16 13:59:03 +09:30
|
|
|
with asyncio_patch("gns3server.compute.docker.Docker.query", return_value=response):
|
|
|
|
assert await vm._get_container_state() == "paused"
|
2015-10-14 18:10:05 +02:00
|
|
|
|
|
|
|
response["State"]["Running"] = False
|
|
|
|
response["State"]["Paused"] = False
|
2020-06-16 13:59:03 +09:30
|
|
|
with asyncio_patch("gns3server.compute.docker.Docker.query", return_value=response):
|
|
|
|
assert await vm._get_container_state() == "exited"
|
2015-10-14 18:10:05 +02:00
|
|
|
|
|
|
|
|
2020-10-02 16:07:50 +09:30
|
|
|
@pytest.mark.asyncio
|
2020-06-16 13:59:03 +09:30
|
|
|
async def test_is_running(vm):
|
|
|
|
|
2015-10-14 18:10:05 +02:00
|
|
|
response = {
|
|
|
|
"State": {
|
|
|
|
"Running": False,
|
|
|
|
"Paused": False
|
|
|
|
}
|
|
|
|
}
|
2020-06-16 13:59:03 +09:30
|
|
|
with asyncio_patch("gns3server.compute.docker.Docker.query", return_value=response):
|
|
|
|
assert await vm.is_running() is False
|
2015-10-14 18:10:05 +02:00
|
|
|
|
|
|
|
response["State"]["Running"] = True
|
2020-06-16 13:59:03 +09:30
|
|
|
with asyncio_patch("gns3server.compute.docker.Docker.query", return_value=response):
|
|
|
|
assert await vm.is_running() is True
|
2015-10-14 18:10:05 +02:00
|
|
|
|
|
|
|
|
2020-10-02 16:07:50 +09:30
|
|
|
@pytest.mark.asyncio
|
2020-06-16 13:59:03 +09:30
|
|
|
async def test_pause(vm):
|
2015-10-14 18:10:05 +02:00
|
|
|
|
2016-04-15 17:57:06 +02:00
|
|
|
with asyncio_patch("gns3server.compute.docker.Docker.query") as mock:
|
2020-06-16 13:59:03 +09:30
|
|
|
await vm.pause()
|
2015-10-14 18:10:05 +02:00
|
|
|
|
|
|
|
mock.assert_called_with("POST", "containers/e90e34656842/pause")
|
2016-05-16 17:39:32 +02:00
|
|
|
assert vm.status == "suspended"
|
2015-10-14 18:10:05 +02:00
|
|
|
|
|
|
|
|
2020-10-02 16:07:50 +09:30
|
|
|
@pytest.mark.asyncio
|
2020-06-16 13:59:03 +09:30
|
|
|
async def test_unpause(vm):
|
2015-10-14 18:10:05 +02:00
|
|
|
|
2016-04-15 17:57:06 +02:00
|
|
|
with asyncio_patch("gns3server.compute.docker.Docker.query") as mock:
|
2020-06-16 13:59:03 +09:30
|
|
|
await vm.unpause()
|
2015-10-14 18:10:05 +02:00
|
|
|
mock.assert_called_with("POST", "containers/e90e34656842/unpause")
|
|
|
|
|
|
|
|
|
2020-10-02 16:07:50 +09:30
|
|
|
@pytest.mark.asyncio
|
2020-06-16 13:59:03 +09:30
|
|
|
async def test_start(vm, manager, free_console_port):
|
2015-10-14 18:10:05 +02:00
|
|
|
|
|
|
|
assert vm.status != "started"
|
|
|
|
vm.adapters = 1
|
|
|
|
|
2020-07-29 16:32:45 +09:30
|
|
|
vm.aux_type = "telnet"
|
2016-03-01 14:53:43 +01:00
|
|
|
vm._start_aux = AsyncioMagicMock()
|
|
|
|
|
|
|
|
vm._get_container_state = AsyncioMagicMock(return_value="stopped")
|
|
|
|
vm._start_ubridge = AsyncioMagicMock()
|
|
|
|
vm._get_namespace = AsyncioMagicMock(return_value=42)
|
|
|
|
vm._add_ubridge_connection = AsyncioMagicMock()
|
|
|
|
vm._start_console = AsyncioMagicMock()
|
|
|
|
|
2016-06-24 18:35:39 -06:00
|
|
|
nio = manager.create_nio({"type": "nio_udp", "lport": free_console_port, "rport": free_console_port, "rhost": "127.0.0.1"})
|
2020-06-16 13:59:03 +09:30
|
|
|
await vm.adapter_add_nio_binding(0, nio)
|
2015-10-14 18:10:05 +02:00
|
|
|
|
2023-08-18 12:20:54 +10:00
|
|
|
with patch("gns3server.compute.docker.Docker.install_busybox"):
|
|
|
|
with asyncio_patch("gns3server.compute.docker.Docker.query") as mock_query:
|
|
|
|
await vm.start()
|
2015-10-14 18:10:05 +02:00
|
|
|
|
|
|
|
mock_query.assert_called_with("POST", "containers/e90e34656842/start")
|
2016-12-14 16:53:20 +01:00
|
|
|
vm._add_ubridge_connection.assert_called_once_with(nio, 0)
|
2016-03-01 14:53:43 +01:00
|
|
|
assert vm._start_ubridge.called
|
|
|
|
assert vm._start_console.called
|
|
|
|
assert vm._start_aux.called
|
2015-10-14 18:10:05 +02:00
|
|
|
assert vm.status == "started"
|
|
|
|
|
|
|
|
|
2020-10-02 16:07:50 +09:30
|
|
|
@pytest.mark.asyncio
|
2020-06-16 13:59:03 +09:30
|
|
|
async def test_start_namespace_failed(vm, manager, free_console_port):
|
2016-02-11 15:49:28 +01:00
|
|
|
|
|
|
|
assert vm.status != "started"
|
|
|
|
vm.adapters = 1
|
|
|
|
|
2016-06-24 18:35:39 -06:00
|
|
|
nio = manager.create_nio({"type": "nio_udp", "lport": free_console_port, "rport": free_console_port, "rhost": "127.0.0.1"})
|
2020-06-16 13:59:03 +09:30
|
|
|
await vm.adapter_add_nio_binding(0, nio)
|
2016-02-11 15:49:28 +01:00
|
|
|
|
2023-08-18 12:20:54 +10:00
|
|
|
with patch("gns3server.compute.docker.Docker.install_busybox"):
|
|
|
|
with asyncio_patch("gns3server.compute.docker.DockerVM._get_container_state", return_value="stopped"):
|
|
|
|
with asyncio_patch("gns3server.compute.docker.Docker.query") as mock_query:
|
|
|
|
with asyncio_patch("gns3server.compute.docker.DockerVM._start_ubridge") as mock_start_ubridge:
|
|
|
|
with asyncio_patch("gns3server.compute.docker.DockerVM._get_namespace", return_value=42) as mock_namespace:
|
|
|
|
with asyncio_patch("gns3server.compute.docker.DockerVM._add_ubridge_connection", side_effect=UbridgeNamespaceError()) as mock_add_ubridge_connection:
|
|
|
|
with asyncio_patch("gns3server.compute.docker.DockerVM._get_log", return_value='Hello not available') as mock_log:
|
2016-02-11 15:49:28 +01:00
|
|
|
|
2023-08-18 12:20:54 +10:00
|
|
|
with pytest.raises(DockerError):
|
|
|
|
await vm.start()
|
2016-02-11 15:49:28 +01:00
|
|
|
|
|
|
|
mock_query.assert_any_call("POST", "containers/e90e34656842/start")
|
2016-12-14 16:53:20 +01:00
|
|
|
mock_add_ubridge_connection.assert_called_once_with(nio, 0)
|
2016-02-11 15:49:28 +01:00
|
|
|
assert mock_start_ubridge.called
|
|
|
|
assert vm.status == "stopped"
|
|
|
|
|
|
|
|
|
2020-10-02 16:07:50 +09:30
|
|
|
@pytest.mark.asyncio
|
2020-06-16 13:59:03 +09:30
|
|
|
async def test_start_without_nio(vm):
|
2016-02-09 14:22:37 +01:00
|
|
|
"""
|
|
|
|
If no nio exists we will create one.
|
|
|
|
"""
|
|
|
|
|
|
|
|
assert vm.status != "started"
|
|
|
|
vm.adapters = 1
|
|
|
|
|
2023-08-18 12:20:54 +10:00
|
|
|
with patch("gns3server.compute.docker.Docker.install_busybox"):
|
|
|
|
with asyncio_patch("gns3server.compute.docker.DockerVM._get_container_state", return_value="stopped"):
|
|
|
|
with asyncio_patch("gns3server.compute.docker.Docker.query") as mock_query:
|
|
|
|
with asyncio_patch("gns3server.compute.docker.DockerVM._start_ubridge") as mock_start_ubridge:
|
|
|
|
with asyncio_patch("gns3server.compute.docker.DockerVM._get_namespace", return_value=42):
|
|
|
|
with asyncio_patch("gns3server.compute.docker.DockerVM._add_ubridge_connection") as mock_add_ubridge_connection:
|
|
|
|
with asyncio_patch("gns3server.compute.docker.DockerVM._start_console") as mock_start_console:
|
|
|
|
await vm.start()
|
2016-02-09 14:22:37 +01:00
|
|
|
|
|
|
|
mock_query.assert_called_with("POST", "containers/e90e34656842/start")
|
|
|
|
assert mock_add_ubridge_connection.called
|
|
|
|
assert mock_start_ubridge.called
|
|
|
|
assert mock_start_console.called
|
|
|
|
assert vm.status == "started"
|
|
|
|
|
|
|
|
|
2020-10-02 16:07:50 +09:30
|
|
|
@pytest.mark.asyncio
|
2020-06-16 13:59:03 +09:30
|
|
|
async def test_start_unpause(vm):
|
2015-10-14 18:10:05 +02:00
|
|
|
|
2023-08-18 12:20:54 +10:00
|
|
|
with patch("gns3server.compute.docker.Docker.install_busybox"):
|
|
|
|
with asyncio_patch("gns3server.compute.docker.DockerVM._get_container_state", return_value="paused"):
|
|
|
|
with asyncio_patch("gns3server.compute.docker.DockerVM.unpause", return_value="paused") as mock:
|
|
|
|
await vm.start()
|
2015-10-14 18:10:05 +02:00
|
|
|
assert mock.called
|
|
|
|
assert vm.status == "started"
|
|
|
|
|
|
|
|
|
2020-10-02 16:07:50 +09:30
|
|
|
@pytest.mark.asyncio
|
2020-06-16 13:59:03 +09:30
|
|
|
async def test_restart(vm):
|
2015-10-14 18:10:05 +02:00
|
|
|
|
2016-04-15 17:57:06 +02:00
|
|
|
with asyncio_patch("gns3server.compute.docker.Docker.query") as mock:
|
2020-06-16 13:59:03 +09:30
|
|
|
await vm.restart()
|
2015-10-14 18:10:05 +02:00
|
|
|
mock.assert_called_with("POST", "containers/e90e34656842/restart")
|
|
|
|
|
|
|
|
|
2020-10-02 16:07:50 +09:30
|
|
|
@pytest.mark.asyncio
|
2020-06-16 13:59:03 +09:30
|
|
|
async def test_stop(vm):
|
|
|
|
|
2016-12-14 12:01:34 +01:00
|
|
|
mock = MagicMock()
|
|
|
|
vm._ubridge_hypervisor = mock
|
2015-10-14 18:10:05 +02:00
|
|
|
vm._ubridge_hypervisor.is_running.return_value = True
|
2016-05-31 21:08:41 +02:00
|
|
|
vm._fix_permissions = MagicMock()
|
2015-10-14 18:10:05 +02:00
|
|
|
|
2016-04-15 17:57:06 +02:00
|
|
|
with asyncio_patch("gns3server.compute.docker.DockerVM._get_container_state", return_value="running"):
|
|
|
|
with asyncio_patch("gns3server.compute.docker.Docker.query") as mock_query:
|
2021-12-02 22:15:23 +10:30
|
|
|
vm._permissions_fixed = False
|
2020-06-16 13:59:03 +09:30
|
|
|
await vm.stop()
|
2015-10-14 18:10:05 +02:00
|
|
|
mock_query.assert_called_with("POST", "containers/e90e34656842/stop", params={"t": 5})
|
2016-12-14 12:01:34 +01:00
|
|
|
assert mock.stop.called
|
|
|
|
assert vm._ubridge_hypervisor is None
|
2016-05-31 21:08:41 +02:00
|
|
|
assert vm._fix_permissions.called
|
2015-10-14 18:10:05 +02:00
|
|
|
|
|
|
|
|
2020-10-02 16:07:50 +09:30
|
|
|
@pytest.mark.asyncio
|
2020-06-16 13:59:03 +09:30
|
|
|
async def test_stop_paused_container(vm):
|
2015-10-14 18:10:05 +02:00
|
|
|
|
2016-04-15 17:57:06 +02:00
|
|
|
with asyncio_patch("gns3server.compute.docker.DockerVM._get_container_state", return_value="paused"):
|
|
|
|
with asyncio_patch("gns3server.compute.docker.DockerVM.unpause") as mock_unpause:
|
|
|
|
with asyncio_patch("gns3server.compute.docker.Docker.query") as mock_query:
|
2020-06-16 13:59:03 +09:30
|
|
|
await vm.stop()
|
2015-10-14 18:10:05 +02:00
|
|
|
mock_query.assert_called_with("POST", "containers/e90e34656842/stop", params={"t": 5})
|
|
|
|
assert mock_unpause.called
|
|
|
|
|
|
|
|
|
2020-10-02 16:07:50 +09:30
|
|
|
@pytest.mark.asyncio
|
2020-06-16 13:59:03 +09:30
|
|
|
async def test_update(vm):
|
2015-10-14 18:10:05 +02:00
|
|
|
|
|
|
|
response = {
|
|
|
|
"Id": "e90e34656806",
|
|
|
|
"Warnings": []
|
|
|
|
}
|
2016-02-12 16:38:16 +01:00
|
|
|
|
|
|
|
original_console = vm.console
|
2016-04-05 16:33:40 +02:00
|
|
|
original_aux = vm.aux
|
2016-02-12 16:38:16 +01:00
|
|
|
|
2020-06-16 13:59:03 +09:30
|
|
|
with asyncio_patch("gns3server.compute.docker.Docker.list_images", return_value=[{"image": "ubuntu"}]):
|
2016-04-15 17:57:06 +02:00
|
|
|
with asyncio_patch("gns3server.compute.docker.DockerVM._get_container_state", return_value="stopped"):
|
|
|
|
with asyncio_patch("gns3server.compute.docker.Docker.query", return_value=response) as mock_query:
|
2020-06-16 13:59:03 +09:30
|
|
|
await vm.update()
|
2015-10-14 18:10:05 +02:00
|
|
|
|
2016-06-13 17:39:04 +02:00
|
|
|
mock_query.assert_any_call("DELETE", "containers/e90e34656842", params={"force": 1, "v": 1})
|
2015-10-14 18:10:05 +02:00
|
|
|
mock_query.assert_any_call("POST", "containers/create", data={
|
|
|
|
"Tty": True,
|
|
|
|
"OpenStdin": True,
|
|
|
|
"StdinOnce": False,
|
|
|
|
"HostConfig":
|
|
|
|
{
|
|
|
|
"CapAdd": ["ALL"],
|
2023-03-19 17:56:07 +10:00
|
|
|
"Mounts": [
|
|
|
|
{
|
|
|
|
"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"
|
|
|
|
}
|
2016-03-24 17:08:16 +01:00
|
|
|
],
|
2020-07-18 21:03:55 +09:30
|
|
|
"Privileged": True,
|
|
|
|
"Memory": 0,
|
|
|
|
"NanoCpus": 0
|
2015-10-14 18:10:05 +02:00
|
|
|
},
|
2016-02-12 11:57:56 +01:00
|
|
|
"Volumes": {},
|
|
|
|
"NetworkDisabled": True,
|
2016-02-23 19:22:35 +01:00
|
|
|
"Hostname": "test",
|
2016-05-19 13:09:07 +02:00
|
|
|
"Image": "ubuntu:latest",
|
2016-05-06 19:07:18 +02:00
|
|
|
"Env": [
|
2016-06-15 10:12:32 +02:00
|
|
|
"container=docker",
|
2016-06-01 11:39:42 +02:00
|
|
|
"GNS3_MAX_ETHERNET=eth0",
|
|
|
|
"GNS3_VOLUMES=/etc/network"
|
2016-05-06 19:07:18 +02:00
|
|
|
],
|
2016-03-04 09:08:40 +01:00
|
|
|
"Entrypoint": ["/gns3/init.sh"],
|
|
|
|
"Cmd": ["/bin/sh"]
|
2015-10-14 18:10:05 +02:00
|
|
|
})
|
2016-02-12 16:38:16 +01:00
|
|
|
assert vm.console == original_console
|
2016-04-05 16:33:40 +02:00
|
|
|
assert vm.aux == original_aux
|
2015-10-14 18:10:05 +02:00
|
|
|
|
|
|
|
|
2020-10-02 16:07:50 +09:30
|
|
|
@pytest.mark.asyncio
|
2020-06-16 13:59:03 +09:30
|
|
|
async def test_update_vnc(vm):
|
2016-04-06 14:57:52 +02:00
|
|
|
|
|
|
|
response = {
|
|
|
|
"Id": "e90e34656806",
|
|
|
|
"Warnings": []
|
|
|
|
}
|
|
|
|
|
2016-10-24 12:21:57 +02:00
|
|
|
vm._console_type = "vnc"
|
|
|
|
vm._console = 5900
|
2016-04-06 14:57:52 +02:00
|
|
|
vm._display = "display"
|
|
|
|
original_console = vm.console
|
|
|
|
original_aux = vm.aux
|
|
|
|
|
2016-04-15 17:57:06 +02:00
|
|
|
with asyncio_patch("gns3server.compute.docker.DockerVM._start_vnc"):
|
2020-06-16 13:59:03 +09:30
|
|
|
with asyncio_patch("gns3server.compute.docker.Docker.list_images", return_value=[{"image": "ubuntu"}]):
|
2016-04-15 17:57:06 +02:00
|
|
|
with asyncio_patch("gns3server.compute.docker.DockerVM._get_container_state", return_value="stopped"):
|
2020-06-16 13:59:03 +09:30
|
|
|
with asyncio_patch("gns3server.compute.docker.Docker.query", return_value=response):
|
|
|
|
await vm.update()
|
2016-04-06 14:57:52 +02:00
|
|
|
|
|
|
|
assert vm.console == original_console
|
|
|
|
assert vm.aux == original_aux
|
2015-10-14 18:10:05 +02:00
|
|
|
|
|
|
|
|
2020-10-02 16:07:50 +09:30
|
|
|
@pytest.mark.asyncio
|
2020-06-16 13:59:03 +09:30
|
|
|
async def test_update_running(vm):
|
2016-02-24 15:47:53 +01:00
|
|
|
|
|
|
|
response = {
|
|
|
|
"Id": "e90e34656806",
|
|
|
|
"Warnings": []
|
|
|
|
}
|
|
|
|
|
|
|
|
original_console = vm.console
|
|
|
|
vm.start = MagicMock()
|
|
|
|
|
2016-04-15 17:57:06 +02:00
|
|
|
with asyncio_patch("gns3server.compute.docker.Docker.list_images", return_value=[{"image": "ubuntu"}]) as mock_list_images:
|
|
|
|
with asyncio_patch("gns3server.compute.docker.DockerVM._get_container_state", return_value="running"):
|
|
|
|
with asyncio_patch("gns3server.compute.docker.Docker.query", return_value=response) as mock_query:
|
2020-06-16 13:59:03 +09:30
|
|
|
await vm.update()
|
2016-02-24 15:47:53 +01:00
|
|
|
|
2016-06-13 17:39:04 +02:00
|
|
|
mock_query.assert_any_call("DELETE", "containers/e90e34656842", params={"force": 1, "v": 1})
|
2016-02-24 15:47:53 +01:00
|
|
|
mock_query.assert_any_call("POST", "containers/create", data={
|
|
|
|
"Tty": True,
|
|
|
|
"OpenStdin": True,
|
|
|
|
"StdinOnce": False,
|
|
|
|
"HostConfig":
|
|
|
|
{
|
|
|
|
"CapAdd": ["ALL"],
|
2023-03-19 17:56:07 +10:00
|
|
|
"Mounts": [
|
|
|
|
{
|
|
|
|
"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"
|
|
|
|
}
|
2016-03-24 17:08:16 +01:00
|
|
|
],
|
2020-07-18 21:03:55 +09:30
|
|
|
"Privileged": True,
|
|
|
|
"Memory": 0,
|
|
|
|
"NanoCpus": 0
|
2016-02-24 15:47:53 +01:00
|
|
|
},
|
|
|
|
"Volumes": {},
|
|
|
|
"NetworkDisabled": True,
|
|
|
|
"Hostname": "test",
|
2016-05-19 13:09:07 +02:00
|
|
|
"Image": "ubuntu:latest",
|
2016-05-06 19:07:18 +02:00
|
|
|
"Env": [
|
2016-06-15 10:12:32 +02:00
|
|
|
"container=docker",
|
2016-06-01 11:39:42 +02:00
|
|
|
"GNS3_MAX_ETHERNET=eth0",
|
|
|
|
"GNS3_VOLUMES=/etc/network"
|
2016-05-06 19:07:18 +02:00
|
|
|
],
|
2016-03-04 09:08:40 +01:00
|
|
|
"Entrypoint": ["/gns3/init.sh"],
|
|
|
|
"Cmd": ["/bin/sh"]
|
2016-02-24 15:47:53 +01:00
|
|
|
})
|
|
|
|
|
|
|
|
assert vm.console == original_console
|
|
|
|
assert vm.start.called
|
|
|
|
|
|
|
|
|
2020-10-02 16:07:50 +09:30
|
|
|
@pytest.mark.asyncio
|
2020-06-16 13:59:03 +09:30
|
|
|
async def test_delete(vm):
|
2015-10-14 18:10:05 +02:00
|
|
|
|
2016-04-15 17:57:06 +02:00
|
|
|
with asyncio_patch("gns3server.compute.docker.DockerVM._get_container_state", return_value="stopped"):
|
|
|
|
with asyncio_patch("gns3server.compute.docker.Docker.query") as mock_query:
|
2020-06-16 13:59:03 +09:30
|
|
|
await vm.delete()
|
2016-06-13 17:39:04 +02:00
|
|
|
mock_query.assert_called_with("DELETE", "containers/e90e34656842", params={"force": 1, "v": 1})
|
2015-10-14 18:10:05 +02:00
|
|
|
|
|
|
|
|
2020-10-02 16:07:50 +09:30
|
|
|
@pytest.mark.asyncio
|
2020-06-16 13:59:03 +09:30
|
|
|
async def test_close(vm, port_manager):
|
|
|
|
|
2015-10-14 18:10:05 +02:00
|
|
|
nio = {"type": "nio_udp",
|
|
|
|
"lport": 4242,
|
|
|
|
"rport": 4343,
|
|
|
|
"rhost": "127.0.0.1"}
|
2016-06-24 18:35:39 -06:00
|
|
|
nio = vm.manager.create_nio(nio)
|
2020-06-16 13:59:03 +09:30
|
|
|
await vm.adapter_add_nio_binding(0, nio)
|
2015-10-14 18:10:05 +02:00
|
|
|
|
2016-04-15 17:57:06 +02:00
|
|
|
with asyncio_patch("gns3server.compute.docker.DockerVM._get_container_state", return_value="stopped"):
|
|
|
|
with asyncio_patch("gns3server.compute.docker.Docker.query") as mock_query:
|
2020-06-16 13:59:03 +09:30
|
|
|
await vm.close()
|
2016-06-13 17:39:04 +02:00
|
|
|
mock_query.assert_called_with("DELETE", "containers/e90e34656842", params={"force": 1, "v": 1})
|
2016-02-29 21:08:25 +01:00
|
|
|
|
2015-10-14 18:10:05 +02:00
|
|
|
assert vm._closed is True
|
|
|
|
assert "4242" not in port_manager.udp_ports
|
|
|
|
|
|
|
|
|
2020-10-02 16:07:50 +09:30
|
|
|
@pytest.mark.asyncio
|
2020-06-16 13:59:03 +09:30
|
|
|
async def test_close_vnc(vm):
|
2016-02-29 21:08:25 +01:00
|
|
|
|
|
|
|
vm._console_type = "vnc"
|
2023-06-02 20:16:06 +09:30
|
|
|
vm._vnc_process = MagicMock()
|
2016-02-29 21:08:25 +01:00
|
|
|
|
2016-04-15 17:57:06 +02:00
|
|
|
with asyncio_patch("gns3server.compute.docker.DockerVM._get_container_state", return_value="stopped"):
|
|
|
|
with asyncio_patch("gns3server.compute.docker.Docker.query") as mock_query:
|
2020-06-16 13:59:03 +09:30
|
|
|
await vm.close()
|
2016-06-13 17:39:04 +02:00
|
|
|
mock_query.assert_called_with("DELETE", "containers/e90e34656842", params={"force": 1, "v": 1})
|
2016-02-29 21:08:25 +01:00
|
|
|
|
|
|
|
assert vm._closed is True
|
2023-06-02 20:16:06 +09:30
|
|
|
assert vm._vnc_process.terminate.called
|
2016-02-29 21:08:25 +01:00
|
|
|
|
|
|
|
|
2020-10-02 16:07:50 +09:30
|
|
|
@pytest.mark.asyncio
|
2020-06-16 13:59:03 +09:30
|
|
|
async def test_get_namespace(vm):
|
|
|
|
|
2015-10-14 18:10:05 +02:00
|
|
|
response = {
|
|
|
|
"State": {
|
|
|
|
"Pid": 42
|
|
|
|
}
|
|
|
|
}
|
2016-04-15 17:57:06 +02:00
|
|
|
with asyncio_patch("gns3server.compute.docker.Docker.query", return_value=response) as mock_query:
|
2020-06-16 13:59:03 +09:30
|
|
|
assert await vm._get_namespace() == 42
|
2015-10-14 18:10:05 +02:00
|
|
|
mock_query.assert_called_with("GET", "containers/e90e34656842/json")
|
|
|
|
|
|
|
|
|
2020-10-02 16:07:50 +09:30
|
|
|
@pytest.mark.asyncio
|
2020-06-16 13:59:03 +09:30
|
|
|
async def test_add_ubridge_connection(vm):
|
2015-10-14 18:10:05 +02:00
|
|
|
|
|
|
|
nio = {"type": "nio_udp",
|
|
|
|
"lport": 4242,
|
|
|
|
"rport": 4343,
|
|
|
|
"rhost": "127.0.0.1"}
|
2016-06-24 18:35:39 -06:00
|
|
|
nio = vm.manager.create_nio(nio)
|
2019-04-01 20:58:18 +07:00
|
|
|
nio.start_packet_capture("/tmp/capture.pcap")
|
2015-10-14 18:10:05 +02:00
|
|
|
vm._ubridge_hypervisor = MagicMock()
|
2016-12-14 16:53:20 +01:00
|
|
|
vm._namespace = 42
|
2020-06-16 13:59:03 +09:30
|
|
|
await vm._add_ubridge_connection(nio, 0)
|
2015-10-14 18:10:05 +02:00
|
|
|
|
|
|
|
calls = [
|
|
|
|
call.send('bridge create bridge0'),
|
2016-10-24 12:35:50 +02:00
|
|
|
call.send("bridge add_nio_tap bridge0 tap-gns3-e0"),
|
|
|
|
call.send('docker move_to_ns tap-gns3-e0 42 eth0'),
|
2015-10-14 18:10:05 +02:00
|
|
|
call.send('bridge add_nio_udp bridge0 4242 127.0.0.1 4343'),
|
2016-02-09 14:22:37 +01:00
|
|
|
call.send('bridge start_capture bridge0 "/tmp/capture.pcap"'),
|
2015-10-14 18:10:05 +02:00
|
|
|
call.send('bridge start bridge0')
|
|
|
|
]
|
2017-07-12 17:39:19 +02:00
|
|
|
assert 'bridge0' in vm._bridges
|
2015-10-14 18:10:05 +02:00
|
|
|
# We need to check any_order ortherwise mock is confused by asyncio
|
|
|
|
vm._ubridge_hypervisor.assert_has_calls(calls, any_order=True)
|
|
|
|
|
|
|
|
|
2020-10-02 16:07:50 +09:30
|
|
|
@pytest.mark.asyncio
|
2020-06-16 13:59:03 +09:30
|
|
|
async def test_add_ubridge_connection_none_nio(vm):
|
2015-10-14 18:10:05 +02:00
|
|
|
|
2016-02-09 14:22:37 +01:00
|
|
|
nio = None
|
2015-10-14 18:10:05 +02:00
|
|
|
vm._ubridge_hypervisor = MagicMock()
|
2016-12-14 16:53:20 +01:00
|
|
|
vm._namespace = 42
|
2016-02-11 15:49:28 +01:00
|
|
|
|
2020-06-16 13:59:03 +09:30
|
|
|
await vm._add_ubridge_connection(nio, 0)
|
2015-10-14 18:10:05 +02:00
|
|
|
|
|
|
|
calls = [
|
2016-10-24 12:35:50 +02:00
|
|
|
call.send('bridge create bridge0'),
|
|
|
|
call.send("bridge add_nio_tap bridge0 tap-gns3-e0"),
|
|
|
|
call.send('docker move_to_ns tap-gns3-e0 42 eth0'),
|
|
|
|
|
2015-10-14 18:10:05 +02:00
|
|
|
]
|
2017-07-12 17:39:19 +02:00
|
|
|
assert 'bridge0' in vm._bridges
|
2015-10-14 18:10:05 +02:00
|
|
|
# We need to check any_order ortherwise mock is confused by asyncio
|
|
|
|
vm._ubridge_hypervisor.assert_has_calls(calls, any_order=True)
|
|
|
|
|
|
|
|
|
2020-10-02 16:07:50 +09:30
|
|
|
@pytest.mark.asyncio
|
2020-06-16 13:59:03 +09:30
|
|
|
async def test_add_ubridge_connection_invalid_adapter_number(vm):
|
2015-10-14 18:10:05 +02:00
|
|
|
|
|
|
|
nio = {"type": "nio_udp",
|
|
|
|
"lport": 4242,
|
|
|
|
"rport": 4343,
|
|
|
|
"rhost": "127.0.0.1"}
|
2016-06-24 18:35:39 -06:00
|
|
|
nio = vm.manager.create_nio(nio)
|
2015-10-14 18:10:05 +02:00
|
|
|
with pytest.raises(DockerError):
|
2020-06-16 13:59:03 +09:30
|
|
|
await vm._add_ubridge_connection(nio, 12)
|
2015-10-14 18:10:05 +02:00
|
|
|
|
|
|
|
|
2020-10-02 16:07:50 +09:30
|
|
|
@pytest.mark.asyncio
|
2020-06-16 13:59:03 +09:30
|
|
|
async def test_add_ubridge_connection_no_free_interface(vm):
|
2015-10-14 18:10:05 +02:00
|
|
|
|
|
|
|
nio = {"type": "nio_udp",
|
|
|
|
"lport": 4242,
|
|
|
|
"rport": 4343,
|
|
|
|
"rhost": "127.0.0.1"}
|
2016-06-24 18:35:39 -06:00
|
|
|
nio = vm.manager.create_nio(nio)
|
2015-10-14 18:10:05 +02:00
|
|
|
with pytest.raises(DockerError):
|
|
|
|
|
2016-05-18 11:23:45 +02:00
|
|
|
# We create fake ethernet interfaces for docker
|
2016-12-13 16:05:38 +01:00
|
|
|
interfaces = ["tap-gns3-e{}".format(index) for index in range(4096)]
|
2015-10-14 18:10:05 +02:00
|
|
|
|
|
|
|
with patch("psutil.net_if_addrs", return_value=interfaces):
|
2020-06-16 13:59:03 +09:30
|
|
|
await vm._add_ubridge_connection(nio, 0)
|
2015-10-14 18:10:05 +02:00
|
|
|
|
|
|
|
|
2020-10-02 16:07:50 +09:30
|
|
|
@pytest.mark.asyncio
|
2020-06-16 13:59:03 +09:30
|
|
|
async def test_adapter_add_nio_binding_1(vm):
|
2015-10-14 18:10:05 +02:00
|
|
|
|
2017-07-12 17:39:19 +02:00
|
|
|
nio = {"type": "nio_udp",
|
|
|
|
"lport": 4242,
|
|
|
|
"rport": 4343,
|
|
|
|
"rhost": "127.0.0.1"}
|
|
|
|
nio = vm.manager.create_nio(nio)
|
2020-06-16 13:59:03 +09:30
|
|
|
await vm.adapter_add_nio_binding(0, nio)
|
|
|
|
assert vm._ethernet_adapters[0].get_nio(0) == nio
|
2017-07-12 17:39:19 +02:00
|
|
|
|
|
|
|
|
2020-10-02 16:07:50 +09:30
|
|
|
@pytest.mark.asyncio
|
2020-06-16 13:59:03 +09:30
|
|
|
async def test_adapter_udpate_nio_binding_bridge_not_started(vm):
|
2017-07-12 17:39:19 +02:00
|
|
|
|
|
|
|
vm._ubridge_apply_filters = AsyncioMagicMock()
|
|
|
|
nio = {"type": "nio_udp",
|
|
|
|
"lport": 4242,
|
|
|
|
"rport": 4343,
|
|
|
|
"rhost": "127.0.0.1"}
|
|
|
|
nio = vm.manager.create_nio(nio)
|
|
|
|
with asyncio_patch("gns3server.compute.docker.DockerVM._get_container_state", return_value="running"):
|
2020-06-16 13:59:03 +09:30
|
|
|
await vm.adapter_add_nio_binding(0, nio)
|
|
|
|
await vm.adapter_update_nio_binding(0, nio)
|
2017-07-12 17:39:19 +02:00
|
|
|
assert vm._ubridge_apply_filters.called is False
|
|
|
|
|
|
|
|
|
2020-10-02 16:07:50 +09:30
|
|
|
@pytest.mark.asyncio
|
2020-06-16 13:59:03 +09:30
|
|
|
async def test_adapter_add_nio_binding_invalid_adapter(vm):
|
|
|
|
|
2015-10-14 18:10:05 +02:00
|
|
|
nio = {"type": "nio_udp",
|
|
|
|
"lport": 4242,
|
|
|
|
"rport": 4343,
|
|
|
|
"rhost": "127.0.0.1"}
|
2016-06-24 18:35:39 -06:00
|
|
|
nio = vm.manager.create_nio(nio)
|
2015-10-14 18:10:05 +02:00
|
|
|
with pytest.raises(DockerError):
|
2020-06-16 13:59:03 +09:30
|
|
|
await vm.adapter_add_nio_binding(12, nio)
|
|
|
|
|
2015-10-14 18:10:05 +02:00
|
|
|
|
2020-10-02 16:07:50 +09:30
|
|
|
@pytest.mark.asyncio
|
2020-06-16 13:59:03 +09:30
|
|
|
async def test_adapter_remove_nio_binding(vm):
|
2015-10-14 18:10:05 +02:00
|
|
|
|
2016-12-14 16:53:20 +01:00
|
|
|
vm.ubridge = MagicMock()
|
|
|
|
vm.ubridge.is_running.return_value = True
|
|
|
|
|
2015-10-14 18:10:05 +02:00
|
|
|
nio = {"type": "nio_udp",
|
|
|
|
"lport": 4242,
|
|
|
|
"rport": 4343,
|
|
|
|
"rhost": "127.0.0.1"}
|
2016-06-24 18:35:39 -06:00
|
|
|
nio = vm.manager.create_nio(nio)
|
2020-06-16 13:59:03 +09:30
|
|
|
await vm.adapter_add_nio_binding(0, nio)
|
2016-12-14 16:53:20 +01:00
|
|
|
|
|
|
|
with asyncio_patch("gns3server.compute.docker.DockerVM._ubridge_send") as delete_ubridge_mock:
|
2020-06-16 13:59:03 +09:30
|
|
|
await vm.adapter_remove_nio_binding(0)
|
2015-10-14 18:10:05 +02:00
|
|
|
assert vm._ethernet_adapters[0].get_nio(0) is None
|
2016-12-14 16:53:20 +01:00
|
|
|
delete_ubridge_mock.assert_any_call('bridge stop bridge0')
|
|
|
|
delete_ubridge_mock.assert_any_call('bridge remove_nio_udp bridge0 4242 127.0.0.1 4343')
|
2015-10-14 18:10:05 +02:00
|
|
|
|
|
|
|
|
2020-10-02 16:07:50 +09:30
|
|
|
@pytest.mark.asyncio
|
2020-06-16 13:59:03 +09:30
|
|
|
async def test_adapter_remove_nio_binding_invalid_adapter(vm):
|
|
|
|
|
2015-10-14 18:10:05 +02:00
|
|
|
with pytest.raises(DockerError):
|
2020-06-16 13:59:03 +09:30
|
|
|
await vm.adapter_remove_nio_binding(12)
|
2015-10-14 18:10:05 +02:00
|
|
|
|
|
|
|
|
2020-10-02 16:07:50 +09:30
|
|
|
@pytest.mark.asyncio
|
2020-06-16 13:59:03 +09:30
|
|
|
async def test_start_capture(vm, tmpdir, manager, free_console_port):
|
2016-02-09 16:07:33 +01:00
|
|
|
|
|
|
|
output_file = str(tmpdir / "test.pcap")
|
2016-06-24 18:35:39 -06:00
|
|
|
nio = manager.create_nio({"type": "nio_udp", "lport": free_console_port, "rport": free_console_port, "rhost": "127.0.0.1"})
|
2020-06-16 13:59:03 +09:30
|
|
|
await vm.adapter_add_nio_binding(0, nio)
|
|
|
|
await vm.start_capture(0, output_file)
|
2016-02-09 16:07:33 +01:00
|
|
|
assert vm._ethernet_adapters[0].get_nio(0).capturing
|
|
|
|
|
|
|
|
|
2020-10-02 16:07:50 +09:30
|
|
|
@pytest.mark.asyncio
|
2020-06-16 13:59:03 +09:30
|
|
|
async def test_stop_capture(vm, tmpdir, manager, free_console_port):
|
2016-02-09 16:07:33 +01:00
|
|
|
|
|
|
|
output_file = str(tmpdir / "test.pcap")
|
2016-06-24 18:35:39 -06:00
|
|
|
nio = manager.create_nio({"type": "nio_udp", "lport": free_console_port, "rport": free_console_port, "rhost": "127.0.0.1"})
|
2020-06-16 13:59:03 +09:30
|
|
|
await vm.adapter_add_nio_binding(0, nio)
|
|
|
|
await vm.start_capture(0, output_file)
|
2016-02-09 16:07:33 +01:00
|
|
|
assert vm._ethernet_adapters[0].get_nio(0).capturing
|
2020-06-16 13:59:03 +09:30
|
|
|
await vm.stop_capture(0)
|
2016-02-09 16:07:33 +01:00
|
|
|
assert vm._ethernet_adapters[0].get_nio(0).capturing is False
|
2016-02-11 15:49:28 +01:00
|
|
|
|
|
|
|
|
2020-10-02 16:07:50 +09:30
|
|
|
@pytest.mark.asyncio
|
2020-06-16 13:59:03 +09:30
|
|
|
async def test_get_log(vm):
|
2018-10-15 17:05:49 +07:00
|
|
|
|
|
|
|
async def read():
|
2016-02-11 15:49:28 +01:00
|
|
|
return b'Hello\nWorld'
|
|
|
|
|
|
|
|
mock_query = MagicMock()
|
|
|
|
mock_query.read = read
|
|
|
|
|
2016-04-15 17:57:06 +02:00
|
|
|
with asyncio_patch("gns3server.compute.docker.Docker.http_query", return_value=mock_query) as mock:
|
2020-06-16 13:59:03 +09:30
|
|
|
await vm._get_log()
|
2016-02-11 15:49:28 +01:00
|
|
|
mock.assert_called_with("GET", "containers/e90e34656842/logs", params={"stderr": 1, "stdout": 1}, data={})
|
2016-02-12 11:57:56 +01:00
|
|
|
|
|
|
|
|
2020-10-02 16:07:50 +09:30
|
|
|
@pytest.mark.asyncio
|
2020-06-16 13:59:03 +09:30
|
|
|
async def test_get_image_information(compute_project, manager):
|
|
|
|
|
|
|
|
response = {}
|
2016-04-15 17:57:06 +02:00
|
|
|
with asyncio_patch("gns3server.compute.docker.Docker.query", return_value=response) as mock:
|
2020-06-16 13:59:03 +09:30
|
|
|
vm = DockerVM("test", str(uuid.uuid4()), compute_project, manager, "ubuntu")
|
|
|
|
await vm._get_image_information()
|
2016-05-19 13:09:07 +02:00
|
|
|
mock.assert_called_with("GET", "images/ubuntu:latest/json")
|
2016-02-12 11:57:56 +01:00
|
|
|
|
2016-10-24 12:21:57 +02:00
|
|
|
|
2020-10-02 16:07:50 +09:30
|
|
|
@pytest.mark.asyncio
|
2020-06-16 13:59:03 +09:30
|
|
|
async def test_mount_binds(vm):
|
|
|
|
|
2016-02-12 11:57:56 +01:00
|
|
|
image_infos = {
|
2017-05-23 10:18:30 +02:00
|
|
|
"Config": {
|
2016-02-12 11:57:56 +01:00
|
|
|
"Volumes": {
|
|
|
|
"/test/experimental": {}
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
dst = os.path.join(vm.working_dir, "test/experimental")
|
|
|
|
assert vm._mount_binds(image_infos) == [
|
2023-03-19 17:56:07 +10:00
|
|
|
{
|
|
|
|
"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"
|
|
|
|
},
|
|
|
|
{
|
|
|
|
"Type": "bind",
|
|
|
|
"Source": dst,
|
|
|
|
"Target": "/gns3volumes/test/experimental"
|
|
|
|
}
|
2016-02-12 11:57:56 +01:00
|
|
|
]
|
|
|
|
|
2016-05-31 21:08:41 +02:00
|
|
|
assert vm._volumes == ["/etc/network", "/test/experimental"]
|
2016-02-12 11:57:56 +01:00
|
|
|
assert os.path.exists(dst)
|
2016-02-29 21:08:25 +01:00
|
|
|
|
|
|
|
|
2020-10-02 16:07:50 +09:30
|
|
|
@pytest.mark.asyncio
|
2020-06-16 13:59:03 +09:30
|
|
|
async def test_start_vnc(vm):
|
|
|
|
|
2016-04-07 13:29:11 +02:00
|
|
|
vm.console_resolution = "1280x1024"
|
2018-11-11 23:25:23 +08:00
|
|
|
with patch("shutil.which", return_value="/bin/Xtigervnc"):
|
2016-04-15 17:57:06 +02:00
|
|
|
with asyncio_patch("gns3server.compute.docker.docker_vm.wait_for_file_creation") as mock_wait:
|
2016-02-29 21:08:25 +01:00
|
|
|
with asyncio_patch("asyncio.create_subprocess_exec") as mock_exec:
|
2020-06-16 13:59:03 +09:30
|
|
|
await vm._start_vnc()
|
2016-02-29 21:08:25 +01:00
|
|
|
assert vm._display is not None
|
2022-06-08 00:05:24 +08:00
|
|
|
assert mock_exec.call_args[0] == ("/bin/Xtigervnc", "-extension", "MIT-SHM", "-geometry", vm.console_resolution, "-depth", "16", "-interface", "127.0.0.1", "-rfbport", str(vm.console), "-AlwaysShared", "-SecurityTypes", "None", ":{}".format(vm._display))
|
2016-02-29 21:08:25 +01:00
|
|
|
mock_wait.assert_called_with("/tmp/.X11-unix/X{}".format(vm._display))
|
|
|
|
|
|
|
|
|
2020-10-02 16:07:50 +09:30
|
|
|
@pytest.mark.asyncio
|
2020-06-16 13:59:03 +09:30
|
|
|
async def test_start_vnc_missing(vm):
|
|
|
|
|
|
|
|
with patch("shutil.which", return_value=None):
|
|
|
|
with pytest.raises(DockerError):
|
|
|
|
await vm._start_vnc()
|
2016-03-01 14:53:43 +01:00
|
|
|
|
|
|
|
|
2020-10-02 16:07:50 +09:30
|
|
|
@pytest.mark.asyncio
|
2020-06-16 13:59:03 +09:30
|
|
|
async def test_start_aux(vm):
|
2016-03-01 14:53:43 +01:00
|
|
|
|
|
|
|
with asyncio_patch("asyncio.subprocess.create_subprocess_exec", return_value=MagicMock()) as mock_exec:
|
2020-06-16 13:59:03 +09:30
|
|
|
await vm._start_aux()
|
2021-06-03 19:11:11 +09:30
|
|
|
mock_exec.assert_called_with(
|
|
|
|
"script",
|
|
|
|
"-qfc",
|
|
|
|
"docker exec -i -t e90e34656842 /gns3/bin/busybox sh -c 'while true; do TERM=vt100 /gns3/bin/busybox sh; done'",
|
|
|
|
"/dev/null",
|
|
|
|
stderr=asyncio.subprocess.STDOUT,
|
|
|
|
stdin=asyncio.subprocess.PIPE,
|
|
|
|
stdout=asyncio.subprocess.PIPE
|
|
|
|
)
|
2016-03-24 17:08:16 +01:00
|
|
|
|
|
|
|
|
2020-10-02 16:07:50 +09:30
|
|
|
@pytest.mark.asyncio
|
2020-06-16 13:59:03 +09:30
|
|
|
async def test_create_network_interfaces(vm):
|
2016-03-24 17:08:16 +01:00
|
|
|
|
|
|
|
vm.adapters = 5
|
|
|
|
network_config = vm._create_network_config()
|
|
|
|
assert os.path.exists(os.path.join(network_config, "interfaces"))
|
|
|
|
assert os.path.exists(os.path.join(network_config, "if-up.d"))
|
|
|
|
|
|
|
|
with open(os.path.join(network_config, "interfaces")) as f:
|
|
|
|
content = f.read()
|
|
|
|
assert "eth0" in content
|
|
|
|
assert "eth4" in content
|
|
|
|
assert "eth5" not in content
|
2016-05-31 21:08:41 +02:00
|
|
|
|
2016-10-24 12:21:57 +02:00
|
|
|
|
2020-10-02 16:07:50 +09:30
|
|
|
@pytest.mark.asyncio
|
2020-06-16 13:59:03 +09:30
|
|
|
async def test_fix_permission(vm):
|
|
|
|
|
2016-05-31 21:08:41 +02:00
|
|
|
vm._volumes = ["/etc"]
|
2017-07-26 12:41:06 +02:00
|
|
|
vm._get_container_state = AsyncioMagicMock(return_value="running")
|
2016-05-31 21:08:41 +02:00
|
|
|
process = MagicMock()
|
|
|
|
with asyncio_patch("asyncio.subprocess.create_subprocess_exec", return_value=process) as mock_exec:
|
2020-06-16 13:59:03 +09:30
|
|
|
await vm._fix_permissions()
|
2016-06-01 20:09:15 +02:00
|
|
|
mock_exec.assert_called_with('docker', 'exec', 'e90e34656842', '/gns3/bin/busybox', 'sh', '-c', '(/gns3/bin/busybox find "/etc" -depth -print0 | /gns3/bin/busybox xargs -0 /gns3/bin/busybox stat -c \'%a:%u:%g:%n\' > "/etc/.gns3_perms") && /gns3/bin/busybox chmod -R u+rX "/etc" && /gns3/bin/busybox chown {}:{} -R "/etc"'.format(os.getuid(), os.getgid()))
|
2016-05-31 21:08:41 +02:00
|
|
|
assert process.wait.called
|
2017-07-06 10:13:00 +02:00
|
|
|
|
|
|
|
|
2020-10-02 16:07:50 +09:30
|
|
|
@pytest.mark.asyncio
|
2020-06-16 13:59:03 +09:30
|
|
|
async def test_fix_permission_not_running(vm):
|
|
|
|
|
2017-07-26 12:41:06 +02:00
|
|
|
vm._volumes = ["/etc"]
|
|
|
|
vm._get_container_state = AsyncioMagicMock(return_value="stopped")
|
|
|
|
process = MagicMock()
|
|
|
|
with asyncio_patch("gns3server.compute.docker.Docker.query") as mock_start:
|
|
|
|
with asyncio_patch("asyncio.subprocess.create_subprocess_exec", return_value=process) as mock_exec:
|
2020-06-16 13:59:03 +09:30
|
|
|
await vm._fix_permissions()
|
2017-07-26 12:41:06 +02:00
|
|
|
mock_exec.assert_called_with('docker', 'exec', 'e90e34656842', '/gns3/bin/busybox', 'sh', '-c', '(/gns3/bin/busybox find "/etc" -depth -print0 | /gns3/bin/busybox xargs -0 /gns3/bin/busybox stat -c \'%a:%u:%g:%n\' > "/etc/.gns3_perms") && /gns3/bin/busybox chmod -R u+rX "/etc" && /gns3/bin/busybox chown {}:{} -R "/etc"'.format(os.getuid(), os.getgid()))
|
|
|
|
assert mock_start.called
|
|
|
|
assert process.wait.called
|
|
|
|
|
|
|
|
|
2020-10-02 16:07:50 +09:30
|
|
|
@pytest.mark.asyncio
|
2020-06-16 13:59:03 +09:30
|
|
|
async def test_read_console_output_with_binary_mode(vm):
|
|
|
|
|
2017-07-06 10:13:00 +02:00
|
|
|
class InputStreamMock(object):
|
|
|
|
def __init__(self):
|
|
|
|
self.sent = False
|
|
|
|
|
2018-10-15 17:05:49 +07:00
|
|
|
async def receive(self):
|
2017-07-06 10:13:00 +02:00
|
|
|
if not self.sent:
|
|
|
|
self.sent = True
|
2018-11-30 18:59:02 +08:00
|
|
|
return MagicMock(type=aiohttp.WSMsgType.BINARY, data=b"test")
|
2017-07-06 10:13:00 +02:00
|
|
|
else:
|
2018-11-30 18:59:02 +08:00
|
|
|
return MagicMock(type=aiohttp.WSMsgType.CLOSE)
|
2017-07-06 10:13:00 +02:00
|
|
|
|
2018-11-30 18:59:02 +08:00
|
|
|
async def close(self):
|
2017-07-06 10:13:00 +02:00
|
|
|
pass
|
|
|
|
|
|
|
|
input_stream = InputStreamMock()
|
|
|
|
output_stream = MagicMock()
|
|
|
|
|
|
|
|
with asyncio_patch('gns3server.compute.docker.docker_vm.DockerVM.stop'):
|
2020-06-16 13:59:03 +09:30
|
|
|
await vm._read_console_output(input_stream, output_stream)
|
2017-07-06 10:13:00 +02:00
|
|
|
output_stream.feed_data.assert_called_once_with(b"test")
|
2020-07-18 21:03:55 +09:30
|
|
|
|
|
|
|
|
2020-10-02 16:07:50 +09:30
|
|
|
@pytest.mark.asyncio
|
2020-07-18 21:03:55 +09:30
|
|
|
async def test_cpus(compute_project, manager):
|
|
|
|
|
|
|
|
response = {
|
|
|
|
"Id": "e90e34656806",
|
|
|
|
"Warnings": []
|
|
|
|
}
|
|
|
|
with asyncio_patch("gns3server.compute.docker.Docker.list_images", return_value=[{"image": "ubuntu"}]):
|
|
|
|
with asyncio_patch("gns3server.compute.docker.Docker.query", return_value=response) as mock:
|
|
|
|
vm = DockerVM("test", str(uuid.uuid4()), compute_project, manager, "ubuntu:latest", cpus=0.5)
|
|
|
|
await vm.create()
|
|
|
|
mock.assert_called_with("POST", "containers/create", data={
|
|
|
|
"Tty": True,
|
|
|
|
"OpenStdin": True,
|
|
|
|
"StdinOnce": False,
|
|
|
|
"HostConfig":
|
|
|
|
{
|
|
|
|
"CapAdd": ["ALL"],
|
2023-03-19 17:56:07 +10:00
|
|
|
"Mounts": [
|
|
|
|
{
|
|
|
|
"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"
|
|
|
|
}
|
2020-07-18 21:03:55 +09:30
|
|
|
],
|
|
|
|
"Privileged": True,
|
|
|
|
"Memory": 0,
|
|
|
|
"NanoCpus": 500000000
|
|
|
|
},
|
|
|
|
"Volumes": {},
|
|
|
|
"NetworkDisabled": True,
|
|
|
|
"Hostname": "test",
|
|
|
|
"Image": "ubuntu:latest",
|
|
|
|
"Env": [
|
|
|
|
"container=docker",
|
|
|
|
"GNS3_MAX_ETHERNET=eth0",
|
|
|
|
"GNS3_VOLUMES=/etc/network"
|
|
|
|
],
|
|
|
|
"Entrypoint": ["/gns3/init.sh"],
|
|
|
|
"Cmd": ["/bin/sh"]
|
|
|
|
})
|
|
|
|
assert vm._cid == "e90e34656806"
|
|
|
|
|
|
|
|
|
2020-10-02 16:07:50 +09:30
|
|
|
@pytest.mark.asyncio
|
2020-07-18 21:03:55 +09:30
|
|
|
async def test_memory(compute_project, manager):
|
|
|
|
|
|
|
|
response = {
|
|
|
|
"Id": "e90e34656806",
|
|
|
|
"Warnings": []
|
|
|
|
}
|
|
|
|
with asyncio_patch("gns3server.compute.docker.Docker.list_images", return_value=[{"image": "ubuntu"}]):
|
|
|
|
with asyncio_patch("gns3server.compute.docker.Docker.query", return_value=response) as mock:
|
|
|
|
vm = DockerVM("test", str(uuid.uuid4()), compute_project, manager, "ubuntu:latest", memory=32)
|
|
|
|
await vm.create()
|
|
|
|
mock.assert_called_with("POST", "containers/create", data={
|
|
|
|
"Tty": True,
|
|
|
|
"OpenStdin": True,
|
|
|
|
"StdinOnce": False,
|
|
|
|
"HostConfig":
|
|
|
|
{
|
|
|
|
"CapAdd": ["ALL"],
|
2023-03-19 17:56:07 +10:00
|
|
|
"Mounts": [
|
|
|
|
{
|
|
|
|
"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"
|
|
|
|
}
|
2020-07-18 21:03:55 +09:30
|
|
|
],
|
|
|
|
"Privileged": True,
|
|
|
|
"Memory": 33554432, # 32MB in bytes
|
|
|
|
"NanoCpus": 0
|
|
|
|
},
|
|
|
|
"Volumes": {},
|
|
|
|
"NetworkDisabled": True,
|
|
|
|
"Hostname": "test",
|
|
|
|
"Image": "ubuntu:latest",
|
|
|
|
"Env": [
|
|
|
|
"container=docker",
|
|
|
|
"GNS3_MAX_ETHERNET=eth0",
|
|
|
|
"GNS3_VOLUMES=/etc/network"
|
|
|
|
],
|
|
|
|
"Entrypoint": ["/gns3/init.sh"],
|
|
|
|
"Cmd": ["/bin/sh"]
|
|
|
|
})
|
|
|
|
assert vm._cid == "e90e34656806"
|