sml-rubber 0.9.13 → 1.5.5
Sign up to get free protection for your applications and to get access to all the features.
- data/CHANGELOG +350 -0
- data/TODO +4 -0
- data/VERSION +1 -1
- data/bin/vulcanize +16 -32
- data/generators/vulcanize/templates/apache/config/rubber/deploy-apache.rb +6 -6
- data/generators/vulcanize/templates/apache/config/rubber/role/apache/monit-apache.conf +2 -2
- data/generators/vulcanize/templates/apache/config/rubber/role/apache/ports.conf +3 -0
- data/generators/vulcanize/templates/apache/config/rubber/role/web_tools/tools-apache-vhost.conf +30 -13
- data/generators/vulcanize/templates/apache/config/rubber/role/web_tools/tools-index.html +6 -2
- data/generators/vulcanize/templates/apache/config/rubber/rubber-apache.yml +0 -1
- data/generators/vulcanize/templates/base/Rakefile +21 -0
- data/generators/vulcanize/templates/base/config/deploy.rb +1 -0
- data/generators/vulcanize/templates/base/config/rubber/common/crontab +7 -1
- data/generators/vulcanize/templates/base/config/rubber/common/monit-postfix.conf +8 -0
- data/generators/vulcanize/templates/base/config/rubber/common/rubber.profile +13 -0
- data/generators/vulcanize/templates/base/config/rubber/deploy-setup.rb +53 -65
- data/generators/vulcanize/templates/base/config/rubber/deploy-util.rb +97 -0
- data/generators/vulcanize/templates/base/config/rubber/rubber-dns.yml +78 -0
- data/generators/vulcanize/templates/base/config/rubber/rubber-rvm.yml +28 -0
- data/generators/vulcanize/templates/base/config/rubber/rubber.yml +28 -34
- data/generators/vulcanize/templates/base/script/cron-runner +1 -1
- data/generators/vulcanize/templates/base/templates.rb +9 -0
- data/generators/vulcanize/templates/base/templates.yml +5 -0
- data/generators/vulcanize/templates/cassandra/config/rubber/deploy-cassandra.rb +88 -0
- data/generators/vulcanize/templates/cassandra/config/rubber/role/cassandra/cassandra.in.sh +60 -0
- data/generators/vulcanize/templates/cassandra/config/rubber/role/cassandra/cassandra.yaml +210 -0
- data/generators/vulcanize/templates/cassandra/config/rubber/role/cassandra/log4j-server.properties +45 -0
- data/generators/vulcanize/templates/cassandra/config/rubber/role/cassandra/monit-cassandra.conf +8 -0
- data/generators/vulcanize/templates/cassandra/config/rubber/rubber-cassandra.yml +18 -0
- data/generators/vulcanize/templates/cassandra/templates.yml +1 -0
- data/generators/vulcanize/templates/complete_mongrel_mysql/config/rubber/role/haproxy/haproxy-mongrel.conf +2 -2
- data/generators/vulcanize/templates/{complete_passenger_mysql → complete_passenger}/config/rubber/role/haproxy/haproxy-passenger.conf +4 -2
- data/generators/vulcanize/templates/{complete_passenger_mysql → complete_passenger}/config/rubber/rubber-complete.yml +0 -0
- data/generators/vulcanize/templates/complete_passenger/templates.rb +9 -0
- data/generators/vulcanize/templates/complete_passenger/templates.yml +9 -0
- data/generators/vulcanize/templates/complete_passenger_mysql/templates.yml +1 -7
- data/generators/vulcanize/templates/complete_passenger_postgresql/templates.yml +4 -0
- data/generators/vulcanize/templates/cruise/config/rubber/deploy-cruise.rb +3 -3
- data/generators/vulcanize/templates/cruise/config/rubber/role/cruise/my.cnf +1 -1
- data/generators/vulcanize/templates/haproxy/config/rubber/deploy-haproxy.rb +5 -5
- data/generators/vulcanize/templates/haproxy/config/rubber/role/haproxy/monit-haproxy.conf +2 -2
- data/generators/vulcanize/templates/haproxy/config/rubber/role/haproxy/syslog-haproxy.conf +8 -3
- data/generators/vulcanize/templates/haproxy/config/rubber/role/haproxy/syslogd-default.conf +4 -0
- data/generators/vulcanize/templates/jetty/config/rubber/deploy-jetty.rb +59 -0
- data/generators/vulcanize/templates/jetty/config/rubber/role/jetty/jetty.sh +589 -0
- data/generators/vulcanize/templates/jetty/config/rubber/role/jetty/jetty.xml +199 -0
- data/generators/vulcanize/templates/jetty/config/rubber/role/jetty/monit-jetty.conf +9 -0
- data/generators/vulcanize/templates/jetty/config/rubber/rubber-jetty.yml +10 -0
- data/generators/vulcanize/templates/jetty/templates.yml +1 -0
- data/generators/vulcanize/templates/memcached/config/rubber/role/memcached/memcached.conf +1 -1
- data/generators/vulcanize/templates/mongrel/config/rubber/deploy-mongrel.rb +5 -5
- data/generators/vulcanize/templates/mongrel/config/rubber/role/mongrel/monit-mongrel.conf +2 -2
- data/generators/vulcanize/templates/monit/config/rubber/common/monit.conf +2 -1
- data/generators/vulcanize/templates/monit/config/rubber/deploy-monit.rb +5 -4
- data/generators/vulcanize/templates/munin/config/rubber/common/monit-munin.conf +2 -2
- data/generators/vulcanize/templates/munin/config/rubber/common/munin-node.conf +1 -1
- data/generators/vulcanize/templates/munin/config/rubber/common/munin-plugins.conf +11 -0
- data/generators/vulcanize/templates/munin/config/rubber/deploy-munin.rb +5 -5
- data/generators/vulcanize/templates/munin/config/rubber/role/web_tools/munin-plugins.conf +1 -1
- data/generators/vulcanize/templates/munin/config/rubber/role/web_tools/munin.conf +1 -0
- data/generators/vulcanize/templates/munin/config/rubber/rubber-munin.yml +1 -1
- data/generators/vulcanize/templates/munin/script/munin/example_mysql_query.rb +6 -8
- data/generators/vulcanize/templates/mysql/config/rubber/common/database.yml +1 -0
- data/generators/vulcanize/templates/mysql/config/rubber/deploy-mysql.rb +40 -27
- data/generators/vulcanize/templates/mysql/config/rubber/role/db/apparmor-mysql.conf +46 -0
- data/generators/vulcanize/templates/mysql/config/rubber/role/db/monit-mysql.cnf +2 -2
- data/generators/vulcanize/templates/mysql/config/rubber/role/db/my.cnf +2 -6
- data/generators/vulcanize/templates/mysql/config/rubber/rubber-mysql.yml +2 -1
- data/generators/vulcanize/templates/mysql_cluster/config/rubber/deploy-mysql_cluster.rb +19 -15
- data/generators/vulcanize/templates/mysql_cluster/config/rubber/role/mysql_sql/monit-mysql_cluster_sql.cnf +2 -2
- data/generators/vulcanize/templates/mysql_proxy/config/rubber/common/monit-mysql_proxy.cnf +2 -2
- data/generators/vulcanize/templates/mysql_proxy/config/rubber/deploy-mysql_proxy.rb +3 -3
- data/generators/vulcanize/templates/nginx/config/rubber/deploy-nginx.rb +5 -5
- data/generators/vulcanize/templates/nginx/config/rubber/role/nginx/monit-nginx.conf +2 -2
- data/generators/vulcanize/templates/passenger/config/rubber/deploy-passenger.rb +11 -2
- data/generators/vulcanize/templates/passenger/config/rubber/role/passenger/munin-passenger-memory.conf +34 -0
- data/generators/vulcanize/templates/passenger/config/rubber/role/passenger/munin-passenger-sudoers.conf +2 -1
- data/generators/vulcanize/templates/passenger/config/rubber/role/passenger/munin-passenger.conf +1 -1
- data/generators/vulcanize/templates/passenger/config/rubber/role/passenger/passenger.conf +28 -3
- data/generators/vulcanize/templates/passenger/config/rubber/rubber-passenger.yml +5 -2
- data/generators/vulcanize/templates/passenger/templates.yml +3 -1
- data/generators/vulcanize/templates/postgresql/config/rubber/common/database.yml +12 -0
- data/generators/vulcanize/templates/postgresql/config/rubber/deploy-postgresql.rb +131 -0
- data/generators/vulcanize/templates/postgresql/config/rubber/role/db/crontab +14 -0
- data/generators/vulcanize/templates/postgresql/config/rubber/role/db/monit-postgresql.conf +10 -0
- data/generators/vulcanize/templates/postgresql/config/rubber/role/db/pg_hba.conf +89 -0
- data/generators/vulcanize/templates/postgresql/config/rubber/role/db/postgresql-sysctl.conf +6 -0
- data/generators/vulcanize/templates/postgresql/config/rubber/role/db/postgresql.conf +504 -0
- data/generators/vulcanize/templates/postgresql/config/rubber/rubber-postgresql.yml +45 -0
- data/generators/vulcanize/templates/postgresql/templates.yml +1 -0
- data/generators/vulcanize/templates/redis/config/rubber/deploy-redis.rb +37 -0
- data/generators/vulcanize/templates/redis/config/rubber/role/redis/crontab +8 -0
- data/generators/vulcanize/templates/redis/config/rubber/role/redis/monit-redis.conf +9 -0
- data/generators/vulcanize/templates/redis/config/rubber/role/redis/redis.conf +141 -0
- data/generators/vulcanize/templates/redis/config/rubber/rubber-redis.yml +4 -0
- data/generators/vulcanize/templates/redis/templates.yml +1 -0
- data/generators/vulcanize/templates/resque/config/initializers/resque.rb +15 -0
- data/generators/vulcanize/templates/resque/config/rubber/common/resque.yml +5 -0
- data/generators/vulcanize/templates/resque/config/rubber/deploy-resque.rb +58 -0
- data/generators/vulcanize/templates/resque/config/rubber/role/resque_web/monit-resque_web.conf +14 -0
- data/generators/vulcanize/templates/resque/config/rubber/role/resque_worker/monit-resque_worker.conf +19 -0
- data/generators/vulcanize/templates/resque/config/rubber/rubber-resque.yml +18 -0
- data/generators/vulcanize/templates/resque/script/resque_worker_management.rb +112 -0
- data/generators/vulcanize/templates/resque/templates.rb +1 -0
- data/generators/vulcanize/templates/resque/templates.yml +3 -0
- data/generators/vulcanize/templates/sphinx/config/rubber/deploy-sphinx.rb +8 -8
- data/generators/vulcanize/templates/sphinx/config/rubber/role/sphinx/crontab +2 -2
- data/generators/vulcanize/templates/sphinx/config/rubber/role/sphinx/monit-sphinx.conf +7 -4
- data/generators/vulcanize/vulcanize_generator.rb +166 -49
- data/lib/generators/vulcanize/USAGE +6 -0
- data/lib/generators/vulcanize/templates/apache/config/rubber/deploy-apache.rb +51 -0
- data/lib/generators/vulcanize/templates/apache/config/rubber/role/apache/deflate.conf +10 -0
- data/lib/generators/vulcanize/templates/apache/config/rubber/role/apache/expires.conf +9 -0
- data/lib/generators/vulcanize/templates/apache/config/rubber/role/apache/headers.conf +6 -0
- data/lib/generators/vulcanize/templates/apache/config/rubber/role/apache/monit-apache.conf +8 -0
- data/lib/generators/vulcanize/templates/apache/config/rubber/role/apache/ports.conf +8 -0
- data/lib/generators/vulcanize/templates/apache/config/rubber/role/apache/setenvif.conf +52 -0
- data/lib/generators/vulcanize/templates/apache/config/rubber/role/web_tools/tools-apache-vhost.conf +79 -0
- data/lib/generators/vulcanize/templates/apache/config/rubber/role/web_tools/tools-apache.auth +7 -0
- data/lib/generators/vulcanize/templates/apache/config/rubber/role/web_tools/tools-index.html +34 -0
- data/lib/generators/vulcanize/templates/apache/config/rubber/rubber-apache.yml +6 -0
- data/lib/generators/vulcanize/templates/apache/templates.yml +1 -0
- data/lib/generators/vulcanize/templates/base/Capfile +14 -0
- data/lib/generators/vulcanize/templates/base/Rakefile +21 -0
- data/lib/generators/vulcanize/templates/base/config/deploy.rb +56 -0
- data/lib/generators/vulcanize/templates/base/config/rubber/common/crontab +22 -0
- data/lib/generators/vulcanize/templates/base/config/rubber/common/monit-postfix.conf +8 -0
- data/lib/generators/vulcanize/templates/base/config/rubber/common/rubber.profile +13 -0
- data/lib/generators/vulcanize/templates/base/config/rubber/deploy-setup.rb +92 -0
- data/lib/generators/vulcanize/templates/base/config/rubber/deploy-util.rb +97 -0
- data/lib/generators/vulcanize/templates/base/config/rubber/rubber-dns.yml +78 -0
- data/lib/generators/vulcanize/templates/base/config/rubber/rubber-rvm.yml +28 -0
- data/lib/generators/vulcanize/templates/base/config/rubber/rubber.yml +235 -0
- data/lib/generators/vulcanize/templates/base/lib/tasks/rubber.rake +15 -0
- data/lib/generators/vulcanize/templates/base/script/cron-rake +18 -0
- data/lib/generators/vulcanize/templates/base/script/cron-runner +18 -0
- data/lib/generators/vulcanize/templates/base/script/cron-sh +67 -0
- data/lib/generators/vulcanize/templates/base/templates.rb +9 -0
- data/lib/generators/vulcanize/templates/base/templates.yml +6 -0
- data/lib/generators/vulcanize/templates/cassandra/config/rubber/deploy-cassandra.rb +88 -0
- data/lib/generators/vulcanize/templates/cassandra/config/rubber/role/cassandra/cassandra.in.sh +60 -0
- data/lib/generators/vulcanize/templates/cassandra/config/rubber/role/cassandra/cassandra.yaml +210 -0
- data/lib/generators/vulcanize/templates/cassandra/config/rubber/role/cassandra/log4j-server.properties +45 -0
- data/lib/generators/vulcanize/templates/cassandra/config/rubber/role/cassandra/monit-cassandra.conf +8 -0
- data/lib/generators/vulcanize/templates/cassandra/config/rubber/rubber-cassandra.yml +18 -0
- data/lib/generators/vulcanize/templates/cassandra/templates.yml +1 -0
- data/lib/generators/vulcanize/templates/complete_mongrel_mysql/config/rubber/role/haproxy/haproxy-mongrel.conf +23 -0
- data/lib/generators/vulcanize/templates/complete_mongrel_mysql/config/rubber/role/nginx/nginx-mongrel.conf +113 -0
- data/lib/generators/vulcanize/templates/complete_mongrel_mysql/config/rubber/rubber-complete.yml +41 -0
- data/lib/generators/vulcanize/templates/complete_mongrel_mysql/templates.yml +6 -0
- data/lib/generators/vulcanize/templates/complete_passenger/config/rubber/role/haproxy/haproxy-passenger.conf +21 -0
- data/lib/generators/vulcanize/templates/complete_passenger/config/rubber/rubber-complete.yml +40 -0
- data/lib/generators/vulcanize/templates/complete_passenger/templates.rb +9 -0
- data/lib/generators/vulcanize/templates/complete_passenger/templates.yml +9 -0
- data/lib/generators/vulcanize/templates/complete_passenger_mysql/templates.yml +4 -0
- data/lib/generators/vulcanize/templates/complete_passenger_postgresql/templates.yml +4 -0
- data/lib/generators/vulcanize/templates/cruise/config/rubber/deploy-cruise.rb +72 -0
- data/lib/generators/vulcanize/templates/cruise/config/rubber/role/cruise/cruise +40 -0
- data/lib/generators/vulcanize/templates/cruise/config/rubber/role/cruise/my.cnf +165 -0
- data/lib/generators/vulcanize/templates/cruise/config/rubber/role/cruise/production.rb +8 -0
- data/lib/generators/vulcanize/templates/cruise/config/rubber/role/cruise/site_config.rb +76 -0
- data/lib/generators/vulcanize/templates/cruise/config/rubber/role/web_tools/cruise-nginx.conf +11 -0
- data/lib/generators/vulcanize/templates/cruise/config/rubber/rubber-cruise.yml +18 -0
- data/lib/generators/vulcanize/templates/cruise/templates.yml +1 -0
- data/lib/generators/vulcanize/templates/haproxy/config/rubber/deploy-haproxy.rb +45 -0
- data/lib/generators/vulcanize/templates/haproxy/config/rubber/role/haproxy/haproxy-base.conf +26 -0
- data/lib/generators/vulcanize/templates/haproxy/config/rubber/role/haproxy/haproxy-default.conf +8 -0
- data/lib/generators/vulcanize/templates/haproxy/config/rubber/role/haproxy/monit-haproxy.conf +9 -0
- data/lib/generators/vulcanize/templates/haproxy/config/rubber/role/haproxy/syslog-haproxy.conf +11 -0
- data/lib/generators/vulcanize/templates/haproxy/config/rubber/role/haproxy/syslogd-default.conf +21 -0
- data/lib/generators/vulcanize/templates/haproxy/config/rubber/role/web_tools/haproxy-nginx.conf +10 -0
- data/lib/generators/vulcanize/templates/haproxy/config/rubber/rubber-haproxy.yml +7 -0
- data/lib/generators/vulcanize/templates/haproxy/templates.yml +1 -0
- data/lib/generators/vulcanize/templates/jetty/config/rubber/deploy-jetty.rb +59 -0
- data/lib/generators/vulcanize/templates/jetty/config/rubber/role/jetty/jetty.sh +589 -0
- data/lib/generators/vulcanize/templates/jetty/config/rubber/role/jetty/jetty.xml +199 -0
- data/lib/generators/vulcanize/templates/jetty/config/rubber/role/jetty/monit-jetty.conf +9 -0
- data/lib/generators/vulcanize/templates/jetty/config/rubber/rubber-jetty.yml +10 -0
- data/lib/generators/vulcanize/templates/jetty/templates.yml +1 -0
- data/lib/generators/vulcanize/templates/memcached/config/memcached.yml +28 -0
- data/lib/generators/vulcanize/templates/memcached/config/rubber/common/memcached.yml +14 -0
- data/lib/generators/vulcanize/templates/memcached/config/rubber/role/memcached/memcached.conf +52 -0
- data/lib/generators/vulcanize/templates/memcached/config/rubber/role/memcached/memcached_munin_plugin +249 -0
- data/lib/generators/vulcanize/templates/memcached/config/rubber/rubber-memcached.yml +7 -0
- data/lib/generators/vulcanize/templates/memcached/templates.yml +1 -0
- data/lib/generators/vulcanize/templates/minimal_mysql/templates.yml +7 -0
- data/lib/generators/vulcanize/templates/minimal_nodb/templates.yml +6 -0
- data/lib/generators/vulcanize/templates/mongrel/config/rubber/deploy-mongrel.rb +75 -0
- data/lib/generators/vulcanize/templates/mongrel/config/rubber/role/mongrel/mongrel_cluster.yml +12 -0
- data/lib/generators/vulcanize/templates/mongrel/config/rubber/role/mongrel/monit-mongrel.conf +20 -0
- data/lib/generators/vulcanize/templates/mongrel/config/rubber/rubber-mongrel.yml +9 -0
- data/lib/generators/vulcanize/templates/mongrel/templates.yml +1 -0
- data/lib/generators/vulcanize/templates/monit/config/rubber/common/monit-default.conf +15 -0
- data/lib/generators/vulcanize/templates/monit/config/rubber/common/monit.conf +252 -0
- data/lib/generators/vulcanize/templates/monit/config/rubber/deploy-monit.rb +33 -0
- data/lib/generators/vulcanize/templates/monit/config/rubber/role/web_tools/monit-admin-nginx.conf +10 -0
- data/lib/generators/vulcanize/templates/monit/config/rubber/rubber-monit.yml +6 -0
- data/lib/generators/vulcanize/templates/monit/templates.yml +1 -0
- data/lib/generators/vulcanize/templates/munin/config/rubber/common/monit-munin.conf +8 -0
- data/lib/generators/vulcanize/templates/munin/config/rubber/common/munin-node.conf +48 -0
- data/lib/generators/vulcanize/templates/munin/config/rubber/common/munin-plugins.conf +11 -0
- data/lib/generators/vulcanize/templates/munin/config/rubber/deploy-munin.rb +46 -0
- data/lib/generators/vulcanize/templates/munin/config/rubber/role/web_tools/munin-nginx.conf +8 -0
- data/lib/generators/vulcanize/templates/munin/config/rubber/role/web_tools/munin-plugins.conf +31 -0
- data/lib/generators/vulcanize/templates/munin/config/rubber/role/web_tools/munin.conf +81 -0
- data/lib/generators/vulcanize/templates/munin/config/rubber/rubber-munin.yml +8 -0
- data/lib/generators/vulcanize/templates/munin/script/munin/example_mysql_query.rb +55 -0
- data/lib/generators/vulcanize/templates/munin/script/munin/example_simple.rb +24 -0
- data/lib/generators/vulcanize/templates/munin/templates.yml +1 -0
- data/lib/generators/vulcanize/templates/mysql/config/rubber/common/database.yml +12 -0
- data/lib/generators/vulcanize/templates/mysql/config/rubber/deploy-mysql.rb +169 -0
- data/lib/generators/vulcanize/templates/mysql/config/rubber/role/db/apparmor-mysql.conf +46 -0
- data/lib/generators/vulcanize/templates/mysql/config/rubber/role/db/crontab +14 -0
- data/lib/generators/vulcanize/templates/mysql/config/rubber/role/db/monit-mysql.cnf +10 -0
- data/lib/generators/vulcanize/templates/mysql/config/rubber/role/db/my.cnf +163 -0
- data/lib/generators/vulcanize/templates/mysql/config/rubber/role/mysql_slave/mysql_slave_munin_plugin +51 -0
- data/lib/generators/vulcanize/templates/mysql/config/rubber/rubber-mysql.yml +47 -0
- data/lib/generators/vulcanize/templates/mysql/templates.yml +1 -0
- data/lib/generators/vulcanize/templates/mysql_cluster/config/rubber/common/mysql_cluster_migrations.rb +13 -0
- data/lib/generators/vulcanize/templates/mysql_cluster/config/rubber/deploy-mysql_cluster.rb +177 -0
- data/lib/generators/vulcanize/templates/mysql_cluster/config/rubber/role/mysql_data/my.cnf +15 -0
- data/lib/generators/vulcanize/templates/mysql_cluster/config/rubber/role/mysql_mgm/ndb_mgmd.cnf +39 -0
- data/lib/generators/vulcanize/templates/mysql_cluster/config/rubber/role/mysql_sql/monit-mysql_cluster_sql.cnf +10 -0
- data/lib/generators/vulcanize/templates/mysql_cluster/config/rubber/role/mysql_sql/my.cnf +23 -0
- data/lib/generators/vulcanize/templates/mysql_cluster/config/rubber/rubber-mysql_cluster.yml +32 -0
- data/lib/generators/vulcanize/templates/mysql_cluster/templates.yml +1 -0
- data/lib/generators/vulcanize/templates/mysql_proxy/config/rubber/common/database.yml +16 -0
- data/lib/generators/vulcanize/templates/mysql_proxy/config/rubber/common/monit-mysql_proxy.cnf +10 -0
- data/lib/generators/vulcanize/templates/mysql_proxy/config/rubber/common/mysql-proxy +153 -0
- data/lib/generators/vulcanize/templates/mysql_proxy/config/rubber/common/mysql-proxy.conf +10 -0
- data/lib/generators/vulcanize/templates/mysql_proxy/config/rubber/common/mysql-proxy.lua +5 -0
- data/lib/generators/vulcanize/templates/mysql_proxy/config/rubber/deploy-mysql_proxy.rb +52 -0
- data/lib/generators/vulcanize/templates/mysql_proxy/config/rubber/rubber-mysql_proxy.yml +11 -0
- data/lib/generators/vulcanize/templates/mysql_proxy/templates.yml +1 -0
- data/lib/generators/vulcanize/templates/nginx/config/rubber/deploy-nginx.rb +45 -0
- data/lib/generators/vulcanize/templates/nginx/config/rubber/role/nginx/crontab +9 -0
- data/lib/generators/vulcanize/templates/nginx/config/rubber/role/nginx/monit-nginx.conf +8 -0
- data/lib/generators/vulcanize/templates/nginx/config/rubber/role/nginx/nginx.conf +42 -0
- data/lib/generators/vulcanize/templates/nginx/config/rubber/role/web_tools/nginx-tools.conf +55 -0
- data/lib/generators/vulcanize/templates/nginx/config/rubber/role/web_tools/tools-index.html +30 -0
- data/lib/generators/vulcanize/templates/nginx/config/rubber/role/web_tools/tools-nginx.auth +7 -0
- data/lib/generators/vulcanize/templates/nginx/config/rubber/rubber-nginx.yml +10 -0
- data/lib/generators/vulcanize/templates/nginx/templates.yml +1 -0
- data/lib/generators/vulcanize/templates/passenger/config/rubber/deploy-passenger.rb +46 -0
- data/lib/generators/vulcanize/templates/passenger/config/rubber/role/passenger/munin-passenger-memory.conf +34 -0
- data/lib/generators/vulcanize/templates/passenger/config/rubber/role/passenger/munin-passenger-sudoers.conf +7 -0
- data/lib/generators/vulcanize/templates/passenger/config/rubber/role/passenger/munin-passenger.conf +47 -0
- data/lib/generators/vulcanize/templates/passenger/config/rubber/role/passenger/passenger-apache-vhost.conf +46 -0
- data/lib/generators/vulcanize/templates/passenger/config/rubber/role/passenger/passenger.conf +35 -0
- data/lib/generators/vulcanize/templates/passenger/config/rubber/rubber-passenger.yml +15 -0
- data/lib/generators/vulcanize/templates/passenger/templates.yml +3 -0
- data/lib/generators/vulcanize/templates/postgresql/config/rubber/common/database.yml +12 -0
- data/lib/generators/vulcanize/templates/postgresql/config/rubber/deploy-postgresql.rb +131 -0
- data/lib/generators/vulcanize/templates/postgresql/config/rubber/role/db/crontab +14 -0
- data/lib/generators/vulcanize/templates/postgresql/config/rubber/role/db/monit-postgresql.conf +10 -0
- data/lib/generators/vulcanize/templates/postgresql/config/rubber/role/db/pg_hba.conf +89 -0
- data/lib/generators/vulcanize/templates/postgresql/config/rubber/role/db/postgresql-sysctl.conf +6 -0
- data/lib/generators/vulcanize/templates/postgresql/config/rubber/role/db/postgresql.conf +504 -0
- data/lib/generators/vulcanize/templates/postgresql/config/rubber/rubber-postgresql.yml +45 -0
- data/lib/generators/vulcanize/templates/postgresql/templates.yml +1 -0
- data/lib/generators/vulcanize/templates/redis/config/rubber/deploy-redis.rb +37 -0
- data/lib/generators/vulcanize/templates/redis/config/rubber/role/redis/crontab +8 -0
- data/lib/generators/vulcanize/templates/redis/config/rubber/role/redis/monit-redis.conf +9 -0
- data/lib/generators/vulcanize/templates/redis/config/rubber/role/redis/redis.conf +141 -0
- data/lib/generators/vulcanize/templates/redis/config/rubber/rubber-redis.yml +4 -0
- data/lib/generators/vulcanize/templates/redis/templates.yml +1 -0
- data/lib/generators/vulcanize/templates/resque/config/initializers/resque.rb +15 -0
- data/lib/generators/vulcanize/templates/resque/config/rubber/common/resque.yml +5 -0
- data/lib/generators/vulcanize/templates/resque/config/rubber/deploy-resque.rb +58 -0
- data/lib/generators/vulcanize/templates/resque/config/rubber/role/resque_web/monit-resque_web.conf +14 -0
- data/lib/generators/vulcanize/templates/resque/config/rubber/role/resque_worker/monit-resque_worker.conf +19 -0
- data/lib/generators/vulcanize/templates/resque/config/rubber/rubber-resque.yml +18 -0
- data/lib/generators/vulcanize/templates/resque/script/resque_worker_management.rb +112 -0
- data/lib/generators/vulcanize/templates/resque/templates.rb +1 -0
- data/lib/generators/vulcanize/templates/resque/templates.yml +3 -0
- data/lib/generators/vulcanize/templates/sphinx/config/rubber/common/sphinx.yml +46 -0
- data/lib/generators/vulcanize/templates/sphinx/config/rubber/deploy-sphinx.rb +112 -0
- data/lib/generators/vulcanize/templates/sphinx/config/rubber/role/sphinx/crontab +11 -0
- data/lib/generators/vulcanize/templates/sphinx/config/rubber/role/sphinx/monit-sphinx.conf +13 -0
- data/lib/generators/vulcanize/templates/sphinx/config/rubber/rubber-sphinx.yml +6 -0
- data/lib/generators/vulcanize/templates/sphinx/templates.yml +1 -0
- data/lib/generators/vulcanize/vulcanize_generator.rb +184 -0
- data/lib/rubber.rb +43 -7
- data/lib/rubber/cloud/aws.rb +38 -4
- data/lib/rubber/dns/base.rb +41 -26
- data/lib/rubber/dns/dyndns.rb +25 -10
- data/lib/rubber/dns/nettica.rb +90 -29
- data/lib/rubber/dns/zerigo.rb +90 -96
- data/lib/rubber/environment.rb +26 -10
- data/lib/rubber/generator.rb +33 -25
- data/lib/rubber/instance.rb +12 -1
- data/lib/rubber/railtie.rb +14 -0
- data/lib/rubber/recipes/rubber.rb +16 -9
- data/lib/rubber/recipes/rubber/deploy.rb +3 -3
- data/lib/rubber/recipes/rubber/instances.rb +73 -8
- data/lib/rubber/recipes/rubber/security_groups.rb +1 -1
- data/lib/rubber/recipes/rubber/setup.rb +245 -96
- data/lib/rubber/recipes/rubber/spot_requests.rb +23 -0
- data/lib/rubber/recipes/rubber/static_ips.rb +83 -0
- data/lib/rubber/recipes/rubber/utils.rb +41 -18
- data/lib/rubber/recipes/rubber/volumes.rb +4 -4
- data/lib/rubber/tasks/rubber.rb +64 -6
- data/lib/rubber/util.rb +36 -1
- data/rails/init.rb +6 -0
- data/test/environment_test.rb +27 -1
- data/test/generator_test.rb +52 -5
- data/test/instance_test.rb +4 -1
- data/test/test_helper.rb +10 -0
- data/test/util_test.rb +4 -1
- data/test/zerigo_test.rb +88 -0
- metadata +309 -49
- data/generators/vulcanize/templates/base/config/rubber/common/profile.rc +0 -9
@@ -80,6 +80,89 @@ namespace :rubber do
|
|
80
80
|
destroy_static_ip(ip)
|
81
81
|
end
|
82
82
|
|
83
|
+
desc 'Move a static IP address from DONOR machine to RECEIVER machine.'
|
84
|
+
task :move_static_ip do
|
85
|
+
donor_alias = get_env 'DONOR', 'Instance alias to get the IP from (e.g., web01)', true
|
86
|
+
receiver_alias = get_env 'RECEIVER', 'Instance alias to assign the IP to (e.g., web02)', true
|
87
|
+
|
88
|
+
# Sanity checks
|
89
|
+
donor = rubber_instances[donor_alias]
|
90
|
+
fatal "Instance does not exist: #{donor_alias}" unless donor
|
91
|
+
|
92
|
+
static_ip = donor.static_ip
|
93
|
+
fatal 'No static IP address to move exists' unless static_ip && static_ip != ''
|
94
|
+
|
95
|
+
receiver = rubber_instances[receiver_alias]
|
96
|
+
fatal "Instance does not exist: #{receiver_alias}" unless receiver
|
97
|
+
|
98
|
+
# Temporary removal of the instances.
|
99
|
+
old_donor = rubber_instances.remove(donor_alias)
|
100
|
+
old_receiver = rubber_instances.remove(receiver_alias)
|
101
|
+
|
102
|
+
rubber_instances.save
|
103
|
+
|
104
|
+
# Getting rid of alias->IP mappings and SSH's known_hosts records.
|
105
|
+
load_roles
|
106
|
+
setup_aliases
|
107
|
+
cleanup_known_hosts(old_donor)
|
108
|
+
cleanup_known_hosts(old_receiver)
|
109
|
+
|
110
|
+
# Detachment of EIPA.
|
111
|
+
success = cloud.detach_static_ip(static_ip)
|
112
|
+
fatal "Failed to detach static IP address #{static_ip}" unless success
|
113
|
+
rubber_instances.artifacts['static_ips'].delete(old_donor.name)
|
114
|
+
|
115
|
+
rubber_instances.save
|
116
|
+
|
117
|
+
# Attachment of EIPA.
|
118
|
+
success = cloud.attach_static_ip(static_ip, old_receiver.instance_id)
|
119
|
+
fatal "Failed to associate static IP address #{static_ip}" unless success
|
120
|
+
|
121
|
+
print "Waiting for #{receiver_alias} to get the address"
|
122
|
+
while true do
|
123
|
+
print '.'
|
124
|
+
sleep 3
|
125
|
+
instance = cloud.describe_instances(old_receiver.instance_id).first
|
126
|
+
break if instance[:external_ip] == static_ip
|
127
|
+
end
|
128
|
+
|
129
|
+
# Partial cleanup of static IP records.
|
130
|
+
rubber_instances.artifacts['static_ips'][old_receiver.name] = static_ip
|
131
|
+
|
132
|
+
rubber_instances.save
|
133
|
+
|
134
|
+
# First half of the sync.
|
135
|
+
new_receiver = Rubber::Configuration::InstanceItem.new(old_receiver.name,
|
136
|
+
old_receiver.domain, old_receiver.roles, old_receiver.instance_id,
|
137
|
+
old_receiver.security_groups)
|
138
|
+
new_receiver.static_ip = static_ip
|
139
|
+
rubber_instances.add(new_receiver)
|
140
|
+
|
141
|
+
rubber_instances.save
|
142
|
+
|
143
|
+
refresh_instance(receiver_alias)
|
144
|
+
|
145
|
+
print "Waiting for #{donor_alias} to get a new address"
|
146
|
+
while true do
|
147
|
+
print '.'
|
148
|
+
sleep 3
|
149
|
+
instance = cloud.describe_instances(old_donor.instance_id).first
|
150
|
+
break if instance[:external_ip] && instance[:external_ip] != ''
|
151
|
+
end
|
152
|
+
|
153
|
+
# Second half of the sync.
|
154
|
+
new_donor = Rubber::Configuration::InstanceItem.new(old_donor.name,
|
155
|
+
old_donor.domain, old_donor.roles, old_donor.instance_id,
|
156
|
+
old_donor.security_groups)
|
157
|
+
rubber_instances.add(new_donor)
|
158
|
+
|
159
|
+
rubber_instances.save
|
160
|
+
|
161
|
+
refresh_instance(donor_alias)
|
162
|
+
|
163
|
+
logger.info "Run 'cap rubber:describe_static_ips' to check the allocated ones"
|
164
|
+
end
|
165
|
+
|
83
166
|
def allocate_static_ip()
|
84
167
|
ip = cloud.create_static_ip()
|
85
168
|
fatal "Failed to allocate static ip" if ip.nil?
|
@@ -16,23 +16,26 @@ namespace :rubber do
|
|
16
16
|
default_roles = rubber_env.staging_roles || "*"
|
17
17
|
roles = ENV['ROLES'] = rubber.get_env("ROLES", "Roles to use for staging instance", true, default_roles)
|
18
18
|
|
19
|
-
# some bootstraps update code (bootstrap_db) but if you don't have that role, need to do it here
|
20
|
-
# Since release directory variable gets reused by cap, we have to just do the symlink here - doing
|
21
|
-
# a update again will fail
|
22
|
-
set :rubber_code_was_updated, false
|
23
|
-
after "deploy:update_code" do
|
24
|
-
set :rubber_code_was_updated, true
|
25
|
-
end
|
26
|
-
|
27
19
|
if rubber_instances[instance_alias]
|
28
20
|
logger.info "Instance already exists, skipping to bootstrap"
|
29
21
|
else
|
30
22
|
rubber.create
|
31
23
|
end
|
24
|
+
|
25
|
+
# stop everything before so monit doesn't start stuff during bootstrapping
|
26
|
+
# if its already installed due to a bundled instance
|
27
|
+
deploy.stop rescue nil
|
28
|
+
|
32
29
|
rubber.bootstrap
|
33
|
-
|
30
|
+
|
31
|
+
# stop everything after in case package upgrades during bootstrap start up
|
32
|
+
# services - we should be able to safely do a deploy:start below
|
34
33
|
deploy.stop rescue nil
|
35
|
-
|
34
|
+
|
35
|
+
# some bootstraps update code (bootstrap_db) but if you don't have that role, need to do it here
|
36
|
+
# Since release directory variable gets reused by cap, we have to just do the symlink here - doing
|
37
|
+
# a update again will fail
|
38
|
+
if ! fetch(:rubber_code_was_updated, false)
|
36
39
|
deploy.update_code
|
37
40
|
end
|
38
41
|
deploy.symlink
|
@@ -105,8 +108,8 @@ namespace :rubber do
|
|
105
108
|
slices = []
|
106
109
|
servers.each do |rolename, svrs|
|
107
110
|
next if svrs.size == 0
|
108
|
-
# figure out size of each slice by
|
109
|
-
slice_size = svrs.size / (options.delete(:groups) || 2)
|
111
|
+
# figure out size of each slice by dividing server count by # of groups
|
112
|
+
slice_size = (Float(svrs.size) / (options.delete(:groups) || 2)).round
|
110
113
|
slice_size = 1 if slice_size == 0
|
111
114
|
slice_idx = 0
|
112
115
|
svrs.each_slice(slice_size) do |srv_slice|
|
@@ -147,22 +150,30 @@ namespace :rubber do
|
|
147
150
|
return local_alias
|
148
151
|
end
|
149
152
|
|
150
|
-
def prepare_script(name, contents)
|
153
|
+
def prepare_script(name, contents, stop_on_error_cmd=rubber_env.stop_on_error_cmd)
|
151
154
|
script = "/tmp/#{name}"
|
152
155
|
# this lets us abort a script if a command in the middle of it errors out
|
153
|
-
contents = "#{
|
156
|
+
contents = "#{stop_on_error_cmd}\n#{contents}" if stop_on_error_cmd
|
154
157
|
put(contents, script)
|
155
158
|
return script
|
156
159
|
end
|
157
160
|
|
158
|
-
def run_script(name, contents)
|
161
|
+
def run_script(name, contents, opts = {})
|
162
|
+
args = opts.delete(:script_args)
|
159
163
|
script = prepare_script(name, contents)
|
160
|
-
run "
|
164
|
+
run "bash #{script} #{args}", opts
|
161
165
|
end
|
162
166
|
|
163
|
-
def sudo_script(name, contents)
|
167
|
+
def sudo_script(name, contents, opts = {})
|
168
|
+
args = opts.delete(:script_args)
|
164
169
|
script = prepare_script(name, contents)
|
165
|
-
|
170
|
+
run "#{sudo} bash -l #{script} #{args}", opts
|
171
|
+
end
|
172
|
+
|
173
|
+
def top.rsudo(command, opts = {}, &block)
|
174
|
+
user = opts.delete(:as)
|
175
|
+
args = "-H -u #{user}" if user
|
176
|
+
run "#{sudo opts} #{args} bash -l -c '#{command}'", opts, &block
|
166
177
|
end
|
167
178
|
|
168
179
|
def get_env(name, desc, required=false, default=nil)
|
@@ -200,4 +211,16 @@ namespace :rubber do
|
|
200
211
|
return opts
|
201
212
|
end
|
202
213
|
|
214
|
+
# some bootstraps update code (bootstrap_db), so keep track so we don't do it multiple times
|
215
|
+
after "deploy:update_code" do
|
216
|
+
set :rubber_code_was_updated, true
|
217
|
+
end
|
218
|
+
|
219
|
+
def update_code_for_bootstrap
|
220
|
+
unless (fetch(:rubber_code_was_updated, false))
|
221
|
+
deploy.setup
|
222
|
+
deploy.update_code
|
223
|
+
end
|
224
|
+
end
|
225
|
+
|
203
226
|
end
|
@@ -104,7 +104,7 @@ namespace :rubber do
|
|
104
104
|
if vol_spec['mount'] && vol_spec['filesystem']
|
105
105
|
# then format/mount/etc if we don't have an entry in hosts file
|
106
106
|
task :_setup_volume, :hosts => ic.external_ip do
|
107
|
-
rubber.
|
107
|
+
rubber.sudo_script 'setup_volume', <<-ENDSCRIPT
|
108
108
|
if ! grep -q '#{vol_spec['mount']}' /etc/fstab; then
|
109
109
|
if mount | grep -q '#{vol_spec['mount']}'; then
|
110
110
|
umount '#{vol_spec['mount']}'
|
@@ -135,7 +135,7 @@ namespace :rubber do
|
|
135
135
|
if ! ic.partitions.include?(part_id)
|
136
136
|
# then format/mount/etc if we don't have an entry in hosts file
|
137
137
|
task :_setup_partition, :hosts => ic.external_ip do
|
138
|
-
rubber.
|
138
|
+
rubber.sudo_script 'setup_partition', <<-ENDSCRIPT
|
139
139
|
if ! fdisk -l 2>&1 | grep -q '#{partition_spec['partition_device']}'; then
|
140
140
|
if grep -q '#{partition_spec['disk_device']}\\b' /etc/fstab; then
|
141
141
|
umount #{partition_spec['disk_device']}
|
@@ -175,7 +175,7 @@ namespace :rubber do
|
|
175
175
|
end
|
176
176
|
# then format/mount/etc if we don't have an entry in hosts file
|
177
177
|
task :_zero_partitions, :hosts => ic.external_ip do
|
178
|
-
rubber.
|
178
|
+
rubber.sudo_script 'zero_partitions', <<-ENDSCRIPT
|
179
179
|
# zero out parition for performance (see amazon DevGuide)
|
180
180
|
echo "Zeroing out raid partitions to improve performance, this way take a while"
|
181
181
|
#{zero_script}
|
@@ -200,7 +200,7 @@ namespace :rubber do
|
|
200
200
|
end
|
201
201
|
|
202
202
|
task :_setup_raid_volume, :hosts => ic.external_ip do
|
203
|
-
rubber.
|
203
|
+
rubber.sudo_script 'setup_raid_volume', <<-ENDSCRIPT
|
204
204
|
if ! grep -q '#{raid_spec['device']}' /etc/fstab; then
|
205
205
|
if mount | grep -q '#{raid_spec['mount']}'; then
|
206
206
|
umount '#{raid_spec['mount']}'
|
data/lib/rubber/tasks/rubber.rb
CHANGED
@@ -98,11 +98,70 @@ namespace :rubber do
|
|
98
98
|
end
|
99
99
|
end
|
100
100
|
|
101
|
+
|
102
|
+
desc <<-DESC
|
103
|
+
Backup database to given backup directory
|
104
|
+
The following arguments affect behavior:
|
105
|
+
BACKUP_DIR (required): Directory where backups will be stored
|
106
|
+
BACKUP_NAME (required): What to name the backup
|
107
|
+
BACKUP_CMD (required): Command used to backup
|
108
|
+
BACKUP_AGE (3): Delete rotated logs older than this many days in the past
|
109
|
+
DESC
|
110
|
+
task :backup do
|
111
|
+
dir = get_env('BACKUP_DIR', true)
|
112
|
+
name = get_env('BACKUP_NAME', true)
|
113
|
+
cmd = get_env('BACKUP_CMD', true)
|
114
|
+
age = (get_env('BACKUP_AGE') || 3).to_i
|
115
|
+
|
116
|
+
time_stamp = Time.now.strftime("%Y-%m-%d_%H-%M")
|
117
|
+
FileUtils.mkdir_p(dir)
|
118
|
+
|
119
|
+
backup_cmd = cmd.gsub(/%([^%]+)%/, '#{\1}')
|
120
|
+
backup_cmd = eval('%Q{' + backup_cmd + '}')
|
121
|
+
|
122
|
+
puts "Backing up with command:"
|
123
|
+
sh backup_cmd
|
124
|
+
puts "Backup created"
|
125
|
+
|
126
|
+
s3_prefix = "#{name}/"
|
127
|
+
backup_bucket = cloud_provider.backup_bucket
|
128
|
+
if backup_bucket
|
129
|
+
init_s3
|
130
|
+
unless AWS::S3::Bucket.list.find { |b| b.name == backup_bucket }
|
131
|
+
AWS::S3::Bucket.create(backup_bucket)
|
132
|
+
end
|
133
|
+
newest = Dir.entries(dir).grep(/^[^.]/).sort_by {|f| File.mtime(File.join(dir,f))}.last
|
134
|
+
dest = "#{s3_prefix}#{newest}"
|
135
|
+
puts "Saving backup to S3: #{backup_bucket}:#{dest}"
|
136
|
+
AWS::S3::S3Object.store(dest, open(File.join(dir, newest)), backup_bucket)
|
137
|
+
end
|
138
|
+
|
139
|
+
tdate = Date.today - age
|
140
|
+
threshold = Time.local(tdate.year, tdate.month, tdate.day)
|
141
|
+
puts "Cleaning backups older than #{age} days"
|
142
|
+
Dir["#{dir}/*"].each do |file|
|
143
|
+
if File.mtime(file) < threshold
|
144
|
+
puts "Deleting #{file}"
|
145
|
+
FileUtils.rm_f(file)
|
146
|
+
end
|
147
|
+
end
|
148
|
+
|
149
|
+
if backup_bucket
|
150
|
+
puts "Cleaning S3 backups older than #{age} days from: #{backup_bucket}:#{s3_prefix}"
|
151
|
+
AWS::S3::Bucket.objects(backup_bucket, :prefix => s3_prefix).clone.each do |obj|
|
152
|
+
if Time.parse(obj.about["last-modified"]) < threshold
|
153
|
+
puts "Deleting #{obj.key}"
|
154
|
+
obj.delete
|
155
|
+
end
|
156
|
+
end
|
157
|
+
end
|
158
|
+
end
|
159
|
+
|
101
160
|
desc <<-DESC
|
102
161
|
Backup database to given backup directory
|
103
162
|
The following arguments affect behavior:
|
104
163
|
BACKUP_DIR (required): Directory where db backups will be stored
|
105
|
-
BACKUP_AGE (
|
164
|
+
BACKUP_AGE (3): Delete rotated logs older than this many days in the past
|
106
165
|
DBUSER (required) User to connect to the db as
|
107
166
|
DBPASS (optional): Pass to connect to the db with
|
108
167
|
DBHOST (required): Host where the db is
|
@@ -120,15 +179,15 @@ namespace :rubber do
|
|
120
179
|
pass = nil if pass.strip.size == 0
|
121
180
|
host = get_env('DBHOST', true)
|
122
181
|
name = get_env('DBNAME', true)
|
123
|
-
|
182
|
+
|
124
183
|
raise "No db_backup_cmd defined in rubber.yml, cannot backup!" unless rubber_env.db_backup_cmd
|
125
184
|
db_backup_cmd = rubber_env.db_backup_cmd.gsub(/%([^%]+)%/, '#{\1}')
|
126
185
|
db_backup_cmd = eval('%Q{' + db_backup_cmd + '}')
|
127
|
-
|
186
|
+
|
128
187
|
puts "Backing up database with command:"
|
129
188
|
sh db_backup_cmd
|
130
189
|
puts "Created backup: #{backup_file}"
|
131
|
-
|
190
|
+
|
132
191
|
s3_prefix = "db/"
|
133
192
|
backup_bucket = cloud_provider.backup_bucket
|
134
193
|
if backup_bucket
|
@@ -150,7 +209,7 @@ namespace :rubber do
|
|
150
209
|
FileUtils.rm_f(file)
|
151
210
|
end
|
152
211
|
end
|
153
|
-
|
212
|
+
|
154
213
|
if backup_bucket
|
155
214
|
puts "Cleaning S3 backups older than #{age} days from: #{backup_bucket}:#{s3_prefix}"
|
156
215
|
AWS::S3::Bucket.objects(backup_bucket, :prefix => s3_prefix).clone.each do |obj|
|
@@ -211,7 +270,6 @@ namespace :rubber do
|
|
211
270
|
|
212
271
|
end
|
213
272
|
|
214
|
-
|
215
273
|
def get_env(name, required=false)
|
216
274
|
value = ENV[name]
|
217
275
|
raise("#{name} is required, pass using environment") if required && ! value
|
data/lib/rubber/util.rb
CHANGED
@@ -30,8 +30,43 @@ module Rubber
|
|
30
30
|
end
|
31
31
|
|
32
32
|
def self.is_rails?
|
33
|
-
File.exist?(File.join(RUBBER_ROOT, 'config', '
|
33
|
+
File.exist?(File.join(RUBBER_ROOT, 'config', 'boot.rb'))
|
34
34
|
end
|
35
35
|
|
36
|
+
def self.is_rails2?
|
37
|
+
defined?(Rails) && defined?(Rails::VERSION) && Rails::VERSION::MAJOR == 2
|
38
|
+
end
|
39
|
+
|
40
|
+
def self.is_rails3?
|
41
|
+
defined?(Rails) && defined?(Rails::VERSION) && Rails::VERSION::MAJOR == 3
|
42
|
+
end
|
43
|
+
|
44
|
+
def self.is_bundler?
|
45
|
+
File.exist?(File.join(RUBBER_ROOT, 'Gemfile'))
|
46
|
+
end
|
47
|
+
|
48
|
+
def self.rubber_as_plugin?
|
49
|
+
File.exist?(File.join(RUBBER_ROOT, 'vendor/plugins/rubber'))
|
50
|
+
end
|
51
|
+
|
52
|
+
def self.prompt(name, desc, required=false, default=nil)
|
53
|
+
value = ENV.delete(name)
|
54
|
+
msg = "#{desc}"
|
55
|
+
msg << " [#{default}]" if default
|
56
|
+
msg << ": "
|
57
|
+
unless value
|
58
|
+
print msg
|
59
|
+
value = gets
|
60
|
+
end
|
61
|
+
value = value.size == 0 ? default : value
|
62
|
+
self.fatal "#{name} is required, pass using environment or enter at prompt" if required && ! value
|
63
|
+
return value
|
64
|
+
end
|
65
|
+
|
66
|
+
def self.fatal(msg, code=1)
|
67
|
+
puts msg
|
68
|
+
exit code
|
69
|
+
end
|
70
|
+
|
36
71
|
end
|
37
72
|
end
|
data/rails/init.rb
ADDED
data/test/environment_test.rb
CHANGED
@@ -1,6 +1,9 @@
|
|
1
|
+
require 'rubygems'
|
2
|
+
gem 'test-unit'
|
3
|
+
|
1
4
|
require 'test/unit'
|
2
5
|
require 'tempfile'
|
3
|
-
require 'test_helper'
|
6
|
+
require File.expand_path(File.join(__FILE__, '..', 'test_helper'))
|
4
7
|
|
5
8
|
class EnvironmentTest < Test::Unit::TestCase
|
6
9
|
include Rubber::Configuration
|
@@ -39,6 +42,14 @@ class EnvironmentTest < Test::Unit::TestCase
|
|
39
42
|
assert_equal 'host1val2', e.var2, 'env not retrieving right val for method missing'
|
40
43
|
end
|
41
44
|
|
45
|
+
def test_host_override
|
46
|
+
env = Rubber::Configuration::Environment.new("#{File.dirname(__FILE__)}/fixtures/basic")
|
47
|
+
e = env.bind('norole', 'host2')
|
48
|
+
assert_equal 'host2val3', e['var3'], 'env not retrieving right val'
|
49
|
+
assert_equal %w[host2val4a host2val4b], e['var4'], 'env not retrieving right val'
|
50
|
+
assert_equal [{'var51a' => 'val51a', 'var52a' => 'val52a'}, {'var53' => 'val53'}, {'var54' => 'val54'}], e['var5'], 'env not retrieving right val'
|
51
|
+
end
|
52
|
+
|
42
53
|
def test_combine
|
43
54
|
env = Rubber::Configuration::Environment
|
44
55
|
assert_equal "new", env.combine("old", "new"), "Last should win for scalar combine"
|
@@ -115,4 +126,19 @@ class EnvironmentTest < Test::Unit::TestCase
|
|
115
126
|
assert_equal 'val5', e.var2.var9, 'env not retrieving right val'
|
116
127
|
end
|
117
128
|
|
129
|
+
def test_instances_in_expansion
|
130
|
+
instance = InstanceItem.new('host1', 'domain.com', [RoleItem.new('role1')], '')
|
131
|
+
instance.external_ip = "1.2.3.4"
|
132
|
+
instances = Instance.new(Tempfile.new('testforinstanceexpansion').path)
|
133
|
+
instances.add(instance)
|
134
|
+
|
135
|
+
File.expects(:exist?).returns(true)
|
136
|
+
YAML.expects(:load_file).returns({'var1' =>'"#{rubber_instances.for_role("role1").first.external_ip}"'})
|
137
|
+
Rubber::Configuration.expects(:rubber_instances).returns(instances)
|
138
|
+
env = Rubber::Configuration::Environment.new(nil)
|
139
|
+
e = env.bind()
|
140
|
+
|
141
|
+
assert_equal "\"1.2.3.4\"", e['var1']
|
142
|
+
end
|
143
|
+
|
118
144
|
end
|
data/test/generator_test.rb
CHANGED
@@ -1,6 +1,9 @@
|
|
1
|
+
require 'rubygems'
|
2
|
+
gem 'test-unit'
|
3
|
+
|
1
4
|
require 'test/unit'
|
2
5
|
require 'tempfile'
|
3
|
-
require 'test_helper'
|
6
|
+
require File.expand_path(File.join(__FILE__, '..', 'test_helper'))
|
4
7
|
|
5
8
|
class GeneratorTest < Test::Unit::TestCase
|
6
9
|
include Rubber::Configuration
|
@@ -90,6 +93,14 @@ class GeneratorTest < Test::Unit::TestCase
|
|
90
93
|
assert ! File.exists?(post_file), "post should not have been executed as dest file unchanged"
|
91
94
|
assert_equal "hello", File.read(out_file.path).strip, "transformed contents are incorrect"
|
92
95
|
|
96
|
+
FileUtils.rm_f(post_file)
|
97
|
+
gen = Generator.new(nil, nil, nil)
|
98
|
+
gen.force = true
|
99
|
+
gen.transform(src)
|
100
|
+
assert File.exists?(out_file.path), "transform did not generate an output file"
|
101
|
+
assert File.exists?(post_file), "forced transform did not execute post"
|
102
|
+
assert_equal "hello", File.read(out_file.path).strip, "transformed contents are incorrect"
|
103
|
+
|
93
104
|
FileUtils.rm_f(post_file)
|
94
105
|
gen = Generator.new(nil, nil, nil)
|
95
106
|
gen.no_post = true
|
@@ -175,7 +186,7 @@ class GeneratorTest < Test::Unit::TestCase
|
|
175
186
|
hello
|
176
187
|
SRC
|
177
188
|
|
178
|
-
assert_raises
|
189
|
+
assert_raises do
|
179
190
|
Generator.new(nil, nil, nil).transform(src)
|
180
191
|
end
|
181
192
|
|
@@ -221,7 +232,7 @@ class GeneratorTest < Test::Unit::TestCase
|
|
221
232
|
FileUtils.rm_rf(out_dir)
|
222
233
|
assert ! File.exists?(out_dir)
|
223
234
|
|
224
|
-
g = Generator.new("#{File.dirname(__FILE__)}/fixtures/basic", ['role1'],
|
235
|
+
g = Generator.new("#{File.dirname(__FILE__)}/fixtures/basic", ['role1'], 'host1', :out_dir => out_dir)
|
225
236
|
g.run()
|
226
237
|
assert File.directory?(out_dir), "scoped transform did not create dir"
|
227
238
|
assert_equal ['bar.conf', 'foo.conf'], list_dir(out_dir), "scoped transform did not create correct files"
|
@@ -232,12 +243,12 @@ class GeneratorTest < Test::Unit::TestCase
|
|
232
243
|
FileUtils.rm_rf(out_dir)
|
233
244
|
end
|
234
245
|
|
235
|
-
def
|
246
|
+
def test_ordering_of_additive
|
236
247
|
out_dir = "#{Dir::tmpdir}/test_rubber_ordering"
|
237
248
|
FileUtils.rm_rf(out_dir)
|
238
249
|
assert ! File.exists?(out_dir)
|
239
250
|
|
240
|
-
g = Generator.new("#{File.dirname(__FILE__)}/fixtures/generator_order", ['role2', 'role1'],
|
251
|
+
g = Generator.new("#{File.dirname(__FILE__)}/fixtures/generator_order", ['role2', 'role1'], 'host1', :out_dir => out_dir)
|
241
252
|
g.run()
|
242
253
|
assert File.directory?(out_dir), "transform did not create dir"
|
243
254
|
assert_equal ['out.conf'], list_dir(out_dir), "transform did not create correct file"
|
@@ -320,4 +331,40 @@ def test_file_pattern
|
|
320
331
|
Generator.new(nil, nil, nil).transform(src)
|
321
332
|
assert ! File.exists?(out_file.path), "transform didn't skip generation of an output file"
|
322
333
|
end
|
334
|
+
|
335
|
+
def test_backup
|
336
|
+
out_file = Tempfile.new('testbak')
|
337
|
+
assert ! File.exists?("#{out_file.path}.bak")
|
338
|
+
File.open(out_file.path, 'w') {|f| f.write("howdy")}
|
339
|
+
|
340
|
+
src = <<-SRC
|
341
|
+
<%
|
342
|
+
@path = '#{out_file.path}'
|
343
|
+
%>
|
344
|
+
hello <%= Time.now.to_f %>
|
345
|
+
SRC
|
346
|
+
|
347
|
+
Generator.new(nil, nil, nil).transform(src)
|
348
|
+
|
349
|
+
assert File.exists?("#{out_file.path}.bak"), "transform didn't generate backup"
|
350
|
+
assert_match /howdy/, File.read("#{out_file.path}.bak"), "transform backup has wrong contents"
|
351
|
+
end
|
352
|
+
|
353
|
+
def test_no_backup
|
354
|
+
out_file = Tempfile.new('testnobak')
|
355
|
+
assert ! File.exists?("#{out_file.path}.bak")
|
356
|
+
File.open(out_file.path, 'w') {|f| f.write("howdy")}
|
357
|
+
src = <<-SRC
|
358
|
+
<%
|
359
|
+
@path = '#{out_file.path}'
|
360
|
+
@backup = false
|
361
|
+
%>
|
362
|
+
hello <%= Time.now.to_f %>
|
363
|
+
SRC
|
364
|
+
|
365
|
+
Generator.new(nil, nil, nil).transform(src)
|
366
|
+
|
367
|
+
assert ! File.exists?("#{out_file.path}.bak"), "transform shouldn't generate backup"
|
368
|
+
end
|
369
|
+
|
323
370
|
end
|