Newer
Older
#!/bin/bash
set -ex
## Setup a Drupal site with CiviCRM configured for unit-testing.
## If a site already exists, destroy and recreate it.
## Usage: mk-drupal-test-site <domain.name> <db_name> </path/to/drupal> </path/to/civi>
## SOURCE:
## https://github.com/civicrm/civicrm-core/blob/master/tools/scripts/mk-drupal-test-site
## Pre-requisites:
## - MySQL admin credentials in ~/.my.cnf
## - Apache vhost with mod_rewrite, etc
## - DNS or /etc/hosts entries for "url"
## - Drupal source tree
## - CiviCRM source tree (outside the drupal root)
## - makepasswd
## - drush
## - (strongly recommended) filesystem with "acl" support
function usage() {
cat <<EOT
Usage: mk-drupal-test-site SITE_URL DB_NAME DRUPAL_ROOT [CIVI_ROOT]
Re/creates a Drupal-based CiviCRM site.
* SITE_URL: URL of the site. Example: example.org
* DB_NAME: MySQL database name. Example: civicrm_test
* DRUPAL_ROOT: Root path of the Drupal website. Example: /var/www/
* CIVI_ROOT: Root path of the CiviCRM directory. Will be symlinked.
You probably want to have a separate version somewhere to avoid
cloning a new version of the code base for each CMS.
The CiviCRM directory can either contain the main git repositories,
or an equivalent of the tar.gz archive.
Example: /srv/repositories/civicrm/
* SQL_DUMP (optional): instead of a standard blank install, import a
specific .sql dump. You can specify two .sql files.
EOT
exit 99;
}
[ "$1" = "--help" ] && usage
[ -z "$1" ] || [ -z "$2" ] || [ -z "$3" ] && usage
[ ! -d "$3" ] && echo "ERROR: $3: Drupal root directory not found." && usage
[ ! -d "$4" ] && echo "ERROR: $4: CiviCRM root directory not found." && usage
SITE_URL="$1"
DB_NAME="$2"
DB_USER="$DB_NAME"
DB_PASS=$(makepasswd --chars=12)
DB_HOST=localhost
DRUPAL_ROOT="$3"
CIVI_ROOT="$4"
FACL_USERS="www-data $(whoami)"
SQL_DUMP="$5"
SQL_DUMP2="$6"
SITE_KEY=$(makepasswd --chars=16)
ADMIN_USER="admin"
ADMIN_PASS=$(makepasswd --chars=12)
# Check if the CiviCRM directory looks OK
if [ -z "$CIVI_ROOT" -o ! -d "$CIVI_ROOT/bin" ]; then
echo "Failed to locate civi root: $CIVI_ROOT"
exit 1
fi
if [ -n "$SQL_DUMP" ]; then
if [ ! -f "$SQL_DUMP" ]; then
echo "$SQL_DUMP: Could not find the .sql file. Try using an absolute path to the file."
exit 3;
fi
fi
## Create database
echo "DROP DATABASE IF EXISTS $DB_NAME" | mysql
echo "CREATE DATABASE $DB_NAME" | mysql
echo "GRANT ALL ON ${DB_NAME}.* TO '${DB_USER}'@'localhost' IDENTIFIED BY '${DB_PASS}'" | mysql
echo "GRANT SUPER ON *.* TO '${DB_USER}'@'localhost'" | mysql
## Create Drupal site
pushd "$DRUPAL_ROOT"
if [ -d "sites/$SITE_URL" ]; then
chmod u+w "sites/$SITE_URL"
rm -rf "sites/$SITE_URL"
fi
# NB: Avoid sending e-mails for the site installation
# On hosts without sendmail (ex: demo sites), this causes the installation to fail.
drush site-install -y \
--db-url="mysql://${DB_USER}:${DB_PASS}@${DB_HOST}/${DB_NAME}" \
--account-name="$ADMIN_USER" \
--account-pass="$ADMIN_PASS" \
--sites-subdir="$SITE_URL"
chmod u+w "sites/$SITE_URL"
## Allow shell and WWW users to both manipulate "files" directory
if which setfacl; then
for FACL_USER in $FACL_USERS ; do
find "$DRUPAL_ROOT/sites/${SITE_URL}/files" -type d | xargs setfacl -m u:${FACL_USER}:rwx -m d:u:${FACL_USER}:rwx
done
fi
## Create Drupal-CiviCRM dirs and config
for SUBDIR in modules files files/civicrm files/civicrm/templates_c ; do
if [ ! -d "sites/${SITE_URL}/${SUBDIR}" ]; then
mkdir "sites/${SITE_URL}/${SUBDIR}"
fi
done

bgm
committed
ln -s "$CIVI_ROOT" "sites/$SITE_URL/modules/civicrm"
| sed "s;%%baseURL%%;http://${SITE_URL};" \
| sed "s;%%cms%%;Drupal;" \
| sed "s;%%CMSdbHost%%;${DB_HOST};" \
| sed "s;%%CMSdbName%%;${DB_NAME};" \
| sed "s;%%CMSdbPass%%;${DB_PASS};" \
| sed "s;%%CMSdbUser%%;${DB_USER};" \
| sed "s;%%crmRoot%%;${DRUPAL_ROOT}/sites/${SITE_URL}/modules/civicrm;" \
| sed "s;%%dbHost%%;${DB_HOST};" \
| sed "s;%%dbName%%;${DB_NAME};" \
| sed "s;%%dbPass%%;${DB_PASS};" \
| sed "s;%%dbUser%%;${DB_USER};" \
| sed "s;%%siteKey%%;${SITE_KEY};" \
| sed "s;%%templateCompileDir%%;${DRUPAL_ROOT}/sites/${SITE_URL}/files/civicrm/templates_c;" \
> "sites/$SITE_URL/civicrm.settings.php"
echo >> "sites/$SITE_URL/civicrm.settings.php"
echo "define('CIVICRM_MAIL_LOG', '/dev/null');" >> "sites/$SITE_URL/civicrm.settings.php"
popd
## Create CiviCRM config
cat > "$CIVI_ROOT/bin/setup.conf" << EOF
SVNROOT="$CIVI_ROOT"
SCHEMA=schema/Schema.xml
DBNAME="$DB_NAME"
DBUSER="$DB_USER"
DBPASS="$DB_PASS"
DBARGS=""
PHP5PATH=
# DBADD=
EOF
cat > "$CIVI_ROOT/tests/phpunit/CiviTest/civicrm.settings.local.php" << EOF
<?php
define('CIVICRM_DSN', "mysql://${DB_USER}:${DB_PASS}@${DB_HOST}/${DB_NAME}");
define('CIVICRM_TEMPLATE_COMPILEDIR', '${DRUPAL_ROOT}/sites/${SITE_URL}/files/civicrm/templates_c');
define('DONT_DOCUMENT_TEST_CONFIG', TRUE);
EOF
cat > "$CIVI_ROOT/tests/phpunit/CiviTest/CiviSeleniumSettings.php" << EOF
<?php
class CiviSeleniumSettings {
var \$publicSandbox = false;
var \$browser = '*firefox';
var \$sandboxURL = 'http://${SITE_URL}';
var \$sandboxPATH = '';
var \$username = 'demo';
var \$password = 'demo';
var \$adminUsername = '${ADMIN_USER}';
var \$adminPassword = '${ADMIN_PASS}';
var \$adminApiKey = 'apikey${ADMIN_PASS}';
var \$siteKey = '${SITE_KEY}';
var \$UFemail = 'noreply@civicrm.org';
function __construct() {
\$this->fullSandboxPath = \$this->sandboxURL . \$this->sandboxPATH;
}
}
EOF
pushd "$CIVI_ROOT"
./bin/setup.sh
popd
if [ -n "$SQL_DUMP" ]; then
echo "Importing SQL dump: $SQL_DUMP"
mysql $DB_NAME < "$SQL_DUMP"
echo "SQL import complete."
if [ -n "$SQL_DUMP2" -a -f "$SQL_DUMP2" ]; then
echo "Importing SQL dump: $SQL_DUMP2"
mysql $DB_NAME < "$SQL_DUMP2"
echo "SQL import complete."
fi
else
pushd "$DRUPAL_ROOT"
drush -l "${SITE_URL}" -y pm-enable civicrm
drush -l "${SITE_URL}" -y pm-enable civicrm_webtest
drush -l "${SITE_URL}" -y user-create --password=demo --mail='demo@example.com' demo
drush -l "${SITE_URL}" -y user-add-role civicrm_webtest_user demo
popd
fi