← Back to team overview

openlp-core team mailing list archive

[Merge] lp:~alisonken1/openlp/pjlink2-v05 into lp:openlp

 

Ken Roberts has proposed merging lp:~alisonken1/openlp/pjlink2-v05 into lp:openlp with lp:~alisonken1/openlp/pjlink2_v04 as a prerequisite.

Commit message:
PJLink2 Update v05

Requested reviews:
  OpenLP Core (openlp-core)

For more details, see:
https://code.launchpad.net/~alisonken1/openlp/pjlink2-v05/+merge/366947

NOTE: Part 5 of a multi-part merge.
      v[1..n] merges are to fix tests

NOTE: Large diff due to test refactoring into multiple files

- Move PJLink ERR[1234A] tests
    from test_projector_pjlink_cmd_routing
    to test_projector_command_routing
- Rename file
    from tests/openlp_core/projectors/test_projector_pjlink_commands_01.py
    to test/openlp_core/test_projector_commands_01.py

- Split test_projector_command_01 into 2 parts to manage tests easier:
    test_projector_commands_01: PJLink get status part 1
    test_projector_commands_02: PJLink get status part 2

- Added set_audio_muted() and set_audio_normal() methods to PJLink class
- Refactor/fix tests test_projector_commands_01

--------------------------------------------------------------------------------
lp:~alisonken1/openlp/pjlink2-v05 (revision 2866)
https://ci.openlp.io/job/Branch-01-Pull/2731/                          [SUCCESS]
https://ci.openlp.io/job/Branch-02a-Linux-Tests/2625/                  [SUCCESS]
https://ci.openlp.io/job/Branch-02b-macOS-Tests/400/                   [SUCCESS]
https://ci.openlp.io/job/Branch-03a-Build-Source/222/                  [SUCCESS]
https://ci.openlp.io/job/Branch-03b-Build-macOS/201/                   [SUCCESS]
https://ci.openlp.io/job/Branch-04a-Code-Lint/1684/                    [SUCCESS]
https://ci.openlp.io/job/Branch-04b-Test-Coverage/1497/                [SUCCESS]
https://ci.openlp.io/job/Branch-05-AppVeyor-Tests/376/                 [SUCCESS]

All builds passed

-- 
Your team OpenLP Core is requested to review the proposed merge of lp:~alisonken1/openlp/pjlink2-v05 into lp:openlp.
=== modified file 'openlp/core/projectors/pjlink.py'
--- openlp/core/projectors/pjlink.py	2019-05-04 10:29:17 +0000
+++ openlp/core/projectors/pjlink.py	2019-05-04 10:29:17 +0000
@@ -861,6 +861,24 @@
         log.debug('({ip}) Sending POWR command'.format(ip=self.entry.name))
         return self.send_command(cmd='POWR', priority=priority)
 
+    def set_audio_mute(self, priority=False):
+        """
+        Send command to set audio to muted
+        """
+        log.debug('({ip}) Setting AVMT to 21 (audio mute)'.format(ip=self.entry.name))
+        self.send_command(cmd='AVMT', opts='21', priority=True)
+        self.status_timer_add(cmd='AVMT', callback=self.get_av_mute_status)
+        self.poll_loop()
+
+    def set_audio_normal(self, priority=False):
+        """
+        Send command to set audio to normal
+        """
+        log.debug('({ip}) Setting AVMT to 20 (audio normal)'.format(ip=self.entry.name))
+        self.send_command(cmd='AVMT', opts='20', priority=True)
+        self.status_timer_add(cmd='AVMT', callback=self.get_av_mute_status)
+        self.poll_loop()
+
     def set_input_source(self, src=None):
         """
         Verify input source available as listed in 'INST' command,
@@ -924,9 +942,9 @@
             log.warning('({ip}) "{cmd}" already in checks - returning'.format(ip=self.entry.name, cmd=cmd))
             return
         log.debug('({ip}) Adding "{cmd}" callback for status timer'.format(ip=self.entry.name, cmd=cmd))
+        self.status_timer_checks[cmd] = callback
         if not self.status_timer.isActive():
             self.status_timer.start()
-        self.status_timer_checks[cmd] = callback
 
     def status_timer_delete(self, cmd):
         """

=== modified file 'openlp/core/projectors/pjlinkcommands.py'
--- openlp/core/projectors/pjlinkcommands.py	2019-05-04 10:29:17 +0000
+++ openlp/core/projectors/pjlinkcommands.py	2019-05-04 10:29:17 +0000
@@ -113,15 +113,21 @@
                 '31': {'shutter': True, 'mute': True}
                 }
     if data not in settings:
-        log.warning('({ip}) Invalid shutter response: {data}'.format(ip=projector.entry.name, data=data))
+        log.warning('({ip}) Invalid av mute response: {data}'.format(ip=projector.entry.name, data=data))
         return
     shutter = settings[data]['shutter']
     mute = settings[data]['mute']
     # Check if we need to update the icons
     update_icons = (shutter != projector.shutter) or (mute != projector.mute)
-    projector.shutter = shutter
-    projector.mute = mute
     if update_icons:
+        if projector.shutter != shutter:
+            projector.shutter = shutter
+            log.debug('({ip}) Setting shutter to {chk}'.format(ip=projector.entry.name,
+                                                               chk='closed' if shutter else 'open'))
+        if projector.mute != mute:
+            projector.mute = mute
+            log.debug('({ip}) Setting speaker to {chk}'.format(ip=projector.entry.name,
+                                                               chk='muted' if shutter else 'normal'))
         if 'AVMT' in projector.status_timer_checks:
             projector.status_timer_delete('AVMT')
         projector.projectorUpdateIcons.emit()

=== modified file 'tests/openlp_core/projectors/test_projector_command_routing.py'
--- tests/openlp_core/projectors/test_projector_command_routing.py	2019-05-04 10:29:17 +0000
+++ tests/openlp_core/projectors/test_projector_command_routing.py	2019-05-04 10:29:17 +0000
@@ -28,7 +28,8 @@
 
 import openlp.core.projectors.pjlink
 from openlp.core.projectors.pjlinkcommands import process_command
-from openlp.core.projectors.constants import E_UNDEFINED, S_DATA_OK
+from openlp.core.projectors.constants import E_AUTHENTICATION, E_PARAMETER, E_PROJECTOR, E_UNAVAILABLE, E_UNDEFINED, \
+    S_DATA_OK, PJLINK_ERRORS, STATUS_MSG
 from openlp.core.projectors.db import Projector
 from openlp.core.projectors.pjlink import PJLink
 from tests.resources.projector.data import TEST1_DATA
@@ -114,19 +115,111 @@
         assert (chk == S_DATA_OK), 'Should have returned S_DATA_OK'
 
     @patch.object(openlp.core.projectors.pjlinkcommands, 'log')
-    def test_routing_pjink_errors(self, mock_log):
+    def test_routing_pjink_err1(self, mock_log):
         """
-        Test rouing when PJLink error received (err1, err2, err3, err4, erra)
+        Test rouing when PJLink ERR1 received
         """
         # GIVEN: Test setup
-        log_error_text = [call('({ip}) CLSS: PJLink returned "ERR1: Undefined Command"'.format(ip=self.pjlink.name))]
-        log_debug_text = [call('({ip}) Processing command "CLSS" with data "ERR1"'.format(ip=self.pjlink.name))]
         err_code = E_UNDEFINED
-
-        # WHEN: routing called
-        chk = process_command(projector=self.pjlink, cmd='CLSS', data='ERR1')
-
-        # THEN: Appropriate log entries should have been made and methods called/not called
-        mock_log.error.assert_has_calls(log_error_text)
-        mock_log.debug.assert_has_calls(log_debug_text)
-        assert (chk == err_code), 'Should have returned E_UNDEFINED'
+        err_msg = STATUS_MSG[err_code]
+        err_str = PJLINK_ERRORS[err_code]
+
+        log_error_text = [call('({ip}) CLSS: {err}'.format(ip=self.pjlink.name, err=err_msg))]
+        log_debug_text = [call('({ip}) Processing command "CLSS" with data "{err}"'.format(ip=self.pjlink.name,
+                                                                                           err=err_str))]
+
+        # WHEN: routing called
+        chk = process_command(projector=self.pjlink, cmd='CLSS', data=err_str)
+
+        # THEN: Appropriate log entries should have been made and methods called/not called
+        mock_log.error.assert_has_calls(log_error_text)
+        mock_log.debug.assert_has_calls(log_debug_text)
+        assert (chk == err_code), 'Should have returned {err}'.format(err=PJLINK_ERRORS[err_code])
+
+    @patch.object(openlp.core.projectors.pjlinkcommands, 'log')
+    def test_routing_pjink_err2(self, mock_log):
+        """
+        Test rouing when PJLink ERR2 received
+        """
+        # GIVEN: Test setup
+        err_code = E_PARAMETER
+        err_msg = STATUS_MSG[err_code]
+        err_str = PJLINK_ERRORS[err_code]
+
+        log_error_text = [call('({ip}) CLSS: {err}'.format(ip=self.pjlink.name, err=err_msg))]
+        log_debug_text = [call('({ip}) Processing command "CLSS" with data "{err}"'.format(ip=self.pjlink.name,
+                                                                                           err=err_str))]
+
+        # WHEN: routing called
+        chk = process_command(projector=self.pjlink, cmd='CLSS', data=err_str)
+
+        # THEN: Appropriate log entries should have been made and methods called/not called
+        mock_log.error.assert_has_calls(log_error_text)
+        mock_log.debug.assert_has_calls(log_debug_text)
+        assert (chk == err_code), 'Should have returned {err}'.format(err=PJLINK_ERRORS[err_code])
+
+    @patch.object(openlp.core.projectors.pjlinkcommands, 'log')
+    def test_routing_pjink_err3(self, mock_log):
+        """
+        Test rouing when PJLink ERR3 received
+        """
+        # GIVEN: Test setup
+        err_code = E_UNAVAILABLE
+        err_msg = STATUS_MSG[err_code]
+        err_str = PJLINK_ERRORS[err_code]
+
+        log_error_text = [call('({ip}) CLSS: {err}'.format(ip=self.pjlink.name, err=err_msg))]
+        log_debug_text = [call('({ip}) Processing command "CLSS" with data "{err}"'.format(ip=self.pjlink.name,
+                                                                                           err=err_str))]
+
+        # WHEN: routing called
+        chk = process_command(projector=self.pjlink, cmd='CLSS', data=err_str)
+
+        # THEN: Appropriate log entries should have been made and methods called/not called
+        mock_log.error.assert_has_calls(log_error_text)
+        mock_log.debug.assert_has_calls(log_debug_text)
+        assert (chk == err_code), 'Should have returned {err}'.format(err=PJLINK_ERRORS[err_code])
+
+    @patch.object(openlp.core.projectors.pjlinkcommands, 'log')
+    def test_routing_pjink_err4(self, mock_log):
+        """
+        Test rouing when PJLink ERR4 received
+        """
+        # GIVEN: Test setup
+        err_code = E_PROJECTOR
+        err_msg = STATUS_MSG[err_code]
+        err_str = PJLINK_ERRORS[err_code]
+
+        log_error_text = [call('({ip}) CLSS: {err}'.format(ip=self.pjlink.name, err=err_msg))]
+        log_debug_text = [call('({ip}) Processing command "CLSS" with data "{err}"'.format(ip=self.pjlink.name,
+                                                                                           err=err_str))]
+
+        # WHEN: routing called
+        chk = process_command(projector=self.pjlink, cmd='CLSS', data=err_str)
+
+        # THEN: Appropriate log entries should have been made and methods called/not called
+        mock_log.error.assert_has_calls(log_error_text)
+        mock_log.debug.assert_has_calls(log_debug_text)
+        assert (chk == err_code), 'Should have returned {err}'.format(err=PJLINK_ERRORS[err_code])
+
+    @patch.object(openlp.core.projectors.pjlinkcommands, 'log')
+    def test_routing_pjink_errA(self, mock_log):
+        """
+        Test rouing when PJLink ERRA received
+        """
+        # GIVEN: Test setup
+        err_code = E_AUTHENTICATION
+        err_msg = STATUS_MSG[err_code]
+        err_str = PJLINK_ERRORS[err_code]
+
+        log_error_text = [call('({ip}) CLSS: {err}'.format(ip=self.pjlink.name, err=err_msg))]
+        log_debug_text = [call('({ip}) Processing command "CLSS" with data "{err}"'.format(ip=self.pjlink.name,
+                                                                                           err=err_str))]
+
+        # WHEN: routing called
+        chk = process_command(projector=self.pjlink, cmd='CLSS', data=err_str)
+
+        # THEN: Appropriate log entries should have been made and methods called/not called
+        mock_log.error.assert_has_calls(log_error_text)
+        mock_log.debug.assert_has_calls(log_debug_text)
+        assert (chk == err_code), 'Should have returned {err}'.format(err=PJLINK_ERRORS[err_code])

=== renamed file 'tests/openlp_core/projectors/test_projector_pjlink_commands_01.py' => 'tests/openlp_core/projectors/test_projector_commands_01.py'
--- tests/openlp_core/projectors/test_projector_pjlink_commands_01.py	2019-04-28 19:21:23 +0000
+++ tests/openlp_core/projectors/test_projector_commands_01.py	2019-05-04 10:29:17 +0000
@@ -22,12 +22,12 @@
 """
 Package to test the openlp.core.projectors.pjlink commands package.
 """
-from unittest import TestCase, skip
+from unittest import TestCase
 from unittest.mock import call, patch
 
 import openlp.core.projectors.pjlink
-from openlp.core.projectors.constants import E_ERROR, E_WARN, PJLINK_ERST_DATA, PJLINK_ERST_STATUS, \
-    PJLINK_POWR_STATUS, S_NOT_CONNECTED, S_OK, S_ON, S_STANDBY, STATUS_CODE
+from openlp.core.projectors.pjlinkcommands import process_command
+from openlp.core.projectors.constants import E_ERROR, E_WARN, PJLINK_ERST_DATA, PJLINK_ERST_STATUS, S_OK
 from openlp.core.projectors.db import Projector
 from openlp.core.projectors.pjlink import PJLink
 from tests.resources.projector.data import TEST1_DATA
@@ -35,320 +35,349 @@
 
 class TestPJLinkCommands(TestCase):
     """
-    Tests for the PJLinkCommands class part 1
+    Tests PJLink get status commands part 1
     """
-    @skip('Needs update to new setup')
-    def test_projector_process_inf1(self):
-        """
-        Test saving INF1 data (manufacturer)
-        """
-        test_data = 'TEst INformation MultiCase'
-
-        # GIVEN: Test object
-        pjlink = PJLink(Projector(**TEST1_DATA), no_poll=True)
-        pjlink.manufacturer = None
-
-        # WHEN: process_inf called with test data
-        pjlink.process_inf1(data=test_data)
-
-        # THEN: Data should be saved
-        assert pjlink.manufacturer == test_data, 'Test data should have been saved'
-
-    @skip('Needs update to new setup')
-    def test_projector_process_inf2(self):
-        """
-        Test saving INF2 data (model)
-        """
-        test_data = 'TEst moDEl MultiCase'
-
-        # GIVEN: Test object
-        pjlink = PJLink(Projector(**TEST1_DATA), no_poll=True)
-        pjlink.model = None
-
-        # WHEN: process_inf called with test data
-        pjlink.process_inf2(data=test_data)
-
-        # THEN: Data should be saved
-        assert pjlink.model == test_data, 'Test data should have been saved'
-
-    @skip('Needs update to new setup')
-    def test_projector_process_info(self):
-        """
-        Test saving INFO data (other information)
-        """
-        test_data = 'TEst ExtrANEous MultiCase INformatoin that MFGR might Set'
-
-        # GIVEN: Test object
-        pjlink = PJLink(Projector(**TEST1_DATA), no_poll=True)
-        pjlink.other_info = None
-
-        # WHEN: process_inf called with test data
-        pjlink.process_info(data=test_data)
-
-        # THEN: Data should be saved
-        assert pjlink.other_info == test_data, 'Test data should have been saved'
-
-    @skip('Needs update to new setup')
-    def test_projector_process_avmt_bad_data(self):
+    def setUp(self):
+        """
+        Initial test setup
+        """
+        self.pjlink = PJLink(Projector(**TEST1_DATA), no_poll=True)
+
+    def tearDown(self):
+        """
+        Test reset
+        """
+        del(self.pjlink)
+
+    @patch.object(openlp.core.projectors.pjlink.PJLink, 'projectorUpdateIcons')
+    @patch.object(openlp.core.projectors.pjlinkcommands, 'log')
+    def test_projector_avmt_audio_muted(self, mock_log, mock_UpdateIcons):
+        """
+        Test avmt status shutter unchanged and mute on
+        """
+        # GIVEN: Test setup
+        log_warning_text = []
+        log_debug_text = [call('({ip}) Processing command "AVMT" with data "21"'.format(ip=self.pjlink.name)),
+                          call('({ip}) Calling function for AVMT'.format(ip=self.pjlink.name)),
+                          call('({ip}) Setting speaker to muted'.format(ip=self.pjlink.name))]
+        self.pjlink.shutter = True
+        self.pjlink.mute = False
+
+        # WHEN: Called with setting shutter closed and mute on
+        process_command(projector=self.pjlink, cmd='AVMT', data='21')
+
+        # THEN: Shutter should be closed and mute should be True
+        assert self.pjlink.shutter, 'Shutter should not have changed'
+        assert self.pjlink.mute, 'Audio should be off'
+        assert mock_UpdateIcons.emit.called, 'Update icons should have been called'
+        mock_log.warning.assert_has_calls(log_warning_text)
+        mock_log.debug.assert_has_calls(log_debug_text)
+
+    @patch.object(openlp.core.projectors.pjlink.PJLink, 'projectorUpdateIcons')
+    @patch.object(openlp.core.projectors.pjlinkcommands, 'log')
+    def test_projector_avmt_bad_data(self, mock_log, mock_UpdateIcons):
         """
         Test avmt bad data fail
         """
         # GIVEN: Test object
-        with patch.object(openlp.core.projectors.pjlink.PJLink, 'projectorUpdateIcons') as mock_UpdateIcons:
-            pjlink = PJLink(Projector(**TEST1_DATA), no_poll=True)
-            pjlink.shutter = True
-            pjlink.mute = True
-
-            # WHEN: Called with an invalid setting
-            pjlink.process_avmt('36')
-
-            # THEN: Shutter should be closed and mute should be True
-            assert pjlink.shutter is True, 'Shutter should changed'
-            assert pjlink.mute is True, 'Audio should not have changed'
-            assert mock_UpdateIcons.emit.called is False, 'Update icons should NOT have been called'
-
-    @skip('Needs update to new setup')
-    def test_projector_process_avmt_closed_muted(self):
+        log_warning_text = [call('({ip}) Invalid av mute response: 36'.format(ip=self.pjlink.name))]
+        log_debug_text = [call('({ip}) Processing command "AVMT" with data "36"'.format(ip=self.pjlink.name)),
+                          call('({ip}) Calling function for AVMT'.format(ip=self.pjlink.name))]
+        self.pjlink.shutter = True
+        self.pjlink.mute = True
+
+        # WHEN: Called with an invalid setting
+        process_command(projector=self.pjlink, cmd='AVMT', data='36')
+
+        # THEN: Shutter should be closed and mute should be True
+        assert self.pjlink.shutter, 'Shutter should changed'
+        assert self.pjlink.mute, 'Audio should not have changed'
+        assert (not mock_UpdateIcons.emit.called), 'Update icons should NOT have been called'
+        mock_log.warning.assert_has_calls(log_warning_text)
+        mock_log.debug.assert_has_calls(log_debug_text)
+
+    @patch.object(openlp.core.projectors.pjlink.PJLink, 'projectorUpdateIcons')
+    @patch.object(openlp.core.projectors.pjlinkcommands, 'log')
+    def test_projector_avmt_closed_muted(self, mock_log, mock_UpdateIcons):
         """
         Test avmt status shutter closed and mute off
         """
         # GIVEN: Test object
-        with patch.object(openlp.core.projectors.pjlink.PJLink, 'projectorUpdateIcons') as mock_UpdateIcons:
-            pjlink = PJLink(Projector(**TEST1_DATA), no_poll=True)
-            pjlink.shutter = False
-            pjlink.mute = False
-
-            # WHEN: Called with setting shutter to closed and mute on
-            pjlink.process_avmt('31')
-
-            # THEN: Shutter should be closed and mute should be True
-            assert pjlink.shutter is True, 'Shutter should have been set to closed'
-            assert pjlink.mute is True, 'Audio should be muted'
-            assert mock_UpdateIcons.emit.called is True, 'Update icons should have been called'
-
-    @skip('Needs update to new setup')
-    def test_projector_process_avmt_shutter_closed(self):
+        log_warning_text = []
+        log_debug_text = [call('({ip}) Processing command "AVMT" with data "31"'.format(ip=self.pjlink.name)),
+                          call('({ip}) Calling function for AVMT'.format(ip=self.pjlink.name)),
+                          call('({ip}) Setting shutter to closed'.format(ip=self.pjlink.name)),
+                          call('({ip}) Setting speaker to muted'.format(ip=self.pjlink.name))]
+        self.pjlink.shutter = False
+        self.pjlink.mute = False
+
+        # WHEN: Called with setting shutter to closed and mute on
+        process_command(projector=self.pjlink, cmd='AVMT', data='31')
+
+        # THEN: Shutter should be closed and mute should be True
+        assert self.pjlink.shutter, 'Shutter should have been set to closed'
+        assert self.pjlink.mute, 'Audio should be muted'
+        assert mock_UpdateIcons.emit.called, 'Update icons should have been called'
+        mock_log.warning.assert_has_calls(log_warning_text)
+        mock_log.debug.assert_has_calls(log_debug_text)
+
+    @patch.object(openlp.core.projectors.pjlink.PJLink, 'projectorUpdateIcons')
+    @patch.object(openlp.core.projectors.pjlinkcommands, 'log')
+    def test_projector_avmt_open_unmuted(self, mock_log, mock_UpdateIcons):
+        """
+        Test avmt status shutter open and mute off
+        """
+        # GIVEN: Test object
+        log_warning_text = []
+        log_debug_text = [call('({ip}) Processing command "AVMT" with data "30"'.format(ip=self.pjlink.name)),
+                          call('({ip}) Calling function for AVMT'.format(ip=self.pjlink.name)),
+                          call('({ip}) Setting shutter to open'.format(ip=self.pjlink.name)),
+                          call('({ip}) Setting speaker to normal'.format(ip=self.pjlink.name))]
+        self.pjlink.shutter = True
+        self.pjlink.mute = True
+
+        # WHEN: Called with setting shutter to closed and mute on
+        process_command(projector=self.pjlink, cmd='AVMT', data='30')
+
+        # THEN: Shutter should be closed and mute should be True
+        assert (not self.pjlink.shutter), 'Shutter should have been set to off'
+        assert (not self.pjlink.mute), 'Audio should be on'
+        assert mock_UpdateIcons.emit.called, 'Update icons should have been called'
+        mock_log.warning.assert_has_calls(log_warning_text)
+        mock_log.debug.assert_has_calls(log_debug_text)
+
+    @patch.object(openlp.core.projectors.pjlink.PJLink, 'projectorUpdateIcons')
+    @patch.object(openlp.core.projectors.pjlinkcommands, 'log')
+    def test_projector_avmt_shutter_closed(self, mock_log, mock_UpdateIcons):
         """
         Test avmt status shutter closed and audio unchanged
         """
         # GIVEN: Test object
-        with patch.object(openlp.core.projectors.pjlink.PJLink, 'projectorUpdateIcons') as mock_UpdateIcons:
-            pjlink = PJLink(Projector(**TEST1_DATA), no_poll=True)
-            pjlink.shutter = False
-            pjlink.mute = True
-
-            # WHEN: Called with setting shutter closed and mute off
-            pjlink.process_avmt('11')
+        log_warning_text = []
+        log_debug_text = [call('({ip}) Processing command "AVMT" with data "11"'.format(ip=self.pjlink.name)),
+                          call('({ip}) Calling function for AVMT'.format(ip=self.pjlink.name)),
+                          call('({ip}) Setting shutter to closed'.format(ip=self.pjlink.name))]
+        self.pjlink.shutter = False
+        self.pjlink.mute = True
+
+        # WHEN: Called with setting shutter closed and mute off
+        process_command(projector=self.pjlink, cmd='AVMT', data='11')
+
+        # THEN: Shutter should be True and mute should be False
+        assert self.pjlink.shutter, 'Shutter should have been set to closed'
+        assert self.pjlink.mute, 'Audio should not have changed'
+        assert mock_UpdateIcons.emit.called, 'Update icons should have been called'
+        mock_log.warning.assert_has_calls(log_warning_text)
+        mock_log.debug.assert_has_calls(log_debug_text)
+
+    @patch.object(openlp.core.projectors.pjlink.PJLink, 'projectorUpdateIcons')
+    @patch.object(openlp.core.projectors.pjlinkcommands, 'log')
+    def test_projector_avmt_status_timer_check_delete(self, mock_log, mock_UpdateIcons):
+        """
+        Test avmt deletes callback in projector.status_timer_check
+        """
+        # GIVEN: Test object
+        log_warning_text = []
+        log_debug_text = [call('({ip}) Processing command "AVMT" with data "11"'.format(ip=self.pjlink.name)),
+                          call('({ip}) Calling function for AVMT'.format(ip=self.pjlink.name)),
+                          call('({ip}) Setting shutter to closed'.format(ip=self.pjlink.name))]
+        self.pjlink.shutter = False
+        self.pjlink.mute = True
+        self.pjlink.status_timer_checks = {'AVMT': self.pjlink.get_av_mute_status}
+
+        # WHEN: Called with setting shutter closed and mute off
+        with patch.object(self.pjlink, 'status_timer') as mock_status_timer:
+            process_command(projector=self.pjlink, cmd='AVMT', data='11')
 
             # THEN: Shutter should be True and mute should be False
-            assert pjlink.shutter is True, 'Shutter should have been set to closed'
-            assert pjlink.mute is True, 'Audio should not have changed'
-            assert mock_UpdateIcons.emit.called is True, 'Update icons should have been called'
-
-    @skip('Needs update to new setup')
-    def test_projector_process_avmt_audio_muted(self):
-        """
-        Test avmt status shutter unchanged and mute on
-        """
-        # GIVEN: Test object
-        with patch.object(openlp.core.projectors.pjlink.PJLink, 'projectorUpdateIcons') as mock_UpdateIcons:
-            pjlink = PJLink(Projector(**TEST1_DATA), no_poll=True)
-            pjlink.shutter = True
-            pjlink.mute = False
-
-            # WHEN: Called with setting shutter closed and mute on
-            pjlink.process_avmt('21')
-
-            # THEN: Shutter should be closed and mute should be True
-            assert pjlink.shutter is True, 'Shutter should not have changed'
-            assert pjlink.mute is True, 'Audio should be off'
-            assert mock_UpdateIcons.emit.called is True, 'Update icons should have been called'
-
-    @skip('Needs update to new setup')
-    def test_projector_process_avmt_open_unmuted(self):
-        """
-        Test avmt status shutter open and mute off
-        """
-        # GIVEN: Test object
-        with patch.object(openlp.core.projectors.pjlink.PJLink, 'projectorUpdateIcons') as mock_UpdateIcons:
-            pjlink = PJLink(Projector(**TEST1_DATA), no_poll=True)
-            pjlink.shutter = True
-            pjlink.mute = True
-
-            # WHEN: Called with setting shutter to closed and mute on
-            pjlink.process_avmt('30')
-
-            # THEN: Shutter should be closed and mute should be True
-            assert pjlink.shutter is False, 'Shutter should have been set to open'
-            assert pjlink.mute is False, 'Audio should be on'
-            assert mock_UpdateIcons.emit.called is True, 'Update icons should have been called'
-
-    @skip('Needs update to new setup')
-    def test_projector_process_clss_one(self):
-        """
-        Test class 1 sent from projector
-        """
-        # GIVEN: Test object
-        pjlink = PJLink(Projector(**TEST1_DATA), no_poll=True)
-
-        # WHEN: Process class response
-        pjlink.process_clss('1')
-
-        # THEN: Projector class should be set to 1
-        assert pjlink.pjlink_class == '1', 'Projector should have set class=1'
-
-    @skip('Needs update to new setup')
-    def test_projector_process_clss_two(self):
-        """
-        Test class 2 sent from projector
-        """
-        # GIVEN: Test object
-        pjlink = PJLink(Projector(**TEST1_DATA), no_poll=True)
-
-        # WHEN: Process class response
-        pjlink.process_clss('2')
-
-        # THEN: Projector class should be set to 1
-        assert pjlink.pjlink_class == '2', 'Projector should have set class=2'
-
-    @skip('Needs update to new setup')
-    def test_projector_process_clss_invalid_nan(self):
-        """
-        Test CLSS reply has no class number
-        """
-        # GIVEN: Test object
-        with patch.object(openlp.core.projectors.pjlink, 'log') as mock_log:
-            pjlink = PJLink(Projector(**TEST1_DATA), no_poll=True)
-            log_debug_calls = [call('({ip}) reset_information() connect status is '
-                                    '{state}'.format(ip=pjlink.name, state=STATUS_CODE[S_NOT_CONNECTED])),
-                               call('({ip}) Setting pjlink_class for this projector to "1"'.format(ip=pjlink.name))]
-            log_error_calls = [call('({ip}) NAN CLSS version reply "Z" - '
-                                    'defaulting to class "1"'.format(ip=pjlink.name))]
-
-            # WHEN: Process invalid reply
-            pjlink.process_clss('Z')
-
-            # THEN: Projector class should be set with default value
-            assert pjlink.pjlink_class == '1', 'Invalid NaN class reply should have set class=1'
-            mock_log.error.assert_has_calls(log_error_calls)
-            mock_log.debug.assert_has_calls(log_debug_calls)
-
-    @skip('Needs update to new setup')
-    def test_projector_process_clss_invalid_no_version(self):
-        """
-        Test CLSS reply has no class number
-        """
-        # GIVEN: Test object
-        with patch.object(openlp.core.projectors.pjlink, 'log') as mock_log:
-            pjlink = PJLink(Projector(**TEST1_DATA), no_poll=True)
-            log_debug_calls = [call('({ip}) reset_information() connect status is '
-                                    '{state}'.format(ip=pjlink.name, state=STATUS_CODE[S_NOT_CONNECTED])),
-                               call('({ip}) Setting pjlink_class for this projector to "1"'.format(ip=pjlink.name))]
-            log_error_calls = [call('({ip}) No numbers found in class version reply "Invalid" '
-                                    '- defaulting to class "1"'.format(ip=pjlink.name))]
-
-            # WHEN: Process invalid reply
-            pjlink.process_clss('Invalid')
-
-            # THEN: Projector class should be set with default value
-            assert pjlink.pjlink_class == '1', 'Invalid class reply should have set class=1'
-            mock_log.error.assert_has_calls(log_error_calls)
-            mock_log.debug.assert_has_calls(log_debug_calls)
-
-    @skip('Needs update to new setup')
-    def test_projector_process_clss_nonstandard_reply_1(self):
-        """
-        Test CLSS request returns non-standard reply 1
-        """
-        # GIVEN: Test object
-        pjlink = PJLink(Projector(**TEST1_DATA), no_poll=True)
-
-        # WHEN: Process non-standard reply
-        pjlink.process_clss('Class 1')
-
-        # THEN: Projector class should be set with proper value
-        assert '1' == pjlink.pjlink_class, 'Non-standard class reply should have set class=1'
-
-    @skip('Needs update to new setup')
-    def test_projector_process_clss_nonstandard_reply_2(self):
-        """
-        Test CLSS request returns non-standard reply 2
-        """
-        # GIVEN: Test object
-        pjlink = PJLink(Projector(**TEST1_DATA), no_poll=True)
-
-        # WHEN: Process non-standard reply
-        pjlink.process_clss('Version2')
-
-        # THEN: Projector class should be set with proper value
-        assert '2' == pjlink.pjlink_class, 'Non-standard class reply should have set class=2'
-
-    @skip('Needs update to new setup')
-    def test_projector_process_erst_all_ok(self):
+            assert self.pjlink.shutter, 'Shutter should have been set to closed'
+            assert self.pjlink.mute, 'Audio should not have changed'
+            assert mock_UpdateIcons.emit.called, 'Update icons should have been called'
+            assert ('AVMT' not in self.pjlink.status_timer_checks), 'Status timer list should not have AVMT callback'
+            assert mock_status_timer.stop.called, 'Projector status_timer.stop() should have been called'
+            mock_log.warning.assert_has_calls(log_warning_text)
+            mock_log.debug.assert_has_calls(log_debug_text)
+
+    @patch.object(openlp.core.projectors.pjlinkcommands, 'log')
+    def test_projector_clss_1(self, mock_log):
+        """
+        Test CLSS request returns non-standard reply 1
+        """
+        # GIVEN: Test object
+        log_error_calls = []
+        log_warning_calls = []
+        log_debug_calls = [call('({ip}) Processing command "CLSS" with data "1"'.format(ip=self.pjlink.name)),
+                           call('({ip}) Calling function for CLSS'.format(ip=self.pjlink.name)),
+                           call('({ip}) Setting pjlink_class for this projector to "1"'.format(ip=self.pjlink.name))]
+
+        # WHEN: Process non-standard reply
+        process_command(projector=self.pjlink, cmd='CLSS', data='1')
+
+        # THEN: Projector class should be set with proper value
+        assert ('1' == self.pjlink.pjlink_class), 'Should have set class=1'
+        mock_log.error.assert_has_calls(log_error_calls)
+        mock_log.warning.assert_has_calls(log_warning_calls)
+        mock_log.debug.assert_has_calls(log_debug_calls)
+
+    @patch.object(openlp.core.projectors.pjlinkcommands, 'log')
+    def test_projector_clss_2(self, mock_log):
+        """
+        Test CLSS request returns non-standard reply 1
+        """
+        # GIVEN: Test object
+        log_error_calls = []
+        log_warning_calls = []
+        log_debug_calls = [call('({ip}) Processing command "CLSS" with data "2"'.format(ip=self.pjlink.name)),
+                           call('({ip}) Calling function for CLSS'.format(ip=self.pjlink.name)),
+                           call('({ip}) Setting pjlink_class for this projector to "2"'.format(ip=self.pjlink.name))]
+
+        # WHEN: Process non-standard reply
+        process_command(projector=self.pjlink, cmd='CLSS', data='2')
+
+        # THEN: Projector class should be set with proper value
+        assert ('2' == self.pjlink.pjlink_class), 'Should have set class=2'
+        mock_log.error.assert_has_calls(log_error_calls)
+        mock_log.warning.assert_has_calls(log_warning_calls)
+        mock_log.debug.assert_has_calls(log_debug_calls)
+
+    @patch.object(openlp.core.projectors.pjlinkcommands, 'log')
+    def test_projector_clss_invalid_nan(self, mock_log):
+        """
+        Test CLSS reply has no class number
+        """
+        # GIVEN: Test setup
+        log_error_calls = [call('({ip}) NAN CLSS version reply "Z" - '
+                                'defaulting to class "1"'.format(ip=self.pjlink.name))]
+        log_debug_calls = [call('({ip}) Processing command "CLSS" with data "Z"'.format(ip=self.pjlink.name)),
+                           call('({ip}) Calling function for CLSS'.format(ip=self.pjlink.name)),
+                           call('({ip}) Setting pjlink_class for this projector to "1"'.format(ip=self.pjlink.name))]
+
+        # WHEN: Process invalid reply
+        process_command(projector=self.pjlink, cmd='CLSS', data='Z')
+
+        # THEN: Projector class should be set with default value
+        assert (self.pjlink.pjlink_class == '1'), 'Invalid NaN class reply should have set class=1'
+        mock_log.error.assert_has_calls(log_error_calls)
+        mock_log.debug.assert_has_calls(log_debug_calls)
+
+    @patch.object(openlp.core.projectors.pjlinkcommands, 'log')
+    def test_projector_clss_invalid_no_version(self, mock_log):
+        """
+        Test CLSS reply has no class number
+        """
+        # GIVEN: Test object
+        log_error_calls = [call('({ip}) No numbers found in class version reply "Invalid" '
+                                '- defaulting to class "1"'.format(ip=self.pjlink.name))]
+        log_debug_calls = [call('({ip}) Processing command "CLSS" with data "Invalid"'.format(ip=self.pjlink.name)),
+                           call('({ip}) Calling function for CLSS'.format(ip=self.pjlink.name)),
+                           call('({ip}) Setting pjlink_class for this projector to "1"'.format(ip=self.pjlink.name))]
+
+        # WHEN: Process invalid reply
+        process_command(projector=self.pjlink, cmd='CLSS', data='Invalid')
+
+        # THEN: Projector class should be set with default value
+        assert (self.pjlink.pjlink_class == '1'), 'Invalid class reply should have set class=1'
+        mock_log.error.assert_has_calls(log_error_calls)
+        mock_log.debug.assert_has_calls(log_debug_calls)
+
+    @patch.object(openlp.core.projectors.pjlinkcommands, 'log')
+    def test_projector_clss_nonstandard_reply_1(self, mock_log):
+        """
+        Test CLSS request returns non-standard reply 1
+        """
+        # GIVEN: Test object
+        log_error_calls = []
+        log_warning_calls = [call('({ip}) Non-standard CLSS reply: "Class 1"'.format(ip=self.pjlink.name))]
+        log_debug_calls = [call('({ip}) Processing command "CLSS" with data "Class 1"'.format(ip=self.pjlink.name)),
+                           call('({ip}) Calling function for CLSS'.format(ip=self.pjlink.name)),
+                           call('({ip}) Setting pjlink_class for this projector to "1"'.format(ip=self.pjlink.name))]
+
+        # WHEN: Process non-standard reply
+        process_command(projector=self.pjlink, cmd='CLSS', data='Class 1')
+
+        # THEN: Projector class should be set with proper value
+        assert ('1' == self.pjlink.pjlink_class), 'Non-standard class reply should have set class=1'
+        mock_log.error.assert_has_calls(log_error_calls)
+        mock_log.warning.assert_has_calls(log_warning_calls)
+        mock_log.debug.assert_has_calls(log_debug_calls)
+
+    @patch.object(openlp.core.projectors.pjlinkcommands, 'log')
+    def test_projector_clss_nonstandard_reply_2(self, mock_log):
+        """
+        Test CLSS request returns non-standard reply 1
+        """
+        # GIVEN: Test object
+        log_warning_calls = [call('({ip}) Non-standard CLSS reply: "Version2"'.format(ip=self.pjlink.name))]
+        log_debug_calls = [call('({ip}) Processing command "CLSS" with data "Version2"'.format(ip=self.pjlink.name)),
+                           call('({ip}) Calling function for CLSS'.format(ip=self.pjlink.name)),
+                           call('({ip}) Setting pjlink_class for this projector to "2"'.format(ip=self.pjlink.name))]
+
+        # WHEN: Process non-standard reply
+        process_command(projector=self.pjlink, cmd='CLSS', data='Version2')
+
+        # THEN: Projector class should be set with proper value
+        assert ('2' == self.pjlink.pjlink_class), 'Non-standard class reply should have set class=1'
+        mock_log.warning.assert_has_calls(log_warning_calls)
+        mock_log.debug.assert_has_calls(log_debug_calls)
+
+    @patch.object(openlp.core.projectors.pjlinkcommands, 'log')
+    def test_projector_erst_all_error(self, mock_log):
+        """
+        Test test_projector_process_erst_all_error
+        """
+        # GIVEN: Test object
+        chk_data = '{fan}{lamp}{temp}{cover}{filt}{other}'.format(fan=PJLINK_ERST_STATUS[E_ERROR],
+                                                                  lamp=PJLINK_ERST_STATUS[E_ERROR],
+                                                                  temp=PJLINK_ERST_STATUS[E_ERROR],
+                                                                  cover=PJLINK_ERST_STATUS[E_ERROR],
+                                                                  filt=PJLINK_ERST_STATUS[E_ERROR],
+                                                                  other=PJLINK_ERST_STATUS[E_ERROR])
+        chk_test = {'Fan': E_ERROR,
+                    'Lamp': E_ERROR,
+                    'Temperature': E_ERROR,
+                    'Cover': E_ERROR,
+                    'Filter': E_ERROR,
+                    'Other': E_ERROR}
+        log_warning_calls = []
+        log_debug_calls = [call('({ip}) Processing command "ERST" with data "{chk}"'.format(ip=self.pjlink.name,
+                                                                                            chk=chk_data)),
+                           call('({ip}) Calling function for ERST'.format(ip=self.pjlink.name))]
+        self.pjlink.projector_errors = None
+
+        # WHEN: process_erst with status set to WARN
+        process_command(projector=self.pjlink, cmd='ERST', data=chk_data)
+
+        # THEN: PJLink instance errors should match chk_value
+        assert (self.pjlink.projector_errors == chk_test), 'Projector errors should be all E_ERROR'
+        mock_log.warning.assert_has_calls(log_warning_calls)
+        mock_log.debug.assert_has_calls(log_debug_calls)
+
+    @patch.object(openlp.core.projectors.pjlinkcommands, 'log')
+    def test_projector_erst_all_ok(self, mock_log):
         """
         Test to verify pjlink.projector_errors is set to None when no errors
         """
+        # GIVEN: Test object
         chk_data = '0' * PJLINK_ERST_DATA['DATA_LENGTH']
-
-        # GIVEN: Test object
-        pjlink = PJLink(Projector(**TEST1_DATA), no_poll=True)
+        log_warning_calls = []
+        log_debug_calls = [call('({ip}) Processing command "ERST" with data "{chk}"'.format(ip=self.pjlink.name,
+                                                                                            chk=chk_data)),
+                           call('({ip}) Calling function for ERST'.format(ip=self.pjlink.name))]
 
         # WHEN: process_erst with no errors
-        pjlink.process_erst(chk_data)
+        process_command(projector=self.pjlink, cmd='ERST', data=chk_data)
 
         # THEN: PJLink instance errors should be None
-        assert pjlink.projector_errors is None, 'projector_errors should have been set to None'
-
-    @skip('Needs update to new setup')
-    def test_projector_process_erst_data_invalid_length(self):
-        """
-        Test test_projector_process_erst_data_invalid_length
-        """
-        # GIVEN: Test object
-        with patch.object(openlp.core.projectors.pjlink, 'log') as mock_log:
-            pjlink = PJLink(Projector(**TEST1_DATA), no_poll=True)
-            pjlink.projector_errors = None
-            chk_data = '0' * (PJLINK_ERST_DATA['DATA_LENGTH'] + 1)
-            log_debug_calls = [call('({ip}) reset_information() connect status is '
-                                    '{state}'.format(ip=pjlink.name, state=STATUS_CODE[S_NOT_CONNECTED]))]
-            log_warn_calls = [call('({ip}) Invalid error status response "0000000": '
-                                   'length != {chk}'.format(ip=pjlink.name, chk=PJLINK_ERST_DATA['DATA_LENGTH']))]
-
-            # WHEN: process_erst called with invalid data (too many values
-            pjlink.process_erst(chk_data)
-
-            # THEN: pjlink.projector_errors should be empty and warning logged
-            assert pjlink.projector_errors is None, 'There should be no errors'
-            mock_log.debug.assert_has_calls(log_debug_calls)
-            mock_log.warning.assert_has_calls(log_warn_calls)
-
-    @skip('Needs update to new setup')
-    def test_projector_process_erst_data_invalid_nan(self):
-        """
-        Test test_projector_process_erst_data_invalid_nan
-        """
-        # GIVEN: Test object
-        with patch.object(openlp.core.projectors.pjlink, 'log') as mock_log:
-            pjlink = PJLink(Projector(**TEST1_DATA), no_poll=True)
-            pjlink.projector_errors = None
-            chk_data = 'Z' + ('0' * (PJLINK_ERST_DATA['DATA_LENGTH'] - 1))
-            log_debug_calls = [call('({ip}) reset_information() connect status is '
-                                    '{state}'.format(ip=pjlink.name, state=STATUS_CODE[S_NOT_CONNECTED]))]
-            log_warn_calls = [call('({ip}) Invalid error status response "Z00000"'.format(ip=pjlink.name))]
-
-            # WHEN: process_erst called with invalid data (too many values
-            pjlink.process_erst(chk_data)
-
-            # THEN: pjlink.projector_errors should be empty and warning logged
-            assert pjlink.projector_errors is None, 'There should be no errors'
-            mock_log.debug.assert_has_calls(log_debug_calls)
-            mock_log.warning.assert_has_calls(log_warn_calls)
-
-    @skip('Needs update to new setup')
-    def test_projector_process_erst_all_warn(self):
-        """
-        Test test_projector_process_erst_all_warn
-        """
+        assert (self.pjlink.projector_errors is None), 'projector_errors should have been set to None'
+        mock_log.warning.assert_has_calls(log_warning_calls)
+        mock_log.debug.assert_has_calls(log_debug_calls)
+
+    @patch.object(openlp.core.projectors.pjlinkcommands, 'log')
+    def test_projector_erst_all_warn(self, mock_log):
+        """
+        Test test_projector_process_erst_all_error
+        """
+        # GIVEN: Test object
         chk_data = '{fan}{lamp}{temp}{cover}{filt}{other}'.format(fan=PJLINK_ERST_STATUS[E_WARN],
                                                                   lamp=PJLINK_ERST_STATUS[E_WARN],
                                                                   temp=PJLINK_ERST_STATUS[E_WARN],
@@ -361,50 +390,71 @@
                     'Cover': E_WARN,
                     'Filter': E_WARN,
                     'Other': E_WARN}
-
-        # GIVEN: Test object
-        pjlink = PJLink(Projector(**TEST1_DATA), no_poll=True)
-        pjlink.projector_errors = None
-
-        # WHEN: process_erst with status set to WARN
-        pjlink.process_erst(chk_data)
-
-        # THEN: PJLink instance errors should match chk_value
-        assert pjlink.projector_errors == chk_test, 'Projector errors should be all E_WARN'
-
-    @skip('Needs update to new setup')
-    def test_projector_process_erst_all_error(self):
-        """
-        Test test_projector_process_erst_all_error
-        """
-        chk_data = '{fan}{lamp}{temp}{cover}{filt}{other}'.format(fan=PJLINK_ERST_STATUS[E_ERROR],
-                                                                  lamp=PJLINK_ERST_STATUS[E_ERROR],
-                                                                  temp=PJLINK_ERST_STATUS[E_ERROR],
-                                                                  cover=PJLINK_ERST_STATUS[E_ERROR],
-                                                                  filt=PJLINK_ERST_STATUS[E_ERROR],
-                                                                  other=PJLINK_ERST_STATUS[E_ERROR])
-        chk_test = {'Fan': E_ERROR,
-                    'Lamp': E_ERROR,
-                    'Temperature': E_ERROR,
-                    'Cover': E_ERROR,
-                    'Filter': E_ERROR,
-                    'Other': E_ERROR}
-
-        # GIVEN: Test object
-        pjlink = PJLink(Projector(**TEST1_DATA), no_poll=True)
-        pjlink.projector_errors = None
-
-        # WHEN: process_erst with status set to WARN
-        pjlink.process_erst(chk_data)
-
-        # THEN: PJLink instance errors should match chk_value
-        assert pjlink.projector_errors == chk_test, 'Projector errors should be all E_ERROR'
-
-    @skip('Needs update to new setup')
-    def test_projector_process_erst_warn_cover_only(self):
+        log_warning_calls = []
+        log_debug_calls = [call('({ip}) Processing command "ERST" with data "{chk}"'.format(ip=self.pjlink.name,
+                                                                                            chk=chk_data)),
+                           call('({ip}) Calling function for ERST'.format(ip=self.pjlink.name))]
+        self.pjlink.projector_errors = None
+
+        # WHEN: process_erst with status set to WARN
+        process_command(projector=self.pjlink, cmd='ERST', data=chk_data)
+
+        # THEN: PJLink instance errors should match chk_value
+        assert (self.pjlink.projector_errors == chk_test), 'Projector errors should be all E_WARN'
+        mock_log.warning.assert_has_calls(log_warning_calls)
+        mock_log.debug.assert_has_calls(log_debug_calls)
+
+    @patch.object(openlp.core.projectors.pjlinkcommands, 'log')
+    def test_projector_erst_data_invalid_length(self, mock_log):
+        """
+        Test test_projector_process_erst_data_invalid_length
+        """
+        # GIVEN: Test object
+        chk_data = '0' * (PJLINK_ERST_DATA['DATA_LENGTH'] + 1)
+        log_warn_calls = [call('({ip}) Invalid error status response "{data}": '
+                               'length != {chk}'.format(ip=self.pjlink.name,
+                                                        data=chk_data, chk=PJLINK_ERST_DATA['DATA_LENGTH']))]
+        log_debug_calls = [call('({ip}) Processing command "ERST" with data "{data}"'.format(ip=self.pjlink.name,
+                                                                                             data=chk_data)),
+                           call('({ip}) Calling function for ERST'.format(ip=self.pjlink.name))]
+        self.pjlink.projector_errors = None
+
+        # WHEN: process_erst called with invalid data (too many values
+        process_command(self.pjlink, cmd='ERST', data=chk_data)
+
+        # THEN: pjlink.projector_errors should be empty and warning logged
+        assert (not self.pjlink.projector_errors), 'There should be no errors'
+        mock_log.warning.assert_has_calls(log_warn_calls)
+        mock_log.debug.assert_has_calls(log_debug_calls)
+
+    @patch.object(openlp.core.projectors.pjlinkcommands, 'log')
+    def test_projector_erst_data_invalid_nan(self, mock_log):
+        """
+        Test ERST called with invalid data
+        """
+        # GIVEN: Test object
+        chk_data = 'Z' + ('0' * (PJLINK_ERST_DATA['DATA_LENGTH'] - 1))
+        log_warn_calls = [call('({ip}) Invalid error status response "{data}"'.format(ip=self.pjlink.name,
+                                                                                      data=chk_data))]
+        log_debug_calls = [call('({ip}) Processing command "ERST" with data "{data}"'.format(ip=self.pjlink.name,
+                                                                                             data=chk_data)),
+                           call('({ip}) Calling function for ERST'.format(ip=self.pjlink.name))]
+        self.pjlink.projector_errors = None
+
+        # WHEN: process_erst called with invalid data (too many values
+        process_command(self.pjlink, cmd='ERST', data=chk_data)
+
+        # THEN: pjlink.projector_errors should be empty and warning logged
+        assert (not self.pjlink.projector_errors), 'There should be no errors'
+        mock_log.warning.assert_has_calls(log_warn_calls)
+        mock_log.debug.assert_has_calls(log_debug_calls)
+
+    @patch.object(openlp.core.projectors.pjlinkcommands, 'log')
+    def test_projector_erst_warn_cover_only(self, mock_log):
         """
         Test test_projector_process_erst_warn_cover_only
         """
+        # GIVEN: Test object
         chk_data = '{fan}{lamp}{temp}{cover}{filt}{other}'.format(fan=PJLINK_ERST_STATUS[S_OK],
                                                                   lamp=PJLINK_ERST_STATUS[S_OK],
                                                                   temp=PJLINK_ERST_STATUS[S_OK],
@@ -412,442 +462,88 @@
                                                                   filt=PJLINK_ERST_STATUS[S_OK],
                                                                   other=PJLINK_ERST_STATUS[S_OK])
         chk_test = {'Cover': E_WARN}
-
-        # GIVEN: Test object
-        pjlink = PJLink(Projector(**TEST1_DATA), no_poll=True)
-        pjlink.projector_errors = None
+        log_warn_calls = []
+        log_debug_calls = [call('({ip}) Processing command "ERST" with data "{data}"'.format(ip=self.pjlink.name,
+                                                                                             data=chk_data)),
+                           call('({ip}) Calling function for ERST'.format(ip=self.pjlink.name))]
+        self.pjlink.projector_errors = None
 
         # WHEN: process_erst with status set to WARN
-        pjlink.process_erst(chk_data)
+        process_command(projector=self.pjlink, cmd='ERST', data=chk_data)
 
         # THEN: PJLink instance errors should match only cover warning
-        assert 1 == len(pjlink.projector_errors), 'There should only be 1 error listed in projector_errors'
-        assert 'Cover' in pjlink.projector_errors, '"Cover" should be the only error listed'
-        assert pjlink.projector_errors['Cover'] == E_WARN, '"Cover" should have E_WARN listed as error'
-        assert chk_test == pjlink.projector_errors, 'projector_errors should match test errors'
-
-    @skip('Needs update to new setup')
-    def test_projector_process_inpt_valid(self):
-        """
-        Test input source status shows current input
-        """
-        # GIVEN: Test object
-        with patch.object(openlp.core.projectors.pjlink, 'log') as mock_log:
-            pjlink = PJLink(Projector(**TEST1_DATA), no_poll=True)
-            pjlink.source = '11'
-            log_debug_calls = [call('({ip}) reset_information() connect status is '
-                                    'S_NOT_CONNECTED'.format(ip=pjlink.name))]
-            chk_source_available = ['11', '12', '21', '22', '31', '32']
-            pjlink.source_available = chk_source_available
-
-            # WHEN: Called with input source
-            pjlink.process_inpt('21')
-
-            # THEN: Input selected should reflect current input
-            assert pjlink.source == '21', 'Input source should be set to "21"'
-            mock_log.debug.assert_has_calls(log_debug_calls)
-
-    @skip('Needs update to new setup')
-    def test_projector_process_input_not_in_list(self):
-        """
-        Test setting input outside of available inputs
-
-        TODO: Future test
-        """
-        pass
-
-    @skip('Needs update to new setup')
-    def test_projector_process_input_not_in_default(self):
-        """
-        Test setting input with no sources available
-        TODO: Future test
-        """
-        pass
-
-    @skip('Needs update to new setup')
-    def test_projector_process_input_invalid(self):
-        """
-        Test setting input with an invalid value
-
-        TODO: Future test
-        """
-
-    @skip('Needs update to new setup')
-    def test_projector_process_inst_class_1(self):
-        """
-        Test saving video source available information
-        """
-
-        # GIVEN: Test object
-        with patch.object(openlp.core.projectors.pjlink, 'log') as mock_log:
-            pjlink = PJLink(Projector(**TEST1_DATA), no_poll=True)
-            pjlink.source_available = []
-            log_debug_calls = [call('({ip}) reset_information() connect status is '
-                                    'S_NOT_CONNECTED'.format(ip=pjlink.name)),
-                               call('({ip}) Setting projector source_available to '
-                                    '"[\'11\', \'12\', \'21\', \'22\', \'31\', \'32\']"'.format(ip=pjlink.name))]
-
-            chk_data = '21 12 11 22 32 31'  # Although they should already be sorted, use unsorted to verify method
-            chk_test = ['11', '12', '21', '22', '31', '32']
-
-            # WHEN: process_inst called with test data
-            pjlink.process_inst(data=chk_data)
-
-            # THEN: Data should have been sorted and saved properly
-            assert pjlink.source_available == chk_test, "Sources should have been sorted and saved"
-            mock_log.debug.assert_has_calls(log_debug_calls)
-
-    @skip('Needs update to new setup')
-    def test_projector_process_lamp_invalid(self):
-        """
-        Test status multiple lamp on/off and hours
-        """
-        # GIVEN: Test object
-        with patch.object(openlp.core.projectors.pjlink, 'log') as mock_log:
-            pjlink = PJLink(Projector(**TEST1_DATA), no_poll=True)
-            pjlink.lamp = [{'Hours': 00000, 'On': True},
-                           {'Hours': 11111, 'On': False}]
-            log_data = [call('({ip}) process_lamp(): Invalid data "11111 1 22222 0 333A3 1"'.format(ip=pjlink.name))]
-
-            # WHEN: Call process_command with invalid lamp data
-            pjlink.process_lamp('11111 1 22222 0 333A3 1')
-
-            # THEN: lamps should not have changed
-            assert 2 == len(pjlink.lamp), 'Projector should have kept 2 lamps specified'
-            assert pjlink.lamp[0]['On'] is True, 'Lamp 1 power status should have stayed TRUE'
-            assert 00000 == pjlink.lamp[0]['Hours'], 'Lamp 1 hours should have been left at 00000'
-            assert pjlink.lamp[1]['On'] is False, 'Lamp 2 power status should have stayed FALSE'
-            assert 11111 == pjlink.lamp[1]['Hours'], 'Lamp 2 hours should have been left at 11111'
-            mock_log.warning.assert_has_calls(log_data)
-
-    @skip('Needs update to new setup')
-    def test_projector_process_lamp_multiple(self):
-        """
-        Test status multiple lamp on/off and hours
-        """
-        # GIVEN: Test object
-        pjlink = PJLink(Projector(**TEST1_DATA), no_poll=True)
-        pjlink.lamp = []
-
-        # WHEN: Call process_command with invalid lamp data
-        pjlink.process_lamp('11111 1 22222 0 33333 1')
-
-        # THEN: Lamp should have been set with proper lamp status
-        assert 3 == len(pjlink.lamp), 'Projector should have 3 lamps specified'
-        assert pjlink.lamp[0]['On'] is True, 'Lamp 1 power status should have been set to TRUE'
-        assert 11111 == pjlink.lamp[0]['Hours'], 'Lamp 1 hours should have been set to 11111'
-        assert pjlink.lamp[1]['On'] is False, 'Lamp 2 power status should have been set to FALSE'
-        assert 22222 == pjlink.lamp[1]['Hours'], 'Lamp 2 hours should have been set to 22222'
-        assert pjlink.lamp[2]['On'] is True, 'Lamp 3 power status should have been set to TRUE'
-        assert 33333 == pjlink.lamp[2]['Hours'], 'Lamp 3 hours should have been set to 33333'
-
-    @skip('Needs update to new setup')
-    def test_projector_process_lamp_single(self):
-        """
-        Test status lamp on/off and hours
-        """
-
-        # GIVEN: Test object
-        pjlink = PJLink(Projector(**TEST1_DATA), no_poll=True)
-        pjlink.lamp = []
-
-        # WHEN: Call process_command with invalid lamp data
-        pjlink.process_lamp('22222 1')
-
-        # THEN: Lamp should have been set with status=ON and hours=22222
-        assert 1 == len(pjlink.lamp), 'Projector should have only 1 lamp'
-        assert pjlink.lamp[0]['On'] is True, 'Lamp power status should have been set to TRUE'
-        assert 22222 == pjlink.lamp[0]['Hours'], 'Lamp hours should have been set to 22222'
-
-    @skip('Needs update to new setup')
-    def test_projector_process_lamp_single_hours_only(self):
-        """
-        Test process lamp with 1 lamp reply hours only and no on/off status
-        """
-        # GIVEN: Test object
-        pjlink = PJLink(Projector(**TEST1_DATA), no_poll=True)
-        pjlink.lamp = []
-
-        # WHEN: Process lamp command called with only hours and no lamp power state
-        pjlink.process_lamp("45")
-
-        # THEN: Lamp should show hours as 45 and lamp power as Unavailable
-        assert 1 == len(pjlink.lamp), 'There should only be 1 lamp available'
-        assert 45 == pjlink.lamp[0]['Hours'], 'Lamp hours should have equalled 45'
-        assert pjlink.lamp[0]['On'] is None, 'Lamp power should be "None"'
-
-    @skip('Needs update to new setup')
-    def test_projector_process_name(self):
-        """
-        Test saving NAME data from projector
-        """
-        # GIVEN: Test object
-        with patch.object(openlp.core.projectors.pjlink, 'log') as mock_log:
-            pjlink = PJLink(Projector(**TEST1_DATA), no_poll=True)
-            chk_data = "Some Name the End-User Set IN Projector"
-            log_debug_calls = [call('({ip}) Setting projector PJLink name to '
-                                    '"Some Name the End-User Set IN Projector"'.format(ip=pjlink.name))]
-
-            # WHEN: process_name called with test data
-            pjlink.process_name(data=chk_data)
-
-            # THEN: name should be set and logged
-            assert pjlink.pjlink_name == chk_data, 'Name test data should have been saved'
-            mock_log.debug.assert_has_calls(log_debug_calls)
-
-    @skip('Needs update to new setup')
-    def test_projector_process_powr_on(self):
-        """
-        Test status power to ON
-        """
-        # GIVEN: Test object
-        with patch.object(openlp.core.projectors.pjlink.PJLink, 'send_command') as mock_send_command, \
-                patch.object(openlp.core.projectors.pjlink.PJLink, 'change_status') as mock_change_status, \
-                patch.object(openlp.core.projectors.pjlink.PJLink, 'projectorUpdateIcons') as mock_UpdateIcons:
-
-            pjlink = PJLink(Projector(**TEST1_DATA), no_poll=True)
-            pjlink.power = S_STANDBY
-
-            # WHEN: process_name called with test data
-            pjlink.process_powr(data=PJLINK_POWR_STATUS[S_ON])
-
-            # THEN: Power should be set to ON
-            assert pjlink.power == S_ON, 'Power should have been set to ON'
-            assert mock_UpdateIcons.emit.called is True, 'projectorUpdateIcons should have been called'
-            mock_send_command.assert_called_once_with('INST')
-            mock_change_status.assert_called_once_with(S_ON)
-
-    @skip('Needs update to new setup')
-    def test_projector_process_powr_invalid(self):
-        """
-        Test process_powr invalid call
-        """
-        # GIVEN: Test object
-        with patch.object(openlp.core.projectors.pjlink, 'log') as mock_log, \
-                patch.object(openlp.core.projectors.pjlink.PJLink, 'send_command') as mock_send_command, \
-                patch.object(openlp.core.projectors.pjlink.PJLink, 'change_status') as mock_change_status, \
-                patch.object(openlp.core.projectors.pjlink.PJLink, 'projectorUpdateIcons') as mock_UpdateIcons:
-
-            pjlink = PJLink(Projector(**TEST1_DATA), no_poll=True)
-            pjlink.power = S_STANDBY
-            log_warn_calls = [call('({ip}) Unknown power response: "99"'.format(ip=pjlink.name))]
-
-            # WHEN: process_name called with test data
-            pjlink.process_powr(data='99')
-
-            # THEN: Power should be set to ON
-            assert pjlink.power == S_STANDBY, 'Power should not have changed'
-            mock_UpdateIcons.emit.assert_not_called()
-            mock_change_status.assert_not_called()
-            mock_send_command.assert_not_called()
-            mock_log.warning.assert_has_calls(log_warn_calls)
-
-    @skip('Needs update to new setup')
-    def test_projector_process_powr_off(self):
-        """
-        Test status power to STANDBY
-        """
-        # GIVEN: Test object
-        with patch.object(openlp.core.projectors.pjlink.PJLink, 'send_command') as mock_send_command, \
-                patch.object(openlp.core.projectors.pjlink.PJLink, 'change_status') as mock_change_status, \
-                patch.object(openlp.core.projectors.pjlink.PJLink, 'projectorUpdateIcons') as mock_UpdateIcons:
-
-            pjlink = PJLink(Projector(**TEST1_DATA), no_poll=True)
-            pjlink.power = S_ON
-
-            # WHEN: process_name called with test data
-            pjlink.process_powr(data=PJLINK_POWR_STATUS[S_STANDBY])
-
-            # THEN: Power should be set to ON
-            assert pjlink.power == S_STANDBY, 'Power should have changed to S_STANDBY'
-            mock_UpdateIcons.emit.assert_called_with()
-            mock_change_status.assert_called_with(313)
-            mock_send_command.assert_not_called()
-
-    @skip('Needs update to new setup')
-    def test_projector_process_rfil_save(self):
-        """
-        Test saving filter type
-        """
-        filter_model = 'Filter Type Test'
-
-        # GIVEN: Test object
-        pjlink = PJLink(Projector(**TEST1_DATA), no_poll=True)
-        pjlink.model_filter = None
-
-        # WHEN: Filter model is received
-        pjlink.process_rfil(data=filter_model)
-
-        # THEN: Filter model number should be saved
-        assert pjlink.model_filter == filter_model, 'Filter type should have been saved'
-
-    @skip('Needs update to new setup')
-    def test_projector_process_rfil_nosave(self):
-        """
-        Test saving filter type previously saved
-        """
-        # GIVEN: Test object
-        with patch.object(openlp.core.projectors.pjlink, 'log') as mock_log:
-
-            pjlink = PJLink(Projector(**TEST1_DATA), no_poll=True)
-            pjlink.model_filter = 'Old filter type'
-            filter_model = 'Filter Type Test'
-            log_warn_calls = [call('({ip}) Filter model already set'.format(ip=pjlink.name)),
-                              call('({ip}) Saved model: "Old filter type"'.format(ip=pjlink.name)),
-                              call('({ip}) New model: "Filter Type Test"'.format(ip=pjlink.name))]
-
-            # WHEN: Filter model is received
-            pjlink.process_rfil(data=filter_model)
-
-            # THEN: Filter model number should be saved
-            assert pjlink.model_filter != filter_model, 'Filter type should NOT have been saved'
-            mock_log.warning.assert_has_calls(log_warn_calls)
-
-    @skip('Needs update to new setup')
-    def test_projector_process_rlmp_save(self):
-        """
-        Test saving lamp type
-        """
-        # GIVEN: Test object
-        # GIVEN: Test object
-        pjlink = PJLink(Projector(**TEST1_DATA), no_poll=True)
-        pjlink.model_lamp = None
-        lamp_model = 'Lamp Type Test'
-
-        # WHEN: Filter model is received
-        pjlink.process_rlmp(data=lamp_model)
-
-        # THEN: Filter model number should be saved
-        assert pjlink.model_lamp == lamp_model, 'Lamp type should have been saved'
-
-    @skip('Needs update to new setup')
-    def test_projector_process_rlmp_nosave(self):
-        """
-        Test saving lamp type previously saved
-        """
-        # GIVEN: Test object
-        with patch.object(openlp.core.projectors.pjlink, 'log') as mock_log:
-
-            pjlink = PJLink(Projector(**TEST1_DATA), no_poll=True)
-            pjlink.model_lamp = 'Old lamp type'
-            lamp_model = 'Lamp Type Test'
-            log_warn_calls = [call('({ip}) Lamp model already set'.format(ip=pjlink.name)),
-                              call('({ip}) Saved lamp: "Old lamp type"'.format(ip=pjlink.name)),
-                              call('({ip}) New lamp: "Lamp Type Test"'.format(ip=pjlink.name))]
-
-            # WHEN: Filter model is received
-            pjlink.process_rlmp(data=lamp_model)
-
-            # THEN: Filter model number should be saved
-            assert pjlink.model_lamp != lamp_model, 'Lamp type should NOT have been saved'
-            mock_log.warning.assert_has_calls(log_warn_calls)
-
-    @skip('Needs update to new setup')
-    def test_projector_process_snum_set(self):
-        """
-        Test saving serial number from projector
-        """
-        # GIVEN: Test object
-        with patch.object(openlp.core.projectors.pjlink, 'log') as mock_log:
-
-            pjlink = PJLink(Projector(**TEST1_DATA), no_poll=True)
-            pjlink.serial_no = None
-            log_debug_calls = [call('({ip}) Setting projector serial number to '
-                                    '"Test Serial Number"'.format(ip=pjlink.name))]
-            test_number = 'Test Serial Number'
-
-            # WHEN: No serial number is set and we receive serial number command
-            pjlink.process_snum(data=test_number)
-
-            # THEN: Serial number should be set
-            assert pjlink.serial_no == test_number, 'Projector serial number should have been set'
-            mock_log.debug.assert_has_calls(log_debug_calls)
-
-    @skip('Needs update to new setup')
-    def test_projector_process_snum_different(self):
-        """
-        Test projector serial number different than saved serial number
-        """
-        # GIVEN: Test object
-        with patch.object(openlp.core.projectors.pjlink, 'log') as mock_log:
-            pjlink = PJLink(Projector(**TEST1_DATA), no_poll=True)
-            pjlink.serial_no = 'Previous serial number'
-            log_warn_calls = [call('({ip}) Projector serial number does not match '
-                                   'saved serial number'.format(ip=pjlink.name)),
-                              call('({ip}) Saved:    "Previous serial number"'.format(ip=pjlink.name)),
-                              call('({ip}) Received: "Test Serial Number"'.format(ip=pjlink.name)),
-                              call('({ip}) NOT saving serial number'.format(ip=pjlink.name))]
-            test_number = 'Test Serial Number'
-
-            # WHEN: No serial number is set and we receive serial number command
-            pjlink.process_snum(data=test_number)
-
-            # THEN: Serial number should be set
-            assert pjlink.serial_no != test_number, 'Projector serial number should NOT have been set'
-            mock_log.warning.assert_has_calls(log_warn_calls)
-
-    @skip('Needs update to new setup')
-    def test_projector_process_sver(self):
-        """
-        Test invalid software version information - too long
-        """
-        # GIVEN: Test object
-        with patch.object(openlp.core.projectors.pjlink, 'log') as mock_log:
-            pjlink = PJLink(Projector(**TEST1_DATA), no_poll=True)
-            pjlink.sw_version = None
-            pjlink.sw_version_received = None
-            test_data = 'Test 1 Subtest 1'
-            log_debug_calls = [call('({ip}) Setting projector software version to '
-                                    '"Test 1 Subtest 1"'.format(ip=pjlink.name))]
-
-            # WHEN: process_sver called with invalid data
-            pjlink.process_sver(data=test_data)
-
-            # THEN: Version information should not change
-            assert pjlink.sw_version == test_data, 'Software version should have been updated'
-            mock_log.debug.assert_has_calls(log_debug_calls)
-
-    @skip('Needs update to new setup')
-    def test_projector_process_sver_changed(self):
-        """
-        Test invalid software version information - Received different than saved
-        """
-        # GIVEN: Test object
-        with patch.object(openlp.core.projectors.pjlink, 'log') as mock_log:
-            pjlink = PJLink(Projector(**TEST1_DATA), no_poll=True)
-            test_data_old = 'Test 1 Subtest 1'
-            test_data_new = 'Test 1 Subtest 2'
-            log_warn_calls = [call('({ip}) Projector software version does not match '
-                                   'saved software version'.format(ip=pjlink.name)),
-                              call('({ip}) Saved:    "Test 1 Subtest 1"'.format(ip=pjlink.name)),
-                              call('({ip}) Received: "Test 1 Subtest 2"'.format(ip=pjlink.name)),
-                              call('({ip}) Updating software version'.format(ip=pjlink.name))]
-            pjlink.sw_version = test_data_old
-
-            # WHEN: process_sver called with invalid data
-            pjlink.process_sver(data=test_data_new)
-
-            # THEN: Version information should not change
-            assert pjlink.sw_version == test_data_new, 'Software version should have changed'
-            mock_log.warning.assert_has_calls(log_warn_calls)
-
-    @skip('Needs update to new setup')
-    def test_projector_process_sver_invalid(self):
-        """
-        Test invalid software version information - too long
-        """
-        test_data = 'This is a test software version line that is too long based on PJLink version 2 specs'
-        log_warn_calls = [call('Invalid software version - too long')]
-
-        # GIVEN: Test object
-        with patch.object(openlp.core.projectors.pjlink, 'log') as mock_log:
-            pjlink = PJLink(Projector(**TEST1_DATA), no_poll=True)
-            pjlink.sw_version = None
-
-            # WHEN: process_sver called with invalid data
-            pjlink.process_sver(data=test_data)
-
-            # THEN: Version information should not change
-            assert pjlink.sw_version is None, 'Software version should not have changed'
-            assert pjlink.sw_version_received is None, 'Received software version should not have changed'
-            mock_log.warning.assert_has_calls(log_warn_calls)
+        assert (1 == len(self.pjlink.projector_errors)), 'There should only be 1 error listed in projector_errors'
+        assert ('Cover' in self.pjlink.projector_errors), '"Cover" should be the only error listed'
+        assert (self.pjlink.projector_errors['Cover'] == E_WARN), '"Cover" should have E_WARN listed as error'
+        assert (chk_test == self.pjlink.projector_errors), 'projector_errors should match test errors'
+        mock_log.warning.assert_has_calls(log_warn_calls)
+        mock_log.debug.assert_has_calls(log_debug_calls)
+
+    @patch.object(openlp.core.projectors.pjlinkcommands, 'log')
+    def test_projector_inf1(self, mock_log):
+        """
+        Test saving INF1 data (manufacturer)
+        """
+        # GIVEN: Test object
+        chk_data = 'TEst INformation MultiCase'
+        log_warn_calls = []
+        log_debug_calls = [call('({ip}) Processing command "INF1" with data "{data}"'.format(ip=self.pjlink.name,
+                                                                                             data=chk_data)),
+                           call('({ip}) Calling function for INF1'.format(ip=self.pjlink.name)),
+                           call('({ip}) Setting projector manufacturer data to '
+                                '"{data}"'.format(ip=self.pjlink.name, data=chk_data))]
+        self.pjlink.manufacturer = None
+
+        # WHEN: process_inf called with test data
+        process_command(projector=self.pjlink, cmd='INF1', data=chk_data)
+
+        # THEN: Data should be saved
+        assert (self.pjlink.manufacturer == chk_data), 'Test data should have been saved'
+        mock_log.warning.assert_has_calls(log_warn_calls)
+        mock_log.debug.assert_has_calls(log_debug_calls)
+
+    @patch.object(openlp.core.projectors.pjlinkcommands, 'log')
+    def test_projector_inf2(self, mock_log):
+        """
+        Test saving INF2 data (model)
+        """
+        # GIVEN: Test object
+        chk_data = 'TEst moDEl MultiCase'
+        log_warn_calls = []
+        log_debug_calls = [call('({ip}) Processing command "INF2" with data "{data}"'.format(ip=self.pjlink.name,
+                                                                                             data=chk_data)),
+                           call('({ip}) Calling function for INF2'.format(ip=self.pjlink.name)),
+                           call('({ip}) Setting projector model to "{data}"'.format(ip=self.pjlink.name,
+                                                                                    data=chk_data))]
+        self.pjlink.model = None
+
+        # WHEN: process_inf called with test data
+        process_command(projector=self.pjlink, cmd='INF2', data=chk_data)
+
+        # THEN: Data should be saved
+        assert (self.pjlink.model == chk_data), 'Test data should have been saved'
+        mock_log.warning.assert_has_calls(log_warn_calls)
+        mock_log.debug.assert_has_calls(log_debug_calls)
+
+    @patch.object(openlp.core.projectors.pjlinkcommands, 'log')
+    def test_projector_info(self, mock_log):
+        """
+        Test saving INF2 data (model)
+        """
+        # GIVEN: Test object
+        chk_data = 'TEst ExtrANEous MultiCase INformatoin that MFGR might Set'
+        log_warn_calls = []
+        log_debug_calls = [call('({ip}) Processing command "INFO" with data "{data}"'.format(ip=self.pjlink.name,
+                                                                                             data=chk_data)),
+                           call('({ip}) Calling function for INFO'.format(ip=self.pjlink.name)),
+                           call('({ip}) Setting projector other_info to "{data}"'.format(ip=self.pjlink.name,
+                                                                                         data=chk_data))]
+        self.pjlink.other_info = None
+
+        # WHEN: process_inf called with test data
+        process_command(projector=self.pjlink, cmd='INFO', data=chk_data)
+
+        # THEN: Data should be saved
+        assert (self.pjlink.other_info == chk_data), 'Test data should have been saved'
+        mock_log.warning.assert_has_calls(log_warn_calls)
+        mock_log.debug.assert_has_calls(log_debug_calls)

=== added file 'tests/openlp_core/projectors/test_projector_commands_02.py'
--- tests/openlp_core/projectors/test_projector_commands_02.py	1970-01-01 00:00:00 +0000
+++ tests/openlp_core/projectors/test_projector_commands_02.py	2019-05-04 10:29:17 +0000
@@ -0,0 +1,476 @@
+# -*- coding: utf-8 -*-
+# vim: autoindent shiftwidth=4 expandtab textwidth=120 tabstop=4 softtabstop=4
+
+##########################################################################
+# OpenLP - Open Source Lyrics Projection                                 #
+# ---------------------------------------------------------------------- #
+# Copyright (c) 2008-2019 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/>. #
+##########################################################################
+"""
+Package to test the openlp.core.projectors.pjlink commands package.
+"""
+from unittest import TestCase, skip
+from unittest.mock import call, patch
+
+import openlp.core.projectors.pjlink
+from openlp.core.projectors.pjlinkcommands import process_command
+from openlp.core.projectors.constants import PJLINK_POWR_STATUS, S_ON, S_STANDBY
+from openlp.core.projectors.db import Projector
+from openlp.core.projectors.pjlink import PJLink
+from tests.resources.projector.data import TEST1_DATA
+
+
+class TestPJLinkCommands(TestCase):
+    """
+    Tests PJLink get status commands part 2
+    """
+    def setUp(self):
+        """
+        Initial test setup
+        """
+        self.pjlink = PJLink(Projector(**TEST1_DATA), no_poll=True)
+
+    def tearDown(self):
+        """
+        Test reset
+        """
+        del(self.pjlink)
+
+    @skip('Needs update to new setup')
+    def test_projector_process_inpt_valid(self):
+        """
+        Test input source status shows current input
+        """
+        # GIVEN: Test object
+        with patch.object(openlp.core.projectors.pjlink, 'log') as mock_log:
+            pjlink = PJLink(Projector(**TEST1_DATA), no_poll=True)
+            pjlink.source = '11'
+            log_debug_calls = [call('({ip}) reset_information() connect status is '
+                                    'S_NOT_CONNECTED'.format(ip=pjlink.name))]
+            chk_source_available = ['11', '12', '21', '22', '31', '32']
+            pjlink.source_available = chk_source_available
+
+            # WHEN: Called with input source
+            process_command(projector=self.pjlink, cmd='INPT', data='21')
+
+            # THEN: Input selected should reflect current input
+            assert pjlink.source == '21', 'Input source should be set to "21"'
+            mock_log.debug.assert_has_calls(log_debug_calls)
+
+    @skip('Needs update to new setup')
+    def test_projector_process_input_not_in_list(self):
+        """
+        Test setting input outside of available inputs
+
+        TODO: Future test
+        """
+        pass
+
+    @skip('Needs update to new setup')
+    def test_projector_process_input_not_in_default(self):
+        """
+        Test setting input with no sources available
+        TODO: Future test
+        """
+        pass
+
+    @skip('Needs update to new setup')
+    def test_projector_process_input_invalid(self):
+        """
+        Test setting input with an invalid value
+
+        TODO: Future test
+        """
+
+    @skip('Needs update to new setup')
+    def test_projector_process_inst_class_1(self):
+        """
+        Test saving video source available information
+        """
+
+        # GIVEN: Test object
+        with patch.object(openlp.core.projectors.pjlink, 'log') as mock_log:
+            pjlink = PJLink(Projector(**TEST1_DATA), no_poll=True)
+            pjlink.source_available = []
+            log_debug_calls = [call('({ip}) reset_information() connect status is '
+                                    'S_NOT_CONNECTED'.format(ip=pjlink.name)),
+                               call('({ip}) Setting projector source_available to '
+                                    '"[\'11\', \'12\', \'21\', \'22\', \'31\', \'32\']"'.format(ip=pjlink.name))]
+
+            chk_data = '21 12 11 22 32 31'  # Although they should already be sorted, use unsorted to verify method
+            chk_test = ['11', '12', '21', '22', '31', '32']
+
+            # WHEN: process_inst called with test data
+            pjlink.process_inst(data=chk_data)
+
+            # THEN: Data should have been sorted and saved properly
+            assert pjlink.source_available == chk_test, "Sources should have been sorted and saved"
+            mock_log.debug.assert_has_calls(log_debug_calls)
+
+    @skip('Needs update to new setup')
+    def test_projector_process_lamp_invalid(self):
+        """
+        Test status multiple lamp on/off and hours
+        """
+        # GIVEN: Test object
+        with patch.object(openlp.core.projectors.pjlink, 'log') as mock_log:
+            pjlink = PJLink(Projector(**TEST1_DATA), no_poll=True)
+            pjlink.lamp = [{'Hours': 00000, 'On': True},
+                           {'Hours': 11111, 'On': False}]
+            log_data = [call('({ip}) process_lamp(): Invalid data "11111 1 22222 0 333A3 1"'.format(ip=pjlink.name))]
+
+            # WHEN: Call process_command with invalid lamp data
+            pjlink.process_lamp('11111 1 22222 0 333A3 1')
+
+            # THEN: lamps should not have changed
+            assert 2 == len(pjlink.lamp), 'Projector should have kept 2 lamps specified'
+            assert pjlink.lamp[0]['On'] is True, 'Lamp 1 power status should have stayed TRUE'
+            assert 00000 == pjlink.lamp[0]['Hours'], 'Lamp 1 hours should have been left at 00000'
+            assert pjlink.lamp[1]['On'] is False, 'Lamp 2 power status should have stayed FALSE'
+            assert 11111 == pjlink.lamp[1]['Hours'], 'Lamp 2 hours should have been left at 11111'
+            mock_log.warning.assert_has_calls(log_data)
+
+    @skip('Needs update to new setup')
+    def test_projector_process_lamp_multiple(self):
+        """
+        Test status multiple lamp on/off and hours
+        """
+        # GIVEN: Test object
+        pjlink = PJLink(Projector(**TEST1_DATA), no_poll=True)
+        pjlink.lamp = []
+
+        # WHEN: Call process_command with invalid lamp data
+        pjlink.process_lamp('11111 1 22222 0 33333 1')
+
+        # THEN: Lamp should have been set with proper lamp status
+        assert 3 == len(pjlink.lamp), 'Projector should have 3 lamps specified'
+        assert pjlink.lamp[0]['On'] is True, 'Lamp 1 power status should have been set to TRUE'
+        assert 11111 == pjlink.lamp[0]['Hours'], 'Lamp 1 hours should have been set to 11111'
+        assert pjlink.lamp[1]['On'] is False, 'Lamp 2 power status should have been set to FALSE'
+        assert 22222 == pjlink.lamp[1]['Hours'], 'Lamp 2 hours should have been set to 22222'
+        assert pjlink.lamp[2]['On'] is True, 'Lamp 3 power status should have been set to TRUE'
+        assert 33333 == pjlink.lamp[2]['Hours'], 'Lamp 3 hours should have been set to 33333'
+
+    @skip('Needs update to new setup')
+    def test_projector_process_lamp_single(self):
+        """
+        Test status lamp on/off and hours
+        """
+
+        # GIVEN: Test object
+        pjlink = PJLink(Projector(**TEST1_DATA), no_poll=True)
+        pjlink.lamp = []
+
+        # WHEN: Call process_command with invalid lamp data
+        pjlink.process_lamp('22222 1')
+
+        # THEN: Lamp should have been set with status=ON and hours=22222
+        assert 1 == len(pjlink.lamp), 'Projector should have only 1 lamp'
+        assert pjlink.lamp[0]['On'] is True, 'Lamp power status should have been set to TRUE'
+        assert 22222 == pjlink.lamp[0]['Hours'], 'Lamp hours should have been set to 22222'
+
+    @skip('Needs update to new setup')
+    def test_projector_process_lamp_single_hours_only(self):
+        """
+        Test process lamp with 1 lamp reply hours only and no on/off status
+        """
+        # GIVEN: Test object
+        pjlink = PJLink(Projector(**TEST1_DATA), no_poll=True)
+        pjlink.lamp = []
+
+        # WHEN: Process lamp command called with only hours and no lamp power state
+        pjlink.process_lamp("45")
+
+        # THEN: Lamp should show hours as 45 and lamp power as Unavailable
+        assert 1 == len(pjlink.lamp), 'There should only be 1 lamp available'
+        assert 45 == pjlink.lamp[0]['Hours'], 'Lamp hours should have equalled 45'
+        assert pjlink.lamp[0]['On'] is None, 'Lamp power should be "None"'
+
+    @skip('Needs update to new setup')
+    def test_projector_process_name(self):
+        """
+        Test saving NAME data from projector
+        """
+        # GIVEN: Test object
+        with patch.object(openlp.core.projectors.pjlink, 'log') as mock_log:
+            pjlink = PJLink(Projector(**TEST1_DATA), no_poll=True)
+            chk_data = "Some Name the End-User Set IN Projector"
+            log_debug_calls = [call('({ip}) Setting projector PJLink name to '
+                                    '"Some Name the End-User Set IN Projector"'.format(ip=pjlink.name))]
+
+            # WHEN: process_name called with test data
+            pjlink.process_name(data=chk_data)
+
+            # THEN: name should be set and logged
+            assert pjlink.pjlink_name == chk_data, 'Name test data should have been saved'
+            mock_log.debug.assert_has_calls(log_debug_calls)
+
+    @skip('Needs update to new setup')
+    def test_projector_process_powr_on(self):
+        """
+        Test status power to ON
+        """
+        # GIVEN: Test object
+        with patch.object(openlp.core.projectors.pjlink.PJLink, 'send_command') as mock_send_command, \
+                patch.object(openlp.core.projectors.pjlink.PJLink, 'change_status') as mock_change_status, \
+                patch.object(openlp.core.projectors.pjlink.PJLink, 'projectorUpdateIcons') as mock_UpdateIcons:
+
+            pjlink = PJLink(Projector(**TEST1_DATA), no_poll=True)
+            pjlink.power = S_STANDBY
+
+            # WHEN: process_name called with test data
+            pjlink.process_powr(data=PJLINK_POWR_STATUS[S_ON])
+
+            # THEN: Power should be set to ON
+            assert pjlink.power == S_ON, 'Power should have been set to ON'
+            assert mock_UpdateIcons.emit.called is True, 'projectorUpdateIcons should have been called'
+            mock_send_command.assert_called_once_with('INST')
+            mock_change_status.assert_called_once_with(S_ON)
+
+    @skip('Needs update to new setup')
+    def test_projector_process_powr_invalid(self):
+        """
+        Test process_powr invalid call
+        """
+        # GIVEN: Test object
+        with patch.object(openlp.core.projectors.pjlink, 'log') as mock_log, \
+                patch.object(openlp.core.projectors.pjlink.PJLink, 'send_command') as mock_send_command, \
+                patch.object(openlp.core.projectors.pjlink.PJLink, 'change_status') as mock_change_status, \
+                patch.object(openlp.core.projectors.pjlink.PJLink, 'projectorUpdateIcons') as mock_UpdateIcons:
+
+            pjlink = PJLink(Projector(**TEST1_DATA), no_poll=True)
+            pjlink.power = S_STANDBY
+            log_warn_calls = [call('({ip}) Unknown power response: "99"'.format(ip=pjlink.name))]
+
+            # WHEN: process_name called with test data
+            pjlink.process_powr(data='99')
+
+            # THEN: Power should be set to ON
+            assert pjlink.power == S_STANDBY, 'Power should not have changed'
+            mock_UpdateIcons.emit.assert_not_called()
+            mock_change_status.assert_not_called()
+            mock_send_command.assert_not_called()
+            mock_log.warning.assert_has_calls(log_warn_calls)
+
+    @skip('Needs update to new setup')
+    def test_projector_process_powr_off(self):
+        """
+        Test status power to STANDBY
+        """
+        # GIVEN: Test object
+        with patch.object(openlp.core.projectors.pjlink.PJLink, 'send_command') as mock_send_command, \
+                patch.object(openlp.core.projectors.pjlink.PJLink, 'change_status') as mock_change_status, \
+                patch.object(openlp.core.projectors.pjlink.PJLink, 'projectorUpdateIcons') as mock_UpdateIcons:
+
+            pjlink = PJLink(Projector(**TEST1_DATA), no_poll=True)
+            pjlink.power = S_ON
+
+            # WHEN: process_name called with test data
+            pjlink.process_powr(data=PJLINK_POWR_STATUS[S_STANDBY])
+
+            # THEN: Power should be set to ON
+            assert pjlink.power == S_STANDBY, 'Power should have changed to S_STANDBY'
+            mock_UpdateIcons.emit.assert_called_with()
+            mock_change_status.assert_called_with(313)
+            mock_send_command.assert_not_called()
+
+    @skip('Needs update to new setup')
+    def test_projector_process_rfil_save(self):
+        """
+        Test saving filter type
+        """
+        filter_model = 'Filter Type Test'
+
+        # GIVEN: Test object
+        pjlink = PJLink(Projector(**TEST1_DATA), no_poll=True)
+        pjlink.model_filter = None
+
+        # WHEN: Filter model is received
+        pjlink.process_rfil(data=filter_model)
+
+        # THEN: Filter model number should be saved
+        assert pjlink.model_filter == filter_model, 'Filter type should have been saved'
+
+    @skip('Needs update to new setup')
+    def test_projector_process_rfil_nosave(self):
+        """
+        Test saving filter type previously saved
+        """
+        # GIVEN: Test object
+        with patch.object(openlp.core.projectors.pjlink, 'log') as mock_log:
+
+            pjlink = PJLink(Projector(**TEST1_DATA), no_poll=True)
+            pjlink.model_filter = 'Old filter type'
+            filter_model = 'Filter Type Test'
+            log_warn_calls = [call('({ip}) Filter model already set'.format(ip=pjlink.name)),
+                              call('({ip}) Saved model: "Old filter type"'.format(ip=pjlink.name)),
+                              call('({ip}) New model: "Filter Type Test"'.format(ip=pjlink.name))]
+
+            # WHEN: Filter model is received
+            pjlink.process_rfil(data=filter_model)
+
+            # THEN: Filter model number should be saved
+            assert pjlink.model_filter != filter_model, 'Filter type should NOT have been saved'
+            mock_log.warning.assert_has_calls(log_warn_calls)
+
+    @skip('Needs update to new setup')
+    def test_projector_process_rlmp_save(self):
+        """
+        Test saving lamp type
+        """
+        # GIVEN: Test object
+        # GIVEN: Test object
+        pjlink = PJLink(Projector(**TEST1_DATA), no_poll=True)
+        pjlink.model_lamp = None
+        lamp_model = 'Lamp Type Test'
+
+        # WHEN: Filter model is received
+        pjlink.process_rlmp(data=lamp_model)
+
+        # THEN: Filter model number should be saved
+        assert pjlink.model_lamp == lamp_model, 'Lamp type should have been saved'
+
+    @skip('Needs update to new setup')
+    def test_projector_process_rlmp_nosave(self):
+        """
+        Test saving lamp type previously saved
+        """
+        # GIVEN: Test object
+        with patch.object(openlp.core.projectors.pjlink, 'log') as mock_log:
+
+            pjlink = PJLink(Projector(**TEST1_DATA), no_poll=True)
+            pjlink.model_lamp = 'Old lamp type'
+            lamp_model = 'Lamp Type Test'
+            log_warn_calls = [call('({ip}) Lamp model already set'.format(ip=pjlink.name)),
+                              call('({ip}) Saved lamp: "Old lamp type"'.format(ip=pjlink.name)),
+                              call('({ip}) New lamp: "Lamp Type Test"'.format(ip=pjlink.name))]
+
+            # WHEN: Filter model is received
+            pjlink.process_rlmp(data=lamp_model)
+
+            # THEN: Filter model number should be saved
+            assert pjlink.model_lamp != lamp_model, 'Lamp type should NOT have been saved'
+            mock_log.warning.assert_has_calls(log_warn_calls)
+
+    @skip('Needs update to new setup')
+    def test_projector_process_snum_set(self):
+        """
+        Test saving serial number from projector
+        """
+        # GIVEN: Test object
+        with patch.object(openlp.core.projectors.pjlink, 'log') as mock_log:
+
+            pjlink = PJLink(Projector(**TEST1_DATA), no_poll=True)
+            pjlink.serial_no = None
+            log_debug_calls = [call('({ip}) Setting projector serial number to '
+                                    '"Test Serial Number"'.format(ip=pjlink.name))]
+            test_number = 'Test Serial Number'
+
+            # WHEN: No serial number is set and we receive serial number command
+            pjlink.process_snum(data=test_number)
+
+            # THEN: Serial number should be set
+            assert pjlink.serial_no == test_number, 'Projector serial number should have been set'
+            mock_log.debug.assert_has_calls(log_debug_calls)
+
+    @skip('Needs update to new setup')
+    def test_projector_process_snum_different(self):
+        """
+        Test projector serial number different than saved serial number
+        """
+        # GIVEN: Test object
+        with patch.object(openlp.core.projectors.pjlink, 'log') as mock_log:
+            pjlink = PJLink(Projector(**TEST1_DATA), no_poll=True)
+            pjlink.serial_no = 'Previous serial number'
+            log_warn_calls = [call('({ip}) Projector serial number does not match '
+                                   'saved serial number'.format(ip=pjlink.name)),
+                              call('({ip}) Saved:    "Previous serial number"'.format(ip=pjlink.name)),
+                              call('({ip}) Received: "Test Serial Number"'.format(ip=pjlink.name)),
+                              call('({ip}) NOT saving serial number'.format(ip=pjlink.name))]
+            test_number = 'Test Serial Number'
+
+            # WHEN: No serial number is set and we receive serial number command
+            pjlink.process_snum(data=test_number)
+
+            # THEN: Serial number should be set
+            assert pjlink.serial_no != test_number, 'Projector serial number should NOT have been set'
+            mock_log.warning.assert_has_calls(log_warn_calls)
+
+    @skip('Needs update to new setup')
+    def test_projector_process_sver(self):
+        """
+        Test invalid software version information - too long
+        """
+        # GIVEN: Test object
+        with patch.object(openlp.core.projectors.pjlink, 'log') as mock_log:
+            pjlink = PJLink(Projector(**TEST1_DATA), no_poll=True)
+            pjlink.sw_version = None
+            pjlink.sw_version_received = None
+            test_data = 'Test 1 Subtest 1'
+            log_debug_calls = [call('({ip}) Setting projector software version to '
+                                    '"Test 1 Subtest 1"'.format(ip=pjlink.name))]
+
+            # WHEN: process_sver called with invalid data
+            pjlink.process_sver(data=test_data)
+
+            # THEN: Version information should not change
+            assert pjlink.sw_version == test_data, 'Software version should have been updated'
+            mock_log.debug.assert_has_calls(log_debug_calls)
+
+    @skip('Needs update to new setup')
+    def test_projector_process_sver_changed(self):
+        """
+        Test invalid software version information - Received different than saved
+        """
+        # GIVEN: Test object
+        with patch.object(openlp.core.projectors.pjlink, 'log') as mock_log:
+            pjlink = PJLink(Projector(**TEST1_DATA), no_poll=True)
+            test_data_old = 'Test 1 Subtest 1'
+            test_data_new = 'Test 1 Subtest 2'
+            log_warn_calls = [call('({ip}) Projector software version does not match '
+                                   'saved software version'.format(ip=pjlink.name)),
+                              call('({ip}) Saved:    "Test 1 Subtest 1"'.format(ip=pjlink.name)),
+                              call('({ip}) Received: "Test 1 Subtest 2"'.format(ip=pjlink.name)),
+                              call('({ip}) Updating software version'.format(ip=pjlink.name))]
+            pjlink.sw_version = test_data_old
+
+            # WHEN: process_sver called with invalid data
+            pjlink.process_sver(data=test_data_new)
+
+            # THEN: Version information should not change
+            assert pjlink.sw_version == test_data_new, 'Software version should have changed'
+            mock_log.warning.assert_has_calls(log_warn_calls)
+
+    @skip('Needs update to new setup')
+    def test_projector_process_sver_invalid(self):
+        """
+        Test invalid software version information - too long
+        """
+        test_data = 'This is a test software version line that is too long based on PJLink version 2 specs'
+        log_warn_calls = [call('Invalid software version - too long')]
+
+        # GIVEN: Test object
+        with patch.object(openlp.core.projectors.pjlink, 'log') as mock_log:
+            pjlink = PJLink(Projector(**TEST1_DATA), no_poll=True)
+            pjlink.sw_version = None
+
+            # WHEN: process_sver called with invalid data
+            pjlink.process_sver(data=test_data)
+
+            # THEN: Version information should not change
+            assert pjlink.sw_version is None, 'Software version should not have changed'
+            assert pjlink.sw_version_received is None, 'Received software version should not have changed'
+            mock_log.warning.assert_has_calls(log_warn_calls)

=== modified file 'tests/openlp_core/projectors/test_projector_pjlink_cmd_routing.py'
--- tests/openlp_core/projectors/test_projector_pjlink_cmd_routing.py	2019-05-04 10:29:17 +0000
+++ tests/openlp_core/projectors/test_projector_pjlink_cmd_routing.py	2019-05-04 10:29:17 +0000
@@ -23,12 +23,11 @@
 Package to test the openlp.core.projectors.pjlink command routing.
 """
 
-from unittest import TestCase, skip
+from unittest import TestCase
 from unittest.mock import call, patch
 
 import openlp.core.projectors.pjlink
-from openlp.core.projectors.constants import E_AUTHENTICATION, E_PARAMETER, E_PROJECTOR, E_UNAVAILABLE, E_UNDEFINED, \
-    PJLINK_ERRORS, PJLINK_PREFIX, STATUS_MSG
+from openlp.core.projectors.constants import PJLINK_PREFIX
 from openlp.core.projectors.db import Projector
 from openlp.core.projectors.pjlink import PJLink
 from tests.resources.projector.data import TEST1_DATA
@@ -134,119 +133,3 @@
         mock_log.warning.assert_has_calls(log_warning_text)
         mock_log.debug.assert_has_calls(log_debug_text)
         assert (mock_process_cmd.call_count == 0), 'process_command should not have been called'
-
-    @skip('Needs update to new setup')
-    def test_routing_err1(self):
-        """
-        Test ERR1 - Undefined projector function
-        """
-        # GIVEN: Test object
-        with patch.object(openlp.core.projectors.pjlink, 'log') as mock_log, \
-                patch.object(openlp.core.projectors.pjlink.PJLink, 'process_clss') as mock_process_clss:
-
-            pjlink = PJLink(Projector(**TEST1_DATA), no_poll=True)
-            log_error_text = [call('({ip}) CLSS: {msg}'.format(ip=self.pjlink.name, msg=STATUS_MSG[E_UNDEFINED]))]
-            log_debug_text = [call('({ip}) Processing command "CLSS" with data "ERR1"'.format(ip=self.pjlink.name)),
-                              call('({ip}) Calling function for CLSS'.format(ip=self.pjlink.name))]
-
-            # WHEN: process_command called with ERR1
-            pjlink.process_command(cmd='CLSS', data=PJLINK_ERRORS[E_UNDEFINED])
-
-            # THEN: Appropriate log entries should have been made and methods called
-            mock_log.error.assert_has_calls(log_error_text)
-            mock_log.debug.assert_has_calls(log_debug_text)
-            mock_process_clss.assert_called_once_with(data=PJLINK_ERRORS[E_UNDEFINED])
-
-    @skip('Needs update to new setup')
-    def test_routing_err2(self):
-        """
-        Test ERR2 - Parameter Error
-        """
-        # GIVEN: Test object
-        with patch.object(openlp.core.projectors.pjlink, 'log') as mock_log, \
-                patch.object(openlp.core.projectors.pjlink.PJLink, 'process_clss') as mock_process_clss:
-
-            pjlink = PJLink(Projector(**TEST1_DATA), no_poll=True)
-            log_error_text = [call('({ip}) CLSS: {msg}'.format(ip=self.pjlink.name, msg=STATUS_MSG[E_PARAMETER]))]
-            log_debug_text = [call('({ip}) Processing command "CLSS" with data "ERR2"'.format(ip=self.pjlink.name)),
-                              call('({ip}) Calling function for CLSS'.format(ip=self.pjlink.name))]
-
-            # WHEN: process_command called with ERR2
-            pjlink.process_command(cmd='CLSS', data=PJLINK_ERRORS[E_PARAMETER])
-
-            # THEN: Appropriate log entries should have been made and methods called/not called
-            mock_log.error.assert_has_calls(log_error_text)
-            mock_log.debug.assert_has_calls(log_debug_text)
-            mock_process_clss.assert_called_once_with(data=PJLINK_ERRORS[E_PARAMETER])
-
-    @skip('Needs update to new setup')
-    def test_routing_err3(self):
-        """
-        Test ERR3 - Unavailable error
-        """
-        # GIVEN: Test object
-        with patch.object(openlp.core.projectors.pjlink, 'log') as mock_log, \
-                patch.object(openlp.core.projectors.pjlink.PJLink, 'process_clss') as mock_process_clss:
-
-            pjlink = PJLink(Projector(**TEST1_DATA), no_poll=True)
-            log_error_text = [call('({ip}) CLSS: {msg}'.format(ip=self.pjlink.name, msg=STATUS_MSG[E_UNAVAILABLE]))]
-            log_debug_text = [call('({ip}) Processing command "CLSS" with data "ERR3"'.format(ip=self.pjlink.name)),
-                              call('({ip}) Calling function for CLSS'.format(ip=self.pjlink.name))]
-
-            # WHEN: process_command called with ERR3
-            pjlink.process_command(cmd='CLSS', data=PJLINK_ERRORS[E_UNAVAILABLE])
-
-            # THEN: Appropriate log entries should have been made and methods called
-            mock_log.error.assert_has_calls(log_error_text)
-            mock_log.debug.assert_has_calls(log_debug_text)
-            mock_process_clss.assert_called_once_with(data=PJLINK_ERRORS[E_UNAVAILABLE])
-
-    @skip('Needs update to new setup')
-    def test_routing_err4(self):
-        """
-        Test ERR3 - Unavailable error
-        """
-        # GIVEN: Test object
-        with patch.object(openlp.core.projectors.pjlink, 'log') as mock_log, \
-                patch.object(openlp.core.projectors.pjlink.PJLink, 'process_clss') as mock_process_clss:
-
-            pjlink = PJLink(Projector(**TEST1_DATA), no_poll=True)
-            log_error_text = [call('({ip}) CLSS: {msg}'.format(ip=self.pjlink.name, msg=STATUS_MSG[E_PROJECTOR]))]
-            log_debug_text = [call('({ip}) Processing command "CLSS" with data "ERR4"'.format(ip=self.pjlink.name)),
-                              call('({ip}) Calling function for CLSS'.format(ip=self.pjlink.name))]
-
-            # WHEN: process_command called with ERR4
-            pjlink.process_command(cmd='CLSS', data=PJLINK_ERRORS[E_PROJECTOR])
-
-            # THEN: Appropriate log entries should have been made and methods called
-            mock_log.error.assert_has_calls(log_error_text)
-            mock_log.debug.assert_has_calls(log_debug_text)
-            mock_process_clss.assert_called_once_with(data=PJLINK_ERRORS[E_PROJECTOR])
-
-    @skip('Needs update to new setup')
-    def test_routing_erra(self):
-        """
-        Test ERRA - Authentication Error
-        """
-        # GIVEN: Test object
-        with patch.object(openlp.core.projectors.pjlink, 'log') as mock_log, \
-                patch.object(openlp.core.projectors.pjlink.PJLink, 'process_pjlink') as mock_process_pjlink, \
-                patch.object(openlp.core.projectors.pjlink.PJLink, 'change_status') as mock_change_status, \
-                patch.object(openlp.core.projectors.pjlink.PJLink, 'disconnect_from_host') as mock_disconnect, \
-                patch.object(openlp.core.projectors.pjlink.PJLink, 'projectorAuthentication') as mock_authentication:
-
-            pjlink = PJLink(Projector(**TEST1_DATA), no_poll=True)
-            log_error_calls = [call('({ip}) PJLINK: {msg}'.format(ip=self.pjlink.name,
-                                                                  msg=STATUS_MSG[E_AUTHENTICATION]))]
-            log_debug_calls = [call('({ip}) Processing command "PJLINK" with data "ERRA"'.format(ip=self.pjlink.name))]
-
-            # WHEN: process_command called with ERRA
-            pjlink.process_command(cmd='PJLINK', data=PJLINK_ERRORS[E_AUTHENTICATION])
-
-            # THEN: Appropriate log entries should have been made and methods called/not called
-            assert mock_disconnect.called is True, 'disconnect_from_host should have been called'
-            mock_log.error.assert_has_calls(log_error_calls)
-            mock_log.debug.assert_has_calls(log_debug_calls)
-            mock_change_status.assert_called_once_with(status=E_AUTHENTICATION)
-            mock_authentication.emit.assert_called_once_with(pjlink.name)
-            mock_process_pjlink.assert_not_called()


Follow ups