1
0
mirror of https://github.com/GNS3/gns3-server synced 2025-01-07 06:30:56 +00:00
gns3-server/tests/controller/test_link.py

119 lines
3.2 KiB
Python
Raw Normal View History

2016-03-11 15:51:35 +00:00
#!/usr/bin/env python
#
# Copyright (C) 2016 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
2016-03-11 15:51:35 +00:00
import pytest
import asyncio
from unittest.mock import MagicMock
2016-03-11 15:51:35 +00:00
2016-03-11 15:51:35 +00:00
from gns3server.controller.link import Link
from gns3server.controller.node import Node
2016-04-15 15:57:06 +00:00
from gns3server.controller.compute import Compute
2016-03-11 15:51:35 +00:00
from gns3server.controller.project import Project
from tests.utils import AsyncioBytesIO
2016-03-11 15:51:35 +00:00
@pytest.fixture
def project():
return Project()
@pytest.fixture
2016-04-15 15:57:06 +00:00
def compute():
return Compute("example.com", controller=MagicMock())
2016-03-11 15:51:35 +00:00
@pytest.fixture
def link(async_run, project, compute):
node1 = Node(project, compute)
node2 = Node(project, compute)
link = Link(project)
async_run(link.add_node(node1, 0, 4))
async_run(link.add_node(node2, 1, 3))
return link
def test_addNode(async_run, project, compute):
node1 = Node(project, compute)
2016-03-11 15:51:35 +00:00
link = Link(project)
async_run(link.add_node(node1, 0, 4))
assert link._nodes == [
2016-03-11 15:51:35 +00:00
{
"node": node1,
2016-03-11 15:51:35 +00:00
"adapter_number": 0,
"port_number": 4
}
]
2016-04-15 15:57:06 +00:00
def test_json(async_run, project, compute):
node1 = Node(project, compute)
node2 = Node(project, compute)
2016-03-11 15:51:35 +00:00
link = Link(project)
async_run(link.add_node(node1, 0, 4))
async_run(link.add_node(node2, 1, 3))
2016-03-11 15:51:35 +00:00
assert link.__json__() == {
"link_id": link.id,
"nodes": [
2016-03-11 15:51:35 +00:00
{
"node_id": node1.id,
2016-03-11 15:51:35 +00:00
"adapter_number": 0,
"port_number": 4
},
{
"node_id": node2.id,
2016-03-11 15:51:35 +00:00
"adapter_number": 1,
"port_number": 3
}
],
"capturing": False,
2016-04-26 15:36:24 +00:00
"capture_file_name": None,
"capture_file_path": None
2016-03-11 15:51:35 +00:00
}
def test_start_streaming_pcap(link, async_run, tmpdir, project):
@asyncio.coroutine
def fake_reader():
output = AsyncioBytesIO()
yield from output.write(b"hello")
output.seek(0)
return output
link._capture_file_name = "test.pcap"
link._capturing = True
link.read_pcap_from_source = fake_reader
async_run(link._start_streaming_pcap())
with open(os.path.join(project.captures_directory, "test.pcap"), "rb") as f:
c = f.read()
assert c == b"hello"
def test_default_capture_file_name(project, compute, async_run):
node1 = Node(project, compute, name="Hello@")
node2 = Node(project, compute, name="w0.rld")
link = Link(project)
async_run(link.add_node(node1, 0, 4))
async_run(link.add_node(node2, 1, 3))
assert link.default_capture_file_name() == "Hello_0-4_to_w0rld_1-3.pcap"