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.
Julien Lancelot 42cab973f7 SONAR-4715 Compute the new "Technical Debt" metric 10 years ago
plugins SONAR-4715 Compute the new "Technical Debt" metric 10 years ago
sonar-application SONAR-4596 Don't install bundled plugins during upgrade 10 years ago
sonar-batch Fix quality flaws 10 years ago
sonar-batch-maven-compat Upgrade to 4.0-SNAPSHOT 11 years ago
sonar-channel Fix some quality flaws 10 years ago
sonar-check-api Upgrade to 4.0-SNAPSHOT 11 years ago
sonar-colorizer Revert "Add package-info files" 10 years ago
sonar-core SONAR-4724 Modify ghost detection query to avoid displaying provisioned resources 10 years ago
sonar-deprecated SONAR-4617 Refactoring away from Resource<T> 10 years ago
sonar-duplications Fix some quality flaws 11 years ago
sonar-graph Fix some quality flaws 10 years ago
sonar-home Fix some quality flaws 10 years ago
sonar-java-api Upgrade to 4.0-SNAPSHOT 11 years ago
sonar-markdown Fix some quality flaws 11 years ago
sonar-maven-plugin Fix quality flaws 11 years ago
sonar-maven3-plugin Upgrade to 4.0-SNAPSHOT 11 years ago
sonar-plugin-api SONAR-4715 Compute the new "Technical Debt" metric 10 years ago
sonar-server SONAR-4715 Compute the new "Technical Debt" metric 10 years ago
sonar-squid Fix some quality flaws 10 years ago
sonar-testing-harness Fix some quality flaws 10 years ago
sonar-ws-client SONAR-4694 Allow project permissions management from the permission web service 10 years ago
.gitattributes Tests should be independent from EOL in resources 13 years ago
.gitignore Complete .gitignore 11 years ago
.mailmap .mailmap file to resolve wrong author names 12 years ago
COPYING Fix crlf 13 years ago
KEYS Add Eric Hartmann's key 12 years ago
README.md Complete build section of readme 10 years ago
copyright.txt Update copyright headers 11 years ago
pom.xml SONAR-4045 downgrade to jruby 1.7.3 10 years ago
push.sh Add unbreakable build script for mac 12 years ago
quick-build.bat Skip sanity checks in dev profile 12 years ago
quick-build.sh Skip sanity checks in dev profile 12 years ago
start-mac-h2.sh Forgot these files during H2 migration 12 years ago

README.md

SonarQube

Put your technical debt under control. For more information please see:

Sources

This Git repository is core platform. Plugins are hosted in SonarCommunity and SonarSource organisations.

Checkout Sources

If you have never used Git before, you need to do some setup first. Run the following commands so that GIT knows your name and email.

git config --global user.name "Your Name"
git config --global user.email "your@email.com"

Setup line endings preferences:

# For Unix/Mac users
git config --global core.autocrlf input
git config --global core.safecrlf true

# For Windows users
git config --global core.autocrlf true
git config --global core.safecrlf true

Get sources by executing:

git clone https://github.com/SonarSource/sonar.git

Committers must configure their SSH key (see GitHub documentation for Windows and Mac) and clone repository:

git clone git@github.com:SonarSource/sonar.git

Build

  • Install JDK 6 or greater
  • Install Maven 3.0.5 or greater
  • Execute mvn clean install. To quickly build in development environment, the script quick-build.sh does not execute unit tests and compile GWT components for Firefox/Chrome only.
  • ZIP file of application is generated in sonar-application/target/

Edit Ruby Code

The development mode is used to edit Ruby on Rails code. The application is automatically reloaded when Ruby files are saved. It avoids restarting the server. Changes are reloaded on the fly. Execute one of the following commands from the sonar-server/ directory to start server:

# for embedded database
sonar-server/derby-start.sh

# or for other dbs
sonar-server/mysql-start.sh
sonar-server/postgresql-start.sh

Then Ruby code can be directly edited from sonar-server/src/main/webapp/WEB-INF/app.

Debug Maven Analysis

Debug Maven analysis by executing mvnDebug sonar:sonar. Then attach your IDE to the remote process (the listening port is 8000).

Example in Intellij Idea : Run -> Edit configurations -> Add new configuration -> Remote -> port 8000.

Profile Maven Analysis with JProfiler

Duplicate $MAVEN_HOME/bin/mvnDebug to mvnJProfiler and replace the property MAVEN_DEBUG_OPTS by:

MAVEN_DEBUG_OPTS="-Xint -agentlib:jprofilerti=port=8849 -Xbootclasspath/a:/path/to/jprofiler/bin/agent.jar"

Then start JProfiler -> Connect to an application on a remote computer

Log All Server SQL Requests

Download log4jdbc4-1.2.jar from http://log4jdbc.googlecode.com/files/log4jdbc4-1.2.jar in $SONAR_HOME/war/sonar-server/WEB-INF/lib/log4jdbc4-1.2.jar, and edit conf/logback.xml:

<logger name="jdbc.sqltiming">
  <level value="OFF"/>
  <appender-ref ref="PROFILING_FILE"/>
</logger>
<logger name="jdbc.connection">
    <level value="INFO"/>
    <appender-ref ref="PROFILING_FILE"/>
</logger>
<logger name="jdbc.audit">
    <level value="OFF"/>
    <appender-ref ref="PROFILING_FILE"/>
</logger>
<logger name="jdbc.resultset">
    <level value="OFF"/>
    <appender-ref ref="PROFILING_FILE"/>
</logger>
<logger name="jdbc.sqlonly">
    <level value="OFF"/>
    <appender-ref ref="PROFILING_FILE"/>
</logger>

License

Copyright 2008-2013 SonarSource.

Licensed under the GNU Lesser General Public License, Version 3.0: http://www.gnu.org/licenses/lgpl.txt