Qt Metrics 2 Description: Difference between revisions

From Qt Wiki
Jump to navigation Jump to search
m (Resized database picture as thumb)
(Edits in Introduction)
Line 1: Line 1:
'''''UNDER CONSTRUCTION'''''
 
{| class="wikitable"
|-
| '''UNDER CONSTRUCTION'''
|}


== INTRODUCTION ==
== INTRODUCTION ==


TBD
The Qt Metrics 2 web portal visualizes the progress of Qt's quality, focusing on Continuous Integration (CI). The goal is to automate laborious manual work that is required, for example, in the CI release cycle, to report the key information, as well as providing real time data with good performance. The Qt integration teams (in The Qt Company) and the global Qt developer community are the target audience.
 
The Qt Metrics web portal visualizes the progress of Qt's quality, focusing on Continuous Integration (CI), code coverage, autotest, release test automation, manual test metrics, and other reports later on. The goal is to automate laborious manual work that is required, for example, in the CI release cycle, to report the key information, as well as providing real time data with good performance. The Qt integration teams (in Digia) and the global Qt developer community are the target audience.


'''Qt Metrics:''' http://testresults.qt.io/qtmetrics-dev/new/ ''(Note: this is a development version)''<br>
'''Qt Metrics 2:''' http://testresults.qt.io/qtmetrics-dev/new/ ''(Note: this is a development version)''<br>
'''Version:''' This document is updated against the report builder v2.8
'''Version:''' This document is updated against the report builder v0.20


This document is divided in chapters; each chapter having its own purpose and target audience: <br>
This document is divided in chapters; each chapter having its own purpose and target audience: <br>
Line 17: Line 19:
=== System Overview ===
=== System Overview ===


TBD
The Qt Metrics system consists of three main components: the parser, the report builder and the database. See the picture below. The parser reads the build logs, test results, or other files that are created in the development and integration process, and pushes the data into the database. The report builder reads the data from the database, and shows predefined metrics and reports based on user's area of interest. The report builder with PHP (Slim framework), Twitter Bootstrap, HTML, CSS, and JavaScript with some jQuery and D3 graphics components. The parser is implemented with Perl (implementation for the 'new-CI' not done yet and solution therefore still open). The database is a MariaDB database.
 
The Qt Metrics system consists of three main components: the parser, the report builder and the database. See Picture 1. The parser reads the build logs, test results, or other files that are created in the development process, and pushes the data into the database. The report builder reads the data from the database, and shows predefined metrics and reports where the user is able to scope and filter the information from. The parser is implemented with Perl and the report builder with HTML, CSS, PHP and Ajax with some jQuery UI and D3 graphics components. The database is a MySQL database.


[[Image:Qtmetricssystem.png]]
[[Image:Qtmetricssystem.png]]
<br>''PICTURE. Generic system architecture''
<br>''PICTURE. Generic system architecture''


<br>
----
----


=== Requirements and Target Audience ===
=== Requirements and Target Audience ===


TBD
{| class="wikitable"
|-
| '''TBD'''
|}


<br>
----
----


Line 38: Line 43:
=== Report Builder Overview ===
=== Report Builder Overview ===


TBD
{| class="wikitable"
|-
| '''TBD'''
|}


The report builder is a collection of PHP files running on the testresults server (running Apache) on the qt.io domain. It utilizes Ajax, JavaScript, and HTML/CSS (HTML5/CSS3 for some visual appearance). Picture 2 below describes the logical elements and functionality of the report builder (please note that the latest changes may not be reflected in all the pictures in this document).
The report builder is a collection of PHP files running on the testresults server (running Apache) on the qt.io domain. It utilizes Ajax, JavaScript, and HTML/CSS (HTML5/CSS3 for some visual appearance). Picture 2 below describes the logical elements and functionality of the report builder (please note that the latest changes may not be reflected in all the pictures in this document).
Line 44: Line 52:
=== Use Cases ===
=== Use Cases ===


TBD
{| class="wikitable"
|-
| '''TBD'''
|}


List roles incl admin.
List roles incl admin.


<br>
----
----


Line 53: Line 65:


This section discusses the Qt Metrics system components and their implementation into a certain level of detail. The target audience is the SW designer(s) maintaining and developing the system.
This section discusses the Qt Metrics system components and their implementation into a certain level of detail. The target audience is the SW designer(s) maintaining and developing the system.


=== Report Builder ===
=== Report Builder ===


TBD
{| class="wikitable"
|-
| '''TBD'''
|}


The report builder implementation consists of one metrics page (CI metrics) having a filter box, status box, and two metrics boxes (Project dashboard and Autotest dashboard). The file structure of the implementation is described in Picture 6 and Picture 7 (complete list of files shown in Table 2 Directories and files).
The report builder implementation consists of one metrics page (CI metrics) having a filter box, status box, and two metrics boxes (Project dashboard and Autotest dashboard). The file structure of the implementation is described in Picture 6 and Picture 7 (complete list of files shown in Table 2 Directories and files).
Line 63: Line 77:
=== Database ===
=== Database ===


The database is a MySQL database, and all tables use MyISAM storage engine. The database is running on the Qt testresults server on the qt.io domain.
The database is a MariaDB database, and all tables use MyISAM storage engine. The database is running on the Qt testresults server on the qt.io domain.


[[Image:Qtmetrics2_db_design.png|1280px|thumb|left|PICTURE. Database tables, their fields, and field types]]
[[Image:Qtmetrics2_db_design.png|1280px|thumb|left|PICTURE. Database tables, their fields, and field types]]
Line 160: Line 174:
=== Parser ===
=== Parser ===


TBD (are all methods available)
{| class="wikitable"
|-
| '''TBD'''
|}
(are all methods available?)


New data is added to the database only by the parser. For CI, data is inserted from the new log files when a new build has completed. This method is called a “single scan”. The data already in the database is never updated since build results never change after a build. However, if there is a need for example to add a new database field or to change a field type, the whole database must be rebuilt from the log files. This method is referred as a “full scan”. There is also a “catch up” method to compare the database against the build log files residing in the server, and to add the possibly missing data. This is needed for example if single scan operations failed for some reason.
New data is added to the database only by the parser. For CI, data is inserted from the new log files when a new build has completed. This method is called a “single scan”. The data already in the database is never updated since build results never change after a build. However, if there is a need for example to add a new database field or to change a field type, the whole database must be rebuilt from the log files. This method is referred as a “full scan”. There is also a “catch up” method to compare the database against the build log files residing in the server, and to add the possibly missing data. This is needed for example if single scan operations failed for some reason.
Line 167: Line 185:
=== Key Functionality ===
=== Key Functionality ===


TBD
{| class="wikitable"
|-
| '''TBD'''
|}


===  JavaScript Libraries ===
===  JavaScript Libraries ===


TBD from https://qt-metrics-jusippol.c9.io/app-design.php
{| class="wikitable"
|-
| '''TBD'''
|}
(from https://qt-metrics-jusippol.c9.io/app-design.php)


====  D3 ====
====  D3 ====
Line 185: Line 210:
==== Twitter Bootstrap ====
==== Twitter Bootstrap ====


<br>
----
----


Line 192: Line 218:


=== Directory Structure and Naming Conventions ===
=== Directory Structure and Naming Conventions ===
{| class="wikitable"
|-
| '''TBD'''
|}
(from https://qt-metrics-jusippol.c9.io/app-design.php)


The list of current directories are shown below.
The list of current directories are shown below.
TBD from https://qt-metrics-jusippol.c9.io/app-design.php


''TABLE. Directories''
''TABLE. Directories''
Line 204: Line 234:
! style="text-align:left;"|(main folder)  
! style="text-align:left;"|(main folder)  
| Common implementation files  
| Common implementation files  
|-
| ajaxrequest.js
| JavaScript file for sending and receiving the Ajax requests
|-
| commondefinitions.php
| Definitions for common flags and values
|-
| commonfunctions.php
| Functions for common use in several metrics pages
|-
| connect.php
| To establish the MySQL connection
|-
| connectionclose.php
| To close the MySQL connection (code currently commented out)
|-
| connectiondefinitions.php
| Database server definitions and flags for MySQL API and connection type
|-
| footer.php
| Footer area
|-
| header.php
| Header area
|-
| index.php
| Default file redirecting to metricspageci.php
|-
| menu.php
| Main menu of metrics pages
|-
| metricspageci.php
| CI Metrics page implementation
|-
| styles.css
| Common style definitions
|-
! style="text-align:left;"|calendar/
| Calendar component from http://www.triconsole.com/php/calendar_datepicker.php
|-
! style="text-align:left;"|ci/
| CI Metrics page implementation files
|-
| ci/calendar/
| Directory for one calendar component image
|-
| ci/definitions.php
| Common definitions used in CI Metrics implementation to tailor views or functionalities
|-
| ci/functions.php
| Common functions used in CI Metrics implementation
|-
| ci/getautotestvalues.php
| To load all the autotest values from database
|-
| ci/getconfvalues.php
| To load all the configuration values from database
|-
| ci/getdatabasestatus.php
| To load the database status, for example the update time, from the database
|-
| ci/getfilters.php
| To layout the filters and call files to load the filter values
|-
| ci/getprojectvalues.php
| To load all the project values from database
|-
| ci/graphbuildphases.php
| To show the build phases graph in project dashboard (level 2)
|-
| ci/listbuilds.php
| To show the project and configuration build history in project dashboard (level 2 and 3)
|-
| ci/listconfigurations.php
| To show the configurations in project dashboard (level 2)
|-
| ci/listfailingautotests.php
| To show the failed autotests in project dashboard (level 2 and 3)
|-
| ci/listgeneraldata.php
| To show the general data for project and configuration build in project dashboard (level 2 and 3)
|-
| ci/listprojects.php
| To show the projects in project dashboard (level 1)
|-
| ci/metricsboxdefinitions.php
| To list the metrics boxes and define their functionality regarding to the filters
|-
| ci/msgautotestdashboardlevel1.html
| Metrics description for autotest dashboard (level 1)
|-
| ci/msgautotestdashboardlevel2.html
| Metrics description for autotest dashboard (level 2)
|-
| ci/msgautotestresultdescription.html
| Description for autotest result history notation used in autotest dashboard (level 2)
|-
| ci/msgfailuredescription.html
| Description for autotest failure categories used in autotest dashboard (level 1 and 2)
|-
| ci/msgprojectdashboardlevel1.html
| Metrics description for project dashboard (level 1)
|-
| ci/msgprojectdashboardlevel2.html
| Metrics description for project dashboard (level 2)
|-
| ci/msgprojectdashboardlevel3.html
| Metrics description for project dashboard (level 3)
|-
| ci/showautotestdashboard.php
| Autotest dashboard metrics box implementation (all sections in the same file)
|-
| ci/showprojectdashboard.php
| Project dashboard metrics box implementation (separate sections implemented in their own files)
|-
|-
! style="text-align:left;"| images/  
! style="text-align:left;"| images/  
Line 333: Line 249:
=== Submitting Code ===
=== Submitting Code ===


The development of the Qt metrics system can be done on any server environment that supports PHP and MySQL. The implemented open source code is made available to the master branch of the qtqa/sysadmin Qt repository in the sysadmin/non-puppet/qtmetrics folder. The submissions follow the common [http://wiki.qt.io/Qt-Contribution-Guidelines Qt contribution guidelines], including the use of the [https://codereview.qt-project.org Gerrit Code Review] tool.
The development of the Qt metrics system can be done on any server environment that supports PHP and MySQL/MariaDB. The implemented open source code is made available to the master branch of the qtqa/sysadmin Qt repository in the sysadmin/non-puppet/qtmetrics folder. The submissions follow the common [http://wiki.qt.io/Qt-Contribution-Guidelines Qt contribution guidelines], including the use of the [https://codereview.qt-project.org Gerrit Code Review] tool.


=== Quality Assurance ===
=== Quality Assurance ===
Line 355: Line 271:
==== Unit testing ====
==== Unit testing ====


The development of the Qt metrics system can be done using any available web development environment that supports PHP and MySQL, like XAMPP, LAMP, WAMP or Cloud9 cloud IDE for example. PHPUnit shall be used for unit testing the classes (test classes are in src/test directory). For that some sample data shall be stored into MySQL database tables (MySQL scripts in src/test directory). New functionality or content may require modifications or additions to the sample data.
The development of the Qt metrics system can be done using any available web development environment that supports PHP and MySQL/MariaDB, like XAMPP, LAMP, WAMP or Cloud9 cloud IDE for example. PHPUnit shall be used for unit testing the classes (test classes are in src/test directory). For that some sample data shall be stored into MySQL/MariaDB database tables (SQL scripts in src/test directory). New functionality or content may require modifications or additions to the sample data.


==== Verification on target server ====
==== Verification on target server ====
Line 383: Line 299:
==== Web security ====
==== Web security ====


TBD
{| class="wikitable"
|-
| '''TBD'''
|}


<br>
----
----


== FUTURE DEVELOPMENT ==
== FUTURE DEVELOPMENT ==


The target is that anyone from the Qt developer community could contribute to the development and improvement of the Qt Metrics page. The development items are listed in the:
The target is that anyone from the Qt developer community could contribute to the development and improvement of the Qt Metrics page.
 
=== Backlog ===
 
The development items are listed in the:


* '''Qt Metrics 2 backlog:''' [[Qt Metrics 2 Backlog]]
* '''Qt Metrics 2 backlog:''' [[Qt Metrics 2 Backlog]]


<br>
----
----



Revision as of 06:37, 19 August 2015

UNDER CONSTRUCTION

INTRODUCTION

The Qt Metrics 2 web portal visualizes the progress of Qt's quality, focusing on Continuous Integration (CI). The goal is to automate laborious manual work that is required, for example, in the CI release cycle, to report the key information, as well as providing real time data with good performance. The Qt integration teams (in The Qt Company) and the global Qt developer community are the target audience.

Qt Metrics 2: http://testresults.qt.io/qtmetrics-dev/new/ (Note: this is a development version)
Version: This document is updated against the report builder v0.20

This document is divided in chapters; each chapter having its own purpose and target audience:
2. Using the System: What (what the users see)
3. Detailed Description: How it works (quick overview to implementation)
4. Developing and Maintenance: How to develop it (how to create new metrics/pages)

System Overview

The Qt Metrics system consists of three main components: the parser, the report builder and the database. See the picture below. The parser reads the build logs, test results, or other files that are created in the development and integration process, and pushes the data into the database. The report builder reads the data from the database, and shows predefined metrics and reports based on user's area of interest. The report builder with PHP (Slim framework), Twitter Bootstrap, HTML, CSS, and JavaScript with some jQuery and D3 graphics components. The parser is implemented with Perl (implementation for the 'new-CI' not done yet and solution therefore still open). The database is a MariaDB database.

Qtmetricssystem.png
PICTURE. Generic system architecture



Requirements and Target Audience

TBD



USING THE SYSTEM

This section introduces the Qt Metrics system from the user point of view.

Report Builder Overview

TBD

The report builder is a collection of PHP files running on the testresults server (running Apache) on the qt.io domain. It utilizes Ajax, JavaScript, and HTML/CSS (HTML5/CSS3 for some visual appearance). Picture 2 below describes the logical elements and functionality of the report builder (please note that the latest changes may not be reflected in all the pictures in this document).

Use Cases

TBD

List roles incl admin.



DETAILED DESCRIPTION

This section discusses the Qt Metrics system components and their implementation into a certain level of detail. The target audience is the SW designer(s) maintaining and developing the system.

Report Builder

TBD

The report builder implementation consists of one metrics page (CI metrics) having a filter box, status box, and two metrics boxes (Project dashboard and Autotest dashboard). The file structure of the implementation is described in Picture 6 and Picture 7 (complete list of files shown in Table 2 Directories and files).

Database

The database is a MariaDB database, and all tables use MyISAM storage engine. The database is running on the Qt testresults server on the qt.io domain.

PICTURE. Database tables, their fields, and field types

Data is parsed from the build log files by default, or from the XML test reports if separately mentioned so in the tables below.

Table Purpose
project Project names, both build projects (currently only the 'Qt5' included) and the parent projects for the testsets (like 'qtbase')
branch Branch name (like '5.5' or 'dev')
state State name (currently only the 'state' builds are included)
platform Target or host platform (like 'linux' / Ubuntu_11.10' / 'x86')
compiler Target or host compiler (like 'g++')
conf Build configuration consisting of target and host platform and compiler, features and full name (like 'linux-g++_shadow-build_Ubuntu_11.10_x86')
phase Phase of the configuration build (like 'configuring Qt')
testset Testset for its parent project (like 'tst_qftp')
testfunction Testfunction for its parent testset (like 'initTestCase'), parsed from XML reports:

<TestFunction name="initTestCase"> <Incident line="0" file="" type="pass"/> <Duration msecs="17.570825"/> </TestFunction>

testrow Testrow for its parent testfunction (like 'WithoutProxy:ok01'), parsed from XML reports:

<TestFunction name="connectToHost"> <Incident line="0" file="" type="pass"> <DataTag> <![CDATA[WithoutProxy:ok01]]> </DataTag> </Incident>...

TABLE. Database tables for 'fixed' data

Table Purpose
project_run Project build data. On most Qt Metrics 2 pages only the Qt5 state build data is shown (unless stated otherwise on the page info)
conf_run Configuration build data for its parent project_run
phase_run Configuration build phase data for its parent conf_run
testset_run Testset result data for its parent conf_run
testfunction_run Testfunction result data for its parent testset_run, parsed from XML reports:

<TestFunction name="initTestCase"> <Incident line="0" file="" type="pass"/> <Duration msecs="17.570825"/> </TestFunction>

testrow_run Testrow result data for its parent testfunction_run, parsed from XML reports:

<TestFunction name="connectToHost"> <Incident line="0" file="" type="pass"> <DataTag> <![CDATA[WithoutProxy:ok01]]> </DataTag> </Incident>...

TABLE. Database tables for build data

Table Purpose
db_status Information on database updates by the parser

TABLE. Database tables for other data

Parser

TBD

(are all methods available?)

New data is added to the database only by the parser. For CI, data is inserted from the new log files when a new build has completed. This method is called a “single scan”. The data already in the database is never updated since build results never change after a build. However, if there is a need for example to add a new database field or to change a field type, the whole database must be rebuilt from the log files. This method is referred as a “full scan”. There is also a “catch up” method to compare the database against the build log files residing in the server, and to add the possibly missing data. This is needed for example if single scan operations failed for some reason.


Key Functionality

TBD

JavaScript Libraries

TBD

(from https://qt-metrics-jusippol.c9.io/app-design.php)

D3

D3 (Data-Driven Documents) is a JavaScript library for manipulating documents based on data, and helps bringing data to life using HTML, SVG and CSS. The http://d3js.org/ and https://github.com/mbostock/d3/wiki/Gallery include guidance and examples, and because of the popularity of D3 many detailed examples are available in the Internet.

Qt Metrics system uses the library with a CDN from http://d3js.org. A horizontal stacked bar graph is used currently in the Project dashboard level 2 to visualize the build phases.

jQuery UI

jQuery UI is a curated set of user interface interactions, effects, widgets, and themes built on top of the jQuery JavaScript Library.

Twitter Bootstrap



DEVELOPMENT AND MAINTENANCE

This chapter describes a few typical development and maintenance cases as a supplement to the detailed description in the previous chapter. The SW designers who are maintaining and developing the system are the target audience.

Directory Structure and Naming Conventions

TBD

(from https://qt-metrics-jusippol.c9.io/app-design.php)

The list of current directories are shown below.

TABLE. Directories

Directory/File Purpose
(main folder) Common implementation files
images/ Directory for common images like logos and icons

Maintaining the Version Info

The report builder version is visible via the About header menu item (about.html) and it shall be updated on every change affecting the UI.

Requests for New Data

New fields should be added to the database only with proper reason and use case. Only the parser adds data into the database. Therefore, if new data fields are needed to the database while specifying or implementing new content of the existing or new metrics boxes or pages, a change request to the parser is needed as well. The change request should include information as to whether the new data is already available, for example in some log files, or whether the change requires a change to the log files.

Submitting Code

The development of the Qt metrics system can be done on any server environment that supports PHP and MySQL/MariaDB. The implemented open source code is made available to the master branch of the qtqa/sysadmin Qt repository in the sysadmin/non-puppet/qtmetrics folder. The submissions follow the common Qt contribution guidelines, including the use of the Gerrit Code Review tool.

Quality Assurance

The following actions should be taken to ensure the quality of the change commits.

Qt coding conventions

Use the Qt Commit Policy, Qt Coding Style, and Qt Coding Conventions where applicable for the PHP, JavaScript, HTML and CSS implementation, plus others if used.

Commits

As a general rule for all Qt contributions, it is important to make atomic commits. That means that each commit should contain exactly one self-contained change. Unrelated changes, or new functionality and error corrections, must not be mixed. Likewise, unrelated small fixes, for example to coding style, should not be hidden in bigger commits, but should be handled in a separate commit.

The Gerrit Early Warning System will make certain checks to the code. It is a good practice to make the check before pushing the changes to Gerrit to avoid unnecessary fix patches. The sanitizer tool, a script made with Perl, can be used for that.

Validating the scripts

It is recommended to follow the HTML5 standard and use the HTML5/CSS3 approach, for example to make the style definitions in the CSS file instead of in the PHP or HTML code. Please utilize the HTML markup validator and the CSS validator by the World Wide Web Consortium (W3C). In addition, use for example JavaScript Lint to validate JavaScript code.

Unit testing

The development of the Qt metrics system can be done using any available web development environment that supports PHP and MySQL/MariaDB, like XAMPP, LAMP, WAMP or Cloud9 cloud IDE for example. PHPUnit shall be used for unit testing the classes (test classes are in src/test directory). For that some sample data shall be stored into MySQL/MariaDB database tables (SQL scripts in src/test directory). New functionality or content may require modifications or additions to the sample data.

Verification on target server

The changes can be verified on the testresults server in a specific verification folder (http://testresults.qt.io/qtmetrics-dev/new) before submitting changed code. The CI team will assist with the access rights.

Verification with different browsers

Verification in all major browsers is essential for any web based service. The Qt metrics system follows responsive design with Twitter Bootstrap to adjust to different screen resolutions. However, it must be noted that, although the pages may utilize large screens, the visible content area should be defined to be as narrow as possible and the most important content to be placed on the left to prevent unnecessary horizontal scrolling.

All changes should be verified at least with the following browsers: Chrome, Firefox, Opera, IE and Safari. Use of different operating systems and browser versions, as well as mobile browsers, is also recommended. It is proposed to list the verified browsers in the Gerrit commit description.

Security and Data Validation

Source data and validation

The source data used in the Qt metrics system is publicly available. The log files for the CI metrics page, for example, can be found in http://testresults.qt.io/ci/. Hence the data itself does not need any user access control.

The parser takes care of data validation before storing data to the database.

Database user access

The report builder of the Qt metrics system uses one user id to read the data from the database. This user has only a read access to the database. The parser uses another user id with write access to store the data to the database. A separate admin user is used for the administration actions, which are authenticated with HTTP basic authentication (see separate chapter).

The database management system cannot be accessed outside the testresults server, where both the report builder and the parser reside.

Web security

TBD



FUTURE DEVELOPMENT

The target is that anyone from the Qt developer community could contribute to the development and improvement of the Qt Metrics page.

Backlog

The development items are listed in the:



SUPPORT

In case of questions, proposals, and improvement ideas, please contact the development team:

  • Juha Sippola (Developer: report builder, database)
  • Tony Sarajärvi (Developer: parser; Use case designer, Key user, Reviewer)
  • Frederik Gladhorn (Use case designer, Key user, Reviewer)
  • Simon Hausman (Key user, Reviewer)
  • Oswald Buddenhagen (Key user, Reviewer)
  • Friedemann Kleint (Key user, Reviewer)