eca2e03b65a55fe79026a2c18ea400cb2061fb67
[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 echo "Setting clock to $newtime."
44 sudo date -s "$newtime"
45
46 #echo "Applying upgrades."
47 #sudo -u freeside freeside-upgrade test
48 # shouldn't happen automatically
49
50 # start Apache on a future date when all of the invoice dates are in the past
51 echo "Restarting Apache."
52 sudo service apache2 start
53
54 echo "Done."