1
0
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:
Julien Duponchelle 2015-01-20 20:54:46 +01:00
parent 57c3463edc
commit 649d4e5143
8 changed files with 27 additions and 14 deletions

View File

@ -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"
} }

View File

@ -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)

View File

@ -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):
""" """

View File

@ -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}

View 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",

View File

@ -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')

View File

@ -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,

View File

@ -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,