mirror of
https://github.com/GNS3/gns3-server
synced 2024-11-30 20:28:08 +00:00
Allow user to set console port
This commit is contained in:
parent
57c3463edc
commit
649d4e5143
@ -20,5 +20,5 @@ X-ROUTE: /vpcs
|
|||||||
"name": "PC TEST 1",
|
"name": "PC TEST 1",
|
||||||
"project_uuid": "a1e920ca-338a-4e9f-b363-aa607b09dd80",
|
"project_uuid": "a1e920ca-338a-4e9f-b363-aa607b09dd80",
|
||||||
"script_file": null,
|
"script_file": null,
|
||||||
"uuid": "aa017896-574d-4a10-bcad-d3001ea98f8b"
|
"uuid": "f598eb3a-67b2-43ab-af37-3c9b1f643cdd"
|
||||||
}
|
}
|
||||||
|
@ -44,6 +44,7 @@ class VPCSHandler:
|
|||||||
vm = yield from vpcs.create_vm(request.json["name"],
|
vm = yield from vpcs.create_vm(request.json["name"],
|
||||||
request.json["project_uuid"],
|
request.json["project_uuid"],
|
||||||
uuid=request.json.get("uuid"),
|
uuid=request.json.get("uuid"),
|
||||||
|
console=request.json.get("console"),
|
||||||
script_file=request.json.get("script_file"))
|
script_file=request.json.get("script_file"))
|
||||||
response.json(vm)
|
response.json(vm)
|
||||||
|
|
||||||
|
@ -157,6 +157,7 @@ class PortManager:
|
|||||||
Get an available TCP console port and reserve it
|
Get an available TCP console port and reserve it
|
||||||
"""
|
"""
|
||||||
|
|
||||||
|
print("FREE")
|
||||||
port = self.find_unused_port(self._console_port_range[0],
|
port = self.find_unused_port(self._console_port_range[0],
|
||||||
self._console_port_range[1],
|
self._console_port_range[1],
|
||||||
host=self._console_host,
|
host=self._console_host,
|
||||||
@ -176,6 +177,7 @@ class PortManager:
|
|||||||
if port in self._used_tcp_ports:
|
if port in self._used_tcp_ports:
|
||||||
raise HTTPConflict(reason="TCP port already {} in use on host".format(port, self._console_host))
|
raise HTTPConflict(reason="TCP port already {} in use on host".format(port, self._console_host))
|
||||||
self._used_tcp_ports.add(port)
|
self._used_tcp_ports.add(port)
|
||||||
|
return port
|
||||||
|
|
||||||
def release_console_port(self, port):
|
def release_console_port(self, port):
|
||||||
"""
|
"""
|
||||||
|
@ -72,13 +72,10 @@ class VPCSVM(BaseVM):
|
|||||||
self._script_file = script_file
|
self._script_file = script_file
|
||||||
self._ethernet_adapter = EthernetAdapter() # one adapter with 1 Ethernet interface
|
self._ethernet_adapter = EthernetAdapter() # one adapter with 1 Ethernet interface
|
||||||
|
|
||||||
try:
|
if self._console is not None:
|
||||||
if not self._console:
|
self._console = self._manager.port_manager.reserve_console_port(self._console)
|
||||||
self._console = self._manager.port_manager.get_free_console_port()
|
else:
|
||||||
else:
|
self._console = self._manager.port_manager.get_free_console_port()
|
||||||
self._console = self._manager.port_manager.reserve_console_port(self._console)
|
|
||||||
except Exception as e:
|
|
||||||
raise VPCSError(e)
|
|
||||||
|
|
||||||
self._check_requirements()
|
self._check_requirements()
|
||||||
|
|
||||||
@ -106,9 +103,9 @@ class VPCSVM(BaseVM):
|
|||||||
|
|
||||||
def __json__(self):
|
def __json__(self):
|
||||||
|
|
||||||
return {"name": self.name,
|
return {"name": self._name,
|
||||||
"uuid": self.uuid,
|
"uuid": self._uuid,
|
||||||
"console": self.console,
|
"console": self._console,
|
||||||
"project_uuid": self.project.uuid,
|
"project_uuid": self.project.uuid,
|
||||||
"script_file": self.script_file}
|
"script_file": self.script_file}
|
||||||
|
|
||||||
|
@ -48,7 +48,7 @@ VPCS_CREATE_SCHEMA = {
|
|||||||
"description": "console TCP port",
|
"description": "console TCP port",
|
||||||
"minimum": 1,
|
"minimum": 1,
|
||||||
"maximum": 65535,
|
"maximum": 65535,
|
||||||
"type": "integer"
|
"type": ["integer", "null"]
|
||||||
},
|
},
|
||||||
"script_file": {
|
"script_file": {
|
||||||
"description": "VPCS startup script",
|
"description": "VPCS startup script",
|
||||||
|
@ -49,6 +49,8 @@ class Response(aiohttp.web.Response):
|
|||||||
try:
|
try:
|
||||||
jsonschema.validate(answer, self._output_schema)
|
jsonschema.validate(answer, self._output_schema)
|
||||||
except jsonschema.ValidationError as e:
|
except jsonschema.ValidationError as e:
|
||||||
log.error("Invalid output schema")
|
log.error("Invalid output schema {} '{}' in schema: {}".format(e.validator,
|
||||||
|
e.validator_value,
|
||||||
|
json.dumps(e.schema)))
|
||||||
raise aiohttp.web.HTTPBadRequest(text="{}".format(e))
|
raise aiohttp.web.HTTPBadRequest(text="{}".format(e))
|
||||||
self.body = json.dumps(answer, indent=4, sort_keys=True).encode('utf-8')
|
self.body = json.dumps(answer, indent=4, sort_keys=True).encode('utf-8')
|
||||||
|
@ -40,7 +40,9 @@ def parse_request(request, input_schema):
|
|||||||
try:
|
try:
|
||||||
jsonschema.validate(request.json, input_schema)
|
jsonschema.validate(request.json, input_schema)
|
||||||
except jsonschema.ValidationError as e:
|
except jsonschema.ValidationError as e:
|
||||||
log.error("Invalid input schema")
|
log.error("Invalid input schema {} '{}' in schema: {}".format(e.validator,
|
||||||
|
e.validator_value,
|
||||||
|
json.dumps(e.schema)))
|
||||||
raise aiohttp.web.HTTPBadRequest(text="Request is not {} '{}' in schema: {}".format(
|
raise aiohttp.web.HTTPBadRequest(text="Request is not {} '{}' in schema: {}".format(
|
||||||
e.validator,
|
e.validator,
|
||||||
e.validator_value,
|
e.validator_value,
|
||||||
|
@ -47,6 +47,15 @@ def test_vpcs_create_script_file(server, project):
|
|||||||
assert response.json["script_file"] == "/tmp/test"
|
assert response.json["script_file"] == "/tmp/test"
|
||||||
|
|
||||||
|
|
||||||
|
def test_vpcs_create_port(server, project):
|
||||||
|
response = server.post("/vpcs", {"name": "PC TEST 1", "project_uuid": project.uuid, "console": 4242})
|
||||||
|
assert response.status == 200
|
||||||
|
assert response.route == "/vpcs"
|
||||||
|
assert response.json["name"] == "PC TEST 1"
|
||||||
|
assert response.json["project_uuid"] == project.uuid
|
||||||
|
assert response.json["console"] == 4242
|
||||||
|
|
||||||
|
|
||||||
def test_vpcs_nio_create_udp(server, vm):
|
def test_vpcs_nio_create_udp(server, vm):
|
||||||
response = server.post("/vpcs/{}/ports/0/nio".format(vm["uuid"]), {"type": "nio_udp",
|
response = server.post("/vpcs/{}/ports/0/nio".format(vm["uuid"]), {"type": "nio_udp",
|
||||||
"lport": 4242,
|
"lport": 4242,
|
||||||
|
Loading…
Reference in New Issue
Block a user