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
-
+
-
+
+
-