forked from openlp/openlp
99 lines
3.7 KiB
Python
99 lines
3.7 KiB
Python
# -*- coding: utf-8 -*-
|
|
|
|
##########################################################################
|
|
# OpenLP - Open Source Lyrics Projection #
|
|
# ---------------------------------------------------------------------- #
|
|
# Copyright (c) 2008-2022 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 <https://www.gnu.org/licenses/>. #
|
|
##########################################################################
|
|
|
|
"""
|
|
Tests for commands that do not need much testing
|
|
"""
|
|
|
|
import logging
|
|
import openlp.core.projectors.pjlinkcommands
|
|
|
|
test_module = openlp.core.projectors.pjlinkcommands.__name__
|
|
_process_lkup = openlp.core.projectors.pjlinkcommands._process_lkup
|
|
_process_srch = openlp.core.projectors.pjlinkcommands._process_srch
|
|
|
|
|
|
def test_lkup_connect(fake_pjlink, settings, caplog):
|
|
"""
|
|
Test LKUP when settings indicate connect
|
|
"""
|
|
# GIVEN: Test setup
|
|
caplog.set_level(logging.DEBUG)
|
|
logs = [(test_module, logging.DEBUG, f'({fake_pjlink.name}) Processing LKUP command')]
|
|
settings.setValue('projector/connect when LKUP received', True)
|
|
|
|
# WHEN: Called
|
|
_process_lkup(projector=fake_pjlink, data=None)
|
|
|
|
# THEN: Only log entry made
|
|
assert caplog.record_tuples == logs, 'Invalid log entries'
|
|
fake_pjlink.connect_to_host.assert_called_once()
|
|
|
|
|
|
def test_lkup_no_connect(fake_pjlink, settings, caplog):
|
|
"""
|
|
Test LKUP when settings indicate no connect
|
|
"""
|
|
# GIVEN: Test setup
|
|
caplog.set_level(logging.DEBUG)
|
|
logs = [(test_module, logging.DEBUG, f'({fake_pjlink.name}) Processing LKUP command')]
|
|
settings.setValue('projector/connect when LKUP received', False)
|
|
|
|
# WHEN: Called
|
|
_process_lkup(projector=fake_pjlink, data=None)
|
|
|
|
# THEN: Only log entry made
|
|
assert caplog.record_tuples == logs, 'Invalid log entries'
|
|
fake_pjlink.connect_to_host.assert_not_called()
|
|
|
|
|
|
def test_srch_no_projector(caplog):
|
|
"""
|
|
Test SRCH command with no projector instance
|
|
"""
|
|
# GIVEN: Test setup
|
|
caplog.set_level(logging.DEBUG)
|
|
logs = [(f'{test_module}', logging.WARNING, 'SRCH packet detected - ignoring')]
|
|
|
|
# WHEN: Called
|
|
t_chk = _process_srch()
|
|
|
|
# THEN: Appropriate return code and log entries
|
|
assert t_chk is None, 'Invalid return code'
|
|
assert caplog.record_tuples == logs, 'Invalid log entries'
|
|
|
|
|
|
def test_srch_with_projector(pjlink, caplog):
|
|
"""
|
|
Test SRCH command with projector
|
|
"""
|
|
# GIVEN: Test setup
|
|
caplog.set_level(logging.DEBUG)
|
|
logs = [(f'{test_module}', logging.WARNING,
|
|
f'({pjlink.entry.name}) SRCH packet detected - ignoring')]
|
|
|
|
# WHEN: Called
|
|
t_chk = _process_srch(projector=pjlink)
|
|
|
|
# THEN: Appropriate return code and log entries
|
|
assert t_chk is None, 'Invalid return code'
|
|
assert caplog.record_tuples == logs, 'Invalid log entries'
|