summaryrefslogtreecommitdiff
path: root/db-testing
blob: 70451a2f097cbd87789362c0922d14ed6467ecdd (plain)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
#!/bin/bash

repoid=4
reponame="testing"
arch="i686"

ftppath="/home/ftp/testing/os/i686"

cvspath="/home/cvs-arch"
cvsmod="testing"
cvstag="TESTING"

stagedir="$HOME/staging/testing"

testing_cleanup() {
	rm -rf $testingtmp
}

# catch ^C
trap testing_cleanup SIGINT

if [ -f /tmp/.repolck.$arch.$repoid ]; then
	owner=`/bin/ls -l /tmp/.repolck.$arch.$repoid | awk '{print $3}'`
	echo "error: db generation is already in progress (started by $owner)"
	exit 1
fi
# lock
touch /tmp/.repolck.$arch.$repoid

# testing is special, so we have to do the CVS checkout stuff here
testingtmp=$(mktemp -d /tmp/testtmp-XXXXXX) || exit 1
cvsdir=$testingtmp/testing
mkdir $cvsdir
cd $cvsdir

if [ "`ls $stagedir/add`" -o "`ls $stagedir/del`" ]; then
	echo "==> Checking out TESTING branches..." >&2
	echo "--- CORE ---"
	CVS_RSH=ssh CVSROOT=:ext:cvs.archlinux.org:/home/cvs-core cvs -q export -r TESTING core
	cp -a core/* . && rm -rf core
	echo "--- EXTRA ---"
	CVS_RSH=ssh CVSROOT=:ext:cvs.archlinux.org:/home/cvs-extra cvs -q export -r TESTING extra
	cp -a extra/* . && rm -rf extra
	echo "--- UNSTABLE ---"
	CVS_RSH=ssh CVSROOT=:ext:cvs.archlinux.org:/home/cvs-unstable cvs -q export -r TESTING unstable
	cp -a unstable/* . && rm -rf unstable
fi

# unlock
rm -f /tmp/.repolck.$arch.$repoid

# call the real script
. `dirname $0`/db-inc

testing_cleanup