Skip to content

Merge pull request #96 from siemens/Python_forSw360CompCreator #1190

Merge pull request #96 from siemens/Python_forSw360CompCreator

Merge pull request #96 from siemens/Python_forSw360CompCreator #1190

Workflow file for this run

name: Build & Test
on:
push:
pull_request:
jobs:
build:
runs-on: self-hosted
defaults:
run:
working-directory: .
outputs:
semver: ${{ steps.gitversion.outputs.semver }}
LicenseClearingTool: ${{ steps.packageBuildResults.outputs.LicenseClearingTool }}
nupkg-LicenseClearingTool: ${{ steps.createNupkg.outputs.nupkg-LicenseClearingTool }}
docker-LicenseClearingTool: ${{ steps.builddocker.outputs.docker-LicenseClearingTool }}
steps:
- name: Checkout
uses: actions/checkout@v3
with:
fetch-depth: 0
- name: Setup Version
uses: gittools/actions/gitversion/[email protected]
with:
versionSpec: '5.3.6'
env:
ACTIONS_ALLOW_UNSECURE_COMMANDS: TRUE
- name: Determine Version
uses: gittools/actions/gitversion/[email protected]
with:
useConfigFile: true
env:
ACTIONS_ALLOW_UNSECURE_COMMANDS: TRUE
- name: get SemVer
id: gitversion
run: |
echo "SemVer: v$($env:GitVersion_SemVer)"
Write-Host "::set-output name=semver::v$($env:GitVersion_SemVer)"
$fileName = "dummy-v$($env:GitVersion_SemVer)"
echo "SemVerMMP: v$($env:GitVersion_MajorMinorPatch)"
Write-Host "Filename: '$fileName'"
- name: Add msbuild to PATH
uses: microsoft/[email protected]
- name: update appSettingsSW360IntegrationTest.json
run: ./Scripts/json_update.ps1 -JsonFile 'src\TestUtilities\appSettingsSW360IntegrationTest.json'
env:
SW360HOST: ${{ secrets.SW360HOST }}
SW360APPPORT: ${{ secrets.SW360APPPORT }}
FOSSYHOST: ${{ secrets.FOSSYHOST }}
FOSSYAPPPORT: ${{ secrets.FOSSYAPPPORT }}
USEREMAIL: ${{ secrets.USEREMAIL }}
ARTIFACTORYAPIKEY: ${{ secrets.ARTIFACTORYAPIKEY }}
JFROGURL: ${{ secrets.JFROGURL }}
SW360AUTHKEY: ${{ secrets.SW360AUTHTOKEN }}
- name: update appsettingsUnitTest.json
run: ./Scripts/json_update_ut.ps1 -JsonFile 'src\UnitTestUtilities\appsettingsUnitTest.json'
env:
SW360HOST: ${{ secrets.SW360HOST }}
SW360APPPORT: ${{ secrets.SW360APPPORT }}
FOSSYHOST: ${{ secrets.FOSSYHOST }}
FOSSYAPPPORT: ${{ secrets.FOSSYAPPPORT }}
JFROGURL: ${{ secrets.JFROGURL }}
- name: Restore Packages
run: dotnet restore src\LicenseClearingTool.sln
- name: Build
run: msbuild -m -t:Rebuild -p:Configuration=Release -bl:continous-clearing.binlog -noconlog src\LicenseClearingTool.sln
- name: Archive Build Log
uses: actions/upload-artifact@v2
if: ${{ success() || failure() }}
with:
name: Compile_Solution_log
path: |
src/*.binlog
*.binlog
- name: Create zip
id: packageBuildResults
run: |
$sourceFolder = Join-Path $env:GITHUB_WORKSPACE "out" | Join-Path -ChildPath "*"
$outFolder = Join-Path $env:GITHUB_WORKSPACE "out" | Join-Path -ChildPath "continuous-clearing"
New-Item -ItemType Directory -Force -Path $outFolder
$fileName = "continuous-clearing-4.0.0.zip"
Write-Host "Filename: '$fileName'"
Write-Host "sourceFolder: '$sourceFolder'"
Write-Host "Outfolder: '$outFolder'"
Write-Host "::set-output name=LicenseClearingTool::$($fileName)"
$outPath = Join-Path $outFolder $fileName
Compress-Archive -DestinationPath $outPath -Path $sourceFolder -CompressionLevel Optimal
- name: SW360 Instance refresh
#if: ${{ false }} # disable for now
run: |
docker exec -dt sw360confctnr1 service postgresql stop
docker stop sw360confctnr1
docker rm sw360confctnr1
docker run --name sw360confctnr1 --memory=7g -t -d -p ${env:SW360APPPORT}:8080 -p 5990:5984 -p 5440:5432 ${env:DOCKERDEVARTIFACTORY}/energy-dev/software-clearing/sw360/sw360conf:latest
Start-Sleep -s 200
env:
SW360APPPORT: ${{ secrets.SW360APPPORT }}
DOCKERDEVARTIFACTORY: ${{ secrets.DOCKERDEVARTIFACTORY }}
- name: Test
#if: ${{ false }} # disable for now
run: |
$TestProjects = Get-ChildItem -Path *test*.csproj -Recurse -exclude TestUtilities.csproj,UnitTestUtilities.csproj
Write-Host "**************************The test projects considered for execution: $TestProjects ******************************"
Write-Host "********************************************************************************************************************"
foreach ($Project in $TestProjects)
{
Write-Host $Project.DirectoryName
$TestProject = $Project.DirectoryName
Push-Location $Project.PSParentPath
dotnet test --no-build --configuration Release
}
- name: Archive Build Output
uses: actions/upload-artifact@v2
with:
name: continuous-clearing
path: |
out/continuous-clearing
- name: Create Nuget Packages
id: createNupkg
run: |
nuget pack CA.nuspec -Version 4.0.0
Write-Host "::set-output name=nupkg-LicenseClearingTool::continuous-clearing.4.0.0.nupkg"
- name: Archive NuGet Packages
uses: actions/upload-artifact@v2
with:
name: nuget-continuous-clearing
path: |
*.nupkg
- name: Build the Docker image
id: builddocker
#if: ${{ false }} # disable for now
run: |
docker build . --file Dockerfile --tag ${{ github.repository }}:continuous-clearing-v4.0.0
docker save ${{ github.repository }}:continuous-clearing-v4.0.0 -o continuous-clearing-v4.0.0.tar
Write-Host "::set-output name=docker-LicenseClearingTool::continuous-clearing-v4.0.0.tar"
- name: Archive docker image
#if: ${{ false }} # disable for now
uses: actions/upload-artifact@v2
with:
name: docker-continuous-clearing
path: |
*.tar
release:
if: github.ref == 'refs/heads/main'
runs-on: self-hosted
needs: build
steps:
- name: Download Build Output
uses: actions/download-artifact@v2
with:
name: continuous-clearing
- name: Download NuGet Package
uses: actions/download-artifact@v2
with:
name: nuget-continuous-clearing
- name: Download Docker image
uses: actions/download-artifact@v2
with:
name: docker-continuous-clearing
- name: Debug
run: |
tree
- name: Create Release
id: create_release
uses: actions/create-release@v1
env:
GITHUB_TOKEN: ${{ secrets.GITHUB_TOKEN }}
with:
tag_name: v4.0.0
#tag_name: ${{ needs.build.outputs.semver }}
release_name: Release v4.0.0
body: |
${{ github.event.head_commit.message }}
draft: true
prerelease: false
- name: Upload Zip
uses: actions/upload-release-asset@v1
env:
GITHUB_TOKEN: ${{ secrets.GITHUB_TOKEN }}
with:
upload_url: ${{ steps.create_release.outputs.upload_url }}
asset_path: ./${{ needs.build.outputs.LicenseClearingTool }}
asset_name: ${{ needs.build.outputs.LicenseClearingTool }}
asset_content_type: application/zip
- name: Upload Nupkg
uses: actions/upload-release-asset@v1
env:
GITHUB_TOKEN: ${{ secrets.GITHUB_TOKEN }}
with:
upload_url: ${{ steps.create_release.outputs.upload_url }}
asset_path: ./${{ needs.build.outputs.nupkg-LicenseClearingTool }}
asset_name: ${{ needs.build.outputs.nupkg-LicenseClearingTool }}
asset_content_type: application/zip
- name: Upload Nupkg
uses: actions/upload-release-asset@v1
env:
GITHUB_TOKEN: ${{ secrets.GITHUB_TOKEN }}
with:
upload_url: ${{ steps.create_release.outputs.upload_url }}
asset_path: ./${{ needs.build.outputs.docker-LicenseClearingTool }}
asset_name: ${{ needs.build.outputs.docker-LicenseClearingTool }}
asset_content_type: application/zip
- name: Upload ReadmeOSS_nupkg file
uses: actions/upload-release-asset@v1
env:
GITHUB_TOKEN: ${{ secrets.GITHUB_TOKEN }}
with:
upload_url: ${{ steps.create_release.outputs.upload_url }}
asset_path: ./ReadmeOSS_continuous-clearing_nupkg.html
asset_name: ReadmeOSS_continuous-clearing_nupkg.html
asset_content_type: text/html
- name: Upload ReadmeOSS_Docker file
uses: actions/upload-release-asset@v1
env:
GITHUB_TOKEN: ${{ secrets.GITHUB_TOKEN }}
with:
upload_url: ${{ steps.create_release.outputs.upload_url }}
asset_path: ./ReadmeOSS_continuous-clearing_DockerImage.html
asset_name: ReadmeOSS_continuous-clearing_DockerImage.html
asset_content_type: text/html