[CI] Update sonic image official build template. (#7198)
* draft * fix * Update new-build-template.yml * Update azure-pipelines-build.yml * Update azure-pipelines-job-groups.yml * fix * fix * draft * fix * fix * fix * fix * fix * fix Signed-off-by: Shilong Liu <shilongliu@microsoft.com> Co-authored-by: Sonic Automation <svc-acs@microsoft.com>
This commit is contained in:
parent
8ec3bdc301
commit
dcb9ef3d44
@ -1,3 +1,5 @@
|
|||||||
|
# The azure pipeline template for Official build, and upgrade version build
|
||||||
|
|
||||||
parameters:
|
parameters:
|
||||||
- name: 'jobFilters'
|
- name: 'jobFilters'
|
||||||
type: object
|
type: object
|
||||||
@ -5,68 +7,93 @@ parameters:
|
|||||||
- name: 'buildOptions'
|
- name: 'buildOptions'
|
||||||
type: string
|
type: string
|
||||||
default: 'SONIC_CONFIG_BUILD_JOBS=1'
|
default: 'SONIC_CONFIG_BUILD_JOBS=1'
|
||||||
- name: 'buildSlave'
|
- name: 'preSteps'
|
||||||
type: string
|
type: stepList
|
||||||
default: 'n'
|
default: []
|
||||||
- name: 'postSteps'
|
- name: 'postSteps'
|
||||||
type: stepList
|
type: stepList
|
||||||
default: []
|
default: []
|
||||||
|
|
||||||
jobs:
|
jobs:
|
||||||
- template: azure-pipelines-job-groups.yml
|
- template: azure-pipelines-image-template.yml
|
||||||
parameters:
|
parameters:
|
||||||
jobFilters: ${{ parameters.jobFilters }}
|
jobFilters: ${{ parameters.jobFilters }}
|
||||||
preSteps:
|
preSteps: ${{ parameters.preSteps }}
|
||||||
- script: |
|
postSteps: ${{ parameters.postSteps }}
|
||||||
containers=$(docker container ls | grep "sonic-slave" | awk '{ print $1 }')
|
jobVariables:
|
||||||
if [ ! -z "$containers" ]; then
|
PLATFORM: $(GROUP_NAME)
|
||||||
docker container kill $containers || true
|
PLATFORM_ARCH: amd64
|
||||||
sleep 5
|
BUILD_OPTIONS: ${{ parameters.buildOptions }}
|
||||||
fi
|
dbg_image: false
|
||||||
if [ "${{ parameters.buildSlave }}" == "y" ]; then
|
swi_image: false
|
||||||
images=$(docker images 'sonic-slave-*' -a -q)
|
raw_image: false
|
||||||
[ ! -z "$images" ] && docker rmi -f $images
|
sync_rpc_image: false
|
||||||
fi
|
platform_rpc: false
|
||||||
sudo rm -rf $(ls -A1)
|
|
||||||
displayName: 'Init'
|
|
||||||
- checkout: self
|
|
||||||
submodules: recursive
|
|
||||||
displayName: 'Checkout code'
|
|
||||||
- script: |
|
|
||||||
make ${{ parameters.buildOptions }} PLATFORM=$GROUP_NAME configure
|
|
||||||
displayName: 'Make configure'
|
|
||||||
postSteps:
|
|
||||||
- ${{ parameters.postSteps }}
|
|
||||||
- publish: $(System.DefaultWorkingDirectory)/target
|
|
||||||
artifact: 'sonic-buildimage.$(GROUP_NAME)$(GROUP_EXTNAME)'
|
|
||||||
displayName: "Archive sonic image"
|
|
||||||
jobGroups:
|
jobGroups:
|
||||||
- name: vs
|
- name: vs
|
||||||
script: |
|
variables:
|
||||||
sudo bash -c "echo 1 > /proc/sys/vm/compact_memory"
|
dbg_image: true
|
||||||
make ${{ parameters.buildOptions }} target/sonic-vs.img.gz
|
|
||||||
- name: broadcom
|
|
||||||
script: |
|
|
||||||
make ${{ parameters.buildOptions }} target/sonic-broadcom.bin target/sonic-aboot-broadcom.swi
|
|
||||||
- name: barefoot
|
- name: barefoot
|
||||||
script: |
|
variables:
|
||||||
make ${{ parameters.buildOptions }} target/sonic-barefoot.bin target/sonic-aboot-barefoot.swi
|
swi_image: true
|
||||||
|
- name: broadcom
|
||||||
|
variables:
|
||||||
|
dbg_image: true
|
||||||
|
swi_image: true
|
||||||
|
raw_image: true
|
||||||
|
sync_rpc_image: true
|
||||||
|
platform_rpc: brcm
|
||||||
- name: centec
|
- name: centec
|
||||||
script: |
|
variables:
|
||||||
make ${{ parameters.buildOptions }} INSTALL_DEBUG_TOOLS=y target/sonic-centec.bin
|
dbg_image: true
|
||||||
mv target/sonic-centec.bin target/sonic-centec-dbg.bin
|
sync_rpc_image: true
|
||||||
make ${{ parameters.buildOptions }} target/sonic-centec.bin
|
platform_rpc: centec
|
||||||
make ${{ parameters.buildOptions }} ENABLE_SYNCD_RPC=y target/docker-syncd-centec-rpc.gz
|
- name: centec-arm64
|
||||||
|
pool: sonicbld_8c
|
||||||
|
variables:
|
||||||
|
arch: arm64
|
||||||
|
timeoutInMinutes: 1800
|
||||||
|
- name: generic
|
||||||
|
variables:
|
||||||
|
dbg_image: true
|
||||||
- name: innovium
|
- name: innovium
|
||||||
script: |
|
variables:
|
||||||
make ${{ parameters.buildOptions }} SONIC_CONFIG_BUILD_JOBS=1 target/sonic-innovium.bin
|
swi_image: true
|
||||||
|
- name: marvell-armhf
|
||||||
|
pool: sonicbld_8c
|
||||||
|
variables:
|
||||||
|
arch: armhf
|
||||||
|
timeoutInMinutes: 1800
|
||||||
- name: mellanox
|
- name: mellanox
|
||||||
script: |
|
variables:
|
||||||
make ${{ parameters.buildOptions }} target/sonic-mellanox.bin
|
dbg_image: true
|
||||||
- name: mellanox
|
sync_rpc_image: true
|
||||||
extName: _rpc
|
platform_rpc: mlnx
|
||||||
script: |
|
|
||||||
make ${{ parameters.buildOptions }} ENABLE_SYNCD_RPC=y all
|
|
||||||
- name: nephos
|
- name: nephos
|
||||||
script: |
|
variables:
|
||||||
make ${{ parameters.buildOptions }} target/sonic-nephos.bin
|
dbg_image: true
|
||||||
|
sync_rpc_image: true
|
||||||
|
platform_rpc: nephos
|
||||||
|
buildSteps:
|
||||||
|
- bash: |
|
||||||
|
if [ $(GROUP_NAME) == vs ]; then
|
||||||
|
if [ $(dbg_image) == true ]; then
|
||||||
|
make $BUILD_OPTIONS INSTALL_DEBUG_TOOLS=y target/sonic-vs.img.gz && mv target/sonic-vs.img.gz target/sonic-vs-dbg.img.gz
|
||||||
|
fi
|
||||||
|
make $BUILD_OPTIONS target/docker-sonic-vs.gz target/sonic-vs.img.gz target/docker-ptf.gz
|
||||||
|
else
|
||||||
|
if [ $(dbg_image) == true ]; then
|
||||||
|
make $BUILD_OPTIONS INSTALL_DEBUG_TOOLS=y target/sonic-$(GROUP_NAME).bin && \
|
||||||
|
mv target/sonic-$(GROUP_NAME).bin target/sonic-$(GROUP_NAME)-dbg.bin
|
||||||
|
fi
|
||||||
|
if [ $(swi_image) == true ]; then
|
||||||
|
make $BUILD_OPTIONS ENABLE_IMAGE_SIGNATURE=y target/sonic-aboot-$(GROUP_NAME).swi
|
||||||
|
fi
|
||||||
|
if [ $(raw_image) == true ]; then
|
||||||
|
make $BUILD_OPTIONS target/sonic-$(GROUP_NAME).raw
|
||||||
|
fi
|
||||||
|
if [ $(sync_rpc_image) == true ]; then
|
||||||
|
make $BUILD_OPTIONS ENABLE_SYNCD_RPC=y target/docker-syncd-$(platform_rpc)-rpc.gz
|
||||||
|
fi
|
||||||
|
make $BUILD_OPTIONS target/sonic-$(GROUP_NAME).bin
|
||||||
|
fi
|
||||||
|
54
.azure-pipelines/azure-pipelines-image-template.yml
Normal file
54
.azure-pipelines/azure-pipelines-image-template.yml
Normal file
@ -0,0 +1,54 @@
|
|||||||
|
# The azure pipeline template for PR build, Official build, and upgrade version build
|
||||||
|
|
||||||
|
parameters:
|
||||||
|
- name: 'jobFilters'
|
||||||
|
type: object
|
||||||
|
default: ''
|
||||||
|
- name: 'preSteps'
|
||||||
|
type: stepList
|
||||||
|
default: []
|
||||||
|
- name: 'buildSteps'
|
||||||
|
type: stepList
|
||||||
|
default: []
|
||||||
|
- name: 'postSteps'
|
||||||
|
type: stepList
|
||||||
|
default: []
|
||||||
|
- name: jobGroups
|
||||||
|
type: object
|
||||||
|
default: []
|
||||||
|
- name: jobVariables
|
||||||
|
type: object
|
||||||
|
default: []
|
||||||
|
jobs:
|
||||||
|
- template: azure-pipelines-job-groups.yml
|
||||||
|
parameters:
|
||||||
|
jobFilters: ${{ parameters.jobFilters }}
|
||||||
|
jobVariables: ${{ parameters.jobVariables }}
|
||||||
|
preSteps:
|
||||||
|
- template: cleanup.yml
|
||||||
|
- ${{ parameters. preSteps }}
|
||||||
|
- script: |
|
||||||
|
if [ -n "$(CACHE_MODE)" ] && echo $(PLATFORM) | grep -E -q "^(vs|broadcom|mellanox)$"; then
|
||||||
|
CACHE_OPTIONS="SONIC_DPKG_CACHE_METHOD=$(CACHE_MODE) SONIC_DPKG_CACHE_SOURCE=/nfs/dpkg_cache/$(PLATFORM)"
|
||||||
|
BUILD_OPTIONS="$(BUILD_OPTIONS) $CACHE_OPTIONS"
|
||||||
|
echo "##vso[task.setvariable variable=BUILD_OPTIONS]$BUILD_OPTIONS"
|
||||||
|
fi
|
||||||
|
displayName: "Make build options"
|
||||||
|
- checkout: self
|
||||||
|
submodules: recursive
|
||||||
|
displayName: 'Checkout code'
|
||||||
|
- script: |
|
||||||
|
sudo modprobe overlay
|
||||||
|
sudo apt-get install -y acl
|
||||||
|
export DOCKER_DATA_ROOT_FOR_MULTIARCH=/data/march/docker
|
||||||
|
sudo bash -c "echo 1 > /proc/sys/vm/compact_memory"
|
||||||
|
ENABLE_DOCKER_BASE_PULL=y make PLATFORM=$(PLATFORM) PLATFORM_ARCH=$(PLATFORM_ARCH) configure
|
||||||
|
displayName: 'Make configure'
|
||||||
|
postSteps:
|
||||||
|
- publish: $(System.DefaultWorkingDirectory)/target
|
||||||
|
artifact: 'sonic-buildimage.$(GROUP_NAME)$(GROUP_EXTNAME)'
|
||||||
|
displayName: "Archive sonic image"
|
||||||
|
- ${{ parameters.postSteps }}
|
||||||
|
- template: cleanup.yml
|
||||||
|
jobGroups: ${{ parameters.jobGroups }}
|
||||||
|
buildSteps: ${{ parameters.buildSteps }}
|
@ -2,6 +2,9 @@ parameters:
|
|||||||
- name: 'preSteps'
|
- name: 'preSteps'
|
||||||
type: stepList
|
type: stepList
|
||||||
default: []
|
default: []
|
||||||
|
- name: 'buildSteps'
|
||||||
|
type: stepList
|
||||||
|
default: []
|
||||||
- name: "postSteps"
|
- name: "postSteps"
|
||||||
type: stepList
|
type: stepList
|
||||||
default: []
|
default: []
|
||||||
@ -16,14 +19,14 @@ parameters:
|
|||||||
default: ''
|
default: ''
|
||||||
- name: 'timeoutInMinutes'
|
- name: 'timeoutInMinutes'
|
||||||
type: 'number'
|
type: 'number'
|
||||||
default: 1440
|
default: 600
|
||||||
- name: 'jobFilters'
|
- name: 'jobFilters'
|
||||||
type: object
|
type: object
|
||||||
default: ''
|
default: ''
|
||||||
|
|
||||||
jobs:
|
jobs:
|
||||||
- ${{ each jobGroup in parameters.jobGroups }}:
|
- ${{ each jobGroup in parameters.jobGroups }}:
|
||||||
- ${{ if or(eq(parameters.jobFilters, ''), containsValue(parameters.jobFilters, jobGroup.name)) }}:
|
- ${{ if or(eq(parameters.jobFilters, ''), containsValue(parameters.jobFilters, jobGroup.name), endswith(variables['Build.DefinitionName'], format('.{0}{1}', jobGroup.name, jobGroup.extName))) }}:
|
||||||
- job: ${{ replace(format('{0}{1}', jobGroup.name, jobGroup.extName), '-', '_') }}
|
- job: ${{ replace(format('{0}{1}', jobGroup.name, jobGroup.extName), '-', '_') }}
|
||||||
${{ each pair in jobGroup }}:
|
${{ each pair in jobGroup }}:
|
||||||
${{ if not(in(pair.key, 'job', 'name', 'extName', 'variables', 'steps', 'script', 'scriptEnv')) }}:
|
${{ if not(in(pair.key, 'job', 'name', 'extName', 'variables', 'steps', 'script', 'scriptEnv')) }}:
|
||||||
@ -50,4 +53,5 @@ jobs:
|
|||||||
displayName: 'JobScript'
|
displayName: 'JobScript'
|
||||||
- ${{ if ne(jobGroup.steps, '') }}:
|
- ${{ if ne(jobGroup.steps, '') }}:
|
||||||
- ${{ jobGroup.steps }}
|
- ${{ jobGroup.steps }}
|
||||||
|
- ${{ parameters.buildSteps }}
|
||||||
- ${{ parameters.postSteps }}
|
- ${{ parameters.postSteps }}
|
||||||
|
@ -9,6 +9,7 @@ schedules:
|
|||||||
branches:
|
branches:
|
||||||
include:
|
include:
|
||||||
- master
|
- master
|
||||||
|
- 202012
|
||||||
always: true
|
always: true
|
||||||
|
|
||||||
trigger: none
|
trigger: none
|
||||||
@ -16,47 +17,13 @@ pr: none
|
|||||||
|
|
||||||
stages:
|
stages:
|
||||||
- stage: Build
|
- stage: Build
|
||||||
|
pool: sonicbld
|
||||||
|
variables:
|
||||||
|
CACHE_MODE: wcache
|
||||||
|
${{ if eq(variables['Build.SourceBranchName'], '202012') }}:
|
||||||
|
VERSION_CONTROL_OPTIONS: 'SONIC_VERSION_CONTROL_COMPONENTS=deb,py2,py3,web'
|
||||||
jobs:
|
jobs:
|
||||||
- template: build-template.yml
|
- template: azure-pipelines-build.yml
|
||||||
parameters:
|
parameters:
|
||||||
platform: broadcom
|
buildOptions: 'USERNAME=admin SONIC_BUILD_JOBS=$(nproc) ${{ variables.VERSION_CONTROL_OPTIONS }}'
|
||||||
platform_short: brcm
|
jobFilters: none
|
||||||
cache_mode: wcache
|
|
||||||
dbg_image: true
|
|
||||||
swi_image: true
|
|
||||||
raw_image: true
|
|
||||||
sync_rpc_image: true
|
|
||||||
|
|
||||||
- template: build-template.yml
|
|
||||||
parameters:
|
|
||||||
platform: mellanox
|
|
||||||
platform_short: mlnx
|
|
||||||
cache_mode: wcache
|
|
||||||
dbg_image: true
|
|
||||||
sync_rpc_image: true
|
|
||||||
|
|
||||||
- template: build-template.yml
|
|
||||||
parameters:
|
|
||||||
platform: vs
|
|
||||||
platform_short: vs
|
|
||||||
dbg_image: true
|
|
||||||
cache_mode: wcache
|
|
||||||
|
|
||||||
- template: build-template.yml
|
|
||||||
parameters:
|
|
||||||
timeout: 3600
|
|
||||||
platform: marvell-armhf
|
|
||||||
platform_arch: armhf
|
|
||||||
platform_short: marvell-armhf
|
|
||||||
cache_mode: wcache
|
|
||||||
pool: sonicbld_8c
|
|
||||||
|
|
||||||
- template: build-template.yml
|
|
||||||
parameters:
|
|
||||||
timeout: 3600
|
|
||||||
platform: centec-arm64
|
|
||||||
platform_arch: arm64
|
|
||||||
platform_short: centec-arm64
|
|
||||||
cache_mode: wcache
|
|
||||||
pool: sonicbld_8c
|
|
||||||
|
Reference in New Issue
Block a user