From a0d0537bc7650c086b6e9facd5ad41c2d56cc222 Mon Sep 17 00:00:00 2001 From: Christian Grasser Date: Thu, 17 Oct 2019 17:54:58 +0200 Subject: [PATCH] - github action as starting point - update NuGet.CommandLine -> NuGet.CommandLine.6.9.1 - add initial appveyor.yml CI config - prepare for boost 1.86.0 - disabled upload of nuget to avoid upload quota exceeded with appveyor - added dummy ApiKey.cs - avoid nuget warnings about: WARNING: NU5125: The 'licenseUrl' element will be deprecated. Consider using the 'license' element instead. WARNING: NU5128: Some target frameworks declared in the dependencies group of the nuspec and the lib/ref folder do not have exact matches in the other location. Consult the list of actions below: - Add a dependency group for native0.0 to the nuspec --- .github/dependabot.yml | 17 ++++ .github/workflows/CI_build.yml | 51 ++++++++++++ appveyor.yml | 106 +++++++++++++++++++++++++ builder/builder/ApiKey.cs | 1 + builder/builder/App.config | 2 +- builder/builder/Nuspec.cs | 13 +-- builder/builder/builder.csproj | 2 +- builder/builderTest/builderTest.csproj | 11 ++- builder/builderTest/packages.config | 1 + 9 files changed, 195 insertions(+), 9 deletions(-) create mode 100644 .github/dependabot.yml create mode 100644 .github/workflows/CI_build.yml create mode 100644 appveyor.yml create mode 100644 builder/builder/ApiKey.cs diff --git a/.github/dependabot.yml b/.github/dependabot.yml new file mode 100644 index 0000000..80fc91f --- /dev/null +++ b/.github/dependabot.yml @@ -0,0 +1,17 @@ +# To get started with Dependabot version updates, you'll need to specify which +# package ecosystems to update and where the package manifests are located. +# Please see the documentation for all configuration options: +# https://help.github.com/github/administering-a-repository/configuration-options-for-dependency-updates + +version: 2 +updates: + - package-ecosystem: "nuget" # See documentation for possible values + directory: "/" # Location of package manifests + schedule: + interval: "monthly" + + # Maintain dependencies for GitHub Actions + - package-ecosystem: "github-actions" + directory: "/" + schedule: + interval: "monthly" diff --git a/.github/workflows/CI_build.yml b/.github/workflows/CI_build.yml new file mode 100644 index 0000000..84d14df --- /dev/null +++ b/.github/workflows/CI_build.yml @@ -0,0 +1,51 @@ +name: CI_build + +on: [push, pull_request] + +jobs: + build: + + runs-on: windows-latest + strategy: + matrix: + build_configuration: [Release] + build_platform: [Any CPU] + build_boost_version: [1_86_0] + build_boost_version_dot: [1.86.0] + build_msvc_version_dot: [14.3, 14.2, 14.1] + steps: + - name: Checkout repo + uses: actions/checkout@v4 + + - name: Setup Nuget.exe + uses: nuget/setup-nuget@v2 + + - name: restore input nuget packages + working-directory: builder\ + run: | + nuget restore builder\packages.config -PackagesDirectory packages + nuget restore builderTest\packages.config -PackagesDirectory packages + + - name: Setup to add MSBuild.exe to path + uses: microsoft/setup-msbuild@v2 + + - name: MSBuild of builder + working-directory: builder\ + run: | + msbuild builder.sln /m /verbosity:minimal /t:restore /p:configuration="${{ matrix.build_configuration }}" /p:platform="${{ matrix.build_platform }}" + msbuild builder.sln /m /p:configuration="${{ matrix.build_configuration }}" /p:platform="${{ matrix.build_platform }}" + + - name: boost binary download created by https://github.com/teeks99/boost-release-windows + working-directory: . + run: | + Set-Location -Path 'D:\a' + New-Item -ItemType directory -Path D:\a\boostorg + Set-Location -Path 'D:\a\boostorg' + (New-Object System.Net.WebClient).DownloadFile("https://boostorg.jfrog.io/artifactory/main/release/${{ matrix.build_boost_version_dot }}/binaries/boost_${{ matrix.build_boost_version }}-msvc-${{ matrix.build_msvc_version_dot }}-64.exe", "D:\a\boostorg\boost_${{ matrix.build_boost_version }}-msvc-${{ matrix.build_msvc_version_dot }}-64.exe") + (New-Object System.Net.WebClient).DownloadFile("https://boostorg.jfrog.io/artifactory/main/release/${{ matrix.build_boost_version_dot }}/binaries/boost_${{ matrix.build_boost_version }}-msvc-${{ matrix.build_msvc_version_dot }}-32.exe", "D:\a\boostorg\boost_${{ matrix.build_boost_version }}-msvc-${{ matrix.build_msvc_version_dot }}-32.exe") + .\boost_${{ matrix.build_boost_version }}-msvc-${{ matrix.build_msvc_version_dot }}-64.exe /SILENT /DIR=D:\a\boostorg\boost | Out-Null + .\boost_${{ matrix.build_boost_version }}-msvc-${{ matrix.build_msvc_version_dot }}-32.exe /SILENT /DIR=D:\a\boostorg\boost | Out-Null + + - name: run builder + working-directory: builder\builder\bin\Release\ + run: .\builder.exe diff --git a/appveyor.yml b/appveyor.yml new file mode 100644 index 0000000..d9529a2 --- /dev/null +++ b/appveyor.yml @@ -0,0 +1,106 @@ +version: 1.85.{build} + + +environment: + matrix: + + - PlatformToolset: v143 + APPVEYOR_BUILD_WORKER_IMAGE: Visual Studio 2022 + BUILD_BOOST_VERSION: 1_85_0 + BUILD_BOOST_VERSION_DOT: 1.85.0 + BUILD_MSVC_VERSION_DOT: 14.3 + +configuration: + - Release + #- Debug + +platform: + - Any CPU + +install: + - if "%platform%"=="Any CPU" set archi=amd64 + - if "%platform%"=="Any CPU" set platform_input=Any CPU + + + - if "%PlatformToolset%"=="v140" call "C:\Program Files (x86)\Microsoft Visual Studio 14.0\VC\vcvarsall.bat" %archi% + - if "%PlatformToolset%"=="v141" call "C:\Program Files (x86)\Microsoft Visual Studio\2017\Community\VC\Auxiliary\Build\vcvarsall.bat" %archi% + - if "%PlatformToolset%"=="v142" call "C:\Program Files (x86)\Microsoft Visual Studio\2019\Community\VC\Auxiliary\Build\vcvarsall.bat" %archi% + - if "%PlatformToolset%"=="v143" call "C:\Program Files\Microsoft Visual Studio\2022\Community\VC\Auxiliary\Build\vcvarsall.bat" %archi% + + - cd "%APPVEYOR_BUILD_FOLDER%"\..\.. + - mkdir boostorg + - cd boostorg + # build from source, but fails due to runtime limitation as each build takes ~ 40min + #- appveyor DownloadFile https://boostorg.jfrog.io/artifactory/main/release/%BUILD_BOOST_VERSION_DOT%/source/boost_%BUILD_BOOST_VERSION%.7z + #- boost.bat + + # Free disk space for boost zip package + - rmdir /q /s C:\Qt + - rmdir /q /s C:\Python26 + - rmdir /q /s C:\Python26-x64 + - rmdir /q /s C:\Python27 + - rmdir /q /s C:\Python27-x64 + - rmdir /q /s C:\Python33 + - rmdir /q /s C:\Python33-x64 + - rmdir /q /s C:\Python34 + - rmdir /q /s C:\Python34-x64 + - rmdir /q /s C:\Python35 + - rmdir /q /s C:\Python35-x64 + - rmdir /q /s C:\Python36 + - rmdir /q /s C:\Python36-x64 + - rmdir /q /s C:\Python37 + - rmdir /q /s C:\Python37-x64 + - rmdir /q /s C:\Python38 + - rmdir /q /s C:\Python38-x64 + - rmdir /q /s C:\Python39 + - rmdir /q /s C:\Python39-x64 + - rmdir /q /s C:\Python310 + - rmdir /q /s C:\Python310-x64 + - rmdir /q /s C:\Python311 + - rmdir /q /s C:\Python311-x64 + - rmdir /q /s C:\Python312 + - rmdir /q /s C:\Python312-x64 + + # complete zip, but fails due to storage limitations on appveyor (artifactory download is much faster than sourceforge) + - appveyor DownloadFile https://boostorg.jfrog.io/artifactory/main/release/%BUILD_BOOST_VERSION_DOT%/binaries/boost_%BUILD_BOOST_VERSION%-bin-msvc-all-32-64.7z + #- appveyor DownloadFile https://sourceforge.net/projects/boost/files/boost-binaries/%BUILD_BOOST_VERSION_DOT%/boost_%BUILD_BOOST_VERSION%-bin-msvc-all-32-64.7z + - 7z x -y boost_%BUILD_BOOST_VERSION%-bin-msvc-all-32-64.7z > nul + - del /q boost_%BUILD_BOOST_VERSION%-bin-msvc-all-32-64.7z + - rename boost_%BUILD_BOOST_VERSION% boost + + + #- appveyor DownloadFile https://boostorg.jfrog.io/artifactory/main/release/%BUILD_BOOST_VERSION_DOT%/binaries/boost_%BUILD_BOOST_VERSION%-msvc-%BUILD_MSVC_VERSION_DOT%-32.exe + #- appveyor DownloadFile https://boostorg.jfrog.io/artifactory/main/release/%BUILD_BOOST_VERSION_DOT%/binaries/boost_%BUILD_BOOST_VERSION%-msvc-%BUILD_MSVC_VERSION_DOT%-64.exe + #- boost_%BUILD_BOOST_VERSION%-msvc-%BUILD_MSVC_VERSION_DOT%-64.exe /SILENT /DIR=C:\boostorg\boost + #- boost_%BUILD_BOOST_VERSION%-msvc-%BUILD_MSVC_VERSION_DOT%-32.exe /SILENT /DIR=C:\boostorg\boost + + - nuget restore "%APPVEYOR_BUILD_FOLDER%"\builder\builder\packages.config -PackagesDirectory "%APPVEYOR_BUILD_FOLDER%"\builder\packages + - nuget restore "%APPVEYOR_BUILD_FOLDER%"\builder\builderTest\packages.config -PackagesDirectory "%APPVEYOR_BUILD_FOLDER%"\builder\packages + + +build_script: + - cd "%APPVEYOR_BUILD_FOLDER%"\builder + - msbuild builder.sln /m /verbosity:minimal /t:restore /p:configuration="%configuration%" /p:platform="%platform_input%" /logger:"C:\Program Files\AppVeyor\BuildAgent\Appveyor.MSBuildLogger.dll" + - msbuild builder.sln /m /verbosity:minimal /p:configuration="%configuration%" /p:platform="%platform_input%" /logger:"C:\Program Files\AppVeyor\BuildAgent\Appveyor.MSBuildLogger.dll" + - cd "%APPVEYOR_BUILD_FOLDER%" + +after_build: + - cd "%APPVEYOR_BUILD_FOLDER%"\builder\builder\bin\Release\ + - call builder.exe + +artifacts: + #- path: installer\build\**\*.* + # name: releases + +deploy: + provider: GitHub + auth_token: + secure: #!TODO! + artifact: releases + draft: false + prerelease: false + force_update: true + on: + appveyor_repo_tag: true + PlatformToolset: v143 + configuration: Release diff --git a/builder/builder/ApiKey.cs b/builder/builder/ApiKey.cs new file mode 100644 index 0000000..8d23279 --- /dev/null +++ b/builder/builder/ApiKey.cs @@ -0,0 +1 @@ +//nuget api key needs to be placed here \ No newline at end of file diff --git a/builder/builder/App.config b/builder/builder/App.config index 4bfa005..5ab1a35 100644 --- a/builder/builder/App.config +++ b/builder/builder/App.config @@ -1,6 +1,6 @@ - + diff --git a/builder/builder/Nuspec.cs b/builder/builder/Nuspec.cs index 58baf4d..3a31bf3 100644 --- a/builder/builder/Nuspec.cs +++ b/builder/builder/Nuspec.cs @@ -63,20 +63,21 @@ private static void CreateNuspec( N("version", version.ToString()), N("authors", Config.Authors), N("owners", Config.Owners), - N("licenseUrl", "https://github.com/sergey-shandar/getboost/blob/master/LICENSE"), + N("license", Xml.A("type", "expression")).Append("BSL-1.0"), N("projectUrl", "https://github.com/sergey-shandar/getboost"), N("requireLicenseAcceptance", "false"), N("description", description), N("dependencies").Append( + N("group", Xml.A("targetFramework", "native")).Append( dependencyList.Select( - d => + d => N( "dependency", Xml.A("id", d.Id), Xml.A("version", d.Version) ) ) - ), + )), N("tags", string.Join(" ", tags)) ), N("files").Append(fileList.Select(f => f.N)) @@ -93,7 +94,7 @@ private static void CreateNuspec( var nupkgFile = id + "." + version + ".nupkg"; Console.WriteLine("uploading: " + nupkgFile); { - var p = Process.Start( +/* var p = Process.Start( new ProcessStartInfo( @"..\..\..\packages\NuGet.CommandLine.6.9.1\tools\nuget.exe", $"push {nupkgFile} -Source https://api.nuget.org/v3/index.json -ApiKey {ApiKey.Value}") @@ -104,14 +105,14 @@ private static void CreateNuspec( if (p.ExitCode != 0) { Environment.Exit(p.ExitCode); } - } + */ } } public static void Create( string nuspecId, string packageId, Version version, - string description, + string description, IEnumerable itemDefinitionGroupList, IEnumerable fileList, IEnumerable compilationUnitList, diff --git a/builder/builder/builder.csproj b/builder/builder/builder.csproj index c7b87ab..85f16ed 100644 --- a/builder/builder/builder.csproj +++ b/builder/builder/builder.csproj @@ -9,7 +9,7 @@ Properties builder builder - v4.8 + v4.8.1 512 diff --git a/builder/builderTest/builderTest.csproj b/builder/builderTest/builderTest.csproj index 7ef023d..dedcdc6 100644 --- a/builder/builderTest/builderTest.csproj +++ b/builder/builderTest/builderTest.csproj @@ -8,7 +8,7 @@ Properties builderTest builderTest - v4.8 + v4.8.1 512 {3AC096D0-A1C2-E12C-1390-A8335801FDAB};{FAE04EC0-301F-11D3-BF4B-00C04F79EFBC} 10.0 @@ -40,7 +40,16 @@ False ..\packages\Framework.G1.1.0.13.0\lib\portable-net45+sl50+win+wp80+MonoAndroid10+MonoTouch10\Framework.G1.dll + + + + + + + + + diff --git a/builder/builderTest/packages.config b/builder/builderTest/packages.config index 8095735..7aaeed9 100644 --- a/builder/builderTest/packages.config +++ b/builder/builderTest/packages.config @@ -1,4 +1,5 @@  + \ No newline at end of file