「セキュリティ/静的解析/Sonar/android」の版間の差分
提供: 初心者エンジニアの簡易メモ
(ページの作成:「 ==sonar解析画面インストール== https://docs.sonarqube.org/latest/setup/get-started-2-minutes/ #zip file(https://binaries.sonarsource.com/Distribution/sonarqube...」) |
(→"does not exist"エラーが出る時) |
||
| 行79: | 行79: | ||
- property "sonar.sources", "src/main/" | - property "sonar.sources", "src/main/" | ||
+ property "sonar.sources", "src/" | + property "sonar.sources", "src/" | ||
| + | |||
| + | ===="WARN app[][o.s.a.p.AbstractManagedProcess] Process exited with exit value [es]: 143"の警告が出る場合==== | ||
| + | tail logs/web.logを見てみる | ||
2020年1月21日 (火) 14:14時点における版
sonar解析画面インストール
https://docs.sonarqube.org/latest/setup/get-started-2-minutes/
- zip file(https://binaries.sonarsource.com/Distribution/sonarqube/sonarqube-8.1.0.31237.zip )をDL
- userとpassは"admin"がデフォで設定されてる。
設定
$ mv ~/Downloads/sonarqube-8.1.0.31237 /d/src/
起動
$ /d/src/sonarqube-8.1.0.31237/bin/macosx-universal-64/sonar.sh console
"java.lang.IllegalStateException: SonarQube requires Java 11 to run"エラー
java11以外になってるようであればjava11へ
java -version openjdk version "11.0.2" 2019-01-15
androidプロジェクト側にsonarを設定
参考:https://android.jlelse.eu/have-code-quality-analysis-in-your-android-project-2a549e04d1a8
プロジェクト直下のbuild.gradle
buildscript {
repositories {
google()
jcenter()
maven {
url "https://plugins.gradle.org/m2/"
}
}
dependencies {
classpath 'com.android.tools.build:gradle:3.5.0'
classpath "org.sonarsource.scanner.gradle:sonarqube-gradle-plugin:2.8"
}
}
app/build.gradle
apply plugin: 'org.sonarqube'
sonarqube {
properties {
property "sonar.projectName", "MyProject"
property "sonar.projectKey", "com.example.myproject"
property "sonar.host.url", "http://localhost:9000"
property "sonar.language", "java"
property "sonar.sources", "src/main/"
property "sonar.login", "admin"
property "sonar.password", "admin"
}
}
androidプロジェクト解析実行
androidプロジェクト直下へ移動
./gradlew sonarqube -Dsonar.host.url=http://localhost:9000/
ビルドが成功したら以下へアクセス
http://localhost:9000/
"app/src/androidTest/java/com/example/sonarapplication/ExampleInstrumentedTest.java:6: エラー: パッケージandroidx.test.ext.junit.runnersは存在しません"エラーとなる場合
以下をコメントアウトすれば良い。
app/src/androidTest/java/com/example/sonarapplication/ExampleInstrumentedTest.java
// import androidx.test.ext.junit.runners.AndroidJUnit4; // @RunWith(AndroidJUnit4.class)
"does not exist"エラーが出る時
> The folder 'src/main/' does not exist for 'jp.co.hoge.hoge1' (base directory = /d/www/android/hoge/hoge1)"
以下ソースのpathが適切か確認する。mainなどがなければ削る。
build.gradle
- property "sonar.sources", "src/main/" + property "sonar.sources", "src/"
"WARN app[][o.s.a.p.AbstractManagedProcess] Process exited with exit value [es]: 143"の警告が出る場合
tail logs/web.logを見てみる
