mirror of
https://github.com/GNS3/gns3-server.git
synced 2025-01-18 07:23:47 +02:00
Look for qemu images in ~/GNS3/images
This commit is contained in:
parent
ee578d3c12
commit
1b68a54234
@ -32,6 +32,7 @@ from ..adapters.ethernet_adapter import EthernetAdapter
|
|||||||
from ..nios.nio_udp import NIOUDP
|
from ..nios.nio_udp import NIOUDP
|
||||||
from ..base_vm import BaseVM
|
from ..base_vm import BaseVM
|
||||||
from ...schemas.qemu import QEMU_OBJECT_SCHEMA
|
from ...schemas.qemu import QEMU_OBJECT_SCHEMA
|
||||||
|
from ...config import Config
|
||||||
|
|
||||||
import logging
|
import logging
|
||||||
log = logging.getLogger(__name__)
|
log = logging.getLogger(__name__)
|
||||||
@ -182,6 +183,10 @@ class QemuVM(BaseVM):
|
|||||||
:param hda_disk_image: QEMU hda disk image path
|
:param hda_disk_image: QEMU hda disk image path
|
||||||
"""
|
"""
|
||||||
|
|
||||||
|
if hda_disk_image[0] != "/":
|
||||||
|
server_config = Config.instance().get_section_config("Server")
|
||||||
|
hda_disk_image = os.path.join(os.path.expanduser(server_config.get("images_path", "~/GNS3/images")), hda_disk_image)
|
||||||
|
|
||||||
log.info("QEMU VM {name} [id={id}] has set the QEMU hda disk image path to {disk_image}".format(name=self._name,
|
log.info("QEMU VM {name} [id={id}] has set the QEMU hda disk image path to {disk_image}".format(name=self._name,
|
||||||
id=self._id,
|
id=self._id,
|
||||||
disk_image=hda_disk_image))
|
disk_image=hda_disk_image))
|
||||||
@ -205,6 +210,10 @@ class QemuVM(BaseVM):
|
|||||||
:param hdb_disk_image: QEMU hdb disk image path
|
:param hdb_disk_image: QEMU hdb disk image path
|
||||||
"""
|
"""
|
||||||
|
|
||||||
|
if hdb_disk_image[0] != "/":
|
||||||
|
server_config = Config.instance().get_section_config("Server")
|
||||||
|
hdb_disk_image = os.path.join(os.path.expanduser(server_config.get("images_path", "~/GNS3/images")), hdb_disk_image)
|
||||||
|
|
||||||
log.info("QEMU VM {name} [id={id}] has set the QEMU hdb disk image path to {disk_image}".format(name=self._name,
|
log.info("QEMU VM {name} [id={id}] has set the QEMU hdb disk image path to {disk_image}".format(name=self._name,
|
||||||
id=self._id,
|
id=self._id,
|
||||||
disk_image=hdb_disk_image))
|
disk_image=hdb_disk_image))
|
||||||
|
@ -56,7 +56,7 @@ def test_qemu_create(server, project, base_params):
|
|||||||
def test_qemu_create_with_params(server, project, base_params):
|
def test_qemu_create_with_params(server, project, base_params):
|
||||||
params = base_params
|
params = base_params
|
||||||
params["ram"] = 1024
|
params["ram"] = 1024
|
||||||
params["hda_disk_image"] = "hda"
|
params["hda_disk_image"] = "/tmp/hda"
|
||||||
|
|
||||||
response = server.post("/projects/{project_id}/qemu/vms".format(project_id=project.id), params, example=True)
|
response = server.post("/projects/{project_id}/qemu/vms".format(project_id=project.id), params, example=True)
|
||||||
assert response.status == 201
|
assert response.status == 201
|
||||||
@ -64,7 +64,7 @@ def test_qemu_create_with_params(server, project, base_params):
|
|||||||
assert response.json["name"] == "PC TEST 1"
|
assert response.json["name"] == "PC TEST 1"
|
||||||
assert response.json["project_id"] == project.id
|
assert response.json["project_id"] == project.id
|
||||||
assert response.json["ram"] == 1024
|
assert response.json["ram"] == 1024
|
||||||
assert response.json["hda_disk_image"] == "hda"
|
assert response.json["hda_disk_image"] == "/tmp/hda"
|
||||||
|
|
||||||
|
|
||||||
def test_qemu_get(server, project, vm):
|
def test_qemu_get(server, project, vm):
|
||||||
@ -122,13 +122,13 @@ def test_qemu_update(server, vm, tmpdir, free_console_port, project):
|
|||||||
"name": "test",
|
"name": "test",
|
||||||
"console": free_console_port,
|
"console": free_console_port,
|
||||||
"ram": 1024,
|
"ram": 1024,
|
||||||
"hdb_disk_image": "hdb"
|
"hdb_disk_image": "/tmp/hdb"
|
||||||
}
|
}
|
||||||
response = server.put("/projects/{project_id}/qemu/vms/{vm_id}".format(project_id=vm["project_id"], vm_id=vm["vm_id"]), params, example=True)
|
response = server.put("/projects/{project_id}/qemu/vms/{vm_id}".format(project_id=vm["project_id"], vm_id=vm["vm_id"]), params, example=True)
|
||||||
assert response.status == 200
|
assert response.status == 200
|
||||||
assert response.json["name"] == "test"
|
assert response.json["name"] == "test"
|
||||||
assert response.json["console"] == free_console_port
|
assert response.json["console"] == free_console_port
|
||||||
assert response.json["hdb_disk_image"] == "hdb"
|
assert response.json["hdb_disk_image"] == "/tmp/hdb"
|
||||||
assert response.json["ram"] == 1024
|
assert response.json["ram"] == 1024
|
||||||
|
|
||||||
|
|
||||||
|
@ -284,3 +284,21 @@ def test_build_command_without_display(vm, loop, fake_qemu_binary):
|
|||||||
with asyncio_patch("asyncio.create_subprocess_exec", return_value=MagicMock()) as process:
|
with asyncio_patch("asyncio.create_subprocess_exec", return_value=MagicMock()) as process:
|
||||||
cmd = loop.run_until_complete(asyncio.async(vm._build_command()))
|
cmd = loop.run_until_complete(asyncio.async(vm._build_command()))
|
||||||
assert "-nographic" in cmd
|
assert "-nographic" in cmd
|
||||||
|
|
||||||
|
|
||||||
|
def test_hda_disk_image(vm, tmpdir):
|
||||||
|
|
||||||
|
with patch("gns3server.config.Config.get_section_config", return_value={"images_path": str(tmpdir)}):
|
||||||
|
vm.hda_disk_image = "/tmp/test"
|
||||||
|
assert vm.hda_disk_image == "/tmp/test"
|
||||||
|
vm.hda_disk_image = "test"
|
||||||
|
assert vm.hda_disk_image == str(tmpdir / "test")
|
||||||
|
|
||||||
|
|
||||||
|
def test_hdb_disk_image(vm, tmpdir):
|
||||||
|
|
||||||
|
with patch("gns3server.config.Config.get_section_config", return_value={"images_path": str(tmpdir)}):
|
||||||
|
vm.hdb_disk_image = "/tmp/test"
|
||||||
|
assert vm.hdb_disk_image == "/tmp/test"
|
||||||
|
vm.hdb_disk_image = "test"
|
||||||
|
assert vm.hdb_disk_image == str(tmpdir / "test")
|
||||||
|
Loading…
Reference in New Issue
Block a user