1
0
mirror of https://github.com/GNS3/gns3-server synced 2025-01-12 17:10:55 +00:00

Update temporary status if project change location

This avoid race condition during file move.
This commit is contained in:
Julien Duponchelle 2015-02-05 11:39:32 +01:00
parent 8367a9eb30
commit dae48b2de4
2 changed files with 28 additions and 4 deletions

View File

@ -114,6 +114,7 @@ class Project:
raise aiohttp.web.HTTPForbidden(text="You are not allowed to modifiy the project directory location") raise aiohttp.web.HTTPForbidden(text="You are not allowed to modifiy the project directory location")
self._path = path self._path = path
self._update_temporary_file()
@property @property
def vms(self): def vms(self):
@ -132,6 +133,13 @@ class Project:
return return
self._temporary = temporary self._temporary = temporary
self._update_temporary_file()
def _update_temporary_file(self):
"""
Update the .gns3_temporary file in order to reflect current
project status.
"""
if self._temporary: if self._temporary:
try: try:

View File

@ -53,21 +53,37 @@ def test_path(tmpdir):
p = Project(location=str(tmpdir)) p = Project(location=str(tmpdir))
assert p.path == os.path.join(str(tmpdir), p.id) assert p.path == os.path.join(str(tmpdir), p.id)
assert os.path.exists(os.path.join(str(tmpdir), p.id)) assert os.path.exists(os.path.join(str(tmpdir), p.id))
assert not os.path.exists(os.path.join(p.path, '.gns3_temporary')) assert not os.path.exists(os.path.join(p.path, ".gns3_temporary"))
def test_changing_path_temporary_flag(tmpdir):
with patch("gns3server.config.Config.get_section_config", return_value={"local": True}):
p = Project(temporary=True)
assert os.path.exists(p.path)
assert os.path.exists(os.path.join(p.path, ".gns3_temporary"))
p.temporary = False
assert not os.path.exists(os.path.join(p.path, ".gns3_temporary"))
with open(str(tmpdir / ".gns3_temporary"), "w+") as f:
f.write("1")
p.path = str(tmpdir)
assert not os.path.exists(os.path.join(str(tmpdir), ".gns3_temporary"))
def test_temporary_path(): def test_temporary_path():
p = Project(temporary=True) p = Project(temporary=True)
assert os.path.exists(p.path) assert os.path.exists(p.path)
assert os.path.exists(os.path.join(p.path, '.gns3_temporary')) assert os.path.exists(os.path.join(p.path, ".gns3_temporary"))
def test_remove_temporary_flag(): def test_remove_temporary_flag():
p = Project(temporary=True) p = Project(temporary=True)
assert os.path.exists(p.path) assert os.path.exists(p.path)
assert os.path.exists(os.path.join(p.path, '.gns3_temporary')) assert os.path.exists(os.path.join(p.path, ".gns3_temporary"))
p.temporary = False p.temporary = False
assert not os.path.exists(os.path.join(p.path, '.gns3_temporary')) assert not os.path.exists(os.path.join(p.path, ".gns3_temporary"))
def test_changing_location_not_allowed(tmpdir): def test_changing_location_not_allowed(tmpdir):