Skip to content

Provides the jQAssistant dashboard for analyzing and visualizing software artifacts' data.

License

Notifications You must be signed in to change notification settings

kontext-e/jqassistant-dashboard-plugin

 
 

Folders and files

NameName
Last commit message
Last commit date

Latest commit

 

History

38 Commits
 
 
 
 
 
 
 
 
 
 
 
 

Repository files navigation

jQAssistant Dashboard Plugin

The project provides a jQAssistant plugin for providing a dashboard, which shows interactive graphics about different metrics of your system. This allows you to have a quick overview about dependencies inside your project, statistics about your contributors, potential problems in your architecture and more.

How It Works

The plugin provides a set of concepts, which are applied by jQAssistant, to enable the dashboard to function. The dashboard itself will then be served as a React App under a certain URL (see How To Use It)

Currently the dashboard provides:

  • An overview page, which shows different metrics as numbers

  • A structure diagram, which enables you to interactively explore your code base

  • The distribution of file types, represented by a pie chart

  • A dependency diagram, which shows you internal dependencies of your project

  • An activity dashboard, that presents different statistics about the frequency and authors of the commits

  • A knowledge distribution, showing what contributor uses what programming languages

  • A hotspot diagram, that indicates potential risks in your code

  • Static code analysis

  • A test coverage diagram

Prerequisites

  • Java 8 or higher

  • jQAssistant 1.7.0 or higher (see below)

How To Use It

You can use the plugin with Maven or with the Command Line Distribution of jQAssistant.

Maven

The plugin can be enabled in a Maven based project by adding it as a dependency to the jQAssistant Maven plugin:

<build>
    <plugins>
        <plugin>
            <groupId>com.buschmais.jqassistant</groupId>
            <artifactId>jqassistant-maven-plugin</artifactId>
            <version>1.7.0</version>
            <executions>
                <execution>
                    <id>default-cli</id>
                    <goals>
                        <goal>scan</goal>
                        <goal>analyze</goal>
                    </goals>
                    <configuration>
                        <!-- Add jqassistant-dashboard:Default as a jQA group-->
                        <groups>
                            <group>jqassistant-dashboard:Default</group>
                            <!-- Insert your own group references here -->
                        </groups>
                        <!-- Include .git folder path as a scan location -->
                        <scanIncludes>
                            <scanInclude>
                                <path>${project.basedir}/.git</path>
                            </scanInclude>
                            <!-- OPTIONAL (1)-->
                            <scanInclude>
                                <path>## Path where yout pmd.xml is generated##/pmd.xml</path>
                            </scanInclude>
                            <!-- OPTIONAL (2) -->
                            <scanInclude>
                                <path>## Path where your jacoco.xml is generated ##</path>
                            </scanInclude>
                        </scanIncludes>
                        <!-- OPTIONAL (2) -->
                        <scanProperties>
                            <jqassistant.plugin.jacoco.filename>jacoco.xml</jqassistant.plugin.jacoco.filename>
                            <jqassistant.plugin.jacoco.dirname>## Path where your jacoco.xml is generated ##</jqassistant.plugin.jacoco.dirname>
                        </scanProperties>
                    </configuration>
                </execution>
            </executions>
            <!-- Add the jqassistant-dashboard-plugin itself as a dependency-->
            <dependencies>
                <dependency>
                    <groupId>org.jqassistant.contrib.plugin</groupId>
                    <artifactId>jqassistant-dashboard-plugin</artifactId>
                    <version>1.7.0</version>
                </dependency>
            </dependencies>
        </plugin>
        <!-- OPTIONAL (1) (this is an example, your configuration may vary) -->
        <plugin>
            <groupId>org.apache.maven.plugins</groupId>
            <artifactId>maven-pmd-plugin</artifactId>
            <version>3.10.0</version>
            <executions>
                <execution>
                    <goals>
                        <goal>pmd</goal>
                    </goals>
                    <phase>package</phase>
                </execution>
            </executions>
        </plugin>
        <!-- OPTIONAL (2) (this is an example, your configuration may vary) -->
        <plugin>
            <groupId>org.jacoco</groupId>
            <artifactId>jacoco-maven-plugin</artifactId>
            <version>0.7.9</version>
            <executions>
                <execution>
                    <id>pre-unit-test</id>
                    <goals>
                        <goal>prepare-agent</goal>
                    </goals>
                    <configuration>
                        <destFile>${project.build.directory}/coverage-reports/jacoco.exec</destFile>
                        <propertyName>surefireArgLine</propertyName>
                    </configuration>
                </execution>
                <execution>
                    <id>post-unit-test</id>
                    <phase>test</phase>
                    <goals>
                        <goal>report</goal>
                    </goals>
                    <configuration>
                        <dataFile>${project.build.directory}/coverage-reports/jacoco.exec</dataFile>
                        <outputDirectory>${project.reporting.outputDirectory}/jacoco</outputDirectory>
                    </configuration>
                </execution>
            </executions>
        </plugin>
    </plugins>
</build>

It is possible to install the following optional plugins:

  1. PMD (example configuration is shown above)

  2. JaCoCo (example configuration is shown above)

Note that in order to be installed properly, you need to insert every corresponding Tag (and all its children) after the "OPTIONAL (*)" comments.

After building the project (e.g. with mvn clean install), you need to start the jQAssistant server with

mvn jqassistant:server

If the server started successfully, you can reach the dashboard under

Note, that the regular Neo4j Browser is still available (http://localhost:7474/browser/).

Command Line Distribution

To enable the plugin with the Command Line Distribution, download the JAR file from Maven Central and put it in the /plugins folder from the distribution.

In addition to that, you need to install the jQA Git Plugin.

To start the jQA server run the following commands: (xxx.jar is your project build)

Linux:

sh bin/jqassistant.sh scan -f .../xxx.jar
sh bin/jqassistant.sh scan -f .../.git/
sh bin/jqassistant.sh analyze -groups jqassistant-dashboard:Default
sh bin/jqassistant.sh server

Windows:

bin\jqassistant.cmd scan -f ...\xxx.jar
bin\jqassistant.cmd scan -f ...\.git\
bin\jqassistant.cmd analyze -groups jqassistant-dashboard:Default
bin\jqassistant.cmd server

How To Add Your Own Concepts

It is possible to change the underlying queries behind the different views. The following represents an example of how to accomplish that, by changing the query of the dependency diagram, so that only dependencies between top level packages (here called components) are displayed.

1. Create Your Concept

We will do that the regular jQAssistant way, by creating an AsciiDoc File, which contains our concept:

/jqassistant/structure.adoc

[[structure]]
[role=group,includesConcepts="structure:*"]
== Structure

=== Concepts

[[structure:Component]]
[source,cypher,role=concept,requiresConcepts="structure:RootPackage"]
.Every package that is a direct child of the root package is a `Component`.
----
MATCH
    (artifact:Main:Artifact)-[:CONTAINS]->(root:Package)-[:CONTAINS]->(component:Package)
WHERE
    root.fqn="org.junit"
SET
    component:Component
RETURN
    component.name as Component
ORDER BY
    Component
----

[[structure:ComponentDependency]]
[source,cypher,role=concept,requiresConcepts="structure:Component"]
.A component depends on another component (`DEPENDS_ON_COMPONENT`) if exists at least one dependency of contained Java types.
----
MATCH
  (c1:Component)-[:CONTAINS*]->(t1:Type),
  (c2:Component)-[:CONTAINS*]->(t2:Type),
  (t1)-[:DEPENDS_ON]->(t2)
WHERE
  c1 <> c2
WITH
  c1, c2, count(t2) as weight
MERGE
  (c1)-[d:DEPENDS_ON_COMPONENT]->(c2)
SET
  d.weight = weight
RETURN
  c1 as Component, c2 as Dependency, weight as Weight
ORDER BY
  Component, Weight desc
----

and the index.adoc, which contains our default group:

/jqassistant/index.adoc

:toc: left
= MyProjectName

This document contains rules which are executed by https://jqassistant.org[jQAssistant]

[[default]]
[role=group,includesGroups="structure"]
== Default Rules

The following groups are executed by default:

- <<structure>>

 include::structure.adoc[]

2. Add "default" Group To pom.xml

You need to insert the following at its designated inside the pom.xml place (see How To Use It)

<group>default</group>

3. Build And Run Your Project

e.g.

mvn clean install
mvn jqassistant:server

4. Modify The Query

For that you need to go to Architecture/Dependencies on the dashboard site. After that you can toggle the expert view on the top right corner of the diagram window. Replace the query with the following:

MATCH
    (dependent_package:Component)-[d:DEPENDS_ON_COMPONENT]-(dependency_package:Component)
WHERE
    dependent_package <> dependency_package
WITH
    dependent_package.fqn as dependent, dependency_package.fqn as dependency, d.weight as dependencies
RETURN
    dependent , dependency, dependencies
ORDER BY
    dependent, dependency

To run the query click on the "Send" button. You should see the result immediately.

Acknowledgements

The plugin could not provide its functionality without the support of the following open source projects:

About

Provides the jQAssistant dashboard for analyzing and visualizing software artifacts' data.

Resources

License

Stars

Watchers

Forks

Packages

No packages published

Languages

  • JavaScript 79.7%
  • Java 14.3%
  • HTML 6.0%