Test work without vpcs binary

This commit is contained in:
Julien Duponchelle 2015-01-20 22:50:26 +01:00
parent 0eaa7be86a
commit 984d47f9c8
5 changed files with 10 additions and 7 deletions

View File

@ -6,7 +6,7 @@ python:
before_install: before_install:
- sudo add-apt-repository ppa:gns3/ppa -y - sudo add-apt-repository ppa:gns3/ppa -y
- sudo apt-get update -q - sudo apt-get update -q
- sudo apt-get install vpcs dynamips - sudo apt-get install dynamips
install: install:
- python setup.py install - python setup.py install

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": "f598eb3a-67b2-43ab-af37-3c9b1f643cdd" "uuid": "12171ed6-4234-4ba7-9ef5-db3631a3a2e4"
} }

View File

@ -157,7 +157,6 @@ 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,

View File

@ -77,8 +77,6 @@ class VPCSVM(BaseVM):
else: else:
self._console = self._manager.port_manager.get_free_console_port() self._console = self._manager.port_manager.get_free_console_port()
self._check_requirements()
def __del__(self): def __del__(self):
self._kill_process() self._kill_process()
@ -169,6 +167,8 @@ class VPCSVM(BaseVM):
Starts the VPCS process. Starts the VPCS process.
""" """
self._check_requirements()
if not self.is_running(): if not self.is_running():
if not self._ethernet_adapter.get_nio(0): if not self._ethernet_adapter.get_nio(0):
raise VPCSError("This VPCS instance must be connected in order to start") raise VPCSError("This VPCS instance must be connected in order to start")

View File

@ -44,21 +44,24 @@ def test_vm(project, manager):
@patch("subprocess.check_output", return_value="Welcome to Virtual PC Simulator, version 0.1".encode("utf-8")) @patch("subprocess.check_output", return_value="Welcome to Virtual PC Simulator, version 0.1".encode("utf-8"))
def test_vm_invalid_vpcs_version(project, manager): def test_vm_invalid_vpcs_version(project, manager, loop):
with pytest.raises(VPCSError): with pytest.raises(VPCSError):
vm = VPCSVM("test", "00010203-0405-0607-0809-0a0b0c0d0e0f", project, manager) vm = VPCSVM("test", "00010203-0405-0607-0809-0a0b0c0d0e0f", project, manager)
loop.run_until_complete(asyncio.async(vm.start()))
assert vm.name == "test" assert vm.name == "test"
assert vm.uuid == "00010203-0405-0607-0809-0a0b0c0d0e0f" assert vm.uuid == "00010203-0405-0607-0809-0a0b0c0d0e0f"
@patch("gns3server.config.Config.get_section_config", return_value={"path": "/bin/test_fake"}) @patch("gns3server.config.Config.get_section_config", return_value={"path": "/bin/test_fake"})
def test_vm_invalid_vpcs_path(project, manager): def test_vm_invalid_vpcs_path(project, manager, loop):
with pytest.raises(VPCSError): with pytest.raises(VPCSError):
vm = VPCSVM("test", "00010203-0405-0607-0809-0a0b0c0d0e0f", project, manager) vm = VPCSVM("test", "00010203-0405-0607-0809-0a0b0c0d0e0f", project, manager)
loop.run_until_complete(asyncio.async(vm.start()))
assert vm.name == "test" assert vm.name == "test"
assert vm.uuid == "00010203-0405-0607-0809-0a0b0c0d0e0f" assert vm.uuid == "00010203-0405-0607-0809-0a0b0c0d0e0f"
@patch("gns3server.modules.vpcs.vpcs_vm.VPCSVM._check_requirements", return_value=True)
def test_start(project, loop, manager): def test_start(project, loop, manager):
with asyncio_patch("asyncio.create_subprocess_exec", return_value=MagicMock()): with asyncio_patch("asyncio.create_subprocess_exec", return_value=MagicMock()):
vm = VPCSVM("test", "00010203-0405-0607-0809-0a0b0c0d0e0f", project, manager) vm = VPCSVM("test", "00010203-0405-0607-0809-0a0b0c0d0e0f", project, manager)
@ -68,6 +71,7 @@ def test_start(project, loop, manager):
assert vm.is_running() assert vm.is_running()
@patch("gns3server.modules.vpcs.vpcs_vm.VPCSVM._check_requirements", return_value=True)
def test_stop(project, loop, manager): def test_stop(project, loop, manager):
process = MagicMock() process = MagicMock()
with asyncio_patch("asyncio.create_subprocess_exec", return_value=process): with asyncio_patch("asyncio.create_subprocess_exec", return_value=process):