QT Testing/en: Unterschied zwischen den Versionen
| Alkurz (Diskussion | Beiträge)  (Weiterleitung nach QT Testing erstellt) Markierung: Neue Weiterleitung | Alkurz (Diskussion | Beiträge)   (Weiterleitung auf QT Testing entfernt) Markierung: Entfernte Weiterleitung | ||
| Zeile 1: | Zeile 1: | ||
| ==Pre-requisites== | |||
| #redirect [[QT_Testing]] | |||
| ===QT download=== | |||
| https://www.qt.io/download  | |||
| ===Supported versions=== | |||
| Expecco supports testing of QT applications on Windows and Linux created with '''QT version 5'''. | |||
| For the different QT versions, development environments (VisualStudio, ...) and computer architecture (32/64 bit) we provide specially created libraries (dll, so). Some of them are delivered with expecco by default. For other versions we generate the library on request. | |||
| ==Testing QT programs== | |||
| ===Test preparations=== | |||
| To test a QT program with expecco, the library expeccoTestService.[dll/so] delivered by us is included in the program to be tested. This is done via a batch or shell script without intervention in the source code of the program to be tested ([[Qt Inject Windows/en#Inject expeccoTestService-Library|Description]]). | |||
| Alternatively, the ExpeccoTestService library call can be inserted into the source code of the application under test ([[Qt Inject Windows/en#Insert into Source Code|Description]]). | |||
| ====Start parameter==== | |||
| The ExpeccoTestService library can be set via environment variables: | |||
| * Log level: <code>ETS_QT_LOG_LEVEL</code> (default value: 0, for logging: 2). | |||
| * Log file: <code>ETS_QT_LOG_FILE</code> (default value: c:\Windows\temp\etsQt.log or /tmp/etsQt.log). | |||
| * Server port: <code>ETS_QT_PORT_NUMBER</code> (default value: 8866). | |||
| <!-- * Timeout preview in ms (QT-Quick): <code>ETS_TIMEOUT_QUICK_IMAGE</code> (default value 200) --> | |||
| ====Required QT libraries at runtime==== | |||
| The ExpeccoTestService library depends on the following QT libraries: | |||
| * Qt5Core | |||
| * Qt5Gui | |||
| * Qt5Network | |||
| * Qt5QmlModels | |||
| * Qt5Qml | |||
| * Qt5Quick | |||
| * Qt5Widgets | |||
| ===Connecting with expecco GUI Browser=== | |||
| The GUI Browser can be used to connect to the program under test: | |||
| <code>Connect</code> - <code>Qt</code>. | |||
| In the following dialog, enter the network address of the computer running the application and the port for the connection (8866 by default). | |||
| ==Testing QT-Quick/QML programs== | |||
| QT-QML applications can be tested with the expecco QTLibrary starting with expecco 21.2. | |||
| ===QT-Quick/QML-Aktionen=== | |||
| For testing QT-Quick/QML programs almost all actions of the QTLibrary can be used, which are defined for testing QT programs based on QWidget / QApplication.  | |||
| These actions for QML testing are labeled / tagged <code>qt-quick</code>. To make this clear on the blocks, they can be displayed with a configurable color ([[Settings TagColorSettings/en|Extras - Settings - Look & Feel - Colors per label (tag)]]). | |||
| QWidget actions are applicable to QT Quick items derived from QQuickItem. | |||
| QQuickItemView actions are applicable to Qt-Quick list items. | |||
| The different handling is encapsulated by the ExpeccoTestService. Thus, the action and the input and output pins remain the same for both QT technologies. | |||
| ===QT-Quick/QML peculiarities=== | |||
| ====Control via Properties==== | |||
| Basis of all QT-Quick/QML interface elements is QQuickItem. Via Properties most of the properties can be set. From QQuickItem there is a multiplicity of derivations. Expecco for it no special building blocks represent, the elements are however controllable over their properties. | |||
| {| class="wikitable" | |||
| ! QT-Quick element !! property !! Comment | |||
| |- | |||
| | Tumbler || currentIndex ||  | |||
| |- | |||
| | Switch|| checked || Suitable actions:<br><code>QCheckButton::GetState</code><br><code>QCheckButton::SetState = %2</code> | |||
| |- | |||
| |colspan="3"| will be continued | |||
| |- | |||
| |} | |||
| ====Actions for selected element==== | |||
| Display actions for GUI elements is not comprehensive because QT-Quick/QML has no predefined elements. | |||
| ====Not yet implemented==== | |||
| * TreeView | |||
| * Menu | |||
| * Selection of cells - so far only one row can be selected | |||
| ==Qt Known Problems== | |||
| ===QApplication::ShortCutEvent=== | |||
| Due to internal changes in QT version 5, the module no longer works. A workaround is to send the key events separately, as shown in the example in the Test/Demo tab of the action. | |||
| ---- | |||
| Back to [[Qt Plugin Reference/en|Qt Plugin Reference]] | |||
Version vom 29. November 2021, 18:40 Uhr
Inhaltsverzeichnis
Pre-requisites[Bearbeiten]
QT download[Bearbeiten]
Supported versions[Bearbeiten]
Expecco supports testing of QT applications on Windows and Linux created with QT version 5.
For the different QT versions, development environments (VisualStudio, ...) and computer architecture (32/64 bit) we provide specially created libraries (dll, so). Some of them are delivered with expecco by default. For other versions we generate the library on request.
Testing QT programs[Bearbeiten]
Test preparations[Bearbeiten]
To test a QT program with expecco, the library expeccoTestService.[dll/so] delivered by us is included in the program to be tested. This is done via a batch or shell script without intervention in the source code of the program to be tested (Description).
Alternatively, the ExpeccoTestService library call can be inserted into the source code of the application under test (Description).
Start parameter[Bearbeiten]
The ExpeccoTestService library can be set via environment variables:
- Log level: ETS_QT_LOG_LEVEL(default value: 0, for logging: 2).
- Log file: ETS_QT_LOG_FILE(default value: c:\Windows\temp\etsQt.log or /tmp/etsQt.log).
- Server port: ETS_QT_PORT_NUMBER(default value: 8866).
Required QT libraries at runtime[Bearbeiten]
The ExpeccoTestService library depends on the following QT libraries:
- Qt5Core
- Qt5Gui
- Qt5Network
- Qt5QmlModels
- Qt5Qml
- Qt5Quick
- Qt5Widgets
Connecting with expecco GUI Browser[Bearbeiten]
The GUI Browser can be used to connect to the program under test:
Connect - Qt.
In the following dialog, enter the network address of the computer running the application and the port for the connection (8866 by default).
Testing QT-Quick/QML programs[Bearbeiten]
QT-QML applications can be tested with the expecco QTLibrary starting with expecco 21.2.
QT-Quick/QML-Aktionen[Bearbeiten]
For testing QT-Quick/QML programs almost all actions of the QTLibrary can be used, which are defined for testing QT programs based on QWidget / QApplication.
These actions for QML testing are labeled / tagged qt-quick. To make this clear on the blocks, they can be displayed with a configurable color (Extras - Settings - Look & Feel - Colors per label (tag)).
QWidget actions are applicable to QT Quick items derived from QQuickItem. QQuickItemView actions are applicable to Qt-Quick list items.
The different handling is encapsulated by the ExpeccoTestService. Thus, the action and the input and output pins remain the same for both QT technologies.
QT-Quick/QML peculiarities[Bearbeiten]
Control via Properties[Bearbeiten]
Basis of all QT-Quick/QML interface elements is QQuickItem. Via Properties most of the properties can be set. From QQuickItem there is a multiplicity of derivations. Expecco for it no special building blocks represent, the elements are however controllable over their properties.
| QT-Quick element | property | Comment | 
|---|---|---|
| Tumbler | currentIndex | |
| Switch | checked | Suitable actions: QCheckButton::GetStateQCheckButton::SetState = %2 | 
| will be continued | ||
Actions for selected element[Bearbeiten]
Display actions for GUI elements is not comprehensive because QT-Quick/QML has no predefined elements.
Not yet implemented[Bearbeiten]
- TreeView
- Menu
- Selection of cells - so far only one row can be selected
Qt Known Problems[Bearbeiten]
QApplication::ShortCutEvent[Bearbeiten]
Due to internal changes in QT version 5, the module no longer works. A workaround is to send the key events separately, as shown in the example in the Test/Demo tab of the action.
Back to Qt Plugin Reference
