# -*- coding: utf-8 -*- ########################################################################## # OpenLP - Open Source Lyrics Projection # # ---------------------------------------------------------------------- # # Copyright (c) 2008-2020 OpenLP Developers # # ---------------------------------------------------------------------- # # 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 . # ########################################################################## """ This module contains tests for the lib submodule of the Remotes plugin. """ import re from unittest import TestCase from PyQt5 import QtWidgets from openlp.core.api.tab import ApiTab from openlp.core.common import get_network_interfaces from openlp.core.common.registry import Registry from openlp.core.common.settings import Settings from tests.helpers.testmixin import TestMixin __default_settings__ = { 'api/twelve hour': True, 'api/port': 4316, 'api/user id': 'openlp', 'api/password': 'password', 'api/authentication enabled': False, 'api/ip address': '0.0.0.0', 'api/thumbnails': True, 'remotes/download version': '0000_00_00' } ZERO_URL = '0.0.0.0' class TestApiTab(TestCase, TestMixin): """ Test the functions in the :mod:`lib` module. """ def setUp(self): """ Create the UI """ self.setup_application() self.build_settings() Settings().extend_default_settings(__default_settings__) self.parent = QtWidgets.QMainWindow() Registry().create() Registry().set_flag('website_version', '00-00-0000') self.form = ApiTab(self.parent) self.interfaces = get_network_interfaces() def tearDown(self): """ Delete all the C++ objects at the end so that we don't have a segfault """ del self.parent del self.form self.destroy_settings() def test_get_ip_address_default(self): """ Test the get_ip_address function with ZERO_URL """ # GIVEN: list of local IP addresses for this machine ip_addresses = [] for _, interface in self.interfaces.items(): ip_addresses.append(interface['ip']) # WHEN: the default ip address is given ip_address = self.form.get_ip_address(ZERO_URL) # THEN: the default ip address will be returned assert re.match(r'\d{1,3}\.\d{1,3}\.\d{1,3}\.\d{1,3}', ip_address), \ 'The return value should be a valid ip address' assert ip_address in ip_addresses, 'The return address should be in the list of local IP addresses' def test_get_ip_address_with_ip(self): """ Test the get_ip_address function with given ip address """ # GIVEN: An ip address given_ip = '192.168.1.1' # WHEN: the default ip address is given ip_address = self.form.get_ip_address(given_ip) # THEN: the default ip address will be returned assert ip_address == given_ip, 'The return value should be %s' % given_ip def test_set_urls(self): """ Test the set_url function to generate correct url links """ # GIVEN: An ip address self.form.address_edit.setText('192.168.1.1') # WHEN: the urls are generated self.form.set_urls() # THEN: the following links are returned assert self.form.remote_url.text() == "http://192.168.1.1:4316/", \ 'The return value should be a fully formed link' assert self.form.stage_url.text() == \ "http://192.168.1.1:4316/stage", \ 'The return value should be a fully formed stage link' assert self.form.live_url.text() == \ "http://192.168.1.1:4316/main", \ 'The return value should be a fully formed main link'