У меня есть рабочий процесс CI, который объединяет работу с задержкой, а затем работу с качеством кода.Моя работа в Linting - это запуск докера, запускающего мой сценарий eslint из кода приложения.Затем моя задача по качеству кода должна запустить экземпляр докера сканера сонара, проверить мой код и отправить отчеты обратно в мой экземпляр сонаркуба.
Проблема в основном в том, что я не могу правильно запустить сонарсканер с любым из решений, которые:
Сонар Docker сканера https://github.com/newtmitch/docker-sonar-scanner
На этом этапе бегун запускает образ, но при запуске его сценария (который только sonar-scanner (with potential arguments)
iполучить этот ответ об ошибке:
sonar scanner unrecognized option -c
, который я не понимаю и не могу контролировать, так как это уже созданный образ докера, извлеченный из концентратора докера
SonarУстановка сканера с нуля в докер-контейнер
Вот что я делаю, это установка сонарного сканера, загрузив его в контейнер следующим образом:
Dockerfile
FROM java:alpine
ENV SONAR_SCANNER_VERSION 3.3.0.1492
RUN apk add --no-cache wget && \
wget https://binaries.sonarsource.com/Distribution/sonar-scanner-cli/sonar-scanner-cli-${SONAR_SCANNER_VERSION}-linux.zip && \
unzip sonar-scanner-cli-${SONAR_SCANNER_VERSION}-linux && \
cd /usr/bin && ln -s /sonar-scanner-cli-${SONAR_SCANNER_VERSION}-linux/bin/sonar-scanner sonar-scanner && \
apk del wget
COPY sonar-scanner-run.sh /usr/bin
RUN ["chmod", "+x", "/usr/bin/sonar-scanner-run.sh"]
Здесь я добавляю wget для возможности загрузки файлов, затем загружаю последнюю версию сонара-сканера по ссылке, найденной в их официальной документации . Iзатем распакуйте его, а затем создайте символическую ссылку на двоичный файл, чтобы я мог выполнить скрипт из любого места.Наконец, я очищаю кеш wget, копирую мой сценарий оболочки, который будет выполняться из gitlab-ci.yml, и запускаю команду chmod, чтобы обойти любые проблемы с правами доступа.
sonar-scanner-run.sh
URL="https://mysonarqubeserver"
USER="myusertoken"
SONAR_PROJECT_KEY="myprojectkey"
COMMAND="sonar-scanner -Dsonar.host.url=\"$URL\" -Dsonar.login=\"$USER\" -Dsonar.projectKey=\"$SONAR_PROJECT_KEY\""
eval $COMMAND
Все переменные окружения задаются sonarqube после создания проекта.
Здесь у меня есть «проблема с Linux», где моя символическая ссылка не создается, так как я получаю этот код ошибки в своих журналах gitlab ci:
Unkown command sonar-scanner
РЕДАКТИРОВАТЬ Символьная ссылка теперь работает (проблема заключалась в том, что разархивированное имя папки было неправильным), но выскакивает другое сообщение.Сонарный сканер на самом деле работает сейчас, вот ошибка:
INFO: ------------- Run sensors on module mytherapy
INFO: Load metrics repository
INFO: Load metrics repository (done) | time=121ms
INFO: Sensor JavaSquidSensor [java]
INFO: Configured Java source version (sonar.java.source): none
INFO: JavaClasspath initialization
INFO: ------------------------------------------------------------------------
INFO: EXECUTION FAILURE
INFO: ------------------------------------------------------------------------
INFO: Total time: 14.285s
ERROR: Error during SonarQube Scanner execution
INFO: Final Memory: 25M/284M
INFO: ------------------------------------------------------------------------
ERROR: Please provide compiled classes of your project with sonar.java.binaries property
Мой проект является реагирующим, поэтому проект javascript.Я не понимаю, почему он требует скомпилированные классы Java
Вот мой файл gitlab-ci.yml на случай, если проблема может быть здесь:
gitlab.ci.yml
cache:
paths:
- node_modules/
stages:
- analysis
- test
lint:
stage: analysis
image: "node:latest"
script: npm i && npm run lint
tags: ["nodejs"]
code quality:
stage: analysis
image: <My image from the registry>
script:
- /usr/bin/sonar-scanner-run.sh
pass tests:
stage: test
image: "node:latest"
script: npm i && npm run test
tags: ["nodejs"]