update tests
[freeside.git] / FS-Test / bin / freeside-test-start
1 #!/bin/bash
2
3 VERSION='5.0.1'
4
5 set -ae
6
7 echo "Stopping services."
8 sudo service freeside stop
9 sudo service apache2 stop
10
11 newname=freeside_`date +%Y%m%d`
12 sharedir=$(perl -MFS::Test -e "print FS::Test::share_dir()")
13
14 # get company_name from existing DB, strip whitespace
15 # (if there is no existing DB, continue anyway)
16 testdbmarker=$(sudo -u freeside \
17   psql -tc 'select value from conf where name='\'company_name''\' | \
18   sed "s/^ //" \
19   || true
20 )
21
22 createdb=YES
23
24 if psql -l |grep -q '^ *freeside '; then
25   if [ "$testdbmarker" = "Freeside Test $VERSION" ]; then
26     createdb=NO
27     echo "Freeside test database found."
28   else
29     echo "Renaming database to $newname."
30     psql postgres -c "ALTER DATABASE freeside RENAME TO $newname"
31   fi
32 fi
33
34 if [ $createdb = YES ]; then
35   echo "Creating new database from stock schema."
36   createdb --owner=freeside freeside
37   sudo -u freeside psql freeside -q -f $sharedir/test.sql > /dev/null
38 fi
39
40 newtime=$(sudo -u freeside \
41   psql -tc 'SELECT to_timestamp(max(_date) + 86400) FROM cust_bill' \
42 )
43 # no longer needed since we don't run LaTeX in the test script
44 #echo "Setting clock to $newtime."
45 #sudo date -s "$newtime"
46
47 #echo "Applying upgrades."
48 #sudo -u freeside freeside-upgrade test
49 # shouldn't happen automatically
50
51 # start Apache on a future date when all of the invoice dates are in the past
52 echo "Restarting Apache."
53 sudo faketime "$newtime" apache2ctl start
54
55 echo "Done."