Skip to content

A Nx plugin that analyzes projects using SonarQube / SonarCloud.

Notifications You must be signed in to change notification settings

ak274/nx-sonarqube

 
 

Repository files navigation

@koliveira15/nx-sonarqube

logo

About

A Nx plugin that analyzes projects using SonarQube / SonarCloud.

graph

To analyze "app-one", we need to know the project's dependencies. Using the Nx project graph, we see that this project has three dependencies, two static and one implicit. With this information, the plugin gathers the source and coverage paths for the analysis.

Sources:

  • apps/app/src
  • libs/lib-b/src
  • libs/lib-c/src
  • libs/libs-d/src
  • libs/libs-e/src
  • libs/libs-f/src

lcov Paths:

  • coverage/apps/app/lcov.info
  • coverage/libs/lib-b/lcov.info
  • coverage/libs/lib-c/lcov.info
  • coverage/libs/libs-d/lcov.info
  • coverage/libs/libs-e/lcov.info
  • coverage/libs/libs-f/lcov.info

Usage

Prerequisites

  1. Nx workspace
  2. SonarQube or Sonar Cloud instance
  3. Jest tests & code coverage enabled

Installation

  1. Install the package:
    npm i -D @koliveira15/nx-sonarqube
  2. Execute the configuration generator to setup sonar for a given project:
    npx nx g @koliveira15/nx-sonarqube:config
  3. Execute the sonar target for the given project:
    npx nx sonar my-project
    or
    npx nx affected --target sonar --parallel 1
    Note: Due to limitations with the scanner, you cannot run more than one scan in parallel

Authentication

Sonar can require authentication credentials. You can set these via environment variables using Nrwl's Nx recipe

SONAR_LOGIN: The authentication token or login of a SonarQube user with either Execute Analysis permission on the project or Global Execute Analysis permission

SONAR_PASSWORD: If you're using an authentication token, leave this blank. If you're using a login, this is the password that goes with your SONAR_LOGIN username

Customization

Modify the executor options based on the configuration table below. These options are based on Analysis Parameters

Name Required Description Default
hostUrl Yes Sonar server URL http://localhost:9000
projectKey Yes The project's unique key. Allowed characters are: letters, numbers, -, _, . and :, with at least one non-digit.
branches No Include branch name in analysis false
exclusions No Files to exclude from coverage
organization No Sonar organization
projectName No Name of the project that will be displayed on the web interface
projectVersion No The project version
qualityGate No Forces the analysis step to poll the SonarQube instance and wait for the Quality Gate status true
qualityGateTimeout No Sets the number of seconds that the scanner should wait for a report to be processed 300
skipImplicitDeps No Skips adding implicit dependencies to the project graph analysis false
verbose No Add more detail to both client and server-side analysis logs false

About

A Nx plugin that analyzes projects using SonarQube / SonarCloud.

Resources

Stars

Watchers

Forks

Releases

No releases published

Packages

No packages published

Languages

  • TypeScript 98.1%
  • JavaScript 1.3%
  • Shell 0.6%