From ee38b1666220bf6b24bcb12ebb8dfe9c07e50a8d Mon Sep 17 00:00:00 2001 From: Louis LABORIE Date: Sun, 7 Apr 2024 11:51:19 +0200 Subject: [PATCH] =?UTF-8?q?Add=20CI=20for=20the=20project=20=E2=9C=A8?= =?UTF-8?q?=E2=9C=A8?= MIME-Version: 1.0 Content-Type: text/plain; charset=UTF-8 Content-Transfer-Encoding: 8bit --- .drone.yml | 42 ++++++++++++++++++++++++++++++++++++++++++ 1 file changed, 42 insertions(+) diff --git a/.drone.yml b/.drone.yml index f49bed5..09efd17 100644 --- a/.drone.yml +++ b/.drone.yml @@ -7,6 +7,48 @@ trigger: - push steps: +- name: build + image: mcr.microsoft.com/dotnet/sdk:8.0 + commands: + - cd VeraxShield + - dotnet restore VeraxShield.sln + - dotnet build VeraxShield.sln -c Release --no-restore + - dotnet publish VeraxShield.sln -c Release --no-restore -o $CI_PROJECT_DIR/build/release + + - name: tests + image: mcr.microsoft.com/dotnet/sdk:8.0 + commands: + - cd VeraxShield + - dotnet restore VeraxShield.sln + - dotnet test VeraxShield.sln --no-restore + depends_on: [build] + + - name: code-inspection + image: hub.codefirst.iut.uca.fr/marc.chevaldonne/codefirst-dronesonarplugin-dotnet8 + secrets: [ SECRET_SONAR_LOGIN ] + environment: + sonar_host: https://codefirst.iut.uca.fr/sonar/ + sonar_token: + from_secret: SECRET_SONAR_LOGIN # Secret de Drone + project_key: VeraxShield + commands: + - cd VeraxShield/ + - dotnet restore VeraxShield.sln + - dotnet sonarscanner begin /k:$${project_key} /d:sonar.host.url=$${sonar_host} /d:sonar.coverageReportPaths="coveragereport/SonarQube.xml" /d:sonar.coverage.exclusions="VeraxShield/wwwroot/**" /d:sonar.login=$${sonar_token} + - dotnet build VeraxShield.sln -c Release --no-restore + - dotnet test VeraxShield.sln --logger trx --no-restore /p:CollectCoverage=true /p:CoverletOutputFormat=cobertura --collect "XPlat Code Coverage" + - reportgenerator -reports:"**/coverage.cobertura.xml" -reporttypes:SonarQube -targetdir:"coveragereport" + - dotnet publish VeraxShield.sln -c Release --no-restore -o $CI_PROJECT_DIR/build/release + - dotnet sonarscanner end /d:sonar.login=$${sonar_token} + when: + branch: + - master + event: + - push + - pull_request + depends_on: [build,tests] + + - name: docker-build-and-push image: plugins/docker settings: