2016-11-16 33 views
2

我正在使用sonar swift plugin和osx中的setup sonar。我使用的是sonar 6.1,sonar-runner 2.8和backelite-sonar-swift-plugin-0.2.4.jar文件。在運行./run-sonar-swift.sh之後,它會產生以下錯誤。我正在使用MySQL DB。 Sonar與數據庫連接並創建所有表格,但最終出現錯誤。在SonarQube掃描儀執行期間,SCM供應商自動檢測執行失敗

Done linting! Found 34 violations, 2 serious in 4 files. 
Running Lizard.....Running SonarQube using SonarQube Runner..WARN: Property 'sonar.jdbc.url' is not supported any more. It will be ignored. There is no longer any DB connection to the SQ database. 
WARN: Property 'sonar.jdbc.username' is not supported any more. It will be ignored. There is no longer any DB connection to the SQ database. 
WARN: Property 'sonar.jdbc.password' is not supported any more. It will be ignored. There is no longer any DB connection to the SQ database. 
....WARN: SCM provider autodetection failed. No SCM provider claims to support this project. Please use sonar.scm.provider to define SCM of your project. 
.ERROR: Error during SonarQube Scanner execution 
ERROR: File [moduleKey=abc.Krish, relative=KrishTests/KrishTests.swift, basedir=/Users/vjayah1/Desktop/Krish] can't be indexed twice. Please check that inclusion/exclusion patterns produce disjoint sets for main and test files 
ERROR: 
ERROR: Re-run SonarQube Scanner using the -X switch to enable full debug logging. 
ERROR - Command 'sonar-runner ' failed with error code: 1 

sonar-runner.properties(/usr/local/Cellar/sonar-runner/2.8/libexec/conf)

#Configure here general information about the environment, such as SonarQube DB details for example 
#No information about specific project should appear here 

#----- Default SonarQube server 
sonar.host.url=http://localhost:9000 

#----- Default source code encoding 
#sonar.sourceEncoding=UTF-8 

#----- Global database settings (not used for SonarQube 5.2+) 
sonar.jdbc.username=root 
sonar.jdbc.password=1234 

#----- PostgreSQL 
#sonar.jdbc.url=jdbc:postgresql://localhost/sonar 

#----- MySQL 
sonar.jdbc.url=jdbc:mysql://localhost:3306/sonar_firstdb?useUnicode=true&characterEncoding=utf8&rewriteBatchedStatements=true 

#----- Oracle 
#sonar.jdbc.url=jdbc:oracle:thin:@localhost/XE 

#----- Microsoft SQLServer 
#sonar.jdbc.url=jdbc:jtds:sqlserver://localhost/sonar;SelectMethod=Cursor 

sonar.properties文件(在/ usr /本地/地窖/ sonarqube /6.1/libexec/conf)

# Property values can: 
# - reference an environment variable, for example sonar.jdbc.url= ${env:SONAR_JDBC_URL} 
# - be encrypted. See http://redirect.sonarsource.com/doc/settings-encryption.html 

#-------------------------------------------------------------------------------------------------- 
# DATABASE 
# 
# IMPORTANT: the embedded H2 database is used by default. It is recommended for tests but not for 
# production use. Supported databases are MySQL, Oracle, PostgreSQL and Microsoft SQLServer. 

# User credentials. 
# Permissions to create tables, indices and triggers must be granted to JDBC user. 
# The schema must be created first. 
sonar.jdbc.username=root 
sonar.jdbc.password=1234 

#----- Embedded Database (default) 
# H2 embedded database server listening port, defaults to 9092 
#sonar.embeddedDatabase.port=9092 
#----- MySQL 5.6 or greater 
# Only InnoDB storage engine is supported (not myISAM). 
# Only the bundled driver is supported. It can not be changed. 
sonar.jdbc.url=jdbc:mysql://localhost:3306/sonar_firstdb?useUnicode=true&characterEncoding=utf8&rewriteBatchedStatements=true 

#----- Oracle 11g/12c 
# - Only thin client is supported 
# - Only versions 11.2.x and 12.x of Oracle JDBC driver are supported 
# - The JDBC driver must be copied into the directory extensions/jdbc-driver/oracle/ 
# - If you need to set the schema, please refer to http://jira.sonarsource.com/browse/SONAR-5000 
#sonar.jdbc.url=jdbc:oracle:thin:@localhost:1521/XE 


#----- PostgreSQL 8.x/9.x 
# If you don't use the schema named "public", please refer to http://jira.sonarsource.com/browse/SONAR-5000 
#sonar.jdbc.url=jdbc:postgresql://localhost/sonar 


#----- Microsoft SQLServer 2012/2014 and SQL Azure 
# A database named sonar must exist and its collation must be case-sensitive (CS) and accent-sensitive (AS) 
# Use the following connection string if you want to use integrated security with Microsoft Sql Server 
# Do not set sonar.jdbc.username or sonar.jdbc.password property if you are using Integrated Security 
# For Integrated Security to work, you have to download the Microsoft SQL JDBC driver package from 
# http://www.microsoft.com/en-us/download/details.aspx?displaylang=en&id=11774 
# and copy sqljdbc_auth.dll to your path. You have to copy the 32 bit or 64 bit version of the dll 
# depending upon the architecture of your server machine. 
# This version of SonarQube has been tested with Microsoft SQL JDBC version 4.1 
#sonar.jdbc.url=jdbc:sqlserver://localhost;databaseName=sonar;integratedSecurity=true 

# Use the following connection string if you want to use SQL Auth while connecting to MS Sql Server. 
# Set the sonar.jdbc.username and sonar.jdbc.password appropriately. 
#sonar.jdbc.url=jdbc:sqlserver://localhost;databaseName=sonar 


#----- Connection pool settings 
# The maximum number of active connections that can be allocated 
# at the same time, or negative for no limit. 
# The recommended value is 1.2 * max sizes of HTTP pools. For example if HTTP ports are 
# enabled with default sizes (50, see property sonar.web.http.maxThreads) 
# then sonar.jdbc.maxActive should be 1.2 * (50) = 120. 
#sonar.jdbc.maxActive=60 

# The maximum number of connections that can remain idle in the 
# pool, without extra ones being released, or negative for no limit. 
#sonar.jdbc.maxIdle=5 

# The minimum number of connections that can remain idle in the pool, 
# without extra ones being created, or zero to create none. 
#sonar.jdbc.minIdle=2 

# The maximum number of milliseconds that the pool will wait (when there 
# are no available connections) for a connection to be returned before 
# throwing an exception, or <= 0 to wait indefinitely. 
#sonar.jdbc.maxWait=5000 

#sonar.jdbc.minEvictableIdleTimeMillis=600000 
#sonar.jdbc.timeBetweenEvictionRunsMillis=30000 



#-------------------------------------------------------------------------------------------------- 
# WEB SERVER 
# Web server is executed in a dedicated Java process. By default heap size is 512Mb. 
# Use the following property to customize JVM options. 
# Recommendations: 
# 
# The HotSpot Server VM is recommended. The property -server should be added if server mode 
# is not enabled by default on your environment: 
# http://docs.oracle.com/javase/8/docs/technotes/guides/vm/server-class.html 
# 
# Startup can be long if entropy source is short of entropy. Adding 
# -Djava.security.egd=file:/dev/./urandom is an option to resolve the problem. 
# See https://wiki.apache.org/tomcat/HowTo/FasterStartUp#Entropy_Source 
# 
#sonar.web.javaOpts=-Xmx512m -Xms128m -XX:+HeapDumpOnOutOfMemoryError 

# Same as previous property, but allows to not repeat all other settings like -Xmx 
#sonar.web.javaAdditionalOpts= 

# Binding IP address. For servers with more than one IP address, this property specifies which 
# address will be used for listening on the specified ports. 
# By default, ports will be used on all IP addresses associated with the server. 
#sonar.web.host=0.0.0.0 

# Web context. When set, it must start with forward slash (for example /sonarqube). 
# The default value is root context (empty value). 
#sonar.web.context= 
# TCP port for incoming HTTP connections. Default value is 9000. 
sonar.web.port=9000 


# The maximum number of connections that the server will accept and process at any given time. 
# When this number has been reached, the server will not accept any more connections until 
# the number of connections falls below this value. The operating system may still accept connections 
# based on the sonar.web.connections.acceptCount property. The default value is 50. 
#sonar.web.http.maxThreads=50 

# The minimum number of threads always kept running. The default value is 5. 
#sonar.web.http.minThreads=5 

# The maximum queue length for incoming connection requests when all possible request processing 
# threads are in use. Any requests received when the queue is full will be refused. 
# The default value is 25. 
#sonar.web.http.acceptCount=25 

# By default users are logged out and sessions closed when server is restarted. 
# If you prefer keeping user sessions open, a secret should be defined. Value is 
# HS256 key encoded with base64. It must be unique for each installation of SonarQube. 
# Example of command-line: 
# echo -n "type_what_you_want" | openssl dgst -sha256 -hmac "key" -binary | base64 
#sonar.auth.jwtBase64Hs256Secret= 

#-------------------------------------------------------------------------------------------------- 
# COMPUTE ENGINE 
# The Compute Engine is responsible for processing background tasks. 
# Compute Engine is executed in a dedicated Java process. Default heap size is 512Mb. 
# Use the following property to customize JVM options. 
# Recommendations: 
# 
# The HotSpot Server VM is recommended. The property -server should be added if server mode 
# is not enabled by default on your environment: 
# http://docs.oracle.com/javase/8/docs/technotes/guides/vm/server-class.html 
# 
#sonar.ce.javaOpts=-Xmx512m -Xms128m -XX:+HeapDumpOnOutOfMemoryError 

# Same as previous property, but allows to not repeat all other settings like -Xmx 
#sonar.ce.javaAdditionalOpts= 
# The number of workers in the Compute Engine. Value must be greater than zero. 
# By default the Compute Engine uses a single worker and therefore processes tasks one at a time. 
# Recommendations: 
# 
# Using N workers will require N times as much Heap memory (see property 
# sonar.ce.javaOpts to tune heap) and produce N times as much IOs on disk, database and 
# Elasticsearch. The number of workers must suit your environment. 
#sonar.ce.workerCount=1 


#-------------------------------------------------------------------------------------------------- 
# ELASTICSEARCH 
# Elasticsearch is used to facilitate fast and accurate information retrieval. 
# It is executed in a dedicated Java process. Default heap size is 1Gb. 

# JVM options of Elasticsearch process 
# Recommendations: 
# 
# Use HotSpot Server VM. The property -server should be added if server mode 
# is not enabled by default on your environment: 
# http://docs.oracle.com/javase/8/docs/technotes/guides/vm/server-class.html 
# 
#sonar.search.javaOpts=-Xmx1G -Xms256m -Xss256k -Djna.nosys=true \ 
# -XX:+UseParNewGC -XX:+UseConcMarkSweepGC -XX:CMSInitiatingOccupancyFraction=75 \ 
# -XX:+UseCMSInitiatingOccupancyOnly -XX:+HeapDumpOnOutOfMemoryError 

# Same as previous property, but allows to not repeat all other settings like -Xmx 
#sonar.search.javaAdditionalOpts= 

# Elasticsearch port. Default is 9001. Use 0 to get a free port. 
# As a security precaution, should be blocked by a firewall and not exposed to the Internet. 
#sonar.search.port=9001 

# Elasticsearch host. The search server will bind this address and the search client will connect to it. 
# Default is 127.0.0.1. 
# As a security precaution, should NOT be set to a publicly available address. 
#sonar.search.host=127.0.0.1 


#-------------------------------------------------------------------------------------------------- 
# UPDATE CENTER 

# Update Center requires an internet connection to request https://update.sonarsource.org 
# It is enabled by default. 
#sonar.updatecenter.activate=true 

# HTTP proxy (default none) 
#http.proxyHost= 
#http.proxyPort= 
# HTTPS proxy (defaults are values of http.proxyHost and http.proxyPort) 
#https.proxyHost= 
#https.proxyPort= 

# NT domain name if NTLM proxy is used 
#http.auth.ntlm.domain= 

# SOCKS proxy (default none) 
#socksProxyHost= 
#socksProxyPort= 

# Proxy authentication (used for HTTP, HTTPS and SOCKS proxies) 
#http.proxyUser= 
#http.proxyPassword= 


#-------------------------------------------------------------------------------------------------- 
# LOGGING 

# Level of logs. Supported values are INFO(default), DEBUG and TRACE (DEBUG + SQL + ES requests) 
#sonar.log.level=INFO 

# Path to log files. Can be absolute or relative to installation directory. 
# Default is <installation home>/logs 
#sonar.path.logs=logs 

# Rolling policy of log files 
# - based on time if value starts with "time:", for example by day ("time:yyyy-MM-dd") 
#  or by month ("time:yyyy-MM") 
# - based on size if value starts with "size:", for example "size:10MB" 
# - disabled if value is "none". That needs logs to be managed by an external system like logrotate. 
#sonar.log.rollingPolicy=time:yyyy-MM-dd 

# Maximum number of files to keep if a rolling policy is enabled. 
# - maximum value is 20 on size rolling policy 
# - unlimited on time rolling policy. Set to zero to disable old file purging. 
#sonar.log.maxFiles=7 

# Access log is the list of all the HTTP requests received by server. If enabled, it is stored 
# in the file {sonar.path.logs}/access.log. This file follows the same rolling policy as for 
# sonar.log (see sonar.log.rollingPolicy and sonar.log.maxFiles). 
#sonar.web.accessLogs.enable=true 

# Format of access log. It is ignored if sonar.web.accessLogs.enable=false. Possible values are: 
# - "common" is the Common Log Format, shortcut to: %h %l %u %user %date "%r" %s %b 
# - "combined" is another format widely recognized, shortcut to: %h %l %u [%t] "%r" %s %b "%i{Referer}" "%i{User-Agent}" 
# - else a custom pattern. See http://logback.qos.ch/manual/layouts.html#AccessPatternLayout. 
# The login of authenticated user is not implemented with "%u" but with "%reqAttribute{LOGIN}" (since version 6.1). 
# The value displayed for anonymous users is "-". 
# If SonarQube is behind a reverse proxy, then the following value allows to display the correct remote IP address: 
#sonar.web.accessLogs.pattern=%i{X-Forwarded-For} %l %u [%t] "%r" %s %b "%i{Referer}" "%i{User-Agent}" 
# Default value is: 
#sonar.web.accessLogs.pattern=combined 


#-------------------------------------------------------------------------------------------------- 
# OTHERS 

# Delay in seconds between processing of notification queue. Default is 60 seconds. 
#sonar.notifications.delay=60 

# Paths to persistent data files (embedded database and search index) and temporary files. 
# Can be absolute or relative to installation directory. 
# Defaults are respectively <installation home>/data and <installation home>/temp 
#sonar.path.data=data 
#sonar.path.temp=temp 


#-------------------------------------------------------------------------------------------------- 
# DEVELOPMENT - only for developers 
# The following properties MUST NOT be used in production environments. 

# Dev mode allows to reload web sources on changes and to restart server when new versions 
# of plugins are deployed. 
#sonar.web.dev=false 

# Path to webapp sources for hot-reloading of Ruby on Rails, JS and CSS (only core, 
# plugins not supported). 
#sonar.web.dev.sources=/path/to/server/sonar-web/src/main/webapp 

# Elasticsearch HTTP connector, for example for KOPF: 
# http://lmenezes.com/elasticsearch-kopf/?location=http://localhost:9010 
#sonar.search.httpPort=-1 

sonar-project.properties(項目根文件夾)

########################## 
# Required configuration # 
########################## 

sonar.projectKey=abc.Krish 
sonar.projectName=Krish 
sonar.projectVersion=1.0 


# Comment if you have a project with mixed ObjC/Swift 
sonar.language=swift 

# Project description 
sonar.projectDescription=prjDescription 

# Path to source directories 
sonar.sources=/Users/vjayah1/Desktop/Krish 
# Path to test directories (comment if no test) 
sonar.tests=/Users/vjayah1/Desktop/Krish/KrishTests 

# Destination Simulator to run tests 
# As string expected in destination argument of xcodebuild command 
# Example = sonar.swift.simulator=platform=iOS Simulator,name=iPhone 6,OS=9.2 
sonar.swift.simulator=platform=iOS Simulator,name=iPhone 7,OS=10.1 

# Xcode project configuration (.xcodeproj) 
# and use the later to specify which project(s) to include in the analysis (comma separated list) 
# Specify either xcodeproj or xcodeproj + xcworkspace 
#sonar.swift.project=MyPrj.xcodeproj 
#sonar.swift.workspace=MyWrkSpc.xcworkspace 



sonar.swift.project=Krish.xcodeproj 





# Scheme to build your application 
sonar.swift.appScheme=Krish 
# Configuration to use for your scheme. if you do not specify that the default will be Debug 
sonar.swift.appConfiguration=Debug 

########################## 
# Optional configuration # 
########################## 

# Encoding of the source code 
sonar.sourceEncoding=UTF-8 


# SCM 
# sonar.scm.enabled=true 
# sonar.scm.url=scm:git:http://xxx 

# JUnit report generated by run-sonar.sh is stored in sonar-reports/TEST-report.xml 
# Change it only if you generate the file on your own 
# The XML files have to be prefixed by TEST- otherwise they are not processed 
# sonar.junit.reportsPath=sonar-reports/ 

# Lizard report generated by run-sonar.sh is stored in sonar-reports/lizard-report.xml 
# Change it only if you generate the file on your own 
# sonar.swift.lizard.report=sonar-reports/lizard-report.xml 

# Cobertura report generated by run-sonar.sh is stored in sonar-reports/coverage.xml 
# Change it only if you generate the file on your own 
# sonar.swift.coverage.reportPattern=sonar-reports/coverage*.xml 

# OCLint report generated by run-sonar.sh is stored in sonar-reports/oclint.xml 
# Change it only if you generate the file on your own 
# sonar.swift.swiftlint.report=sonar-reports/*swiftlint.txt 

# Paths to exclude from coverage report (tests, 3rd party libraries etc.) 
# sonar.swift.excludedPathsFromCoverage=pattern1,pattern2 
sonar.swift.excludedPathsFromCoverage=.*Tests.* 
+0

「SCM提供商自動偵測失敗」的警告,實際誤差小於 - 「文件[moduleKey = abc.Krish,相對= KrishTests/KrishTests.swift,basedir =/Users/vjayah1/Desktop/Krish]不能被索引兩次,請檢查包含/排除模式爲主文件和測試文件產生不相交的集合。 – Godin

回答

0

這是一個配置的問題:

# Path to source directories 
sonar.sources=/Users/vjayah1/Desktop/Krish 
# Path to test directories (comment if no test) 
sonar.tests=/Users/vjayah1/Desktop/Krish/KrishTests 

源文件夾遞歸索引。所以/Users/vjayah1/Desktop/Krish也將包含/Users/vjayah1/Desktop/Krish/KrishTests

你應該從主要來源排除test文件夾:

sonar.exclusions=/Users/vjayah1/Desktop/Krish/KrishTests/**/* 
相關問題