diff --git a/CODEOWNERS b/CODEOWNERS index 05689a05d6..80e046649b 100644 --- a/CODEOWNERS +++ b/CODEOWNERS @@ -9,12 +9,9 @@ # Adding codeowner for Python specific files such that GitHub automatically adds python folks as a reviewer. build/python.props @vrdmr @gavin-aguiar @YunchuWang @pdthummar @hallvictoria +eng/build/Workers.Python.props @vrdmr @gavin-aguiar @YunchuWang @pdthummar @hallvictoria # Deps.json validation file test/WebJobs.Script.Tests/Microsoft.Azure.WebJobs.Script.WebHost.deps.json @fabiocav @brettsam @mathewc -src/WebJobs.Script.WebHost/PreJIT/* @vrdmr @pragnagopa @eliaslopezgt @VpOfEngineering @azure/azure-functions-core - -# CI owners - -eng/ci/* @fabiocav @jviau @brettsam +src/WebJobs.Script.WebHost/PreJIT/* @vrdmr @pragnagopa @eliaslopezgt @azure/azure-functions-core diff --git a/Directory.Build.props b/Directory.Build.props index 20c7ec1f73..b37c6fdba6 100644 --- a/Directory.Build.props +++ b/Directory.Build.props @@ -11,6 +11,7 @@ $(MSBuildThisFileDirectory) $(RepoRoot)eng/ + $(EngRoot)build/ diff --git a/Directory.Build.targets b/Directory.Build.targets index 9c9f2a6f8f..adc05e884c 100644 --- a/Directory.Build.targets +++ b/Directory.Build.targets @@ -1,5 +1,5 @@ - + diff --git a/build/build-extensions.ps1 b/build/build-extensions.ps1 index ba83ca973c..479c6b3e0e 100644 --- a/build/build-extensions.ps1 +++ b/build/build-extensions.ps1 @@ -1,219 +1 @@ -param ( - [string]$buildNumber = "0", - [string]$suffix = "", - [ValidateSet("6", "8", "")][string]$minorVersionPrefix = "", - [string]$hashesForHardlinksFile = "hashesForHardlinks.txt" -) - -Import-Module "$PSScriptRoot\Get-AzureFunctionsVersion.psm1" -Force -$rootDir = Split-Path -Parent $PSScriptRoot -$outDir = "$rootDir\out" -$publishDir = "$outDir\pub\WebJobs.Script.WebHost" - -$extensionVersion = Get-AzureFunctionsVersion $buildNumber $suffix $minorVersionPrefix -Write-Host "Site extension version: $extensionVersion" - -function ZipContent([string] $sourceDirectory, [string] $target) { - $stopwatch = [System.Diagnostics.Stopwatch]::StartNew() - - Write-Host "======================================" - Write-Host "Zipping $sourceDirectory into $target" - - if (Test-Path $target) { - Remove-Item $target - } - - Add-Type -assembly "system.io.compression.filesystem" - [IO.Compression.ZipFile]::CreateFromDirectory($sourceDirectory, $target) - - Write-Host "Done zipping $target. Elapsed: $($stopwatch.Elapsed)" - Write-Host "======================================" - Write-Host "" -} - -function BuildRuntime([string] $targetRid, [bool] $isSelfContained) { - $stopwatch = [System.Diagnostics.Stopwatch]::StartNew() - - $publishTarget = "$publishDir\release_$targetRid" - $projectPath = "$rootDir\src\WebJobs.Script.WebHost\WebJobs.Script.WebHost.csproj" - if (-not (Test-Path $projectPath)) - { - throw "Project path '$projectPath' does not exist." - } - - $cmd = "publish", $projectPath , "-r", "$targetRid", "--self-contained", "$isSelfContained", "-v", "m", "-c", "Release", "-p:IsPackable=false", "-p:BuildNumber=$buildNumber", "-p:MinorVersionPrefix=$minorVersionPrefix" - - Write-Host "======================================" - Write-Host "Building $targetRid" - Write-Host " Self-Contained: $isSelfContained" - Write-Host " Publish Directory: $publishTarget" - Write-Host "" - Write-Host "dotnet $cmd" - Write-Host "" - - & dotnet $cmd - - if ($LASTEXITCODE -ne 0) - { - exit $LASTEXITCODE - } - - Write-Host "" - $symbols = Get-ChildItem -Path $publishTarget -Filter *.pdb - $symbols += Get-ChildItem -Path "$publishTarget\workers\dotnet-isolated\*" -Include "*.pdb", "*.dbg" -Recurse - Write-Host "Zipping symbols: $($symbols.Count) symbols found" - - $symbolsPath = "$publishDir\Symbols" - if (!(Test-Path -PathType Container $symbolsPath)) { - New-Item -ItemType Directory -Path $symbolsPath | Out-Null - } - - $symbols | Compress-Archive -DestinationPath "$symbolsPath\Functions.Symbols.$extensionVersion.$targetRid.zip" | Out-Null - $symbols | Remove-Item | Out-Null - - Write-Host "" - CleanOutput $publishTarget - Write-Host "" - Write-Host "Done building $targetRid. Elapsed: $($stopwatch.Elapsed)" - Write-Host "======================================" - Write-Host "" -} - -function GetFolderSizeInMb([string] $rootPath) { - return [math]::Round((Get-ChildItem $rootPath -Recurse | Measure-Object -Property Length -Sum -ErrorAction Stop).Sum / 1Mb, 2) -} - -function CleanOutput([string] $rootPath) { - Write-Host "Cleaning build output under $rootPath" - Write-Host " Current size: $(GetFolderSizeInMb $rootPath) Mb" - - Write-Host " Removing any linux and osx runtimes" - Remove-Item -Recurse -Force "$privateSiteExtensionPath\$bitness\runtimes\linux" -ErrorAction SilentlyContinue - Remove-Item -Recurse -Force "$privateSiteExtensionPath\$bitness\runtimes\osx" -ErrorAction SilentlyContinue - - Write-Host " Removing python worker" - Remove-Item -Recurse -Force "$rootPath\workers\python" -ErrorAction SilentlyContinue - - $keepRuntimes = @('win', 'win-x86', 'win10-x86', 'win-x64', 'win10-x64') - Write-Host " Removing all powershell runtimes except $keepRuntimes" - Get-ChildItem "$rootPath\workers\powershell" -Directory -ErrorAction SilentlyContinue | - ForEach-Object { Get-ChildItem "$($_.FullName)\runtimes" -Directory -Exclude $keepRuntimes } | - Remove-Item -Recurse -Force -ErrorAction SilentlyContinue - - Write-Host " Removing FunctionsNetHost(linux executable) and dependencies from dotnet-isolated worker" - $dotnetIsolatedBinPath = Join-Path $rootPath "workers\dotnet-isolated\bin" - if (Test-Path $dotnetIsolatedBinPath) { - Remove-Item -Path (Join-Path $dotnetIsolatedBinPath "FunctionsNetHost") -ErrorAction SilentlyContinue - Get-ChildItem -Path $dotnetIsolatedBinPath -Filter "*.so" | Remove-Item -ErrorAction SilentlyContinue - } - - Write-Host " Current size: $(GetFolderSizeInMb $rootPath) Mb" -} - -function CreateSiteExtensions() { - $stopwatch = [System.Diagnostics.Stopwatch]::StartNew() - $siteExtensionPath = "$publishDir\temp_extension" - - if (Test-Path $siteExtensionPath) { - Write-Host " Existing site extension path found. Deleting." - Remove-Item $siteExtensionPath -Recurse -Force | Out-Null - } - - # The official site extension needs to be nested inside a folder with its version. - # Not using the suffix (eg: '-ci') here as it may not work correctly in a private stamp - $officialSiteExtensionPath = "$siteExtensionPath\$extensionVersion" - - Write-Host "======================================" - Write-Host "Copying build to temp directory to prepare for zipping official site extension." - Copy-Item -Path $publishDir\release_win-x86\ -Destination $officialSiteExtensionPath\32bit -Force -Recurse > $null - Copy-Item -Path $publishDir\release_win-x64 -Destination $officialSiteExtensionPath\64bit -Force -Recurse > $null - Copy-Item -Path $officialSiteExtensionPath\32bit\applicationHost.xdt -Destination $officialSiteExtensionPath -Force > $null - Write-Host " Deleting workers directory: $officialSiteExtensionPath\32bit\workers" - Remove-Item -Recurse -Force "$officialSiteExtensionPath\32bit\workers" -ErrorAction SilentlyContinue - Write-Host " Moving workers directory: $officialSiteExtensionPath\64bit\workers to $officialSiteExtensionPath\workers" - Move-Item -Path "$officialSiteExtensionPath\64bit\workers" -Destination "$officialSiteExtensionPath\workers" - - # This goes in the root dir - Copy-Item $rootDir\src\WebJobs.Script.WebHost\extension.xml $siteExtensionPath > $null - - Write-Host "Done copying. Elapsed: $($stopwatch.Elapsed)" - Write-Host "======================================" - Write-Host "" - - Write-Host "======================================" - Write-Host "Generating hashes for hard links" - WriteHashesFile $siteExtensionPath/$extensionVersion - Write-Host "Done generating hashes for hard links into $siteExtensionPath/$extensionVersion" - Write-Host "======================================" - Write-Host - - $zipOutput = "$publishDir\SiteExtension" - $hashesForHardLinksPath = "$siteExtensionPath\$extensionVersion\$hashesForHardlinksFile" - New-Item -Itemtype directory -path $zipOutput -Force > $null - if ($minorVersionPrefix -eq "") { - ZipContent $siteExtensionPath "$zipOutput\Functions.$extensionVersion.zip" - } elseif ($minorVersionPrefix -eq "8") { - Write-Host "======================================" - # Only the "Functions" site extension supports hard links - Write-Host "MinorVersionPrefix is '8'. Removing $hashesForHardLinksPath before zipping." - Remove-Item -Force "$hashesForHardLinksPath" -ErrorAction Stop - # The .NET 8 host doesn't require any workers. Doing this to save space. - Write-Host "Removing workers before zipping." - # The host requires that this folder exists and it cannot be empty - Remove-Item -Recurse -Force "$siteExtensionPath\$extensionVersion\workers" -ErrorAction Stop - New-Item -Path "$siteExtensionPath\$extensionVersion" -Name "workers" -ItemType Directory -ErrorAction Stop | Out-Null - Set-Content -Force -Path "$siteExtensionPath\$extensionVersion\workers\this_folder_intentionally_empty.txt" -Value ".NET 8 builds do not have workers. However, this folder must contain at least one file." -ErrorAction Stop - Write-Host "======================================" - Write-Host - ZipContent $siteExtensionPath "$zipOutput\FunctionsInProc8.$extensionVersion.zip" - } elseif ($minorVersionPrefix -eq "6") { - # Only the "Functions" site extension supports hard links - Write-Host "======================================" - Write-Host "MinorVersionPrefix is '6'. Removing $hashesForHardLinksPath before zipping." - Remove-Item -Force "$hashesForHardLinksPath" -ErrorAction Stop - Write-Host "======================================" - Write-Host - ZipContent $siteExtensionPath "$zipOutput\FunctionsInProc.$extensionVersion.zip" - } - - Remove-Item $siteExtensionPath -Recurse -Force > $null - - Write-Host "======================================" - $stopwatch.Reset() - Write-Host "Copying build to temp directory to prepare for zipping private site extension." - Copy-Item -Path $publishDir\release_win-x86\ -Destination $siteExtensionPath\SiteExtensions\Functions\32bit -Force -Recurse > $null - Copy-Item -Path $siteExtensionPath\SiteExtensions\Functions\32bit\applicationHost.xdt -Destination $siteExtensionPath\SiteExtensions\Functions -Force > $null - Write-Host "Done copying. Elapsed: $($stopwatch.Elapsed)" - Write-Host "======================================" - Write-Host "" - - $zipOutput = "$publishDir\PrivateSiteExtension" - New-Item -Itemtype directory -path $zipOutput -Force > $null - ZipContent $siteExtensionPath "$zipOutput\Functions.Private.$extensionVersion.win-x32.inproc.zip" - - Remove-Item $siteExtensionPath -Recurse -Force > $null -} - -function WriteHashesFile([string] $directoryPath) { - New-Item -Path "$directoryPath/../temp_hashes" -ItemType Directory | Out-Null - $temp_current = (Get-Location) - Set-Location $directoryPath - Get-ChildItem -Recurse $directoryPath | Where-Object { $_.PsIsContainer -eq $false } | Foreach-Object { "Hash:" + [System.Convert]::ToBase64String([System.Text.Encoding]::UTF8.GetBytes((Get-FileHash -Algorithm MD5 $_.FullName).Hash)) + " FileName:" + (Resolve-Path -Relative -Path $_.FullName) } | Out-File -FilePath "$directoryPath\..\temp_hashes\$hashesForHardlinksFile" - Move-Item -Path "$directoryPath/../temp_hashes/$hashesForHardlinksFile" -Destination "$directoryPath" -Force - Set-Location $temp_current - Remove-Item "$directoryPath/../temp_hashes" -Recurse -Force > $null -} - -Write-Host "Output directory: $publishDir" -if (Test-Path $publishDir) { - Write-Host " Existing build output found. Deleting." - Remove-Item $publishDir -Recurse -Force -ErrorAction Stop -} - -Write-Host "Extensions version: $extensionVersion" -Write-Host "" - -BuildRuntime "win-x86" -BuildRuntime "win-x64" - -CreateSiteExtensions +Write-Error "This script is no longer used. Instead, publish src/WebJobs.Script.SiteExtension/WebJobs.Script.SiteExtension.proj directly." diff --git a/build/common.props b/build/common.props index 8bd0de1d66..9e6d02bf3a 100644 --- a/build/common.props +++ b/build/common.props @@ -8,12 +8,12 @@ 0 0 - + <_VersionSuffix Condition="'$(PreviewVersion)' != ''">-preview.$(PreviewVersion).$(BuildNumber) <_VersionSuffix Condition="'$(PreviewVersion)' == '' and '$(VersionSuffix)' != ''">-$(VersionSuffix) - + $(MajorVersion).$(MinorVersion).$(PatchVersion) $(VersionPrefix)$(_VersionSuffix) $(MajorVersion).$(MinorVersion).0.0 diff --git a/build/python.props b/build/python.props index a9038ec9e1..ebfd61c498 100644 --- a/build/python.props +++ b/build/python.props @@ -1,5 +1,6 @@ - - - + + + + diff --git a/build/update-hostreferences.ps1 b/build/update-hostreferences.ps1 deleted file mode 100644 index 07fedd72a0..0000000000 --- a/build/update-hostreferences.ps1 +++ /dev/null @@ -1,171 +0,0 @@ -function WriteLog -{ - param ( - [Parameter(Mandatory=$true)] - [ValidateNotNullOrEmpty()] - [System.String] - $Message, - - [Switch] - $Throw - ) - - $Message = (Get-Date -Format G) + " -- $Message" - - if ($Throw) - { - throw $Message - } - - Write-Host $Message -} - -Class PackageInfo { - [string]$Name - [string]$Version -} - -function NewPackageInfo -{ - param ( - [Parameter(Mandatory=$true)] - [ValidateNotNullOrEmpty()] - [System.String] - $PackageInformation - ) - - $parts = $PackageInformation.Split(" ") - - if ($parts.Count -gt 2) - { - WriteLog "Invalid package format. The string should only contain 'nameversion'. Current value: '$PackageInformation'" - } - - $packageInfo = [PackageInfo]::New() - $packageInfo.Name = $parts[0] - $packageInfo.Version = $parts[1] - - return $packageInfo -} - -function GetPackageInfo -{ - param ( - [Parameter(Mandatory=$true)] - [ValidateNotNullOrEmpty()] - [System.String] - $Name, - - [Parameter(Mandatory=$false)] - [System.String] - $MajorVersion - ) - - $result = $null - $includeAllVersion = if (-not [string]::IsNullOrWhiteSpace($MajorVersion)) { "-AllVersions" } else { "" } - - $packageInfo = & { NuGet list $Name -Source $SOURCE -PreRelease $includeAllVersion } - - if ($packageInfo -like "*No packages found*") - { - WriteLog "Package name $Name not found in $SOURCE." -Throw - } - - if (-not $MajorVersion) - { - $result = NewPackageInfo -PackageInformation $packageInfo - } - else - { - foreach ($thisPackage in $packageInfo.Split([System.Environment]::NewLine)) - { - $package = NewPackageInfo -PackageInformation $thisPackage - - if ($package.Version.StartsWith($MajorVersion)) - { - $result = $package - break - } - } - } - - return $result -} - -WriteLog "Script started." - -# Make sure the project path exits -$path = "$PSScriptRoot\..\src\WebJobs.Script" -if (-not (Test-Path $path)) -{ - WriteLog "Failed to find '$path' to update package references" -Throw -} - -$URL = "https://raw.githubusercontent.com/Azure/azure-functions-integration-tests/main/integrationTestsBuild/V4/HostBuild.json" -$SOURCE = "https://azfunc.pkgs.visualstudio.com/e6a70c92-4128-439f-8012-382fe78d6396/_packaging/AzureFunctionsPreRelease/nuget/v3/index.json" - -WriteLog "Get the list of packages to update" - -$packagesToUpdate = Invoke-RestMethod -Uri $URL -ErrorAction Stop -if ($packagesToUpdate.Count -eq 0) -{ - WriteLog "There are no packages to update in '$URL'" -Throw -} - -# Update packages references -WriteLog "Package references to update: $($packagesToUpdate.Count)" - -$currentDirectory = Get-Location -try -{ - set-location $path - - foreach ($package in $packagesToUpdate) - { - $packageInfo = GetPackageInfo -Name $package.Name -MajorVersion $package.MajorVersion - - if ($package.Name -eq "Microsoft.Azure.Functions.PythonWorker") - { - # The PythonWorker is not defined in the src/WebJobs.Script/WebJobs.Script.csproj. It is defined in build/python.props. - # To update the package version, the xml file build/python.props needs to be updated directly. - $pythonPropsFilePath = "$PSScriptRoot\python.props" - - if (-not (Test-Path $pythonPropsFilePath)) - { - WriteLog "Python Props file '$pythonPropsFilePath' does not exist." -Throw - } - - WriteLog "Set Python package version in '$pythonPropsFilePath' to '$($packageInfo.Version)'" - - # Read the xml file - [xml]$xml = Get-Content $pythonPropsFilePath -Raw -ErrorAction Stop - - # Replace the package version - $xml.Project.ItemGroup.PackageReference.Version = $packageInfo.Version - - # Save the file - $xml.Save($pythonPropsFilePath) - - if ($LASTEXITCODE -ne 0) - { - WriteLog "Failed to update Python Props file" -Throw - } - } - else - { - WriteLog "Adding '$($packageInfo.Name)' '$($packageInfo.Version)' to project" - & { dotnet add package $packageInfo.Name -v $packageInfo.Version -s $SOURCE --no-restore } - - if ($LASTEXITCODE -ne 0) - { - WriteLog "dotnet add package '$($packageInfo.Name)' -v '$($packageInfo.Version)' -s $SOURCE --no-restore failed" -Throw - } - } - } -} -finally -{ - Set-Location $currentDirectory -} - -WriteLog "Script completed." \ No newline at end of file diff --git a/eng/build/Engineering.targets b/eng/build/Engineering.targets index 2e4906c2e9..5f8423e5f3 100644 --- a/eng/build/Engineering.targets +++ b/eng/build/Engineering.targets @@ -1,5 +1,6 @@ + diff --git a/eng/build/Workers.Dotnet.props b/eng/build/Workers.Dotnet.props new file mode 100644 index 0000000000..2637018a77 --- /dev/null +++ b/eng/build/Workers.Dotnet.props @@ -0,0 +1,15 @@ + + + + + + + + + + <_DotnetWorkerFiles Include="@(None)" Condition="'%(None.DestinationSubDirectory)' == 'workers\dotnet-isolated\bin\'" /> + + + + + diff --git a/eng/build/Workers.Java.props b/eng/build/Workers.Java.props new file mode 100644 index 0000000000..1a2aeb9f19 --- /dev/null +++ b/eng/build/Workers.Java.props @@ -0,0 +1,7 @@ + + + + + + + diff --git a/eng/build/Workers.Node.props b/eng/build/Workers.Node.props new file mode 100644 index 0000000000..961f06b52e --- /dev/null +++ b/eng/build/Workers.Node.props @@ -0,0 +1,7 @@ + + + + + + + diff --git a/eng/build/Workers.Powershell.props b/eng/build/Workers.Powershell.props new file mode 100644 index 0000000000..cb60560979 --- /dev/null +++ b/eng/build/Workers.Powershell.props @@ -0,0 +1,29 @@ + + + + + + + + + + + <_KeepPowerShellRuntime Include="win;win-x86;win10-x86;win-x64;win10-x64" /> + + + + + <_PowershellRuntimesToKeepRegex>@(_KeepPowerShellRuntime->'%(Identity)(/|\\)', '|') + <_PowershellRuntimesToRemoveRegex>^workers(/|\\)powershell(/|\\).*(/|\\)runtimes(/|\\)(?!$(_PowershellRuntimesToKeepRegex)) + + + + <_PowershellRuntimeToRemove Include="@(None)" Condition="'%(None.TargetPath)' != '' AND $([System.Text.RegularExpressions.Regex]::IsMatch('%(None.TargetPath)', $(_PowershellRuntimesToRemoveRegex)))" /> + + + + diff --git a/eng/build/Workers.Python.props b/eng/build/Workers.Python.props new file mode 100644 index 0000000000..15ed2797fd --- /dev/null +++ b/eng/build/Workers.Python.props @@ -0,0 +1,15 @@ + + + + + + + + + + + + + + + diff --git a/eng/build/Workers.props b/eng/build/Workers.props new file mode 100644 index 0000000000..047a7a0860 --- /dev/null +++ b/eng/build/Workers.props @@ -0,0 +1,21 @@ + + + + + + + + + <_WorkerPublishFiles Include="@(ResolvedFileToPublish)" Condition="$([System.String]::new('%(ResolvedFileToPublish.TargetPath)').StartsWith('workers'))" /> + + + + + + + + + + + + diff --git a/eng/build/ZipPublish.targets b/eng/build/ZipPublish.targets new file mode 100644 index 0000000000..6dc234eb47 --- /dev/null +++ b/eng/build/ZipPublish.targets @@ -0,0 +1,55 @@ + + + + + + + + + + + + + + $(PackageOutputPath) + $([MSBuild]::EnsureTrailingSlash('$(ZipArtifactsPath)')) + <_RuntimeIdentifierWithPeriod Condition="'$(RuntimeIdentifier)' != ''">.$(RuntimeIdentifier.ToLowerInvariant()) + + + + + + + + + + + + + $([MSBuild]::EnsureTrailingSlash('$(ZipArtifactsPath)'))%(TargetName) + + + + + + <_ZipArtifactTargetPath Include="@(ZipArtifact->'%(TargetPath)')" /> + <_ZipArtifactTargetDirectories Include="@(_ZipArtifactTargetPath->'%(RootDir)%(Directory)'->Distinct())" /> + + + + + + + + + + diff --git a/eng/ci/templates/official/jobs/build-artifacts-linux.yml b/eng/ci/templates/official/jobs/build-artifacts-linux.yml index 3b1be3af19..440ec3a814 100644 --- a/eng/ci/templates/official/jobs/build-artifacts-linux.yml +++ b/eng/ci/templates/official/jobs/build-artifacts-linux.yml @@ -6,18 +6,19 @@ jobs: project: src/WebJobs.Script.WebHost/WebJobs.Script.WebHost.csproj configuration: release runtime: linux-x64 - log_dir: $(Build.ArtifactStagingDirectory)/log - build_args: '-v m -c $(configuration) -r $(runtime) --self-contained true -p:BuildNumber=$(buildNumber) -p:IsPackable=false' - publish_zip_dir: $(Build.ArtifactStagingDirectory)/Linux + artifacts_path: $(Build.ArtifactStagingDirectory) + log_dir: $(artifacts_path)/log + zip_artifacts_path: $(artifacts_path)/Linux + build_args: '-v m -c $(configuration) -r $(runtime) --self-contained true -p:BuildNumber=$(buildNumber)' templateContext: - outputParentDirectory: $(Build.ArtifactStagingDirectory) + outputParentDirectory: $(artifacts_path) outputs: # TODO: onboard to Azure Artifacts Drops to allow accessing this from docker linux pipeline in msazure # https://eng.ms/docs/cloud-ai-platform/devdiv/one-engineering-system-1es/1es-docs/azure-artifacts/artifact-services-onboarding - output: pipelineArtifact displayName: Publish linux artifacts - path: $(publish_zip_dir) + path: $(zip_artifacts_path) artifact: Linux - output: pipelineArtifact displayName: Publish logs @@ -58,4 +59,4 @@ jobs: publishWebProjects: false # we use our own publish logic zipAfterPublish: false # we use our own zip logic projects: $(project) - arguments: '$(build_args) --no-build -p:PublishZipDir=$(publish_zip_dir) -bl:$(log_dir)/publish.binlog' + arguments: '$(build_args) --no-build -p:ZipArtifactsPath=$(zip_artifacts_path) -bl:$(log_dir)/publish.binlog' diff --git a/eng/ci/templates/official/jobs/build-artifacts-windows.yml b/eng/ci/templates/official/jobs/build-artifacts-windows.yml index 63031dc138..439619025d 100644 --- a/eng/ci/templates/official/jobs/build-artifacts-windows.yml +++ b/eng/ci/templates/official/jobs/build-artifacts-windows.yml @@ -2,6 +2,20 @@ jobs: - job: BuildArtifactsWindows displayName: Build Windows Artifacts + pool: + name: 1es-pool-azfunc + image: 1es-windows-2022 + os: windows + + variables: + ${{ if or( eq( variables['Build.Reason'], 'PullRequest' ), and(not( contains( variables['Build.SourceBranch'], 'release/in-proc' ) ), not( contains( variables['Build.SourceBranch'], 'release/4.' ) ), not( contains( variables['Build.SourceBranch'], 'release/ExtensionsMetadataGenerator/' ) ) ) ) }}: + packSuffixSwitchTemp: --version-suffix $(buildNumber) + emgSuffixSwitchTemp: --version-suffix ci$(buildNumber) + packSuffixSwitch: $[variables.packSuffixSwitchTemp] + emgSuffixSwitch: $[variables.emgSuffixSwitchTemp] + nuget_package_path: $(Build.ArtifactStagingDirectory)/NugetPackages + log_dir: $(Build.ArtifactStagingDirectory)/log + templateContext: outputParentDirectory: $(Build.ArtifactStagingDirectory) outputs: @@ -15,48 +29,29 @@ jobs: artifact: PrivateSiteExtension - output: pipelineArtifact displayName: Publish site extension symbols - path: $(Build.ArtifactStagingDirectory)/Symbols + path: $(Build.ArtifactStagingDirectory)/SiteExtensionSymbols artifact: Symbols - output: pipelineArtifact displayName: Publish nuget packages path: $(Build.ArtifactStagingDirectory)/NugetPackages artifact: NugetPackages - - pool: - name: 1es-pool-azfunc - image: 1es-windows-2022 - os: windows - - variables: - ${{ if or( eq( variables['Build.Reason'], 'PullRequest' ), and(not( contains( variables['Build.SourceBranch'], 'release/in-proc.' ) ), not( contains( variables['Build.SourceBranch'], 'release/4.' ) ), not( contains( variables['Build.SourceBranch'], 'release/ExtensionsMetadataGenerator/' ) ) ) ) }}: - suffixTemp: $(buildNumber) - packSuffixSwitchTemp: --version-suffix $(buildNumber) - emgSuffixSwitchTemp: --version-suffix ci$(buildNumber) - suffix: $[variables.suffixTemp] # this resolves to an empty string if it is missing - packSuffixSwitch: $[variables.packSuffixSwitchTemp] - emgSuffixSwitch: $[variables.emgSuffixSwitchTemp] + - output: pipelineArtifact + displayName: Publish logs + path: $(log_dir) + artifact: Windows_Log + sbomEnabled: false + condition: always() steps: - template: /eng/ci/templates/install-dotnet.yml@self - - - task: PowerShell@2 - displayName: Build artifacts - inputs: - filePath: build/build-extensions.ps1 - arguments: '-buildNumber "$(buildNumber)" -suffix "$(suffix)"' - - - task: CopyFiles@2 - inputs: - SourceFolder: out/pub/WebJobs.Script.WebHost - Contents: '**/*.zip' - TargetFolder: $(Build.ArtifactStagingDirectory) + - template: /eng/ci/templates/steps/build-site-ext.yml@self - task: DotNetCoreCLI@2 displayName: Build host packages inputs: command: custom custom: pack - arguments: -p:BuildNumber=$(buildNumber) -c release $(packSuffixSwitch) + arguments: -p:BuildNumber=$(buildNumber) -c release $(packSuffixSwitch) -o $(nuget_package_path) projects: | **/WebJobs.Script.csproj **/WebJobs.Script.WebHost.csproj @@ -78,17 +73,12 @@ jobs: pattern: Microsoft.Azure.WebJobs.Script.Abstractions*.dll signType: dll - - task: DeleteFiles@1 - displayName: Delete CodeSignSummary files - inputs: - contents: '**/CodeSignSummary-*.md' - - task: DotNetCoreCLI@2 displayName: Pack Abstractions inputs: command: custom custom: pack - arguments: '--no-build -c release' + arguments: '--no-build -c release -o $(nuget_package_path)' projects: | **/WebJobs.Script.Abstractions.csproj @@ -99,24 +89,19 @@ jobs: pattern: Microsoft.Azure.WebJobs.Script.ExtensionsMetadataGenerator*.dll signType: dll-strong-name - - task: DeleteFiles@1 - displayName: Delete CodeSignSummary files - inputs: - contents: '**/CodeSignSummary-*.md' - - task: DotNetCoreCLI@2 displayName: Pack ExtensionsMetadataGenerator inputs: command: custom custom: pack - arguments: '--no-build -c release $(emgSuffixSwitch)' + arguments: '--no-build -c release $(emgSuffixSwitch) -o $(nuget_package_path)' projects: | **/ExtensionsMetadataGenerator.csproj - template: ci/sign-files.yml@eng parameters: displayName: Sign NugetPackages - folderPath: out/pkg/release + folderPath: $(nuget_package_path) pattern: '*.nupkg' signType: nuget @@ -125,8 +110,7 @@ jobs: inputs: contents: '**/CodeSignSummary-*.md' - - task: CopyFiles@2 + - task: DeleteFiles@1 + displayName: Delete CodeSignSummary files inputs: - SourceFolder: out/pkg/release - Contents: '**/*.nupkg' - TargetFolder: $(Build.ArtifactStagingDirectory)/NugetPackages + contents: '$(nuget_package_path)/**/CodeSignSummary-*.md' diff --git a/eng/ci/templates/steps/build-site-ext.yml b/eng/ci/templates/steps/build-site-ext.yml new file mode 100644 index 0000000000..fbdeb5df15 --- /dev/null +++ b/eng/ci/templates/steps/build-site-ext.yml @@ -0,0 +1,32 @@ +parameters: + - name: project + type: string + default: src/WebJobs.Script.SiteExtension/WebJobs.Script.SiteExtension.csproj + +steps: + # Restore must be a separate step so we can pass in 'PublishReadyToRun=true' + - task: DotNetCoreCLI@2 + displayName: Restore site extension + inputs: + command: custom + custom: restore + projects: ${{ parameters.project }} + arguments: '-v m -p:PublishReadyToRun=true -bl:$(log_dir)/site_ext.restore.binlog' + + - task: DotNetCoreCLI@2 + displayName: Build site extension + inputs: + command: custom + custom: build + projects: ${{ parameters.project }} + arguments: '--no-restore -v m -c release -p:BuildNumber=$(buildNumber) -bl:$(log_dir)/site_ext.build.binlog' + + - task: DotNetCoreCLI@2 + displayName: Publish site extension + inputs: + command: custom + custom: publish + publishWebProjects: false # we use our own publish logic + zipAfterPublish: false # we use our own zip logic + projects: ${{ parameters.project }} + arguments: '--no-build -v m -c release -p:BuildNumber=$(buildNumber) -p:ZipArtifactsPath=$(Build.ArtifactStagingDirectory) -bl:$(log_dir)/site_ext.publish.binlog' diff --git a/src/WebJobs.Script.SiteExtension/Publish.MultiTFM.targets b/src/WebJobs.Script.SiteExtension/Publish.MultiTFM.targets new file mode 100644 index 0000000000..e66bc0bc5d --- /dev/null +++ b/src/WebJobs.Script.SiteExtension/Publish.MultiTFM.targets @@ -0,0 +1,23 @@ + + + + + + + + + + + <_TargetFramework Include="$(TargetFrameworks)" /> + + <_TargetFrameworkNormalized Include="@(_TargetFramework->Trim()->Distinct())" /> + <_InnerBuildProjects Include="$(MSBuildProjectFile)"> + TargetFramework=%(_TargetFrameworkNormalized.Identity) + + + + + + diff --git a/src/WebJobs.Script.SiteExtension/Publish.SingleTFM.targets b/src/WebJobs.Script.SiteExtension/Publish.SingleTFM.targets new file mode 100644 index 0000000000..7137585c65 --- /dev/null +++ b/src/WebJobs.Script.SiteExtension/Publish.SingleTFM.targets @@ -0,0 +1,168 @@ + + + + + + + + + ValidatePublishSettings; + PublishProjectReferences; + PublishPrivateProjectReferences; + RemoveUnneededRuntimes; + MoveSymbols; + DeletePrivateSymbols; + WriteHardLinkHashes; + + ZipAfterPublish;ZipArtifactsPath + + + + + + + + + + + SiteExtension/$(Version)/ + $([MSBuild]::NormalizePath('$(PublishDir)$(SiteExtensionRelativeDir)')) + PrivateSiteExtension/SiteExtensions/Functions/ + $([MSBuild]::NormalizePath('$(PublishDir)$(PrivateSiteExtensionRelativeDir)')) + + + + + + + + + + + + + $(SiteExtensionRelativeDir)%(None.TargetPath) + + + + + + + <_ProjectReferenceWithRuntimes Include="@(ProjectReference)"> + + + RuntimeIdentifier=%(PublishRuntimeIdentifier.Identity); + SelfContained=%(PublishRuntimeIdentifier.SelfContained) + + %(PublishRuntimeIdentifier.Identity) + $(SiteExtensionDir)%(PublishRuntimeIdentifier.PublishDir)/ + $(PrivateSiteExtensionDir)%(PublishRuntimeIdentifier.PublishDir)/ + %(PublishRuntimeIdentifier.PrivateExtension) + false + + + + + + + + + + + + <_PublishProjectReferenceExistent Include="@(_MSBuildProjectReferenceExistent)"> + %(AdditionalProperties);PublishDir=%(PublishDir);_IsPublishing=true;PublishWorkers=false + + + + + + + + + + <_PublishPrivateProjectReferenceExistent Include="@(_MSBuildProjectReferenceExistent)" Condition="%(PublishPrivate)"> + %(AdditionalProperties);PublishDir=%(PublishPrivateDir);_IsPublishing=true + + + + + + + + + + + <_RuntimesToRemove Include="@(PublishRuntimeIdentifier->'$(SiteExtensionDir)%(PublishDir)/runtimes/linux')" /> + <_RuntimesToRemove Include="@(PublishRuntimeIdentifier->'$(SiteExtensionDir)%(PublishDir)/runtimes/osx')" /> + <_RuntimesToRemove Include="@(PublishRuntimeIdentifier->'$(PrivateSiteExtensionDir)%(PublishDir)/runtimes/linux')" Condition="%(PrivateExtension)" /> + <_RuntimesToRemove Include="@(PublishRuntimeIdentifier->'$(PrivateSiteExtensionDir)%(PublishDir)/runtimes/osx')" Condition="%(PrivateExtension)" /> + + + + + + + + + + + + + <_SymbolDirs Include="@(PublishRuntimeIdentifier->'$(SiteExtensionDir)%(PublishDir)')"> + $(PublishDir)Symbols/$(SiteExtensionName).Symbols.$(Version).%(Identity) + $(SiteExtensionName).Symbols.$(Version).%(Identity).zip + + <_WorkerSymbols Include="$(SiteExtensionDir)workers/**/*.pdb" Destination="$(PublishDir)Symbols/$(SiteExtensionName).Symbols.$(Version).%(PublishRuntimeIdentifier.Identity)/workers" /> + + + + + + + + + + + <_PrivateSymbolsToRemove Include="$(PrivateSiteExtensionDir)/**/*.pdb" /> + + + + + + + + <_FilesToHash Include="$(SiteExtensionDir)**" /> + + + + + + + + + + <_HashedFiles RelativePath=".$([System.IO.Path]::DirectorySeparatorChar)$([MSBuild]::MakeRelative('$(SiteExtensionDir)', '%(Identity)'))" /> + + + + + diff --git a/src/WebJobs.Script.SiteExtension/Tasks.targets b/src/WebJobs.Script.SiteExtension/Tasks.targets new file mode 100644 index 0000000000..67f3ef84c7 --- /dev/null +++ b/src/WebJobs.Script.SiteExtension/Tasks.targets @@ -0,0 +1,100 @@ + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + diff --git a/src/WebJobs.Script.SiteExtension/WebJobs.Script.SiteExtension.csproj b/src/WebJobs.Script.SiteExtension/WebJobs.Script.SiteExtension.csproj new file mode 100644 index 0000000000..03a21cb341 --- /dev/null +++ b/src/WebJobs.Script.SiteExtension/WebJobs.Script.SiteExtension.csproj @@ -0,0 +1,28 @@ + + + + + + + net8.0 + win + Functions + true + $(MSBuildThisFileDirectory)Publish.SingleTFM.targets + $(MSBuildThisFileDirectory)Publish.MultiTFM.targets + false + + + + + + + + + + + + + + + diff --git a/src/WebJobs.Script.SiteExtension/applicationHost.xdt b/src/WebJobs.Script.SiteExtension/applicationHost.xdt new file mode 100644 index 0000000000..1344402c99 --- /dev/null +++ b/src/WebJobs.Script.SiteExtension/applicationHost.xdt @@ -0,0 +1,13 @@ + + + + + + + + + + + + + diff --git a/src/WebJobs.Script.SiteExtension/extension.xml b/src/WebJobs.Script.SiteExtension/extension.xml new file mode 100644 index 0000000000..46338aa98a --- /dev/null +++ b/src/WebJobs.Script.SiteExtension/extension.xml @@ -0,0 +1,3 @@ + + disabled + diff --git a/src/WebJobs.Script.SiteExtension/readme.md b/src/WebJobs.Script.SiteExtension/readme.md new file mode 100644 index 0000000000..1e01261a06 --- /dev/null +++ b/src/WebJobs.Script.SiteExtension/readme.md @@ -0,0 +1,24 @@ +# Site Extension + +This project is responsible for building the artifacts we ship to antares as a site extension. + +## Usage + +Like any MSBuild project, this can be restored, build, and published separately or together. + +``` shell +# Together +dotnet publish -c {config} + +# Separately +dotnet restore -p:PublishReadyToRun=true # needs to be set to true (fixed in .net9 SDK) +dotnet build -c {config} --no-restore +dotnet publish -c {config} --no-build +``` + +By default the outputs will not be zipped. To the zip the final outputs, add `-p:ZipAfterPublish=true` to the `publish` command. + + +## Outputs + +The output site extension can be found at `{repo_root}/out/pub/WebJobs.Script.SiteExtension/{config}_win`. When using `-p:ZipAfterPublish=true`, the zipped package is found at `{repo_root}/out/pkg/{config}` diff --git a/src/WebJobs.Script.WebHost/WebJobs.Script.WebHost.csproj b/src/WebJobs.Script.WebHost/WebJobs.Script.WebHost.csproj index 9e3f9ff483..b6815d6030 100644 --- a/src/WebJobs.Script.WebHost/WebJobs.Script.WebHost.csproj +++ b/src/WebJobs.Script.WebHost/WebJobs.Script.WebHost.csproj @@ -1,6 +1,6 @@  - + net8.0 Microsoft.Azure.WebJobs.Script.WebHost @@ -11,6 +11,7 @@ false NU5104 6.35.0 + win-x86;win-x64;linux-x64 true @@ -58,10 +59,6 @@ - - - - @@ -133,42 +130,4 @@ - - - - - - - - - - - - - - - - - - - - - - - $(PublishDir).. - $(PublishZipDir)\$(AssemblyName).$(Version).$(ArtifactsPivots).zip - - - - - - diff --git a/src/WebJobs.Script/WebJobs.Script.csproj b/src/WebJobs.Script/WebJobs.Script.csproj index 901e626711..80b332e8f7 100644 --- a/src/WebJobs.Script/WebJobs.Script.csproj +++ b/src/WebJobs.Script/WebJobs.Script.csproj @@ -50,20 +50,10 @@ - - - - - - - - - - diff --git a/test/WebJobs.Script.Tests.Integration/WebJobs.Script.Tests.Integration.csproj b/test/WebJobs.Script.Tests.Integration/WebJobs.Script.Tests.Integration.csproj index 1dc96aa3bd..0de2ac4786 100644 --- a/test/WebJobs.Script.Tests.Integration/WebJobs.Script.Tests.Integration.csproj +++ b/test/WebJobs.Script.Tests.Integration/WebJobs.Script.Tests.Integration.csproj @@ -1,6 +1,5 @@ - net8.0 false @@ -20,6 +19,9 @@ true + + + @@ -37,13 +39,11 @@ - - NU1701 - + - + + -