2015-02-18 15:13:09 +00:00
|
|
|
# -*- coding: utf-8 -*-
|
|
|
|
#
|
2020-06-16 04:29:03 +00:00
|
|
|
# Copyright (C) 2020 GNS3 Technologies Inc.
|
2015-02-18 15:13:09 +00: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/>.
|
|
|
|
|
|
|
|
import uuid
|
|
|
|
import os
|
|
|
|
import pytest
|
2020-08-13 07:40:31 +00:00
|
|
|
from unittest.mock import patch, MagicMock
|
2020-06-16 04:29:03 +00:00
|
|
|
from tests.utils import asyncio_patch
|
2015-02-18 15:13:09 +00:00
|
|
|
|
2016-04-15 15:57:06 +00:00
|
|
|
from gns3server.compute.vpcs import VPCS
|
2017-07-20 15:29:42 +00:00
|
|
|
from gns3server.compute.dynamips import Dynamips
|
2016-04-15 15:57:06 +00:00
|
|
|
from gns3server.compute.qemu import Qemu
|
2016-06-07 13:34:04 +00:00
|
|
|
from gns3server.compute.error import NodeError, ImageMissingError
|
2015-12-14 15:06:51 +00:00
|
|
|
from gns3server.utils import force_unix_path
|
2015-02-18 15:13:09 +00:00
|
|
|
|
|
|
|
|
2015-04-13 12:33:13 +00:00
|
|
|
@pytest.fixture(scope="function")
|
2024-05-09 10:11:12 +00:00
|
|
|
async def vpcs(event_loop, port_manager):
|
2020-06-16 04:29:03 +00:00
|
|
|
|
2015-04-13 12:33:13 +00:00
|
|
|
VPCS._instance = None
|
|
|
|
vpcs = VPCS.instance()
|
|
|
|
vpcs.port_manager = port_manager
|
|
|
|
return vpcs
|
|
|
|
|
|
|
|
|
2015-04-15 12:31:40 +00:00
|
|
|
@pytest.fixture(scope="function")
|
2024-05-09 10:11:12 +00:00
|
|
|
async def qemu(event_loop, port_manager):
|
2020-06-16 04:29:03 +00:00
|
|
|
|
2015-04-27 21:12:13 +00:00
|
|
|
Qemu._instance = None
|
2020-08-13 07:40:31 +00:00
|
|
|
Qemu._init_config_disk = MagicMock() # do not create the config.img image
|
2015-04-27 21:12:13 +00:00
|
|
|
qemu = Qemu.instance()
|
|
|
|
qemu.port_manager = port_manager
|
|
|
|
return qemu
|
2015-04-15 12:31:40 +00:00
|
|
|
|
|
|
|
|
2020-06-16 04:29:03 +00:00
|
|
|
async def test_create_node_new_topology(compute_project, vpcs):
|
|
|
|
|
2016-05-11 17:35:36 +00:00
|
|
|
node_id = str(uuid.uuid4())
|
2020-06-16 04:29:03 +00:00
|
|
|
node = await vpcs.create_node("PC 1", compute_project.id, node_id)
|
|
|
|
assert node in compute_project.nodes
|
|
|
|
|
2015-02-18 15:13:09 +00:00
|
|
|
|
2020-06-16 04:29:03 +00:00
|
|
|
async def test_create_twice_same_node_new_topology(compute_project, vpcs):
|
2015-02-18 15:13:09 +00:00
|
|
|
|
2020-06-16 04:29:03 +00:00
|
|
|
compute_project._nodes = set()
|
2016-05-11 17:35:36 +00:00
|
|
|
node_id = str(uuid.uuid4())
|
2020-06-16 04:29:03 +00:00
|
|
|
node = await vpcs.create_node("PC 1", compute_project.id, node_id, console=2222)
|
|
|
|
assert node in compute_project.nodes
|
|
|
|
assert len(compute_project.nodes) == 1
|
|
|
|
await vpcs.create_node("PC 2", compute_project.id, node_id, console=2222)
|
|
|
|
assert len(compute_project.nodes) == 1
|
2015-03-02 14:35:36 +00:00
|
|
|
|
|
|
|
|
2020-06-16 04:29:03 +00:00
|
|
|
async def test_create_node_new_topology_without_uuid(compute_project, vpcs):
|
|
|
|
|
|
|
|
node = await vpcs.create_node("PC 1", compute_project.id, None)
|
|
|
|
assert node in compute_project.nodes
|
2016-05-11 17:35:36 +00:00
|
|
|
assert len(node.id) == 36
|
2015-02-18 15:13:09 +00:00
|
|
|
|
|
|
|
|
2020-06-16 04:29:03 +00:00
|
|
|
async def test_create_node_old_topology(compute_project, tmpdir, vpcs):
|
2015-02-18 15:13:09 +00:00
|
|
|
|
2016-04-15 15:57:06 +00:00
|
|
|
with patch("gns3server.compute.project.Project.is_local", return_value=True):
|
2015-02-18 15:13:09 +00:00
|
|
|
# Create an old topology directory
|
|
|
|
project_dir = str(tmpdir / "testold")
|
2016-05-11 17:35:36 +00:00
|
|
|
node_dir = os.path.join(project_dir, "testold-files", "vpcs", "pc-1")
|
2020-06-16 04:29:03 +00:00
|
|
|
compute_project.path = project_dir
|
|
|
|
compute_project.name = "testold"
|
2016-05-11 17:35:36 +00:00
|
|
|
os.makedirs(node_dir, exist_ok=True)
|
|
|
|
with open(os.path.join(node_dir, "startup.vpc"), "w+") as f:
|
2015-02-18 15:13:09 +00:00
|
|
|
f.write("1")
|
|
|
|
|
2016-05-11 17:35:36 +00:00
|
|
|
node_id = 1
|
2020-06-16 04:29:03 +00:00
|
|
|
node = await vpcs.create_node("PC 1", compute_project.id, node_id)
|
2016-05-11 17:35:36 +00:00
|
|
|
assert len(node.id) == 36
|
2015-02-18 15:13:09 +00:00
|
|
|
|
2015-02-25 17:23:41 +00:00
|
|
|
assert os.path.exists(os.path.join(project_dir, "testold-files")) is False
|
|
|
|
|
2016-05-11 17:35:36 +00:00
|
|
|
node_dir = os.path.join(project_dir, "project-files", "vpcs", node.id)
|
|
|
|
with open(os.path.join(node_dir, "startup.vpc")) as f:
|
2015-02-25 17:23:41 +00:00
|
|
|
assert f.read() == "1"
|
2015-04-14 16:46:55 +00:00
|
|
|
|
|
|
|
|
2016-11-04 14:42:29 +00:00
|
|
|
def test_get_abs_image_path(qemu, tmpdir, config):
|
2020-06-16 04:29:03 +00:00
|
|
|
|
2015-04-27 21:12:13 +00:00
|
|
|
os.makedirs(str(tmpdir / "QEMU"))
|
2015-12-14 15:06:51 +00:00
|
|
|
path1 = force_unix_path(str(tmpdir / "test1.bin"))
|
2015-04-14 16:46:55 +00:00
|
|
|
open(path1, 'w+').close()
|
|
|
|
|
2015-12-14 15:06:51 +00:00
|
|
|
path2 = force_unix_path(str(tmpdir / "QEMU" / "test2.bin"))
|
2015-04-14 16:46:55 +00:00
|
|
|
open(path2, 'w+').close()
|
|
|
|
|
2016-11-04 14:42:29 +00:00
|
|
|
config.set_section_config("Server", {"images_path": str(tmpdir)})
|
|
|
|
assert qemu.get_abs_image_path(path1) == path1
|
|
|
|
assert qemu.get_abs_image_path("test1.bin") == path1
|
|
|
|
assert qemu.get_abs_image_path(path2) == path2
|
|
|
|
assert qemu.get_abs_image_path("test2.bin") == path2
|
|
|
|
assert qemu.get_abs_image_path("../test1.bin") == path1
|
2015-04-14 16:46:55 +00:00
|
|
|
|
2015-11-09 18:02:10 +00:00
|
|
|
|
2016-11-04 14:42:29 +00:00
|
|
|
def test_get_abs_image_path_non_local(qemu, tmpdir, config):
|
2020-06-16 04:29:03 +00:00
|
|
|
|
2015-11-09 18:02:10 +00:00
|
|
|
path1 = tmpdir / "images" / "QEMU" / "test1.bin"
|
|
|
|
path1.write("1", ensure=True)
|
2015-12-14 15:06:51 +00:00
|
|
|
path1 = force_unix_path(str(path1))
|
2015-11-09 18:02:10 +00:00
|
|
|
|
|
|
|
path2 = tmpdir / "private" / "QEMU" / "test2.bin"
|
|
|
|
path2.write("1", ensure=True)
|
2015-12-14 15:06:51 +00:00
|
|
|
path2 = force_unix_path(str(path2))
|
2015-11-09 18:02:10 +00:00
|
|
|
|
|
|
|
# If non local we can't use path outside images directory
|
2016-11-04 14:42:29 +00:00
|
|
|
config.set_section_config("Server", {"images_path": str(tmpdir / "images"), "local": False})
|
|
|
|
assert qemu.get_abs_image_path(path1) == path1
|
|
|
|
with pytest.raises(NodeError):
|
|
|
|
qemu.get_abs_image_path(path2)
|
|
|
|
with pytest.raises(NodeError):
|
|
|
|
qemu.get_abs_image_path("C:\\test2.bin")
|
2015-11-09 18:02:10 +00:00
|
|
|
|
2016-11-04 14:42:29 +00:00
|
|
|
config.set_section_config("Server", {"images_path": str(tmpdir / "images"), "local": True})
|
|
|
|
assert qemu.get_abs_image_path(path2) == path2
|
2015-05-04 08:57:08 +00:00
|
|
|
|
2015-04-14 16:46:55 +00:00
|
|
|
|
2016-11-04 14:42:29 +00:00
|
|
|
def test_get_abs_image_additional_image_paths(qemu, tmpdir, config):
|
2020-06-16 04:29:03 +00:00
|
|
|
|
2016-06-02 13:19:34 +00:00
|
|
|
path1 = tmpdir / "images1" / "QEMU" / "test1.bin"
|
|
|
|
path1.write("1", ensure=True)
|
|
|
|
path1 = force_unix_path(str(path1))
|
|
|
|
|
|
|
|
path2 = tmpdir / "images2" / "test2.bin"
|
|
|
|
path2.write("1", ensure=True)
|
|
|
|
path2 = force_unix_path(str(path2))
|
|
|
|
|
2016-11-04 14:42:29 +00:00
|
|
|
config.set_section_config("Server", {
|
|
|
|
"images_path": str(tmpdir / "images1"),
|
|
|
|
"additional_images_path": "/tmp/null24564;{}".format(str(tmpdir / "images2")),
|
|
|
|
"local": False})
|
|
|
|
|
|
|
|
assert qemu.get_abs_image_path("test1.bin") == path1
|
|
|
|
assert qemu.get_abs_image_path("test2.bin") == path2
|
|
|
|
# Absolute path
|
|
|
|
assert qemu.get_abs_image_path(str(path2)) == path2
|
2016-06-02 13:19:34 +00:00
|
|
|
|
2016-11-04 14:42:29 +00:00
|
|
|
with pytest.raises(ImageMissingError):
|
|
|
|
qemu.get_abs_image_path("test4.bin")
|
2016-06-02 13:19:34 +00:00
|
|
|
|
|
|
|
|
2016-11-04 14:42:29 +00:00
|
|
|
def test_get_abs_image_recursive(qemu, tmpdir, config):
|
2020-06-16 04:29:03 +00:00
|
|
|
|
2016-06-02 14:44:38 +00:00
|
|
|
path1 = tmpdir / "images1" / "QEMU" / "demo" / "test1.bin"
|
|
|
|
path1.write("1", ensure=True)
|
|
|
|
path1 = force_unix_path(str(path1))
|
|
|
|
|
|
|
|
path2 = tmpdir / "images1" / "QEMU" / "test2.bin"
|
|
|
|
path2.write("1", ensure=True)
|
|
|
|
path2 = force_unix_path(str(path2))
|
|
|
|
|
2016-11-04 14:42:29 +00:00
|
|
|
config.set_section_config("Server", {
|
|
|
|
"images_path": str(tmpdir / "images1"),
|
|
|
|
"local": False})
|
|
|
|
assert qemu.get_abs_image_path("test1.bin") == path1
|
|
|
|
assert qemu.get_abs_image_path("test2.bin") == path2
|
|
|
|
# Absolute path
|
|
|
|
assert qemu.get_abs_image_path(str(path1)) == path1
|
2016-06-02 14:44:38 +00:00
|
|
|
|
|
|
|
|
2016-11-04 14:42:29 +00:00
|
|
|
def test_get_abs_image_recursive_ova(qemu, tmpdir, config):
|
2020-06-16 04:29:03 +00:00
|
|
|
|
2016-06-02 14:44:38 +00:00
|
|
|
path1 = tmpdir / "images1" / "QEMU" / "demo" / "test.ova" / "test1.bin"
|
|
|
|
path1.write("1", ensure=True)
|
|
|
|
path1 = force_unix_path(str(path1))
|
|
|
|
|
|
|
|
path2 = tmpdir / "images1" / "QEMU" / "test.ova" / "test2.bin"
|
|
|
|
path2.write("1", ensure=True)
|
|
|
|
path2 = force_unix_path(str(path2))
|
|
|
|
|
2016-11-04 14:42:29 +00:00
|
|
|
config.set_section_config("Server", {
|
|
|
|
"images_path": str(tmpdir / "images1"),
|
|
|
|
"local": False})
|
2021-09-01 10:01:37 +00:00
|
|
|
assert qemu.get_abs_image_path("demo/test.ova/test1.bin") == path1
|
2016-11-04 14:42:29 +00:00
|
|
|
assert qemu.get_abs_image_path("test.ova/test2.bin") == path2
|
|
|
|
# Absolute path
|
|
|
|
assert qemu.get_abs_image_path(str(path1)) == path1
|
2016-06-02 14:44:38 +00:00
|
|
|
|
|
|
|
|
2016-11-04 14:42:29 +00:00
|
|
|
def test_get_relative_image_path(qemu, tmpdir, config):
|
2020-06-16 04:29:03 +00:00
|
|
|
|
2016-06-02 13:19:34 +00:00
|
|
|
os.makedirs(str(tmpdir / "images1" / "QEMU"))
|
2017-01-18 11:39:10 +00:00
|
|
|
os.makedirs(str(tmpdir / "images1" / "VBOX"))
|
2016-06-02 13:19:34 +00:00
|
|
|
path1 = force_unix_path(str(tmpdir / "images1" / "test1.bin"))
|
2015-04-14 16:46:55 +00:00
|
|
|
open(path1, 'w+').close()
|
|
|
|
|
2016-06-02 13:19:34 +00:00
|
|
|
path2 = force_unix_path(str(tmpdir / "images1" / "QEMU" / "test2.bin"))
|
2015-04-14 16:46:55 +00:00
|
|
|
open(path2, 'w+').close()
|
|
|
|
|
2016-06-02 13:19:34 +00:00
|
|
|
os.makedirs(str(tmpdir / "images2"))
|
|
|
|
path3 = force_unix_path(str(tmpdir / "images2" / "test3.bin"))
|
|
|
|
open(path3, 'w+').close()
|
|
|
|
|
2017-01-18 11:39:10 +00:00
|
|
|
path4 = force_unix_path(str(tmpdir / "test4.bin"))
|
|
|
|
open(path4, 'w+').close()
|
|
|
|
|
|
|
|
# The user use an image of another emulator we return the full path
|
|
|
|
path5 = force_unix_path(str(tmpdir / "images1" / "VBOX" / "test5.bin"))
|
|
|
|
open(path5, 'w+').close()
|
|
|
|
|
2016-11-04 14:42:29 +00:00
|
|
|
config.set_section_config("Server", {
|
2016-06-02 13:19:34 +00:00
|
|
|
"images_path": str(tmpdir / "images1"),
|
2017-01-18 11:39:10 +00:00
|
|
|
"additional_images_path": str(tmpdir / "images2"),
|
|
|
|
"local": True
|
2016-11-04 14:42:29 +00:00
|
|
|
})
|
|
|
|
assert qemu.get_relative_image_path(path1) == "test1.bin"
|
|
|
|
assert qemu.get_relative_image_path("test1.bin") == "test1.bin"
|
|
|
|
assert qemu.get_relative_image_path(path2) == "test2.bin"
|
|
|
|
assert qemu.get_relative_image_path("test2.bin") == "test2.bin"
|
|
|
|
assert qemu.get_relative_image_path("../test1.bin") == "test1.bin"
|
|
|
|
assert qemu.get_relative_image_path("test3.bin") == "test3.bin"
|
2017-01-18 11:39:10 +00:00
|
|
|
assert qemu.get_relative_image_path(path4) == path4
|
|
|
|
assert qemu.get_relative_image_path(path5) == path5
|
2015-04-13 12:33:13 +00:00
|
|
|
|
|
|
|
|
2020-06-16 04:29:03 +00:00
|
|
|
async def test_list_images(qemu, tmpdir):
|
2015-04-13 12:33:13 +00:00
|
|
|
|
2016-11-28 18:49:50 +00:00
|
|
|
fake_images = ["a.qcow2", "b.qcow2", ".blu.qcow2", "a.qcow2.md5sum"]
|
2020-01-07 23:10:33 +00:00
|
|
|
tmp_images_dir = os.path.join(tmpdir, "images")
|
|
|
|
os.makedirs(tmp_images_dir, exist_ok=True)
|
2015-04-13 12:33:13 +00:00
|
|
|
for image in fake_images:
|
2020-01-07 23:10:33 +00:00
|
|
|
with open(os.path.join(tmp_images_dir, image), "w+") as f:
|
2015-04-13 12:33:13 +00:00
|
|
|
f.write("1")
|
|
|
|
|
2020-01-07 23:10:33 +00:00
|
|
|
with patch("gns3server.utils.images.default_images_directory", return_value=str(tmp_images_dir)):
|
2020-06-16 04:29:03 +00:00
|
|
|
assert sorted(await qemu.list_images(), key=lambda k: k['filename']) == [
|
2017-12-18 11:08:14 +00:00
|
|
|
{"filename": "a.qcow2", "path": "a.qcow2", "md5sum": "c4ca4238a0b923820dcc509a6f75849b", "filesize": 1},
|
|
|
|
{"filename": "b.qcow2", "path": "b.qcow2", "md5sum": "c4ca4238a0b923820dcc509a6f75849b", "filesize": 1}
|
2015-10-05 09:07:15 +00:00
|
|
|
]
|
|
|
|
|
|
|
|
|
2020-06-16 04:29:03 +00:00
|
|
|
async def test_list_images_recursives(qemu, tmpdir):
|
2015-10-05 09:07:15 +00:00
|
|
|
|
2020-01-07 23:10:33 +00:00
|
|
|
tmp_images_dir = os.path.join(tmpdir, "images")
|
|
|
|
os.makedirs(tmp_images_dir, exist_ok=True)
|
2016-11-28 18:49:50 +00:00
|
|
|
fake_images = ["a.qcow2", "b.qcow2", ".blu.qcow2", "a.qcow2.md5sum"]
|
2015-10-05 09:07:15 +00:00
|
|
|
for image in fake_images:
|
2020-01-07 23:10:33 +00:00
|
|
|
with open(os.path.join(tmp_images_dir, image), "w+") as f:
|
2015-10-05 09:07:15 +00:00
|
|
|
f.write("1")
|
2020-01-07 23:10:33 +00:00
|
|
|
os.makedirs(os.path.join(tmp_images_dir, "c"))
|
2016-11-28 18:49:50 +00:00
|
|
|
fake_images = ["c.qcow2", "c.qcow2.md5sum"]
|
2015-10-05 09:07:15 +00:00
|
|
|
for image in fake_images:
|
2020-01-07 23:10:33 +00:00
|
|
|
with open(os.path.join(tmp_images_dir, "c", image), "w+") as f:
|
2015-10-05 09:07:15 +00:00
|
|
|
f.write("1")
|
|
|
|
|
2020-01-07 23:10:33 +00:00
|
|
|
with patch("gns3server.utils.images.default_images_directory", return_value=str(tmp_images_dir)):
|
2016-11-28 18:49:50 +00:00
|
|
|
|
2020-06-16 04:29:03 +00:00
|
|
|
assert sorted(await qemu.list_images(), key=lambda k: k['filename']) == [
|
2017-12-17 22:06:19 +00:00
|
|
|
{"filename": "a.qcow2", "path": "a.qcow2", "md5sum": "c4ca4238a0b923820dcc509a6f75849b", "filesize": 1},
|
2017-12-18 11:08:14 +00:00
|
|
|
{"filename": "b.qcow2", "path": "b.qcow2", "md5sum": "c4ca4238a0b923820dcc509a6f75849b", "filesize": 1},
|
2017-04-18 14:01:07 +00:00
|
|
|
{"filename": "c.qcow2", "path": force_unix_path(os.path.sep.join(["c", "c.qcow2"])), "md5sum": "c4ca4238a0b923820dcc509a6f75849b", "filesize": 1}
|
2015-04-13 12:33:13 +00:00
|
|
|
]
|
|
|
|
|
|
|
|
|
2020-06-16 04:29:03 +00:00
|
|
|
async def test_list_images_empty(qemu, tmpdir):
|
|
|
|
|
2016-04-15 15:57:06 +00:00
|
|
|
with patch("gns3server.compute.Qemu.get_images_directory", return_value=str(tmpdir)):
|
2020-06-16 04:29:03 +00:00
|
|
|
assert await qemu.list_images() == []
|
2015-04-13 12:33:13 +00:00
|
|
|
|
|
|
|
|
2020-06-16 04:29:03 +00:00
|
|
|
async def test_list_images_directory_not_exist(qemu):
|
|
|
|
|
2016-04-15 15:57:06 +00:00
|
|
|
with patch("gns3server.compute.Qemu.get_images_directory", return_value="/bla"):
|
2020-06-16 04:29:03 +00:00
|
|
|
assert await qemu.list_images() == []
|
|
|
|
|
2016-05-16 12:30:09 +00:00
|
|
|
|
2020-06-16 04:29:03 +00:00
|
|
|
async def test_delete_node(vpcs, compute_project):
|
2016-05-16 12:30:09 +00:00
|
|
|
|
2020-06-16 04:29:03 +00:00
|
|
|
compute_project._nodes = set()
|
2016-05-16 12:30:09 +00:00
|
|
|
node_id = str(uuid.uuid4())
|
2020-06-16 04:29:03 +00:00
|
|
|
node = await vpcs.create_node("PC 1", compute_project.id, node_id, console=2222)
|
|
|
|
assert node in compute_project.nodes
|
2016-05-16 12:30:09 +00:00
|
|
|
with patch("gns3server.compute.project.Project.emit") as mock_emit:
|
2020-06-16 04:29:03 +00:00
|
|
|
await vpcs.delete_node(node_id)
|
2016-05-16 12:30:09 +00:00
|
|
|
mock_emit.assert_called_with("node.deleted", node)
|
2020-06-16 04:29:03 +00:00
|
|
|
assert node not in compute_project.nodes
|
2017-07-20 15:29:42 +00:00
|
|
|
|
|
|
|
|
2020-06-16 04:29:03 +00:00
|
|
|
async def test_duplicate_vpcs(vpcs, compute_project):
|
|
|
|
|
2017-07-20 15:29:42 +00:00
|
|
|
source_node_id = str(uuid.uuid4())
|
2020-06-16 04:29:03 +00:00
|
|
|
source_node = await vpcs.create_node("PC-1", compute_project.id, source_node_id, console=2222)
|
2017-07-20 15:29:42 +00:00
|
|
|
with open(os.path.join(source_node.working_dir, "startup.vpc"), "w+") as f:
|
|
|
|
f.write("set pcname PC-1\nip dhcp\n")
|
|
|
|
destination_node_id = str(uuid.uuid4())
|
2020-06-16 04:29:03 +00:00
|
|
|
destination_node = await vpcs.create_node("PC-2", compute_project.id, destination_node_id, console=2223)
|
|
|
|
await vpcs.duplicate_node(source_node_id, destination_node_id)
|
2017-07-20 15:29:42 +00:00
|
|
|
with open(os.path.join(destination_node.working_dir, "startup.vpc")) as f:
|
2017-10-16 11:02:44 +00:00
|
|
|
startup = f.read().strip()
|
|
|
|
assert startup == "set pcname PC-2\nip dhcp\n".strip()
|
2017-07-20 15:29:42 +00:00
|
|
|
|
|
|
|
|
2020-06-16 04:29:03 +00:00
|
|
|
async def test_duplicate_ethernet_switch(compute_project):
|
|
|
|
|
2017-07-20 15:29:42 +00:00
|
|
|
with asyncio_patch('gns3server.compute.dynamips.nodes.ethernet_switch.EthernetSwitch.create'):
|
|
|
|
dynamips_manager = Dynamips.instance()
|
|
|
|
source_node_id = str(uuid.uuid4())
|
2020-06-16 04:29:03 +00:00
|
|
|
await dynamips_manager.create_node("SW-1", compute_project.id, source_node_id, node_type='ethernet_switch')
|
2017-07-20 15:29:42 +00:00
|
|
|
destination_node_id = str(uuid.uuid4())
|
2020-06-16 04:29:03 +00:00
|
|
|
await dynamips_manager.create_node("SW-2", compute_project.id, destination_node_id, node_type='ethernet_switch')
|
|
|
|
await dynamips_manager.duplicate_node(source_node_id, destination_node_id)
|