2015-01-19 17:23:41 +02:00
|
|
|
#!/usr/bin/env python
|
|
|
|
# -*- coding: utf-8 -*-
|
|
|
|
#
|
|
|
|
# Copyright (C) 2015 GNS3 Technologies Inc.
|
|
|
|
#
|
|
|
|
# This program is free software: you can redistribute it and/or modify
|
|
|
|
# it under the terms of the GNU General Public License as published by
|
|
|
|
# the Free Software Foundation, either version 3 of the License, or
|
|
|
|
# (at your option) any later version.
|
|
|
|
#
|
|
|
|
# This program is distributed in the hope that it will be useful,
|
|
|
|
# but WITHOUT ANY WARRANTY; without even the implied warranty of
|
|
|
|
# MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
|
|
|
|
# GNU General Public License for more details.
|
|
|
|
#
|
|
|
|
# You should have received a copy of the GNU General Public License
|
|
|
|
# along with this program. If not, see <http://www.gnu.org/licenses/>.
|
|
|
|
|
|
|
|
import os
|
2015-01-26 13:10:30 +02:00
|
|
|
import asyncio
|
2015-01-23 12:28:58 +02:00
|
|
|
import pytest
|
2015-01-23 17:57:41 +02:00
|
|
|
import aiohttp
|
2015-01-26 14:54:44 +02:00
|
|
|
import shutil
|
2015-02-04 18:18:53 +02:00
|
|
|
from uuid import uuid4
|
2015-01-23 15:07:10 +02:00
|
|
|
from unittest.mock import patch
|
|
|
|
|
2015-01-20 14:04:20 +02:00
|
|
|
from gns3server.modules.project import Project
|
2015-01-23 12:28:58 +02:00
|
|
|
from gns3server.modules.vpcs import VPCS, VPCSVM
|
|
|
|
|
|
|
|
|
|
|
|
@pytest.fixture(scope="module")
|
|
|
|
def manager(port_manager):
|
|
|
|
m = VPCS.instance()
|
|
|
|
m.port_manager = port_manager
|
|
|
|
return m
|
|
|
|
|
|
|
|
|
|
|
|
@pytest.fixture(scope="function")
|
|
|
|
def vm(project, manager):
|
|
|
|
return VPCSVM("test", "00010203-0405-0607-0809-0a0b0c0d0e0f", project, manager)
|
2015-01-20 14:04:20 +02:00
|
|
|
|
2015-01-19 17:23:41 +02:00
|
|
|
|
|
|
|
def test_affect_uuid():
|
|
|
|
p = Project()
|
2015-02-04 22:48:29 +02:00
|
|
|
assert len(p.id) == 36
|
2015-01-19 17:23:41 +02:00
|
|
|
|
2015-02-04 22:48:29 +02:00
|
|
|
p = Project(project_id='00010203-0405-0607-0809-0a0b0c0d0e0f')
|
|
|
|
assert p.id == '00010203-0405-0607-0809-0a0b0c0d0e0f'
|
2015-01-19 17:23:41 +02:00
|
|
|
|
2015-01-20 14:04:20 +02:00
|
|
|
|
2015-01-19 17:23:41 +02:00
|
|
|
def test_path(tmpdir):
|
2015-01-24 01:38:59 +02:00
|
|
|
with patch("gns3server.config.Config.get_section_config", return_value={"local": True}):
|
|
|
|
p = Project(location=str(tmpdir))
|
2015-02-04 22:48:29 +02:00
|
|
|
assert p.path == os.path.join(str(tmpdir), p.id)
|
|
|
|
assert os.path.exists(os.path.join(str(tmpdir), p.id))
|
2015-02-04 18:18:53 +02:00
|
|
|
assert not os.path.exists(os.path.join(p.path, '.gns3_temporary'))
|
2015-01-19 17:23:41 +02:00
|
|
|
|
2015-01-20 14:04:20 +02:00
|
|
|
|
2015-01-19 17:23:41 +02:00
|
|
|
def test_temporary_path():
|
2015-02-04 18:18:53 +02:00
|
|
|
p = Project(temporary=True)
|
|
|
|
assert os.path.exists(p.path)
|
|
|
|
assert os.path.exists(os.path.join(p.path, '.gns3_temporary'))
|
|
|
|
|
|
|
|
|
|
|
|
def test_remove_temporary_flag():
|
|
|
|
p = Project(temporary=True)
|
2015-01-19 17:23:41 +02:00
|
|
|
assert os.path.exists(p.path)
|
2015-02-04 18:18:53 +02:00
|
|
|
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'))
|
2015-01-19 17:23:41 +02:00
|
|
|
|
2015-01-20 14:04:20 +02:00
|
|
|
|
2015-01-24 01:38:59 +02:00
|
|
|
def test_changing_location_not_allowed(tmpdir):
|
|
|
|
with patch("gns3server.config.Config.get_section_config", return_value={"local": False}):
|
|
|
|
with pytest.raises(aiohttp.web.HTTPForbidden):
|
|
|
|
p = Project(location=str(tmpdir))
|
2015-01-23 17:57:41 +02:00
|
|
|
|
|
|
|
|
2015-02-04 22:17:00 +02:00
|
|
|
def test_changing_path_not_allowed(tmpdir):
|
|
|
|
with patch("gns3server.config.Config.get_section_config", return_value={"local": False}):
|
|
|
|
with pytest.raises(aiohttp.web.HTTPForbidden):
|
|
|
|
p = Project()
|
|
|
|
p.path = str(tmpdir)
|
|
|
|
|
|
|
|
|
2015-01-19 17:23:41 +02:00
|
|
|
def test_json(tmpdir):
|
|
|
|
p = Project()
|
2015-02-04 22:52:46 +02:00
|
|
|
assert p.__json__() == {"location": p.location, "path": p.path, "project_id": p.id, "temporary": False}
|
2015-01-20 15:31:47 +02:00
|
|
|
|
|
|
|
|
2015-01-23 12:28:58 +02:00
|
|
|
def test_vm_working_directory(tmpdir, vm):
|
2015-01-24 01:38:59 +02:00
|
|
|
with patch("gns3server.config.Config.get_section_config", return_value={"local": True}):
|
|
|
|
p = Project(location=str(tmpdir))
|
|
|
|
assert os.path.exists(p.vm_working_directory(vm))
|
2015-02-04 22:48:29 +02:00
|
|
|
assert os.path.exists(os.path.join(str(tmpdir), p.id, vm.module_name, vm.id))
|
2015-01-23 12:28:58 +02:00
|
|
|
|
|
|
|
|
2015-01-23 17:57:41 +02:00
|
|
|
def test_mark_vm_for_destruction(vm):
|
|
|
|
project = Project()
|
2015-01-23 15:34:50 +02:00
|
|
|
project.add_vm(vm)
|
|
|
|
project.mark_vm_for_destruction(vm)
|
|
|
|
assert len(project._vms_to_destroy) == 1
|
|
|
|
assert len(project.vms) == 0
|
2015-01-23 12:28:58 +02:00
|
|
|
|
|
|
|
|
2015-01-26 13:10:30 +02:00
|
|
|
def test_commit(manager, loop):
|
2015-01-23 17:57:41 +02:00
|
|
|
project = Project()
|
2015-01-23 12:28:58 +02:00
|
|
|
vm = VPCSVM("test", "00010203-0405-0607-0809-0a0b0c0d0e0f", project, manager)
|
2015-01-23 15:34:50 +02:00
|
|
|
project.add_vm(vm)
|
2015-01-23 12:28:58 +02:00
|
|
|
directory = project.vm_working_directory(vm)
|
|
|
|
project.mark_vm_for_destruction(vm)
|
|
|
|
assert len(project._vms_to_destroy) == 1
|
|
|
|
assert os.path.exists(directory)
|
2015-01-26 13:10:30 +02:00
|
|
|
loop.run_until_complete(asyncio.async(project.commit()))
|
2015-01-23 12:28:58 +02:00
|
|
|
assert len(project._vms_to_destroy) == 0
|
|
|
|
assert os.path.exists(directory) is False
|
2015-01-23 15:34:50 +02:00
|
|
|
assert len(project.vms) == 0
|
2015-01-23 12:48:20 +02:00
|
|
|
|
|
|
|
|
2015-01-26 14:54:44 +02:00
|
|
|
def test_commit_permission_issue(manager, loop):
|
|
|
|
project = Project()
|
|
|
|
vm = VPCSVM("test", "00010203-0405-0607-0809-0a0b0c0d0e0f", project, manager)
|
|
|
|
project.add_vm(vm)
|
|
|
|
directory = project.vm_working_directory(vm)
|
|
|
|
project.mark_vm_for_destruction(vm)
|
|
|
|
assert len(project._vms_to_destroy) == 1
|
|
|
|
assert os.path.exists(directory)
|
|
|
|
os.chmod(directory, 0)
|
|
|
|
with pytest.raises(aiohttp.web.HTTPInternalServerError):
|
|
|
|
loop.run_until_complete(asyncio.async(project.commit()))
|
|
|
|
os.chmod(directory, 700)
|
|
|
|
|
|
|
|
|
2015-01-26 13:10:30 +02:00
|
|
|
def test_project_delete(loop):
|
2015-01-23 17:57:41 +02:00
|
|
|
project = Project()
|
2015-01-23 12:48:20 +02:00
|
|
|
directory = project.path
|
|
|
|
assert os.path.exists(directory)
|
2015-01-26 13:10:30 +02:00
|
|
|
loop.run_until_complete(asyncio.async(project.delete()))
|
2015-01-23 12:48:20 +02:00
|
|
|
assert os.path.exists(directory) is False
|
2015-01-23 15:07:10 +02:00
|
|
|
|
|
|
|
|
2015-01-26 14:54:44 +02:00
|
|
|
def test_project_delete_permission_issue(loop):
|
|
|
|
project = Project()
|
|
|
|
directory = project.path
|
|
|
|
assert os.path.exists(directory)
|
|
|
|
os.chmod(directory, 0)
|
|
|
|
with pytest.raises(aiohttp.web.HTTPInternalServerError):
|
|
|
|
loop.run_until_complete(asyncio.async(project.delete()))
|
|
|
|
os.chmod(directory, 700)
|
|
|
|
|
|
|
|
|
2015-01-23 17:57:41 +02:00
|
|
|
def test_project_add_vm(manager):
|
|
|
|
project = Project()
|
2015-01-23 15:07:10 +02:00
|
|
|
vm = VPCSVM("test", "00010203-0405-0607-0809-0a0b0c0d0e0f", project, manager)
|
2015-01-23 15:34:50 +02:00
|
|
|
project.add_vm(vm)
|
2015-01-23 15:07:10 +02:00
|
|
|
assert len(project.vms) == 1
|
|
|
|
|
|
|
|
|
2015-01-26 13:10:30 +02:00
|
|
|
def test_project_close(loop, manager):
|
2015-01-23 17:57:41 +02:00
|
|
|
project = Project()
|
2015-01-23 15:07:10 +02:00
|
|
|
vm = VPCSVM("test", "00010203-0405-0607-0809-0a0b0c0d0e0f", project, manager)
|
|
|
|
project.add_vm(vm)
|
|
|
|
with patch("gns3server.modules.vpcs.vpcs_vm.VPCSVM.close") as mock:
|
2015-01-26 13:10:30 +02:00
|
|
|
loop.run_until_complete(asyncio.async(project.close()))
|
2015-01-23 15:07:10 +02:00
|
|
|
assert mock.called
|
2015-01-23 17:02:26 +02:00
|
|
|
|
|
|
|
|
2015-01-26 13:10:30 +02:00
|
|
|
def test_project_close_temporary_project(loop, manager):
|
2015-01-23 17:02:26 +02:00
|
|
|
"""A temporary project is deleted when closed"""
|
|
|
|
|
2015-01-23 17:57:41 +02:00
|
|
|
project = Project(temporary=True)
|
2015-01-23 17:02:26 +02:00
|
|
|
directory = project.path
|
|
|
|
assert os.path.exists(directory)
|
2015-01-26 13:10:30 +02:00
|
|
|
loop.run_until_complete(asyncio.async(project.close()))
|
2015-01-23 17:02:26 +02:00
|
|
|
assert os.path.exists(directory) is False
|
2015-01-23 18:39:17 +02:00
|
|
|
|
|
|
|
|
|
|
|
def test_get_default_project_directory():
|
|
|
|
|
|
|
|
project = Project()
|
|
|
|
path = os.path.normpath(os.path.expanduser("~/GNS3/projects"))
|
|
|
|
assert project._get_default_project_directory() == path
|
|
|
|
assert os.path.exists(path)
|
2015-02-04 18:18:53 +02:00
|
|
|
|
|
|
|
|
|
|
|
def test_clean_project_directory(tmpdir):
|
|
|
|
|
|
|
|
# A non anonymous project with uuid.
|
|
|
|
project1 = tmpdir / uuid4()
|
|
|
|
project1.mkdir()
|
|
|
|
|
|
|
|
# A non anonymous project.
|
|
|
|
oldproject = tmpdir / uuid4()
|
|
|
|
oldproject.mkdir()
|
|
|
|
|
|
|
|
# an anonymous project
|
|
|
|
project2 = tmpdir / uuid4()
|
|
|
|
project2.mkdir()
|
|
|
|
tmp = (project2 / ".gns3_temporary")
|
|
|
|
with open(str(tmp), 'w+') as f:
|
|
|
|
f.write("1")
|
|
|
|
|
|
|
|
with patch("gns3server.config.Config.get_section_config", return_value={"project_directory": str(tmpdir)}):
|
|
|
|
Project.clean_project_directory()
|
|
|
|
|
|
|
|
assert os.path.exists(str(project1))
|
|
|
|
assert os.path.exists(str(oldproject))
|
|
|
|
assert not os.path.exists(str(project2))
|