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