2021-02-24 23:44:58 -06:00
|
|
|
# Starter pipeline
|
|
|
|
# Start with a minimal pipeline that you can customize to build and deploy your code.
|
|
|
|
# Add steps that build, run tests, deploy, and more:
|
|
|
|
# https://aka.ms/yaml
|
|
|
|
|
|
|
|
trigger: none
|
|
|
|
pr: none
|
|
|
|
|
2022-03-30 03:08:52 -05:00
|
|
|
resources:
|
|
|
|
repositories:
|
|
|
|
- repository: buildimage
|
|
|
|
type: github
|
|
|
|
name: Azure/sonic-buildimage
|
|
|
|
ref: master
|
|
|
|
endpoint: build
|
|
|
|
|
2021-02-24 23:44:58 -06:00
|
|
|
schedules:
|
|
|
|
- cron: "0 0 * * *"
|
|
|
|
displayName: Daily Build
|
|
|
|
branches:
|
|
|
|
include:
|
|
|
|
- 202012
|
|
|
|
always: true
|
|
|
|
|
2022-03-30 23:40:19 -05:00
|
|
|
resources:
|
|
|
|
repositories:
|
|
|
|
- repository: buildimage
|
|
|
|
type: github
|
|
|
|
name: Azure/sonic-buildimage
|
|
|
|
ref: master
|
|
|
|
endpoint: build
|
|
|
|
|
2021-02-24 23:44:58 -06:00
|
|
|
pool: sonicbld
|
|
|
|
|
2022-03-20 21:27:24 -05:00
|
|
|
parameters:
|
|
|
|
- name: 'jobFilters'
|
|
|
|
type: object
|
|
|
|
default:
|
|
|
|
- vs
|
|
|
|
- barefoot
|
|
|
|
- broadcom
|
|
|
|
- centec
|
|
|
|
- centec-arm64
|
|
|
|
- generic
|
|
|
|
- innovium
|
|
|
|
- marvell-armhf
|
|
|
|
- mellanox
|
|
|
|
|
2021-02-24 23:44:58 -06:00
|
|
|
stages:
|
|
|
|
- stage: Build
|
2021-04-21 13:06:15 -05:00
|
|
|
variables:
|
|
|
|
CACHE_MODE: none
|
|
|
|
VERSION_CONTROL_OPTIONS: 'SONIC_VERSION_CONTROL_COMPONENTS='
|
2021-02-24 23:44:58 -06:00
|
|
|
jobs:
|
|
|
|
- template: azure-pipelines-build.yml
|
|
|
|
parameters:
|
2022-03-20 21:27:24 -05:00
|
|
|
jobFilters: ${{ parameters.jobFilters }}
|
2022-03-31 00:07:46 -05:00
|
|
|
buildOptions: '${{ variables.VERSION_CONTROL_OPTIONS }} ENABLE_DOCKER_BASE_PULL=n SONIC_BUILD_JOBS=$(nproc) ENABLE_IMAGE_SIGNATURE=y'
|
2021-04-21 13:06:15 -05:00
|
|
|
preSteps:
|
2022-03-30 03:08:52 -05:00
|
|
|
- template: .azure-pipelines/template-clean-sonic-slave.yml@buildimage
|
2021-02-24 23:44:58 -06:00
|
|
|
- stage: UpgradeVersions
|
|
|
|
jobs:
|
|
|
|
- job: UpgradeVersions
|
|
|
|
pool:
|
|
|
|
vmImage: 'ubuntu-20.04'
|
|
|
|
steps:
|
|
|
|
- script: |
|
|
|
|
if [ -z "$(which gh)" ]; then
|
|
|
|
sudo apt-key adv --keyserver keyserver.ubuntu.com --recv-key C99B11DEB97541F0
|
|
|
|
sudo apt-add-repository https://cli.github.com/packages
|
|
|
|
sudo apt update
|
|
|
|
sudo apt install gh
|
|
|
|
fi
|
|
|
|
displayName: 'Install gh'
|
|
|
|
- checkout: self
|
|
|
|
displayName: 'Checkout code'
|
|
|
|
- download: current
|
|
|
|
patterns: '**/versions-*'
|
|
|
|
- script: |
|
|
|
|
mkdir -p target
|
|
|
|
default_platform=broadcom
|
|
|
|
artifacts=$(find $(Pipeline.Workspace) -maxdepth 1 -type d -name 'sonic-buildimage.*' | grep -v "sonic-buildimage.${default_platform}")
|
|
|
|
echo "artifacts$artifacts"
|
|
|
|
cp -r $(Pipeline.Workspace)/sonic-buildimage.${default_platform}/versions target/
|
|
|
|
make freeze FREEZE_VERSION_OPTIONS=-r
|
|
|
|
find files/build/versions
|
2021-04-21 13:06:15 -05:00
|
|
|
ordered_artifacts=$(echo "$artifacts" | grep -v -E "arm64|armhf" && echo "$artifacts" | grep -E "arm64|armhf")
|
|
|
|
for artifact in $ordered_artifacts
|
2021-02-24 23:44:58 -06:00
|
|
|
do
|
|
|
|
rm -rf target/versions
|
|
|
|
cp -r $artifact/versions target/
|
2021-04-21 13:06:15 -05:00
|
|
|
OPTIONS="-a -d"
|
|
|
|
[[ "$artifact" == *arm64* || "$artifact" == *armhf* ]] && OPTIONS="-d"
|
|
|
|
make freeze FREEZE_VERSION_OPTIONS="$OPTIONS"
|
2021-02-24 23:44:58 -06:00
|
|
|
done
|
|
|
|
git diff files/build/versions
|
|
|
|
displayName: 'Freeze Versions'
|
|
|
|
- script: |
|
|
|
|
if [ -z "$GIT_USER" ]; then
|
|
|
|
echo "Skipped to send the pull request, GIT_USER not set."
|
|
|
|
exit 0
|
|
|
|
fi
|
|
|
|
GIT_STATUS=$(git status --porcelain files/build/versions)
|
|
|
|
if [ -z "$GIT_STATUS" ]; then
|
|
|
|
echo "Skipped to send the pull request, no version change in files/build/versions"
|
|
|
|
exit 0
|
|
|
|
fi
|
|
|
|
if [ ! -d "$HOME" ]; then
|
|
|
|
sudo mkdir -p $HOME
|
|
|
|
sudo chown -R $(id -un):$(id -gn) $HOME
|
|
|
|
fi
|
|
|
|
SOURCE_BRANCH=$(Build.SourceBranch)
|
|
|
|
REPO_NAME=$(Build.Repository.Name)
|
|
|
|
[ -z "$GIT_REPO" ] && GIT_REPO=${REPO_NAME#*/}
|
|
|
|
BRANCH_NAME=repd/versions/${SOURCE_BRANCH#refs/heads/}
|
|
|
|
echo '#!/bin/bash' > git_env_password.sh
|
|
|
|
echo 'echo $GIT_PASSWORD' >> git_env_password.sh
|
|
|
|
chmod a+x git_env_password.sh
|
|
|
|
export GIT_ASKPASS=./git_env_password.sh
|
|
|
|
|
|
|
|
git config user.name $GIT_USER
|
|
|
|
git config credential.https://github.com.username $GIT_USER
|
|
|
|
git add files/build/versions
|
2021-03-11 10:50:29 -06:00
|
|
|
git commit -m "[ci/build]: Upgrade SONiC package versions"
|
2021-02-24 23:44:58 -06:00
|
|
|
git checkout -b $BRANCH_NAME
|
|
|
|
git remote add remote https://github.com/$GIT_USER/$GIT_REPO
|
|
|
|
git push remote HEAD:refs/heads/$BRANCH_NAME -f
|
|
|
|
git branch -u remote/$BRANCH_NAME
|
|
|
|
|
|
|
|
echo $GIT_PASSWORD | gh auth login --with-token
|
|
|
|
TITLE="Upgrade SONiC Versions"
|
|
|
|
BODY="Upgrade SONiC Versions"
|
|
|
|
RET=0
|
|
|
|
if ! gh pr create -t "$TITLE" -b "$BODY" -B $(Build.SourceBranch) -R $(Build.Repository.Name) > pr.log 2>&1; then
|
|
|
|
if ! grep -q "already exists" pr.log; then
|
|
|
|
RET=1
|
|
|
|
fi
|
|
|
|
fi
|
|
|
|
cat pr.log
|
|
|
|
exit $RET
|
|
|
|
env:
|
|
|
|
GIT_USER: $(GIT_USER)
|
|
|
|
GIT_PASSWORD: $(GIT_PASSWORD)
|
|
|
|
displayName: 'Send Pull Request'
|
|
|
|
- publish: $(System.DefaultWorkingDirectory)/files/build/versions
|
|
|
|
artifact: 'sonic-buildimage.versions'
|
|
|
|
displayName: 'Archive SONiC versions'
|
|
|
|
|