Metadata-Version: 2.1
Name: qtchecker
Version: 0.2.0
Summary: Live image viewer application for photon science detectors.
Home-page: https://github.com/jkotan/qtchecker
Author: J.Kotanski
Author-email: jan.kotanski@desy.de
License: GPLv2
Keywords: pyqt gui test checker helper
Platform: UNKNOWN
Classifier: Development Status :: 5 - Production/Stable
Classifier: Intended Audience :: Science/Research
Classifier: Topic :: Scientific/Engineering :: Physics
Classifier: Topic :: Software Development :: Libraries :: Python Modules
Classifier: License :: OSI Approved :: GNU General Public License v2 (GPLv2)
Classifier: Programming Language :: Python :: 2.7
Classifier: Programming Language :: Python :: 3
Classifier: Programming Language :: Python :: 3.4
Classifier: Programming Language :: Python :: 3.5
Classifier: Programming Language :: Python :: 3.6
Classifier: Programming Language :: Python :: 3.7

Qt Checker
==========

Authors: Jan Kotański <jan.kotanski at desy.de>

Introduction
------------

This is a simple helper module to perform PyQt GUI tests.

| Source code: https://github.com/jkotan/qtchecker
| Project Web page: https://jkotan.github.io/qtchecker
|


With the ``qtchecker`` module its user

1. creates ``QtChecker`` object  with the global QApplication object and a given tested QWidget dialog parameters
2. defines a sequence of checks with ``setChecks()`` method and the following helper classes:

- ``AttrCheck``  - read a tested dialog attribute value
- ``CmdCheck`` - execute a tested dialog command and read its result value
- ``WrapAttrCheck`` - execute a wrapper command on a tested dialog attribute
- ``WrapCmdCheck`` - execute a wrapper command on a result value of a tested dialog command
- ``ExtAttrCheck`` - read an external attribute value defined outside the dialog
- ``ExtCmdCheck`` - execute an external command defined outside the dialog and read its result value

3. starts event loop and performs checkes with ``executeChecks()`` or  ``executeChecksAndClose()`` method
4. compare results by reading ``results`` attribute of executing

for example

.. code-block:: python

    import unittest

    from PyQt5 import QtGui
    from PyQt5 import QtCore
    from PyQt5 import QtTest

    from qtchecker.qtChecker import QtChecker, CmdCheck, WrapAttrCheck, ExtCmdCheck

    # import my dialog module
    from lavuelib import liveViewer


    # QApplication object should be one for all tess
    app = QtGui.QApplication([])


    class GuiTest(unittest.TestCase):

        def __init__(self, methodName):
            unittest.TestCase.__init__(self, methodName)

	def test_run(self):

	    # my tested MainWindow dialog
	    dialog = liveViewer.MainWindow()
	    dialog.show()

	    # create QtChecker object
	    qtck = QtChecker(app, dialog)

	    # define a sequence of action of the dialog
	    qtck.setChecks([
		# read return value of execute isConnected command
		CmdCheck(
		    # a python path to a method executed in the first action
		    "_MainWindow__lavue._LiveViewer__sourcewg.isConnected"
		),
		# click pushButton with the left-mouse-click
		WrapAttrCheck(
		    # a python path to an pushButton object
		    "_MainWindow__lavue._LiveViewer__sourcewg._SourceTabWidget__sourcetabs[],0._ui.pushButton",
		    # Wrapper command to be executed on the action object
		    QtTest.QTest.mouseClick,
		    # additional parameters of the wrapper command
		    [QtCore.Qt.LeftButton]
		),
		# read a result of external "getLAvueState" command
		ExtCmdCheck(
		    # parent object of the external command
		    self,
		    # external command name
		    "getLavueState"
		),
	    ])

	    # execute the check actions and close the dialog
	    status = qtck.executeChecksAndClose()
	    self.assertEqual(status, 0)

	    # compare results returned by each action
	    qtck.compareResults(self,
		[
		    # a result of isConnected() command
		    True,
		    # a result of the mouseClick on the pushButton
		    None,
		    # a result of getLavueState() command
		    '{"connected": false}'
		]
	    )

       def getLavueState(self):
           """ an external command """

           import tango
           return tango.DeviceProxy("po/lavuecontroller/1").LavueState



More examples can be found at like `LavueTests
<https://github.com/jkotan/lavue/blob/develop/test/CommandLineArgument_test.py/>`_
or `LavueStateTests
<https://github.com/jkotan/lavue/blob/develop/test/CommandLineLavueState_test.py/>`_.

Installation
------------

QtChecker requires the following python packages: ``qt4`` or  ``qt5`` or ``pyqtgraph``.



From sources
""""""""""""

Download the latest QtChecker version from https://github.com/jkotan/qtchecker

Extract sources and run

.. code-block:: console

   $ python setup.py install

The ``setup.py`` script may need: ``setuptools  sphinx`` python packages as well as ``qtbase5-dev-tools`` or ``libqt4-dev-bin``.

Debian packages
"""""""""""""""

Debian `buster` and `stretch` or Ubuntu  `focal`, `eoan`, `bionic` packages can be found in the HDRI repository.

To install the debian packages, add the PGP repository key

.. code-block:: console

   $ sudo su
   $ wget -q -O - http://repos.pni-hdri.de/debian_repo.pub.gpg | apt-key add -

and then download the corresponding source list, e.g.

.. code-block:: console

   $ cd /etc/apt/sources.list.d

and

.. code-block:: console

   $ wget http://repos.pni-hdri.de/buster-pni-hdri.list

or

.. code-block:: console

   $ wget http://repos.pni-hdri.de/stretch-pni-hdri.list

or

.. code-block:: console

   $ wget http://repos.pni-hdri.de/focal-pni-hdri.list

respectively.

Finally,

.. code-block:: console

   $ apt-get update
   $ apt-get install python-qtchecker

.. code-block:: console

   $ apt-get update
   $ apt-get install python3-qtchecker

for python 3 version.

From pip
""""""""

To install it from pip you need to install pyqt5 in advance, e.g.

.. code-block:: console

   $ python3 -m venv myvenv
   $ . myvenv/bin/activate

   $ pip install pyqt5

   $ pip install qtchecker


