mirror of
https://github.com/GNS3/gns3-server
synced 2024-12-01 04:38:12 +00:00
Fix duplicate name for VM
This commit is contained in:
parent
bda1812811
commit
c12413e0ce
@ -98,10 +98,9 @@ class Node:
|
|||||||
|
|
||||||
@name.setter
|
@name.setter
|
||||||
def name(self, new_name):
|
def name(self, new_name):
|
||||||
self._project.update_node_name(self, new_name)
|
self._name = self._project.update_node_name(self, new_name)
|
||||||
self._name = new_name
|
|
||||||
# The text in label need to be always the node name
|
# The text in label need to be always the node name
|
||||||
self._label["text"] = new_name
|
self._label["text"] = self._name
|
||||||
|
|
||||||
@property
|
@property
|
||||||
def node_type(self):
|
def node_type(self):
|
||||||
@ -278,7 +277,7 @@ class Node:
|
|||||||
elif key == "console_type":
|
elif key == "console_type":
|
||||||
self._console_type = value
|
self._console_type = value
|
||||||
elif key == "name":
|
elif key == "name":
|
||||||
self._name = value
|
self.name = value
|
||||||
elif key in ["node_id", "project_id", "console_host"]:
|
elif key in ["node_id", "project_id", "console_host"]:
|
||||||
pass
|
pass
|
||||||
else:
|
else:
|
||||||
|
@ -147,33 +147,6 @@ class Project:
|
|||||||
"""
|
"""
|
||||||
return self._computes
|
return self._computes
|
||||||
|
|
||||||
def allocate_node_name(self, base_name):
|
|
||||||
"""
|
|
||||||
Allocates a new unique name for a node in this project.
|
|
||||||
|
|
||||||
:param base_name: base name for the node which will be completed with a unique number.
|
|
||||||
|
|
||||||
:returns: allocated name or None if one could not be found
|
|
||||||
"""
|
|
||||||
|
|
||||||
if '{0}' in base_name or '{id}' in base_name:
|
|
||||||
# base name is a template, replace {0} or {id} by an unique identifier
|
|
||||||
for number in range(1, 1000000):
|
|
||||||
name = base_name.format(number, id=number)
|
|
||||||
if name not in self._allocated_node_names:
|
|
||||||
self._allocated_node_names.add(name)
|
|
||||||
return name
|
|
||||||
else:
|
|
||||||
if base_name not in self._allocated_node_names:
|
|
||||||
return base_name
|
|
||||||
# base name is not unique, let's find a unique name by appending a number
|
|
||||||
for number in range(1, 1000000):
|
|
||||||
name = base_name + str(number)
|
|
||||||
if name not in self._allocated_node_names:
|
|
||||||
self._allocated_node_names.add(name)
|
|
||||||
return name
|
|
||||||
return None
|
|
||||||
|
|
||||||
def remove_allocated_node_name(self, name):
|
def remove_allocated_node_name(self, name):
|
||||||
"""
|
"""
|
||||||
Removes an allocated node name
|
Removes an allocated node name
|
||||||
@ -184,15 +157,36 @@ class Project:
|
|||||||
if name in self._allocated_node_names:
|
if name in self._allocated_node_names:
|
||||||
self._allocated_node_names.remove(name)
|
self._allocated_node_names.remove(name)
|
||||||
|
|
||||||
def update_allocated_node_name(self, name):
|
def update_allocated_node_name(self, base_name):
|
||||||
"""
|
"""
|
||||||
Updates a node name
|
Updates a node name or generate a new if no node
|
||||||
|
name is available.
|
||||||
|
|
||||||
:param name: new node name
|
:param base_name: new node base name
|
||||||
"""
|
"""
|
||||||
|
|
||||||
self.remove_allocated_node_name(name)
|
if base_name is None:
|
||||||
|
return None
|
||||||
|
self.remove_allocated_node_name(base_name)
|
||||||
|
if '{0}' in base_name or '{id}' in base_name:
|
||||||
|
# base name is a template, replace {0} or {id} by an unique identifier
|
||||||
|
for number in range(1, 1000000):
|
||||||
|
name = base_name.format(number, id=number)
|
||||||
|
if name not in self._allocated_node_names:
|
||||||
self._allocated_node_names.add(name)
|
self._allocated_node_names.add(name)
|
||||||
|
return name
|
||||||
|
else:
|
||||||
|
if base_name not in self._allocated_node_names:
|
||||||
|
self._allocated_node_names.add(base_name)
|
||||||
|
return base_name
|
||||||
|
# base name is not unique, let's find a unique name by appending a number
|
||||||
|
for number in range(1, 1000000):
|
||||||
|
name = base_name + str(number)
|
||||||
|
if name not in self._allocated_node_names:
|
||||||
|
self._allocated_node_names.add(name)
|
||||||
|
return name
|
||||||
|
raise aiohttp.web.HTTPConflict(text="A node name could not be allocated (node limit reached?)")
|
||||||
|
|
||||||
|
|
||||||
def has_allocated_node_name(self, name):
|
def has_allocated_node_name(self, name):
|
||||||
"""
|
"""
|
||||||
@ -210,11 +204,8 @@ class Project:
|
|||||||
def update_node_name(self, node, new_name):
|
def update_node_name(self, node, new_name):
|
||||||
|
|
||||||
if new_name and node.name != new_name:
|
if new_name and node.name != new_name:
|
||||||
if self.has_allocated_node_name(new_name):
|
return self.update_allocated_node_name(new_name)
|
||||||
raise aiohttp.web.HTTPConflict(text="{} node name is already allocated in this project".format(new_name))
|
return new_name
|
||||||
self.update_allocated_node_name(new_name)
|
|
||||||
return True
|
|
||||||
return False
|
|
||||||
|
|
||||||
@asyncio.coroutine
|
@asyncio.coroutine
|
||||||
def add_node(self, compute, name, node_id, **kwargs):
|
def add_node(self, compute, name, node_id, **kwargs):
|
||||||
@ -224,11 +215,6 @@ class Project:
|
|||||||
:param kwargs: See the documentation of node
|
:param kwargs: See the documentation of node
|
||||||
"""
|
"""
|
||||||
if node_id not in self._nodes:
|
if node_id not in self._nodes:
|
||||||
|
|
||||||
name = self.allocate_node_name(name)
|
|
||||||
if not name:
|
|
||||||
raise aiohttp.web.HTTPConflict(text="A node name could not be allocated (node limit reached?)")
|
|
||||||
|
|
||||||
node = Node(self, compute, name, node_id=node_id, **kwargs)
|
node = Node(self, compute, name, node_id=node_id, **kwargs)
|
||||||
if compute not in self._project_created_on_compute:
|
if compute not in self._project_created_on_compute:
|
||||||
# For a local server we send the project path
|
# For a local server we send the project path
|
||||||
|
@ -50,6 +50,30 @@ def node(compute, project):
|
|||||||
return node
|
return node
|
||||||
|
|
||||||
|
|
||||||
|
def test_name(compute, project):
|
||||||
|
"""
|
||||||
|
If node use a name template generate names
|
||||||
|
"""
|
||||||
|
node = Node(project, compute, "PC",
|
||||||
|
node_id=str(uuid.uuid4()),
|
||||||
|
node_type="vpcs",
|
||||||
|
console_type="vnc",
|
||||||
|
properties={"startup_script": "echo test"})
|
||||||
|
assert node.name == "PC"
|
||||||
|
node = Node(project, compute, "PC{0}",
|
||||||
|
node_id=str(uuid.uuid4()),
|
||||||
|
node_type="vpcs",
|
||||||
|
console_type="vnc",
|
||||||
|
properties={"startup_script": "echo test"})
|
||||||
|
assert node.name == "PC1"
|
||||||
|
node = Node(project, compute, "PC{0}",
|
||||||
|
node_id=str(uuid.uuid4()),
|
||||||
|
node_type="vpcs",
|
||||||
|
console_type="vnc",
|
||||||
|
properties={"startup_script": "echo test"})
|
||||||
|
assert node.name == "PC2"
|
||||||
|
|
||||||
|
|
||||||
def test_eq(compute, project, node, controller):
|
def test_eq(compute, project, node, controller):
|
||||||
assert node == Node(project, compute, "demo1", node_id=node.id, node_type="qemu")
|
assert node == Node(project, compute, "demo1", node_id=node.id, node_type="qemu")
|
||||||
assert node != "a"
|
assert node != "a"
|
||||||
|
Loading…
Reference in New Issue
Block a user