Advertisement
Guest User

Untitled

a guest
Aug 16th, 2018
106
0
Never
Not a member of Pastebin yet? Sign Up, it unlocks many cool features!
text 4.14 KB | None | 0 0
  1. #!/usr/bin/env bash
  2.  
  3. if [ $# -lt 3 ]; then
  4. echo "usage: $0 <db-name> <db-user> <db-pass> [db-host] [wp-version]"
  5. exit 1
  6. fi
  7.  
  8. DB_NAME=$1
  9. DB_USER=$2
  10. DB_PASS=$3
  11. DB_HOST=${4-localhost}
  12. WP_VERSION=${5}
  13. if [[ ${5} == "latest" ]]; then
  14. WP_TEST_VERSION="trunk"
  15. else
  16. WP_TEST_VERSION="tags/${5}"
  17. fi
  18.  
  19. SCRIPTPATH=`pwd -P`
  20.  
  21. WP_TESTS_DIR="${SCRIPTPATH}/wordpress-tests-lib"
  22. WP_CORE_DIR="${SCRIPTPATH}/wordpress/"
  23.  
  24. set -ex
  25.  
  26. install_wp() {
  27. rm -Rf "$WP_CORE_DIR"
  28. mkdir -p "$WP_CORE_DIR"
  29. if [[ $WP_TEST_VERSION == "trunk" ]]; then
  30. wget -nv -O /tmp/wordpress.zip https://wordpress.org/nightly-builds/wordpress-latest.zip
  31. unzip -d . /tmp/wordpress.zip
  32. elif [[ $WP_VERSION == "" ]]; then
  33. wget -nv -O /tmp/wordpress.tar.gz https://wordpress.org/latest.tar.gz
  34. tar --strip-components=1 -zxmf /tmp/wordpress.tar.gz -C "$WP_CORE_DIR"
  35. WP_TEST_VERSION=$(cd "$WP_CORE_DIR"; wp core version --allow-root)
  36. else
  37. ARCHIVE_NAME="wordpress-$WP_VERSION"
  38. wget -nv -O /tmp/wordpress.tar.gz https://wordpress.org/${ARCHIVE_NAME}.tar.gz
  39. tar --strip-components=1 -zxmf /tmp/wordpress.tar.gz -C "$WP_CORE_DIR"
  40. fi
  41.  
  42. wget -nv -O "${WP_CORE_DIR}/wp-content/db.php" https://raw.github.com/markoheijnen/wp-mysqli/master/db.php
  43. }
  44.  
  45. install_test_suite() {
  46. # portable in-place argument for both GNU sed and Mac OSX sed
  47. if [[ $(uname -s) == 'Darwin' ]]; then
  48. local ioption='-i .bak'
  49. else
  50. local ioption='-i'
  51. fi
  52.  
  53. # set up testing suite
  54. rm -Rf "$WP_TESTS_DIR"
  55. mkdir -p "$WP_TESTS_DIR"
  56. cd "$WP_TESTS_DIR"
  57.  
  58. if [[ $WP_TEST_VERSION == "trunk" ]]; then
  59. svn co --quiet http://develop.svn.wordpress.org/trunk/tests/phpunit/includes/
  60. svn co --quiet http://develop.svn.wordpress.org/trunk/tests/phpunit/data/
  61. wget -nv -O wp-tests-config.php https://develop.svn.wordpress.org/trunk/wp-tests-config-sample.php
  62. elif [[ $WP_VERSION == "" ]]; then
  63. svn co --quiet http://develop.svn.wordpress.org/trunk/tests/phpunit/includes/
  64. svn co --quiet http://develop.svn.wordpress.org/trunk/tests/phpunit/data/
  65. wget -nv -O wp-tests-config.php https://develop.svn.wordpress.org/trunk/wp-tests-config-sample.php
  66. else
  67. svn co --quiet http://develop.svn.wordpress.org/tags/${WP_VERSION}/tests/phpunit/includes/
  68. svn co --quiet http://develop.svn.wordpress.org/tags/${WP_VERSION}/tests/phpunit/data/
  69. wget -nv -O wp-tests-config.php https://develop.svn.wordpress.org/tags/${WP_VERSION}/wp-tests-config-sample.php
  70. fi
  71.  
  72. sed $ioption "s:dirname( __FILE__ ) . '/src/':'${WP_CORE_DIR}':" wp-tests-config.php
  73. sed $ioption "s/youremptytestdbnamehere/$DB_NAME/" wp-tests-config.php
  74. sed $ioption "s/yourusernamehere/$DB_USER/" wp-tests-config.php
  75. sed $ioption "s/yourpasswordhere/$DB_PASS/" wp-tests-config.php
  76. sed $ioption "s|localhost|${DB_HOST}|" wp-tests-config.php
  77. echo "\$table_prefix = 'wptests' . ( getenv('TEST_TOKEN') !== false ? getenv('TEST_TOKEN') : '' ) . '_';" >> wp-tests-config.php
  78. }
  79.  
  80. install_db() {
  81. # parse DB_HOST for port or socket references
  82. local PARTS=(${DB_HOST//\:/ })
  83. local DB_HOSTNAME=${PARTS[0]};
  84. local DB_SOCK_OR_PORT=${PARTS[1]};
  85. local EXTRA=""
  86.  
  87. if ! [ -z $DB_HOSTNAME ] ; then
  88. if [[ "$DB_SOCK_OR_PORT" =~ ^[0-9]+$ ]] ; then
  89. EXTRA=" --host=$DB_HOSTNAME --port=$DB_SOCK_OR_PORT --protocol=tcp"
  90. elif ! [ -z $DB_SOCK_OR_PORT ] ; then
  91. EXTRA=" --socket=$DB_SOCK_OR_PORT"
  92. elif ! [ -z $DB_HOSTNAME ] ; then
  93. EXTRA=" --host=$DB_HOSTNAME --protocol=tcp"
  94. fi
  95. fi
  96.  
  97. # create database
  98. MYSQL=`which mysql`
  99.  
  100. $MYSQL --user="$DB_USER" --password="$DB_PASS"$EXTRA -e "DROP DATABASE IF EXISTS $DB_NAME;"
  101. $MYSQL --user="$DB_USER" --password="$DB_PASS"$EXTRA -e "CREATE DATABASE IF NOT EXISTS $DB_NAME;"
  102. $MYSQL --user="$DB_USER" --password="$DB_PASS"$EXTRA -e "GRANT USAGE ON *.* TO $DB_USER@$DB_HOSTNAME IDENTIFIED BY '$DB_PASS';"
  103. $MYSQL --user="$DB_USER" --password="$DB_PASS"$EXTRA -e "GRANT ALL PRIVILEGES ON $DB_NAME.* TO $DB_USER@$DB_HOSTNAME;"
  104. $MYSQL --user="$DB_USER" --password="$DB_PASS"$EXTRA -e "FLUSH PRIVILEGES;"
  105. $MYSQL --user="$DB_USER" --password="$DB_PASS"$EXTRA -e "USE $DB_NAME;"
  106.  
  107. # mysqladmin create $DB_NAME --user="$DB_USER" --password="$DB_PASS"$EXTRA
  108. }
  109.  
  110. install_wp
  111. install_test_suite
  112. install_db
Advertisement
Add Comment
Please, Sign In to add comment
Advertisement