/jqa-jira-plugin

This is a Jira parser for jQAssistant. It enables jQAssistant to scan and to analyze data from Jira.

Primary LanguageJavaGNU General Public License v3.0GPL-3.0

jQAssistant Jira Plugin

This is a Jira parser for jQAssistant. It enables jQAssistant to scan and to analyze data from Jira.

Getting Started

Download the jQAssistant command line tool for your system: jQAssistant - Get Started.

Next download the latest version from the release tab. Put the jqa-jira-plugin-*.jar into the plugins folder of the jQAssistant command line tool.

Finally, you need to configure the plugin via XML. The file must be named jira-plugin-configuration.xml:

<jira-configuration>

    <url>http://dummy-url.com</url>

    <api-token>
        <email>foo@bar.com</email>
        <token>atlassian-token</token>
    </api-token>

    <projects>
        <project>
            <key>PX</key>
        </project>        
        <project>
            <key>PY</key>
        </project>
    </projects>

</jira-configuration>

To create an Atlassian token go to this page. Now scan your configuration and wait for the plugin to finish:

jqassistant.sh scan -f jira-plugin-configuration.xml

You can then start a local Neo4j server to start querying the database at http://localhost:7474:

jqassistant.sh server

Self-Signed Certificate

If your JIRA instance uses a self-signed certificate register it with the Keytool:

keytool -import -alias JIRA -file jira.crt -keystore $JAVA_HOME/jre/lib/security/cacerts

Model

Neo4j model for the jQAssistant Jira plugin

Use Cases

Overview

Count bugs per release:

MATCH 
    (t:IssueType {name:'Bug'})<-[:IS_OF_TYPE]-(i:Issue)-[:AFFECTS]->(v:Version) 
RETURN 
    v.name as Version, count(i) as `Bug Total`
ORDER BY
    `Bug Total` DESC

Count bugs by priority:

MATCH 
    (t:IssueType {name:'Bug'})<-[:IS_OF_TYPE]-(i:Issue)-[:IS_OF_PRIORITY]->(p:Priority) 
RETURN 
    p.name as Priority, count(i) as `Issue Total`
ORDER BY
    `Issue Total` DESC

Count issues by status:

MATCH 
    (i:Issue)-[:HAS_STATUS]->(s:Status) 
RETURN 
    s.name as Status, count(i) as `Issue Total`
ORDER BY
    `Issue Total` DESC

User Overview

Count reported issues per user:

MATCH 
    (i:Issue)-[:REPORTED_BY]->(u:User) 
RETURN 
    u.name as User, count(i) as `Issue Total`
ORDER BY
    `Issue Total` DESC

Count assigned issues per user:

MATCH 
    (i:Issue)-[:ASSIGNED_TO]->(u:User) 
RETURN 
    u.name as User, count(i) as `Issue Total`
ORDER BY
    `Issue Total` DESC

Issue Relations

Show issues with few links to other issues. Those are probably ones which can always be implemented:

MATCH 
    (i:Issue)
RETURN 
    i.key as Issue, SIZE((i)-[:HAS_LINK]->()) as `Link Total`
ORDER BY
    `Link Total` ASC

Show issues which are referenced by a lot of other issues. Those issues should be solved as soon as possible.

MATCH 
    (i:Issue)
RETURN 
    i.key as Issue, SIZE((i)<-[:POINTS_AT]-()) as `Reference Total`
ORDER BY
    `Reference Total` DESC

Issue Quality

Show issues with a lot of comments. Probably the first description was not clear enough:

MATCH 
    (i:Issue)
RETURN 
    i.key as Issue, SIZE((i)-[:HAS_COMMENT]->()) as `Comment Total`
ORDER BY
    `Comment Total` DESC

Supported Jira Versions

Unfortunately, we did not find any documentation which Jira versions are supported by the JIRA REST Java Client. According to the BitBucket repository description every version newer than JIRA 4.2 is supported:

Java client library (useful for any JVM languages) which allows to communicate with JIRA via its new REST API (JIRA 4.2 and newer).

The README.md references a Wiki entry from 2010. This again references an ATLASSIAN Marketplace page which is out of date since 2013.

If it does not work with your Jira instance please open an Issue and write your Jira version in there.

Performance

A real benchmark does not make sense as the performance of the plugin depends on the performance of the Jira instance. Nevertheless, we want to provide some numbers which we received while testing the plugin against available Jira instances.

Instance Issue Count User Count Issue Link Count Time to Scan
#1 ~7400 ~50 ~1400 ~9 min
#2 ~1550 ~1400 ~100 ~5 min

Rate Limits

When running against a Jira cloud instance there could be an issue with rate limits. For more information please see the CONTRIBUTING.md.

Contribute

We really appreciate your help! If you want to contribute please have a look at the CONTRIBUTING.md.