UI testing tool, #37340
[freeside.git] / FS-Test / bin / freeside-test-start
1 #!/bin/bash
2
3 VERSION='3.8.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 if [ -f /usr/local/etc/freeside/htpasswd ]; then
41   newhtpasswd=htpasswd_`date +%Y%m%d`
42   echo "Renaming htpasswd to $newhtpasswd."
43   sudo mv /usr/local/etc/freeside/htpasswd /usr/local/etc/freeside/$newhtpasswd
44 fi
45
46 echo "Installing new htpasswd."
47 sudo cp $sharedir/htpasswd /usr/local/etc/freeside/htpasswd
48
49 newtime=$(sudo -u freeside \
50   psql -tc 'SELECT to_timestamp(max(_date) + 86400) FROM cust_bill' \
51 )
52 echo "Setting clock to $newtime."
53 sudo date -s "$newtime"
54
55 #echo "Applying upgrades."
56 #sudo -u freeside freeside-upgrade test
57 # shouldn't happen automatically
58
59 # start Apache on a future date when all of the invoice dates are in the past
60 echo "Restarting Apache."
61 sudo service apache2 start
62
63 echo "Done."