summaryrefslogtreecommitdiff
path: root/test/lib/common.inc
diff options
context:
space:
mode:
Diffstat (limited to 'test/lib/common.inc')
-rw-r--r--test/lib/common.inc113
1 files changed, 113 insertions, 0 deletions
diff --git a/test/lib/common.inc b/test/lib/common.inc
new file mode 100644
index 0000000..5abe2ed
--- /dev/null
+++ b/test/lib/common.inc
@@ -0,0 +1,113 @@
+pkgdir="$(dirname $0)/packages"
+
+oneTimeSetUp() {
+ local p
+ echo -n 'Building packages...'
+ for p in "${pkgdir}"/*; do
+ pushd $p >/dev/null
+ linux32 makepkg -cf --config ${curdir}/lib/makepkg-i686.conf >/dev/null 2>&1 || exit 1
+ linux64 makepkg -cf --config ${curdir}/lib/makepkg-x86_64.conf >/dev/null 2>&1 || exit 1
+ popd >/dev/null
+ done
+ echo 'done'
+ echo
+}
+
+oneTimeTearDown() {
+ find "${pkgdir}" -name '*.pkg.tar.*' -delete
+}
+
+setUp() {
+ local p
+ local pkg
+
+ [ -f "${curdir}/../config.local" ] && exit 1
+ TMP="$(mktemp -d /tmp/$(basename $0).XXXXXXXXXX)"
+ #echo "Using ${TMP}"
+
+ mkdir -p "${TMP}/"{ftp,tmp,staging,{package,source}-cleanup,svn-{packages,community}-{copy,repo}}
+ mkdir -p "${TMP}/ftp/"{{core,extra,community,testing,community-testing}/os,packages/{arch,community}}/{i686,any,x86_64}
+ mkdir -p "${TMP}/staging/"{core,extra,community,testing,community-testing}
+
+ echo -n 'Creating svn repository...'
+ svnadmin create "${TMP}/svn-packages-repo"
+ svnadmin create "${TMP}/svn-community-repo"
+ svn checkout -q "file://${TMP}/svn-packages-repo" "${TMP}/svn-packages-copy"
+ svn checkout -q "file://${TMP}/svn-community-repo" "${TMP}/svn-community-copy"
+
+ for p in "${pkgdir}"/*; do
+ pkg=$(basename $p)
+ mkdir -p "${TMP}/svn-packages-copy/${pkg}"/{trunk,repos}
+ cp "${p}/PKGBUILD" "${TMP}/svn-packages-copy"/${pkg}/trunk/
+ svn add -q "${TMP}/svn-packages-copy"/${pkg}
+ svn commit -q -m"initial commit of ${pkg}" "${TMP}/svn-packages-copy"
+ done
+ echo 'done'
+
+ cat <<eot > "${curdir}/../config.local"
+ FTP_BASE="${TMP}/ftp"
+ SVNREPO="file://${TMP}/svn-packages-repo"
+ SVNREPOCOMMUNITY="file://${TMP}/svn-community-repo"
+ CLEANUP_DESTDIR="${TMP}/package-cleanup"
+ SOURCE_CLEANUP_DESTDIR="${TMP}/source-cleanup"
+ STAGING="${TMP}/staging"
+ TMPDIR="${TMP}/tmp"
+eot
+ . "${curdir}/../config"
+}
+
+tearDown() {
+ rm -rf "${TMP}"
+ rm -f "${curdir}/../config.local"
+ echo
+}
+
+testPackages() {
+ local p
+ for p in "${pkgdir}"/*; do
+ pushd $p >/dev/null
+ namcap *.pkg.tar.* || fail 'namcap failed'
+ popd >/dev/null
+ done
+}
+
+releasePackage() {
+ local repo=$1
+ local pkgbase=$2
+ local arch=$3
+
+ pushd "${TMP}/svn-packages-copy"/${pkgbase}/trunk/ >/dev/null
+ archrelease ${repo}-${arch} >/dev/null
+ popd >/dev/null
+ cp "${pkgdir}/${pkgbase}"/*.pkg.tar.* "${STAGING}"/${repo}/
+}
+
+checkAnyPackage() {
+ local repo=$1
+ local pkg=$2
+ local arch
+
+ [ -f "${FTP_BASE}/packages/arch/any/${pkg}" ] || fail "packages/arch/any/${pkg} not found"
+
+ for arch in any i686 x86_64; do
+ [ -L "${FTP_BASE}/${repo}/os/${arch}/${pkg}" ] || fail "${repo}/os/${arch}/${pkg} not a symlink"
+ [ "$(readlink -e "${FTP_BASE}/${repo}/os/${arch}/${pkg}")" == "${FTP_BASE}/packages/arch/any/${pkg}" ] || fail "${repo}/os/${arch}/${pkg} does not link to packages/arch/any/${pkg}"
+ done
+ [ -f "${STAGING}"/${repo}/${pkg} ] && fail "${repo}/${pkg} found in staging dir"
+
+ bsdtar -xf "${FTP_BASE}/${repo}/os/${arch}/${repo}.db.tar.gz" -O | grep -q ${pkg} || fail "${pkg} not in ${repo}/os/${arch}/${repo}.db.tar.gz"
+}
+
+checkPackage() {
+ local repo=$1
+ local pkg=$2
+ local arch=$3
+
+ [ -f "${FTP_BASE}/packages/arch/${arch}/${pkg}" ] || fail "packages/arch/${arch}/${pkg} not found"
+ [ -L "${FTP_BASE}/${repo}/os/${arch}/${pkg}" ] || fail "${repo}/os/${arch}/${pkg} not a symlink"
+ [ -f "${STAGING}"/${repo}/${pkg} ] && fail "${repo}/${pkg} found in staging dir"
+
+ [ "$(readlink -e "${FTP_BASE}/${repo}/os/${arch}/${pkg}")" == "${FTP_BASE}/packages/arch/${arch}/${pkg}" ] || fail "${repo}/os/${arch}/${pkg} does not link to packages/arch/${arch}/${pkg}"
+
+ bsdtar -xf "${FTP_BASE}/${repo}/os/${arch}/${repo}.db.tar.gz" -O | grep -q ${pkg} || fail "${pkg} not in ${repo}/os/${arch}/${repo}.db.tar.gz"
+}