forked from openlp/openlp
- Update string format to Python3 style
- Added projector multiple lamp values test - Updated strings for translation (they should all be ok now) - Fix merge conflicts (projector_pjlink1 and projector_ui tests) Convert string format from Python2 '%s %s' % (value1, value2) to Python3 '{key1} {key2}'.format(key1=value1, key2=value2) Jenkins down - local pep8 and tests (except windows tests) passed. Previous Jenkins test: -------------------------------- lp:~alisonken1/openlp/string... bzr-revno: 2650
This commit is contained in:
commit
907e1df129
@ -182,9 +182,10 @@ class ProjectorEditForm(QDialog, Ui_ProjectorEditForm):
|
|||||||
QtWidgets.QMessageBox.warning(self,
|
QtWidgets.QMessageBox.warning(self,
|
||||||
translate('OpenLP.ProjectorEdit', 'Duplicate Name'),
|
translate('OpenLP.ProjectorEdit', 'Duplicate Name'),
|
||||||
translate('OpenLP.ProjectorEdit',
|
translate('OpenLP.ProjectorEdit',
|
||||||
'There is already an entry with name "%s" in '
|
'There is already an entry with name "{name}" in '
|
||||||
'the database as ID "%s". <br />'
|
'the database as ID "{record}". <br />'
|
||||||
'Please enter a different name.' % (name, record.id)))
|
'Please enter a different name.'.format(name=name,
|
||||||
|
record=record.id)))
|
||||||
valid = False
|
valid = False
|
||||||
return
|
return
|
||||||
adx = self.ip_text.text()
|
adx = self.ip_text.text()
|
||||||
@ -198,17 +199,17 @@ class ProjectorEditForm(QDialog, Ui_ProjectorEditForm):
|
|||||||
QtWidgets.QMessageBox.warning(self,
|
QtWidgets.QMessageBox.warning(self,
|
||||||
translate('OpenLP.ProjectorWizard', 'Duplicate IP Address'),
|
translate('OpenLP.ProjectorWizard', 'Duplicate IP Address'),
|
||||||
translate('OpenLP.ProjectorWizard',
|
translate('OpenLP.ProjectorWizard',
|
||||||
'IP address "%s"<br />is already in the database as ID %s.'
|
'IP address "{ip}"<br />is already in the database '
|
||||||
'<br /><br />Please Enter a different IP address.' %
|
'as ID {data}.<br /><br />Please Enter a different '
|
||||||
(adx, ip.id)))
|
'IP address.'.format(ip=adx, data=ip.id)))
|
||||||
valid = False
|
valid = False
|
||||||
return
|
return
|
||||||
else:
|
else:
|
||||||
QtWidgets.QMessageBox.warning(self,
|
QtWidgets.QMessageBox.warning(self,
|
||||||
translate('OpenLP.ProjectorWizard', 'Invalid IP Address'),
|
translate('OpenLP.ProjectorWizard', 'Invalid IP Address'),
|
||||||
translate('OpenLP.ProjectorWizard',
|
translate('OpenLP.ProjectorWizard',
|
||||||
'IP address "%s"<br>is not a valid IP address.'
|
'IP address "{ip}"<br>is not a valid IP address.'
|
||||||
'<br /><br />Please enter a valid IP address.' % adx))
|
'<br /><br />Please enter a valid IP address.'.format(ip=adx)))
|
||||||
valid = False
|
valid = False
|
||||||
return
|
return
|
||||||
port = int(self.port_text.text())
|
port = int(self.port_text.text())
|
||||||
@ -219,8 +220,8 @@ class ProjectorEditForm(QDialog, Ui_ProjectorEditForm):
|
|||||||
'Port numbers below 1000 are reserved for admin use only, '
|
'Port numbers below 1000 are reserved for admin use only, '
|
||||||
'<br />and port numbers above 32767 are not currently usable.'
|
'<br />and port numbers above 32767 are not currently usable.'
|
||||||
'<br /><br />Please enter a valid port number between '
|
'<br /><br />Please enter a valid port number between '
|
||||||
' 1000 and 32767.'
|
'1000 and 32767.<br /><br />'
|
||||||
'<br /><br />Default PJLink port is %s' % PJLINK_PORT))
|
'Default PJLink port is {port}'.format(port=PJLINK_PORT)))
|
||||||
valid = False
|
valid = False
|
||||||
if valid:
|
if valid:
|
||||||
self.projector.ip = self.ip_text.text()
|
self.projector.ip = self.ip_text.text()
|
||||||
|
@ -344,7 +344,7 @@ class ProjectorManager(OpenLPMixin, RegistryMixin, QWidget, Ui_ProjectorManager,
|
|||||||
real_projector = item.data(QtCore.Qt.UserRole)
|
real_projector = item.data(QtCore.Qt.UserRole)
|
||||||
projector_name = str(item.text())
|
projector_name = str(item.text())
|
||||||
visible = real_projector.link.status_connect >= S_CONNECTED
|
visible = real_projector.link.status_connect >= S_CONNECTED
|
||||||
log.debug('(%s) Building menu - visible = %s' % (projector_name, visible))
|
log.debug('({name}) Building menu - visible = {visible}'.format(name=projector_name, visible=visible))
|
||||||
self.delete_action.setVisible(True)
|
self.delete_action.setVisible(True)
|
||||||
self.edit_action.setVisible(True)
|
self.edit_action.setVisible(True)
|
||||||
self.connect_action.setVisible(not visible)
|
self.connect_action.setVisible(not visible)
|
||||||
@ -394,7 +394,7 @@ class ProjectorManager(OpenLPMixin, RegistryMixin, QWidget, Ui_ProjectorManager,
|
|||||||
projectordb=self.projectordb,
|
projectordb=self.projectordb,
|
||||||
edit=edit)
|
edit=edit)
|
||||||
source = source_select_form.exec(projector.link)
|
source = source_select_form.exec(projector.link)
|
||||||
log.debug('(%s) source_select_form() returned %s' % (projector.link.ip, source))
|
log.debug('({ip}) source_select_form() returned {data}'.format(ip=projector.link.ip, data=source))
|
||||||
if source is not None and source > 0:
|
if source is not None and source > 0:
|
||||||
projector.link.set_input_source(str(source))
|
projector.link.set_input_source(str(source))
|
||||||
return
|
return
|
||||||
@ -473,8 +473,9 @@ class ProjectorManager(OpenLPMixin, RegistryMixin, QWidget, Ui_ProjectorManager,
|
|||||||
return
|
return
|
||||||
projector = list_item.data(QtCore.Qt.UserRole)
|
projector = list_item.data(QtCore.Qt.UserRole)
|
||||||
msg = QtWidgets.QMessageBox()
|
msg = QtWidgets.QMessageBox()
|
||||||
msg.setText(translate('OpenLP.ProjectorManager', 'Delete projector (%s) %s?') % (projector.link.ip,
|
msg.setText(translate('OpenLP.ProjectorManager',
|
||||||
projector.link.name))
|
'Delete projector ({ip}) {name}?'.format(ip=projector.link.ip,
|
||||||
|
name=projector.link.name)))
|
||||||
msg.setInformativeText(translate('OpenLP.ProjectorManager', 'Are you sure you want to delete this projector?'))
|
msg.setInformativeText(translate('OpenLP.ProjectorManager', 'Are you sure you want to delete this projector?'))
|
||||||
msg.setStandardButtons(msg.Cancel | msg.Ok)
|
msg.setStandardButtons(msg.Cancel | msg.Ok)
|
||||||
msg.setDefaultButton(msg.Cancel)
|
msg.setDefaultButton(msg.Cancel)
|
||||||
@ -522,7 +523,7 @@ class ProjectorManager(OpenLPMixin, RegistryMixin, QWidget, Ui_ProjectorManager,
|
|||||||
list_item = None
|
list_item = None
|
||||||
deleted = self.projectordb.delete_projector(projector.db_item)
|
deleted = self.projectordb.delete_projector(projector.db_item)
|
||||||
for item in self.projector_list:
|
for item in self.projector_list:
|
||||||
log.debug('New projector list - item: %s %s' % (item.link.ip, item.link.name))
|
log.debug('New projector list - item: {ip} {name}'.format(ip=item.link.ip, name=item.link.name))
|
||||||
|
|
||||||
def on_disconnect_projector(self, opt=None):
|
def on_disconnect_projector(self, opt=None):
|
||||||
"""
|
"""
|
||||||
@ -627,53 +628,58 @@ class ProjectorManager(OpenLPMixin, RegistryMixin, QWidget, Ui_ProjectorManager,
|
|||||||
"""
|
"""
|
||||||
lwi = self.projector_list_widget.item(self.projector_list_widget.currentRow())
|
lwi = self.projector_list_widget.item(self.projector_list_widget.currentRow())
|
||||||
projector = lwi.data(QtCore.Qt.UserRole)
|
projector = lwi.data(QtCore.Qt.UserRole)
|
||||||
message = '<b>%s</b>: %s<BR />' % (translate('OpenLP.ProjectorManager', 'Name'),
|
message = '<b>{title}</b>: {data}<BR />'.format(title=translate('OpenLP.ProjectorManager', 'Name'),
|
||||||
projector.link.name)
|
data=projector.link.name)
|
||||||
message = '%s<b>%s</b>: %s<br />' % (message, translate('OpenLP.ProjectorManager', 'IP'),
|
message += '<b>{title}</b>: {data}<br />'.format(title=translate('OpenLP.ProjectorManager', 'IP'),
|
||||||
projector.link.ip)
|
data=projector.link.ip)
|
||||||
message = '%s<b>%s</b>: %s<br />' % (message, translate('OpenLP.ProjectorManager', 'Port'),
|
message += '<b>{title}</b>: {data}<br />'.format(title=translate('OpenLP.ProjectorManager', 'Port'),
|
||||||
projector.link.port)
|
data=projector.link.port)
|
||||||
message = '%s<b>%s</b>: %s<br />' % (message, translate('OpenLP.ProjectorManager', 'Notes'),
|
message += '<b>{title}</b>: {data}<br />'.format(title=translate('OpenLP.ProjectorManager', 'Notes'),
|
||||||
projector.link.notes)
|
data=projector.link.notes)
|
||||||
message = '%s<hr /><br >' % message
|
message += '<hr /><br >'
|
||||||
if projector.link.manufacturer is None:
|
if projector.link.manufacturer is None:
|
||||||
message = '%s%s' % (message, translate('OpenLP.ProjectorManager',
|
message += translate('OpenLP.ProjectorManager', 'Projector information not available at this time.')
|
||||||
'Projector information not available at this time.'))
|
|
||||||
else:
|
else:
|
||||||
message = '%s<b>%s</b>: %s<BR />' % (message, translate('OpenLP.ProjectorManager', 'Projector Name'),
|
message += '<b>{title}</b>: {data}<br />'.format(title=translate('OpenLP.ProjectorManager',
|
||||||
projector.link.pjlink_name)
|
'Projector Name'),
|
||||||
message = '%s<b>%s</b>: %s<br />' % (message, translate('OpenLP.ProjectorManager', 'Manufacturer'),
|
data=projector.link.pjlink_name)
|
||||||
projector.link.manufacturer)
|
message += '<b>{title}</b>: {data}<br />'.format(title=translate('OpenLP.ProjectorManager', 'Manufacturer'),
|
||||||
message = '%s<b>%s</b>: %s<br />' % (message, translate('OpenLP.ProjectorManager', 'Model'),
|
data=projector.link.manufacturer)
|
||||||
projector.link.model)
|
message += '<b>{title}</b>: {data}<br />'.format(title=translate('OpenLP.ProjectorManager', 'Model'),
|
||||||
message = '%s<b>%s</b>: %s<br /><br />' % (message, translate('OpenLP.ProjectorManager', 'Other info'),
|
data=projector.link.model)
|
||||||
projector.link.other_info)
|
message += '<b>{title}</b>: {data}<br /><br />'.format(title=translate('OpenLP.ProjectorManager',
|
||||||
message = '%s<b>%s</b>: %s<br />' % (message, translate('OpenLP.ProjectorManager', 'Power status'),
|
'Other info'),
|
||||||
ERROR_MSG[projector.link.power])
|
data=projector.link.other_info)
|
||||||
message = '%s<b>%s</b>: %s<br />' % (message, translate('OpenLP.ProjectorManager', 'Shutter is'),
|
message += '<b>{title}</b>: {data}<br />'.format(title=translate('OpenLP.ProjectorManager', 'Power status'),
|
||||||
translate('OpenLP.ProjectorManager', 'Closed')
|
data=ERROR_MSG[projector.link.power])
|
||||||
if projector.link.shutter else translate('OpenLP', 'Open'))
|
message += '<b>{title}</b>: {data}<br />'.format(title=translate('OpenLP.ProjectorManager', 'Shutter is'),
|
||||||
|
data=translate('OpenLP.ProjectorManager', 'Closed')
|
||||||
|
if projector.link.shutter
|
||||||
|
else translate('OpenLP', 'Open'))
|
||||||
message = '%s<b>%s</b>: %s<br />' % (message,
|
message = '%s<b>%s</b>: %s<br />' % (message,
|
||||||
translate('OpenLP.ProjectorManager', 'Current source input is'),
|
translate('OpenLP.ProjectorManager', 'Current source input is'),
|
||||||
projector.link.source)
|
projector.link.source)
|
||||||
count = 1
|
count = 1
|
||||||
for item in projector.link.lamp:
|
for item in projector.link.lamp:
|
||||||
message = '%s <b>%s %s</b> (%s) %s: %s<br />' % (message,
|
message += '<b>{title} {count}</b> {status} '.format(title=translate('OpenLP.ProjectorManager',
|
||||||
translate('OpenLP.ProjectorManager', 'Lamp'),
|
'Lamp'),
|
||||||
count,
|
count=count,
|
||||||
translate('OpenLP.ProjectorManager', 'On')
|
status=translate('OpenLP.ProjectorManager',
|
||||||
if item['On']
|
' is on')
|
||||||
else translate('OpenLP.ProjectorManager', 'Off'),
|
if item['On']
|
||||||
translate('OpenLP.ProjectorManager', 'Hours'),
|
else translate('OpenLP.ProjectorManager',
|
||||||
item['Hours'])
|
'is off'))
|
||||||
count = count + 1
|
|
||||||
message = '%s<hr /><br />' % message
|
message += '<b>{title}</b>: {hours}<br />'.format(title=translate('OpenLP.ProjectorManager', 'Hours'),
|
||||||
|
hours=item['Hours'])
|
||||||
|
count += 1
|
||||||
|
message += '<hr /><br />'
|
||||||
if projector.link.projector_errors is None:
|
if projector.link.projector_errors is None:
|
||||||
message = '%s%s' % (message, translate('OpenLP.ProjectorManager', 'No current errors or warnings'))
|
message += translate('OpenLP.ProjectorManager', 'No current errors or warnings')
|
||||||
else:
|
else:
|
||||||
message = '%s<b>%s</b>' % (message, translate('OpenLP.ProjectorManager', 'Current errors/warnings'))
|
message += '<b>{data}</b>'.format(data=translate('OpenLP.ProjectorManager', 'Current errors/warnings'))
|
||||||
for (key, val) in projector.link.projector_errors.items():
|
for (key, val) in projector.link.projector_errors.items():
|
||||||
message = '%s<b>%s</b>: %s<br />' % (message, key, ERROR_MSG[val])
|
message += '<b>{key}</b>: {data}<br />'.format(key=key, data=ERROR_MSG[val])
|
||||||
QtWidgets.QMessageBox.information(self, translate('OpenLP.ProjectorManager', 'Projector Information'), message)
|
QtWidgets.QMessageBox.information(self, translate('OpenLP.ProjectorManager', 'Projector Information'), message)
|
||||||
|
|
||||||
def _add_projector(self, projector):
|
def _add_projector(self, projector):
|
||||||
@ -743,7 +749,7 @@ class ProjectorManager(OpenLPMixin, RegistryMixin, QWidget, Ui_ProjectorManager,
|
|||||||
if start:
|
if start:
|
||||||
item.link.connect_to_host()
|
item.link.connect_to_host()
|
||||||
for item in self.projector_list:
|
for item in self.projector_list:
|
||||||
log.debug('New projector list - item: (%s) %s' % (item.link.ip, item.link.name))
|
log.debug('New projector list - item: ({ip}) {name}'.format(ip=item.link.ip, name=item.link.name))
|
||||||
|
|
||||||
@pyqtSlot(str)
|
@pyqtSlot(str)
|
||||||
def add_projector_from_wizard(self, ip, opts=None):
|
def add_projector_from_wizard(self, ip, opts=None):
|
||||||
@ -753,7 +759,7 @@ class ProjectorManager(OpenLPMixin, RegistryMixin, QWidget, Ui_ProjectorManager,
|
|||||||
:param ip: IP address of new record item to find
|
:param ip: IP address of new record item to find
|
||||||
:param opts: Needed by PyQt5
|
:param opts: Needed by PyQt5
|
||||||
"""
|
"""
|
||||||
log.debug('add_projector_from_wizard(ip=%s)' % ip)
|
log.debug('add_projector_from_wizard(ip={ip})'.format(ip=ip))
|
||||||
item = self.projectordb.get_projector_by_ip(ip)
|
item = self.projectordb.get_projector_by_ip(ip)
|
||||||
self.add_projector(item)
|
self.add_projector(item)
|
||||||
|
|
||||||
@ -764,7 +770,7 @@ class ProjectorManager(OpenLPMixin, RegistryMixin, QWidget, Ui_ProjectorManager,
|
|||||||
|
|
||||||
:param projector: Projector() instance of projector with updated information
|
:param projector: Projector() instance of projector with updated information
|
||||||
"""
|
"""
|
||||||
log.debug('edit_projector_from_wizard(ip=%s)' % projector.ip)
|
log.debug('edit_projector_from_wizard(ip={ip})'.format(ip=projector.ip))
|
||||||
self.old_projector.link.name = projector.name
|
self.old_projector.link.name = projector.name
|
||||||
self.old_projector.link.ip = projector.ip
|
self.old_projector.link.ip = projector.ip
|
||||||
self.old_projector.link.pin = None if projector.pin == '' else projector.pin
|
self.old_projector.link.pin = None if projector.pin == '' else projector.pin
|
||||||
@ -816,7 +822,9 @@ class ProjectorManager(OpenLPMixin, RegistryMixin, QWidget, Ui_ProjectorManager,
|
|||||||
else:
|
else:
|
||||||
status_code = status
|
status_code = status
|
||||||
message = ERROR_MSG[status] if msg is None else msg
|
message = ERROR_MSG[status] if msg is None else msg
|
||||||
log.debug('(%s) updateStatus(status=%s) message: "%s"' % (item.link.name, status_code, message))
|
log.debug('({name}) updateStatus(status={status}) message: "{message}"'.format(name=item.link.name,
|
||||||
|
status=status_code,
|
||||||
|
message=message))
|
||||||
if status in STATUS_ICONS:
|
if status in STATUS_ICONS:
|
||||||
if item.status == status:
|
if item.status == status:
|
||||||
return
|
return
|
||||||
@ -826,14 +834,14 @@ class ProjectorManager(OpenLPMixin, RegistryMixin, QWidget, Ui_ProjectorManager,
|
|||||||
status_code = ERROR_STRING[status]
|
status_code = ERROR_STRING[status]
|
||||||
elif status in STATUS_STRING:
|
elif status in STATUS_STRING:
|
||||||
status_code = STATUS_STRING[status]
|
status_code = STATUS_STRING[status]
|
||||||
log.debug('(%s) Updating icon with %s' % (item.link.name, status_code))
|
log.debug('({name}) Updating icon with {code}'.format(name=item.link.name, code=status_code))
|
||||||
item.widget.setIcon(item.icon)
|
item.widget.setIcon(item.icon)
|
||||||
self.update_icons()
|
self.update_icons()
|
||||||
|
|
||||||
def get_toolbar_item(self, name, enabled=False, hidden=False):
|
def get_toolbar_item(self, name, enabled=False, hidden=False):
|
||||||
item = self.one_toolbar.findChild(QtWidgets.QAction, name)
|
item = self.one_toolbar.findChild(QtWidgets.QAction, name)
|
||||||
if item == 0:
|
if item == 0:
|
||||||
log.debug('No item found with name "%s"' % name)
|
log.debug('No item found with name "{name}"'.format(name=name))
|
||||||
return
|
return
|
||||||
item.setVisible(False if hidden else True)
|
item.setVisible(False if hidden else True)
|
||||||
item.setEnabled(True if enabled else False)
|
item.setEnabled(True if enabled else False)
|
||||||
@ -918,11 +926,12 @@ class ProjectorManager(OpenLPMixin, RegistryMixin, QWidget, Ui_ProjectorManager,
|
|||||||
|
|
||||||
:param name: Name from QListWidgetItem
|
:param name: Name from QListWidgetItem
|
||||||
"""
|
"""
|
||||||
QtWidgets.QMessageBox.warning(self, translate('OpenLP.ProjectorManager',
|
title = '"{name} {message}" '.format(name=name,
|
||||||
'"%s" Authentication Error' % name),
|
message=translate('OpenLP.ProjectorManager', 'Authentication Error'))
|
||||||
|
QtWidgets.QMessageBox.warning(self, title,
|
||||||
'<br />There was an authentication error while trying to connect.'
|
'<br />There was an authentication error while trying to connect.'
|
||||||
'<br /><br />Please verify your PIN setting '
|
'<br /><br />Please verify your PIN setting '
|
||||||
'for projector item "%s"' % name)
|
'for projector item "{name}"'.format(name=name))
|
||||||
|
|
||||||
@pyqtSlot(str)
|
@pyqtSlot(str)
|
||||||
def no_authentication_error(self, name):
|
def no_authentication_error(self, name):
|
||||||
@ -932,11 +941,12 @@ class ProjectorManager(OpenLPMixin, RegistryMixin, QWidget, Ui_ProjectorManager,
|
|||||||
|
|
||||||
:param name: Name from QListWidgetItem
|
:param name: Name from QListWidgetItem
|
||||||
"""
|
"""
|
||||||
QtWidgets.QMessageBox.warning(self, translate('OpenLP.ProjectorManager',
|
title = '"{name} {message}" '.format(name=name,
|
||||||
'"%s" No Authentication Error' % name),
|
message=translate('OpenLP.ProjectorManager', 'No Authentication Error'))
|
||||||
|
QtWidgets.QMessageBox.warning(self, title,
|
||||||
'<br />PIN is set and projector does not require authentication.'
|
'<br />PIN is set and projector does not require authentication.'
|
||||||
'<br /><br />Please verify your PIN setting '
|
'<br /><br />Please verify your PIN setting '
|
||||||
'for projector item "%s"' % name)
|
'for projector item "{name}"'.format(name=name))
|
||||||
|
|
||||||
|
|
||||||
class ProjectorItem(QObject):
|
class ProjectorItem(QObject):
|
||||||
@ -972,5 +982,5 @@ def not_implemented(function):
|
|||||||
QtWidgets.QMessageBox.information(None,
|
QtWidgets.QMessageBox.information(None,
|
||||||
translate('OpenLP.ProjectorManager', 'Not Implemented Yet'),
|
translate('OpenLP.ProjectorManager', 'Not Implemented Yet'),
|
||||||
translate('OpenLP.ProjectorManager',
|
translate('OpenLP.ProjectorManager',
|
||||||
'Function "%s"<br />has not been implemented yet.'
|
'Function "{function}"<br />has not been implemented yet.'
|
||||||
'<br />Please check back again later.' % function))
|
'<br />Please check back again later.'.format(function=function)))
|
||||||
|
@ -115,7 +115,7 @@ def Build_Tab(group, source_key, default, projector, projectordb, edit=False):
|
|||||||
if edit:
|
if edit:
|
||||||
for key in sourcelist:
|
for key in sourcelist:
|
||||||
item = QLineEdit()
|
item = QLineEdit()
|
||||||
item.setObjectName('source_key_%s' % key)
|
item.setObjectName('source_key_{key}'.format(key=key))
|
||||||
source_item = projectordb.get_source_by_code(code=key, projector_id=projector.db_item.id)
|
source_item = projectordb.get_source_by_code(code=key, projector_id=projector.db_item.id)
|
||||||
if source_item is None:
|
if source_item is None:
|
||||||
item.setText(PJLINK_DEFAULT_CODES[key])
|
item.setText(PJLINK_DEFAULT_CODES[key])
|
||||||
@ -161,7 +161,7 @@ def set_button_tooltip(bar):
|
|||||||
button.setToolTip(translate('OpenLP.SourceSelectForm',
|
button.setToolTip(translate('OpenLP.SourceSelectForm',
|
||||||
'Save changes and return to OpenLP'))
|
'Save changes and return to OpenLP'))
|
||||||
else:
|
else:
|
||||||
log.debug('No tooltip for button {}'.format(button.text()))
|
log.debug('No tooltip for button {text}'.format(text=button.text()))
|
||||||
|
|
||||||
|
|
||||||
class FingerTabBarWidget(QTabBar):
|
class FingerTabBarWidget(QTabBar):
|
||||||
@ -359,16 +359,20 @@ class SourceSelectTabs(QDialog):
|
|||||||
continue
|
continue
|
||||||
item = self.projectordb.get_source_by_code(code=code, projector_id=projector.id)
|
item = self.projectordb.get_source_by_code(code=code, projector_id=projector.id)
|
||||||
if item is None:
|
if item is None:
|
||||||
log.debug("(%s) Adding new source text %s: %s" % (projector.ip, code, text))
|
log.debug("({ip}) Adding new source text {code}: {text}".format(ip=projector.ip,
|
||||||
|
code=code,
|
||||||
|
text=text))
|
||||||
item = ProjectorSource(projector_id=projector.id, code=code, text=text)
|
item = ProjectorSource(projector_id=projector.id, code=code, text=text)
|
||||||
else:
|
else:
|
||||||
item.text = text
|
item.text = text
|
||||||
log.debug('(%s) Updating source code %s with text="%s"' % (projector.ip, item.code, item.text))
|
log.debug('({ip}) Updating source code {code} with text="{text}"'.format(ip=projector.ip,
|
||||||
|
code=item.code,
|
||||||
|
text=item.text))
|
||||||
self.projectordb.add_source(item)
|
self.projectordb.add_source(item)
|
||||||
selected = 0
|
selected = 0
|
||||||
else:
|
else:
|
||||||
selected = self.button_group.checkedId()
|
selected = self.button_group.checkedId()
|
||||||
log.debug('SourceSelectTabs().accepted() Setting source to %s' % selected)
|
log.debug('SourceSelectTabs().accepted() Setting source to {selected}'.format(selected=selected))
|
||||||
self.done(selected)
|
self.done(selected)
|
||||||
|
|
||||||
|
|
||||||
@ -417,7 +421,7 @@ class SourceSelectSingle(QDialog):
|
|||||||
if self.edit:
|
if self.edit:
|
||||||
for key in keys:
|
for key in keys:
|
||||||
item = QLineEdit()
|
item = QLineEdit()
|
||||||
item.setObjectName('source_key_%s' % key)
|
item.setObjectName('source_key_{key}'.format(key=key))
|
||||||
source_item = self.projectordb.get_source_by_code(code=key, projector_id=self.projector.db_item.id)
|
source_item = self.projectordb.get_source_by_code(code=key, projector_id=self.projector.db_item.id)
|
||||||
if source_item is None:
|
if source_item is None:
|
||||||
item.setText(PJLINK_DEFAULT_CODES[key])
|
item.setText(PJLINK_DEFAULT_CODES[key])
|
||||||
@ -498,14 +502,18 @@ class SourceSelectSingle(QDialog):
|
|||||||
continue
|
continue
|
||||||
item = self.projectordb.get_source_by_code(code=code, projector_id=projector.id)
|
item = self.projectordb.get_source_by_code(code=code, projector_id=projector.id)
|
||||||
if item is None:
|
if item is None:
|
||||||
log.debug("(%s) Adding new source text %s: %s" % (projector.ip, code, text))
|
log.debug("({ip}) Adding new source text {code}: {text}".format(ip=projector.ip,
|
||||||
|
code=code,
|
||||||
|
text=text))
|
||||||
item = ProjectorSource(projector_id=projector.id, code=code, text=text)
|
item = ProjectorSource(projector_id=projector.id, code=code, text=text)
|
||||||
else:
|
else:
|
||||||
item.text = text
|
item.text = text
|
||||||
log.debug('(%s) Updating source code %s with text="%s"' % (projector.ip, item.code, item.text))
|
log.debug('({ip}) Updating source code {code} with text="{text}"'.format(ip=projector.ip,
|
||||||
|
code=item.code,
|
||||||
|
text=item.text))
|
||||||
self.projectordb.add_source(item)
|
self.projectordb.add_source(item)
|
||||||
selected = 0
|
selected = 0
|
||||||
else:
|
else:
|
||||||
selected = self.button_group.checkedId()
|
selected = self.button_group.checkedId()
|
||||||
log.debug('SourceSelectDialog().accepted() Setting source to %s' % selected)
|
log.debug('SourceSelectDialog().accepted() Setting source to {selected}'.format(selected=selected))
|
||||||
self.done(selected)
|
self.done(selected)
|
||||||
|
@ -124,3 +124,30 @@ class TestPJLink(TestCase):
|
|||||||
'Lamp power status should have been set to TRUE')
|
'Lamp power status should have been set to TRUE')
|
||||||
self.assertEquals(pjlink.lamp[0]['Hours'], 22222,
|
self.assertEquals(pjlink.lamp[0]['Hours'], 22222,
|
||||||
'Lamp hours should have been set to 22222')
|
'Lamp hours should have been set to 22222')
|
||||||
|
|
||||||
|
@patch.object(pjlink_test, 'projectorReceivedData')
|
||||||
|
def projector_process_multiple_lamp_test(self, mock_projectorReceivedData):
|
||||||
|
"""
|
||||||
|
Test setting multiple lamp on/off and hours
|
||||||
|
"""
|
||||||
|
# GIVEN: Test object
|
||||||
|
pjlink = pjlink_test
|
||||||
|
|
||||||
|
# WHEN: Call process_command with lamp data
|
||||||
|
pjlink.process_command('LAMP', '11111 1 22222 0 33333 1')
|
||||||
|
|
||||||
|
# THEN: Lamp should have been set with proper lamp status
|
||||||
|
self.assertEquals(len(pjlink.lamp), 3,
|
||||||
|
'Projector should have 3 lamps specified')
|
||||||
|
self.assertEquals(pjlink.lamp[0]['On'], True,
|
||||||
|
'Lamp 1 power status should have been set to TRUE')
|
||||||
|
self.assertEquals(pjlink.lamp[0]['Hours'], 11111,
|
||||||
|
'Lamp 1 hours should have been set to 11111')
|
||||||
|
self.assertEquals(pjlink.lamp[1]['On'], False,
|
||||||
|
'Lamp 2 power status should have been set to FALSE')
|
||||||
|
self.assertEquals(pjlink.lamp[1]['Hours'], 22222,
|
||||||
|
'Lamp 2 hours should have been set to 22222')
|
||||||
|
self.assertEquals(pjlink.lamp[2]['On'], True,
|
||||||
|
'Lamp 3 power status should have been set to TRUE')
|
||||||
|
self.assertEquals(pjlink.lamp[2]['Hours'], 33333,
|
||||||
|
'Lamp 3 hours should have been set to 33333')
|
||||||
|
Loading…
Reference in New Issue
Block a user