mirror of
https://github.com/netdata/libbpf.git
synced 2026-04-06 00:29:07 +08:00
vmtests: speed up fetching of bpf-next sources
Attempt to first fetch bpf-next tree from a snapshot, falling back to shallow clone, and if that is not enough, doing a full bpf-next clone. This should both improve a speed and (because of full clone fallback) improve test reliability if libbpf wasn't synced in a while. Signed-off-by: Andrii Nakryiko <andriin@fb.com>
This commit is contained in:
committed by
Andrii Nakryiko
parent
bf3ab4b0d8
commit
c57be0b4d6
@@ -8,17 +8,31 @@ REPO_PATH=$1
|
|||||||
|
|
||||||
BPF_NEXT_ORIGIN=https://git.kernel.org/pub/scm/linux/kernel/git/bpf/bpf-next.git
|
BPF_NEXT_ORIGIN=https://git.kernel.org/pub/scm/linux/kernel/git/bpf/bpf-next.git
|
||||||
LINUX_SHA=$(cat ${LIBBPF_PATH}/CHECKPOINT-COMMIT)
|
LINUX_SHA=$(cat ${LIBBPF_PATH}/CHECKPOINT-COMMIT)
|
||||||
|
SNAPSHOT_URL=https://git.kernel.org/pub/scm/linux/kernel/git/bpf/bpf-next.git/snapshot/bpf-next-${LINUX_SHA}.tar.gz
|
||||||
|
|
||||||
echo REPO_PATH = ${REPO_PATH}
|
echo REPO_PATH = ${REPO_PATH}
|
||||||
echo LINUX_SHA = ${LINUX_SHA}
|
echo LINUX_SHA = ${LINUX_SHA}
|
||||||
|
|
||||||
if [ ! -d "${REPO_PATH}" ]; then
|
if [ ! -d "${REPO_PATH}" ]; then
|
||||||
mkdir -p ${REPO_PATH}
|
mkdir -p $(dirname "${REPO_PATH}")
|
||||||
cd ${REPO_PATH}
|
cd $(dirname "${REPO_PATH}")
|
||||||
git init
|
# attempt to fetch desired bpf-next repo snapshot
|
||||||
git remote add bpf-next ${BPF_NEXT_ORIGIN}
|
if wget ${SNAPSHOT_URL} ; then
|
||||||
for depth in 32 64 128; do
|
tar xf bpf-next-${LINUX_SHA}.tar.gz
|
||||||
git fetch --depth ${depth} bpf-next
|
mv bpf-next-${LINUX_SHA} $(basename ${REPO_PATH})
|
||||||
git reset --hard ${LINUX_SHA} && break
|
else
|
||||||
done
|
# but fallback to git fetch approach if that fails
|
||||||
|
mkdir -p ${REPO_PATH}
|
||||||
|
cd ${REPO_PATH}
|
||||||
|
git init
|
||||||
|
git remote add bpf-next ${BPF_NEXT_ORIGIN}
|
||||||
|
# try shallow clone first
|
||||||
|
git fetch --depth 32 bpf-next
|
||||||
|
# check if desired SHA exists
|
||||||
|
if ! git cat-file -e ${LINUX_SHA}^{commit} ; then
|
||||||
|
# if not, fetch all of bpf-next; slow and painful
|
||||||
|
git fetch bpf-next
|
||||||
|
fi
|
||||||
|
git reset --hard ${LINUX_SHA}
|
||||||
|
fi
|
||||||
fi
|
fi
|
||||||
|
|||||||
Reference in New Issue
Block a user