mirror of
https://github.com/GNS3/gns3-server.git
synced 2025-01-18 07:23:47 +02:00
Initial config path for IOU
This commit is contained in:
parent
dd1833c4f0
commit
03b6563864
@ -62,7 +62,7 @@ class IOUHandler:
|
|||||||
ram=request.json.get("ram"),
|
ram=request.json.get("ram"),
|
||||||
nvram=request.json.get("nvram"),
|
nvram=request.json.get("nvram"),
|
||||||
l1_keepalives=request.json.get("l1_keepalives"),
|
l1_keepalives=request.json.get("l1_keepalives"),
|
||||||
initial_config=request.json.get("initial_config")
|
initial_config=request.json.get("initial_config_content")
|
||||||
)
|
)
|
||||||
vm.path = request.json.get("path", vm.path)
|
vm.path = request.json.get("path", vm.path)
|
||||||
response.set_status(201)
|
response.set_status(201)
|
||||||
@ -116,7 +116,7 @@ class IOUHandler:
|
|||||||
vm.ram = request.json.get("ram", vm.ram)
|
vm.ram = request.json.get("ram", vm.ram)
|
||||||
vm.nvram = request.json.get("nvram", vm.nvram)
|
vm.nvram = request.json.get("nvram", vm.nvram)
|
||||||
vm.l1_keepalives = request.json.get("l1_keepalives", vm.l1_keepalives)
|
vm.l1_keepalives = request.json.get("l1_keepalives", vm.l1_keepalives)
|
||||||
vm.initial_config = request.json.get("initial_config", vm.initial_config)
|
vm.initial_config = request.json.get("initial_config_content", vm.initial_config)
|
||||||
|
|
||||||
response.json(vm)
|
response.json(vm)
|
||||||
|
|
||||||
|
@ -200,6 +200,7 @@ class IOUVM(BaseVM):
|
|||||||
"ram": self._ram,
|
"ram": self._ram,
|
||||||
"nvram": self._nvram,
|
"nvram": self._nvram,
|
||||||
"l1_keepalives": self._l1_keepalives,
|
"l1_keepalives": self._l1_keepalives,
|
||||||
|
"initial_config": self.relative_initial_config_file
|
||||||
}
|
}
|
||||||
|
|
||||||
@property
|
@property
|
||||||
@ -890,7 +891,7 @@ class IOUVM(BaseVM):
|
|||||||
|
|
||||||
path = os.path.join(self.working_dir, 'initial-config.cfg')
|
path = os.path.join(self.working_dir, 'initial-config.cfg')
|
||||||
if os.path.exists(path):
|
if os.path.exists(path):
|
||||||
return path.replace(self.project.path, "")[1:]
|
return 'initial-config.cfg'
|
||||||
else:
|
else:
|
||||||
return None
|
return None
|
||||||
|
|
||||||
|
@ -66,7 +66,7 @@ IOU_CREATE_SCHEMA = {
|
|||||||
"description": "Always up ethernet interface",
|
"description": "Always up ethernet interface",
|
||||||
"type": ["boolean", "null"]
|
"type": ["boolean", "null"]
|
||||||
},
|
},
|
||||||
"initial_config": {
|
"initial_config_content": {
|
||||||
"description": "Initial configuration of the IOU",
|
"description": "Initial configuration of the IOU",
|
||||||
"type": ["string", "null"]
|
"type": ["string", "null"]
|
||||||
}
|
}
|
||||||
@ -115,7 +115,7 @@ IOU_UPDATE_SCHEMA = {
|
|||||||
"description": "Always up ethernet interface",
|
"description": "Always up ethernet interface",
|
||||||
"type": ["boolean", "null"]
|
"type": ["boolean", "null"]
|
||||||
},
|
},
|
||||||
"initial_config": {
|
"initial_config_content": {
|
||||||
"description": "Initial configuration of the IOU",
|
"description": "Initial configuration of the IOU",
|
||||||
"type": ["string", "null"]
|
"type": ["string", "null"]
|
||||||
}
|
}
|
||||||
@ -177,9 +177,13 @@ IOU_OBJECT_SCHEMA = {
|
|||||||
"description": "Always up ethernet interface",
|
"description": "Always up ethernet interface",
|
||||||
"type": "boolean"
|
"type": "boolean"
|
||||||
},
|
},
|
||||||
|
"initial_config": {
|
||||||
|
"description": "Path of the initial config content relative to project directory",
|
||||||
|
"type": ["string", "null"]
|
||||||
|
}
|
||||||
},
|
},
|
||||||
"additionalProperties": False,
|
"additionalProperties": False,
|
||||||
"required": ["name", "vm_id", "console", "project_id", "path", "serial_adapters", "ethernet_adapters", "ram", "nvram", "l1_keepalives"]
|
"required": ["name", "vm_id", "console", "project_id", "path", "serial_adapters", "ethernet_adapters", "ram", "nvram", "l1_keepalives", "initial_config"]
|
||||||
}
|
}
|
||||||
|
|
||||||
IOU_NIO_SCHEMA = {
|
IOU_NIO_SCHEMA = {
|
||||||
|
@ -72,7 +72,7 @@ def test_iou_create_with_params(server, project, base_params):
|
|||||||
params["serial_adapters"] = 4
|
params["serial_adapters"] = 4
|
||||||
params["ethernet_adapters"] = 0
|
params["ethernet_adapters"] = 0
|
||||||
params["l1_keepalives"] = True
|
params["l1_keepalives"] = True
|
||||||
params["initial_config"] = "hostname test"
|
params["initial_config_content"] = "hostname test"
|
||||||
|
|
||||||
response = server.post("/projects/{project_id}/iou/vms".format(project_id=project.id), params, example=True)
|
response = server.post("/projects/{project_id}/iou/vms".format(project_id=project.id), params, example=True)
|
||||||
assert response.status == 201
|
assert response.status == 201
|
||||||
@ -84,8 +84,9 @@ def test_iou_create_with_params(server, project, base_params):
|
|||||||
assert response.json["ram"] == 1024
|
assert response.json["ram"] == 1024
|
||||||
assert response.json["nvram"] == 512
|
assert response.json["nvram"] == 512
|
||||||
assert response.json["l1_keepalives"] is True
|
assert response.json["l1_keepalives"] is True
|
||||||
|
assert "initial-config.cfg" in response.json["initial_config"]
|
||||||
with open(initial_config_file(project, response.json)) as f:
|
with open(initial_config_file(project, response.json)) as f:
|
||||||
assert f.read() == params["initial_config"]
|
assert f.read() == params["initial_config_content"]
|
||||||
|
|
||||||
|
|
||||||
def test_iou_get(server, project, vm):
|
def test_iou_get(server, project, vm):
|
||||||
@ -138,7 +139,7 @@ def test_iou_update(server, vm, tmpdir, free_console_port, project):
|
|||||||
"ethernet_adapters": 4,
|
"ethernet_adapters": 4,
|
||||||
"serial_adapters": 0,
|
"serial_adapters": 0,
|
||||||
"l1_keepalives": True,
|
"l1_keepalives": True,
|
||||||
"initial_config": "hostname test"
|
"initial_config_content": "hostname test"
|
||||||
}
|
}
|
||||||
response = server.put("/projects/{project_id}/iou/vms/{vm_id}".format(project_id=vm["project_id"], vm_id=vm["vm_id"]), params)
|
response = server.put("/projects/{project_id}/iou/vms/{vm_id}".format(project_id=vm["project_id"], vm_id=vm["vm_id"]), params)
|
||||||
assert response.status == 200
|
assert response.status == 200
|
||||||
@ -149,6 +150,7 @@ def test_iou_update(server, vm, tmpdir, free_console_port, project):
|
|||||||
assert response.json["ram"] == 512
|
assert response.json["ram"] == 512
|
||||||
assert response.json["nvram"] == 2048
|
assert response.json["nvram"] == 2048
|
||||||
assert response.json["l1_keepalives"] is True
|
assert response.json["l1_keepalives"] is True
|
||||||
|
assert "initial-config.cfg" in response.json["initial_config"]
|
||||||
with open(initial_config_file(project, response.json)) as f:
|
with open(initial_config_file(project, response.json)) as f:
|
||||||
assert f.read() == "hostname test"
|
assert f.read() == "hostname test"
|
||||||
|
|
||||||
@ -244,4 +246,4 @@ def test_get_initial_config_with_config_file(server, project, vm):
|
|||||||
response = server.get("/projects/{project_id}/iou/vms/{vm_id}/initial_config".format(project_id=vm["project_id"], vm_id=vm["vm_id"]), example=True)
|
response = server.get("/projects/{project_id}/iou/vms/{vm_id}/initial_config".format(project_id=vm["project_id"], vm_id=vm["vm_id"]), example=True)
|
||||||
assert response.status == 200
|
assert response.status == 200
|
||||||
assert response.json["content"] == "TEST"
|
assert response.json["content"] == "TEST"
|
||||||
assert response.json["path"] == "project-files/iou/{vm_id}/initial-config.cfg".format(vm_id=vm["vm_id"])
|
assert response.json["path"] == "initial-config.cfg"
|
||||||
|
Loading…
Reference in New Issue
Block a user