You can not select more than 25 topics Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.
Simon Brandhof af17164712 Add template of pull request for contributors 6 years ago
.travis BUILD-478 Set TRAVIS_BUILD_DIR in ramdisk 6 years ago
gradle/wrapper Move To Gradle 6 years ago
plugins Move To Gradle 6 years ago
scripts Move To Gradle 6 years ago
server Move To Gradle 6 years ago
sonar-application Move To Gradle 6 years ago
sonar-check-api Move To Gradle 6 years ago
sonar-core Move To Gradle 6 years ago
sonar-duplications Move To Gradle 6 years ago
sonar-home Move To Gradle 6 years ago
sonar-markdown Move To Gradle 6 years ago
sonar-plugin-api Move To Gradle 6 years ago
sonar-plugin-api-deps Move To Gradle 6 years ago
sonar-scanner-engine Add missing dependencies in sonar-scanner-engine 6 years ago
sonar-scanner-engine-shaded Move To Gradle 6 years ago
sonar-scanner-protocol Move To Gradle 6 years ago
sonar-testing-harness Move To Gradle 6 years ago
sonar-ws Move To Gradle 6 years ago
sonar-ws-generator Move To Gradle 6 years ago
tests Move To Gradle 6 years ago
.cix.yml Temporarily disable QA tests on Oracle DB 6 years ago
.gitignore Move To Gradle 6 years ago
.travis.yml Move To Gradle 6 years ago
LICENSE.txt Add LICENSE.txt 8 years ago
NOTICE.txt Add NOTICE.txt file [ci skip] 7 years ago
PULL_REQUEST_TEMPLATE.md Add template of pull request for contributors 6 years ago
README.md Complete README of sources 6 years ago
build.gradle Add missing dependencies in sonar-scanner-engine 6 years ago
build.sh Move To Gradle 6 years ago
cix.sh Move To Gradle 6 years ago
debug-server.sh SONAR-5709 Add properties sonar.search.javaAdditionalOpts and sonar.web.javaAdditionalOpts 9 years ago
enable-organizations.sh Rename enable_organizations.sh to enable-organizations.sh 7 years ago
gradle.properties Fix gradle.properties 6 years ago
gradlew Move To Gradle 6 years ago
gradlew.bat Move To Gradle 6 years ago
logs.sh [script] add logs.sh + tail all SQ log files in start.sh 7 years ago
run-db-unit-tests.sh Move To Gradle 6 years ago
run-integration-tests.sh Move To Gradle 6 years ago
run-perf-tests.sh Move To Gradle 6 years ago
run-upgrade-tests.sh Move To Gradle 6 years ago
settings.gradle Move To Gradle 6 years ago
start.sh [SCRIPTS] add support for patches to start.sh 8 years ago
stop.sh Move To Gradle 6 years ago
travis.sh Move To Gradle 6 years ago

README.md

SonarQube Build Status Quality Gate Coverage

Continuous Inspection

SonarQube provides the capability to not only show health of an application but also to highlight issues newly introduced. With a Quality Gate in place, you can fix the leak and therefore improve code quality systematically.

Have Question or Feedback?

For support questions (“How do I?”, “I got this error, why?”, …), please first read the documentation and then head to Stackoverflow. We actively follow the sonarqube tag there, and there are chances that we have already answered to a question similar to yours.

To provide feedback (request a feature, report a bug etc.) use the SonarQube Google Group. Be aware that this group is a community, so the standard pleasantries (“Hi”, “Thanks”, …) are expected. And if you don’t get an answer to your thread, you should sit on your hands for at least three days before bumping it. Operators are not standing by. :-)

Contributing

Pull Request

Please create a new thread in SonarQube Google Group when contributing a new feature. You have to be sure that the feature complies with our roadmap and expectations.

To submit a code contribution, create a pull request for this repository. Please explain your motives to contribute this change (if it’s not a new feature): what problem you are trying to fix, what improvement you are trying to make.

Make sure that you follow our code style and all tests are passing (Travis build is executed for each pull request).

Building

To build sources locally follow these instructions.

Build and Run Unit Tests

Execute from project base directory:

./gradlew build

The zip distribution file is generated in sonar-application/build/distributions/. Unzip it and start server by executing:

# on linux
bin/linux-x86-64/sonar.sh start 
# or on MacOS
bin/macosx-universal-64/sonar.sh start
# or on Windows
bin\windows-x86-64\StartSonar.bat 

Run Integration Tests

Integration tests are grouped into categories, listed in [tests/build.gradle](). A single category should be run at a time, by executing from project base directory:

./gradlew integrationTest -Dcategory=<category>

Example:

./gradlew integrationTest -Dcategory=Category1

Configure Integration Tests

Environment of tests can be configured with command-line properties and file ~/.sonar/orchestrator/orchestrator.properties, if it exists. Here is a template example:

# Token used to download SonarSource private artifacts from https://repox.sonarsource.com,
# required for the category "Plugins".
# Generate your API key at https://repox.sonarsource.com/webapp/#/profile
#orchestrator.artifactory.apiKey=

# Personal access token used to request SonarSource development licenses at https://github.com/sonarsource/licenses,
# required for the category "Plugins". 
# Generate a token from https://github.com/settings/tokens
#github.token=

# Browser to be used in Selenium tests. 
# Values are:  
# - "firefox" (default). Supports only versions <= 46
# - "marionette", for versions of Firefox greater than 46
# - "chrome". Requires the Chrome driver to be installed (see https://sites.google.com/a/chromium.org/chromedriver/). 
#             On MacOS, simply run "brew install chromedriver".
#orchestrator.browser=firefox

# Port of SonarQube server, for example 10000. Default value is 0 (random).
#orchestrator.container.port=0

# Maven installation, used by the tests running Scanner for Maven.
# By default Maven binary is searched in $PATH
#maven.home=/usr/local/Cellar/maven/3.5.0/libexec

# Database connection. Embedded H2 is used by default.

# Example for PostgreSQL:
#sonar.jdbc.dialect=postgresql
#sonar.jdbc.url=jdbc:postgresql://localhost:15432/sonar
#sonar.jdbc.rootUsername=postgres
#sonar.jdbc.rootPassword=sonarsource
#sonar.jdbc.rootUrl=jdbc:postgresql://localhost:15432/postgres
#sonar.jdbc.username=sonar
#sonar.jdbc.password=sonar    
#sonar.jdbc.schema=public

# Example for Oracle 12c:
#sonar.jdbc.dialect=oracle
#sonar.jdbc.url=jdbc:oracle:thin:@localhost:1521/ORCL
#sonar.jdbc.rootUrl=jdbc:oracle:thin:@localhost:1521/ORCL
#sonar.jdbc.rootUsername=SYSTEM
#sonar.jdbc.rootPassword=system
#sonar.jdbc.username=sonar
#sonar.jdbc.password=sonar
#sonar.jdbc.driverMavenKey=com.oracle.jdbc:ojdbc8:12.2.0.1.0

# Example for SQLServer
#sonar.jdbc.dialect=mssql
#sonar.jdbc.url=jdbc:jtds:sqlserver://localhost/sonar;SelectMethod=Cursor
#sonar.jdbc.rootUrl=jdbc:jtds:sqlserver://localhost;SelectMethod=Cursor
#sonar.jdbc.rootUsername=admin
#sonar.jdbc.rootPassword=admin
#sonar.jdbc.username=sonar
#sonar.jdbc.password=sonar

The path to a custom configuration file can be provided with command-line property -Dorchestrator.configUrl=file:///path/to/orchestrator.properties or with environment variable ORCHESTRATOR_CONFIG_URL=file:///path/to/orchestrator.properties.

License

Copyright 2008-2018 SonarSource.

Licensed under the GNU Lesser General Public License, Version 3.0