ci: Изменена версия oscript для тестирования и сборки. #114
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
# MIT License | |
# Copyright (C) 2020 Tymko Oleg <[email protected]> and contributors | |
# All rights reserved. | |
name: Контроль качества | |
# Любой пуш и pr в проекте но с фильтром по основному проекту | |
on: [push, pull_request] | |
env: | |
# отключение безопасности установки, от 2020-10-01 | |
ACTIONS_ALLOW_UNSECURE_COMMANDS: true | |
jobs: | |
build: | |
if: github.repository == 'arkuznetsov/irac' | |
runs-on: ${{ matrix.os }} | |
strategy: | |
fail-fast: false | |
matrix: | |
os: [ubuntu-latest] | |
oscript_version: ['1.9.1'] | |
steps: | |
# Загрузка проекта | |
- name: Актуализация | |
uses: actions/checkout@v2 | |
with: | |
# Disabling shadow clone is recomended | |
fetch-depth: 0 | |
# https://stackoverflow.com/questions/58033366/how-to-get-current-branch-within-github-actions | |
- name: Извлечение имени текущей ветки | |
shell: bash | |
run: echo "##[set-output name=branch;]$(echo ${GITHUB_REF#refs/heads/})" | |
id: extract_branch | |
# Установка OneScript конкретной версии | |
- name: Установка OneScript | |
uses: otymko/[email protected] | |
with: | |
version: ${{ matrix.oscript_version }} | |
# Установка зависимостей пакета | |
- name: Установка зависимостей | |
run: | | |
opm install opm | |
opm install --dev | |
# Запуск тестов и сбор покрытия кода | |
- name: Тестирование и расчет покрытия кода | |
run: oscript ./tasks/coverage.os | |
- name: Извлечение версии пакета | |
shell: bash | |
run: echo "##[set-output name=version;]`cat packagedef | grep ".Версия(" | sed 's|[^"]*"||' | sed -r 's/".+//'`" | |
id: extract_version | |
- name: Установка Sonar-scanner | |
uses: warchant/setup-sonar-scanner@v1 | |
# Анализ проекта в SonarQube (ветка) | |
- name: Анализ в SonarQube (branch) | |
if: github.event_name == 'push' | |
run: sonar-scanner | |
-Dsonar.login=${{ secrets.SONARQUBE_TOKEN }} | |
-Dsonar.host.url=${{ secrets.SONARQUBE_HOST }} | |
-Dsonar.branch.name=${{ steps.extract_branch.outputs.branch }} | |
-Dsonar.projectVersion=${{ steps.extract_version.outputs.version }} | |
# Анализ проекта в SonarQube (PR) | |
# https://docs.sonarqube.org/latest/analysis/pull-request/ | |
- name: Анализ в SonarQube (pull-request) | |
if: github.event_name == 'pull_request' | |
run: sonar-scanner | |
-Dsonar.login=${{ secrets.SONARQUBE_TOKEN }} | |
-Dsonar.host.url=${{ secrets.SONARQUBE_HOST }} | |
-Dsonar.branch.name=${{ steps.extract_branch.outputs.branch }} | |
-Dsonar.pullrequest.key=${{ github.event.pull_request.number }} | |
-Dsonar.pullrequest.branch=${{ github.event.pull_request.head.ref }} | |
-Dsonar.pullrequest.base=${{ github.event.pull_request.base.ref }} | |
-Dsonar.scm.revision=${{ github.event.pull_request.head.sha }} |