Skip to content

Commit

Permalink
Combine JAR Packages for Windows, Linux, and MacOS (#669)
Browse files Browse the repository at this point in the history
* unpack all JARs

* fix macos job

* remove -f for macos tree

* move build files from java and linux into macos directory for combined JAR

* test with download and publish pipeline artifacts instead

* use full download task name rather than shortcut

* add job dependencies

* combine JAR packages into one

* update version from version.txt

* change relative path for version.txt

* test

* typo

* Update java_packaging.yml for Azure Pipelines

* Update java_packaging.yml for Azure Pipelines

* test without output variable

* Update java_packaging.yml for Azure Pipelines

* test with type rather than cat command

* Update java_packaging.yml for Azure Pipelines

* Update java_packaging.yml for Azure Pipelines

* Update java_packaging.yml for Azure Pipelines

* Update java_packaging.yml for Azure Pipelines

* Update java_packaging.yml for Azure Pipelines

* set version in each job

* Update java_packaging.yml for Azure Pipelines

* Update java_packaging.yml for Azure Pipelines

* add back dependencies

* final

---------

Co-authored-by: Sayan Shaw <[email protected]>
  • Loading branch information
sayanshaw24 and Sayan Shaw authored Mar 15, 2024
1 parent ebc652d commit 2321329
Showing 1 changed file with 76 additions and 19 deletions.
95 changes: 76 additions & 19 deletions .pipelines/java_packaging.yml
Original file line number Diff line number Diff line change
Expand Up @@ -13,6 +13,15 @@ stages:
pool: {name: 'onnxruntime-Win-CPU-2022'}

steps:
- task: PowerShell@2
displayName: 'Set version'
inputs:
targetType: 'inline'
script: |
$_ExtVersion=(cat version.txt)
echo "##vso[task.setvariable variable=OrtExtVersion;]$_ExtVersion"
workingDirectory: '$(Build.SourcesDirectory)'

- script: |
call .\build.bat -DOCOS_BUILD_JAVA=ON
displayName: build the extensions java package
Expand All @@ -25,7 +34,7 @@ stages:

- script: |
cd $(Build.ArtifactStagingDirectory)
jar xvf onnxruntime-extensions-0.11.0.jar
jar xvf onnxruntime-extensions-$(OrtExtVersion).jar
tree $(Build.ArtifactStagingDirectory) /f
displayName: Unpack JAR to sign DLL
Expand All @@ -35,18 +44,9 @@ stages:
DisplayName: 'Sign DLL'
DoEsrp: 'true'

- script: |
cd $(Build.ArtifactStagingDirectory)
rm onnxruntime-extensions-0.11.0.jar
jar cmf0 META-INF/MANIFEST.MF onnxruntime-extensions-0.11.0.jar *
tree $(Build.ArtifactStagingDirectory) /f
displayName: Repack JAR with signed DLL
- task: PublishPipelineArtifact@1
displayName: 'Publish Windows Artifact'
inputs:
targetPath: '$(Build.ArtifactStagingDirectory)'
artifact: 'drop-signed-windows-onnxruntime-extensions-java-cpu'
- publish: $(Build.ArtifactStagingDirectory)/ai/onnxruntime/extensions/native/
displayName: 'Publish Windows Binaries for Combined JAR'
artifact: WindowsBinaries

- template: templates/component-governance-component-detection-steps.yml
parameters :
Expand All @@ -62,6 +62,15 @@ stages:
pool: {name: 'Azure-Pipelines-EO-Ubuntu-2004-aiinfra'}

steps:
- task: PowerShell@2
displayName: 'Set version'
inputs:
targetType: 'inline'
script: |
$_ExtVersion=(cat version.txt)
echo "##vso[task.setvariable variable=OrtExtVersion;]$_ExtVersion"
workingDirectory: '$(Build.SourcesDirectory)'

- script: |
sh ./build.sh -DOCOS_BUILD_JAVA=ON
displayName: build the extensions java package
Expand All @@ -72,11 +81,16 @@ stages:
SourceFolder: 'out/$(Agent.OS)/RelWithDebInfo/java/build/libs'
TargetFolder: '$(Build.ArtifactStagingDirectory)'

- task: PublishPipelineArtifact@1
displayName: 'Publish Linux Artifact'
inputs:
targetPath: '$(Build.ArtifactStagingDirectory)'
artifact: 'drop-linux-onnxruntime-extensions-java-cpu'
- script: |
cd $(Build.ArtifactStagingDirectory)
echo $(OrtExtVersion)
jar xvf onnxruntime-extensions-$(OrtExtVersion).jar
tree $(Build.ArtifactStagingDirectory) /f
displayName: Unpack JAR
- publish: $(Build.ArtifactStagingDirectory)/ai/onnxruntime/extensions/native/
displayName: 'Publish Linux Binaries for Combined JAR'
artifact: LinuxBinaries

- template: templates/component-governance-component-detection-steps.yml
parameters :
Expand All @@ -87,12 +101,24 @@ stages:
condition: always()

- job: MacOS_CPU_Java_Packaging
dependsOn:
- Windows_CPU_Java_Packaging
- Linux_CPU_Java_Packaging
workspace:
clean: all
pool:
vmImage: 'macOS-13'

steps:
- task: PowerShell@2
displayName: 'Set version'
inputs:
targetType: 'inline'
script: |
$_ExtVersion=(cat version.txt)
echo "##vso[task.setvariable variable=OrtExtVersion;]$_ExtVersion"
workingDirectory: '$(Build.SourcesDirectory)'

- script: |
sh ./build.sh -DOCOS_BUILD_JAVA=ON
displayName: build the extensions java package
Expand All @@ -103,11 +129,42 @@ stages:
SourceFolder: 'out/$(Agent.OS)/RelWithDebInfo/java/build/libs'
TargetFolder: '$(Build.ArtifactStagingDirectory)'

- script: |
cd $(Build.ArtifactStagingDirectory)
echo $(OrtExtVersion)
jar xvf onnxruntime-extensions-$(OrtExtVersion).jar
brew install tree
tree $(Build.ArtifactStagingDirectory)
displayName: Unpack JAR to view contents
- task: DownloadPipelineArtifact@0
displayName: 'Download Windows Pipeline Artifact'
inputs:
artifactName: 'WindowsBinaries'
targetPath: '$(Build.ArtifactStagingDirectory)/ai/onnxruntime/extensions/native/'

- task: DownloadPipelineArtifact@0
displayName: 'Download Linux Pipeline Artifact'
inputs:
artifactName: 'LinuxBinaries'
targetPath: '$(Build.ArtifactStagingDirectory)/ai/onnxruntime/extensions/native/'

- script: |
brew install tree
tree $(Build.ArtifactStagingDirectory)
displayName: Print contents
- script: |
cd $(Build.ArtifactStagingDirectory)
rm onnxruntime-extensions-$(OrtExtVersion).jar
jar cmf0 META-INF/MANIFEST.MF onnxruntime-extensions-$(OrtExtVersion).jar *
displayName: Combine and pack JAR with Windows, Linux and MacOS Binaries
- task: PublishPipelineArtifact@1
displayName: 'Publish MacOS Artifact'
inputs:
targetPath: '$(Build.ArtifactStagingDirectory)'
artifact: 'drop-macos-onnxruntime-extensions-java-cpu'
artifact: 'drop-onnxruntime-extensions-java-cpu'

- template: templates/component-governance-component-detection-steps.yml
parameters :
Expand Down

0 comments on commit 2321329

Please sign in to comment.