axtro-rubber 1.2.3 → 1.5.7
Sign up to get free protection for your applications and to get access to all the features.
- data/CHANGELOG +210 -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 +29 -16
- data/generators/vulcanize/templates/apache/config/rubber/role/web_tools/tools-index.html +1 -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 +6 -1
- data/generators/vulcanize/templates/base/config/rubber/common/monit-postfix.conf +2 -2
- data/generators/vulcanize/templates/base/config/rubber/common/rubber.profile +3 -4
- data/generators/vulcanize/templates/base/config/rubber/deploy-setup.rb +56 -48
- data/generators/vulcanize/templates/base/config/rubber/deploy-util.rb +97 -0
- data/generators/vulcanize/templates/base/config/rubber/rubber-dns.yml +0 -1
- data/generators/vulcanize/templates/base/config/rubber/rubber-rvm.yml +28 -0
- data/generators/vulcanize/templates/base/config/rubber/rubber.yml +8 -13
- 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 +2 -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 +5 -5
- 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/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 +4 -2
- 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 +43 -8
- 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 +1 -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/crontab +1 -1
- data/generators/vulcanize/templates/nginx/config/rubber/role/nginx/monit-nginx.conf +2 -2
- data/generators/vulcanize/templates/passenger/config/rubber/deploy-passenger.rb +10 -1
- data/generators/vulcanize/templates/passenger/config/rubber/role/passenger/munin-passenger-memory.conf +1 -1
- data/generators/vulcanize/templates/passenger/config/rubber/role/passenger/munin-passenger-sudoers.conf +2 -2
- 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 +3 -3
- 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 +8 -7
- 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 +46 -27
- 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 +14 -6
- 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/sphinx/config/rubber/deploy-sphinx.rb +8 -8
- 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 +115 -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/{generators/vulcanize/templates/nginx_frontend → lib/generators/vulcanize/templates/nginx}/config/rubber/role/web_tools/nginx-tools.conf +0 -0
- data/{generators/vulcanize/templates/nginx_frontend → lib/generators/vulcanize/templates/nginx}/config/rubber/role/web_tools/tools-index.html +0 -0
- data/{generators/vulcanize/templates/nginx_frontend → lib/generators/vulcanize/templates/nginx}/config/rubber/role/web_tools/tools-nginx.auth +0 -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 +42 -6
- data/lib/rubber/cloud/aws.rb +8 -6
- data/lib/rubber/dns/dyndns.rb +6 -7
- data/lib/rubber/dns/zerigo.rb +66 -125
- data/lib/rubber/environment.rb +15 -7
- data/lib/rubber/generator.rb +37 -27
- data/lib/rubber/instance.rb +1 -1
- data/lib/rubber/railtie.rb +14 -0
- data/lib/rubber/recipes/rubber.rb +6 -0
- data/lib/rubber/recipes/rubber/deploy.rb +3 -3
- data/lib/rubber/recipes/rubber/instances.rb +28 -64
- data/lib/rubber/recipes/rubber/setup.rb +102 -56
- data/lib/rubber/recipes/rubber/utils.rb +39 -16
- data/lib/rubber/recipes/rubber/volumes.rb +6 -7
- data/lib/rubber/tasks/rubber.rb +1 -1
- data/lib/rubber/util.rb +36 -1
- data/rails/init.rb +1 -4
- data/test/environment_test.rb +9 -1
- data/test/generator_test.rb +49 -5
- data/test/instance_test.rb +1 -1
- data/test/test_helper.rb +6 -0
- data/test/util_test.rb +1 -1
- data/test/zerigo_test.rb +88 -0
- metadata +222 -62
- data/generators/vulcanize/templates/nginx_frontend/config/rubber/deploy-nginx_frontend.rb +0 -85
- data/generators/vulcanize/templates/nginx_frontend/config/rubber/role/nginx_frontend/logrotate-nginx_frontend +0 -14
- data/generators/vulcanize/templates/nginx_frontend/config/rubber/role/nginx_frontend/monit-nginx_frontend.conf +0 -8
- data/generators/vulcanize/templates/nginx_frontend/config/rubber/role/nginx_frontend/nginx.conf +0 -50
- data/generators/vulcanize/templates/nginx_frontend/config/rubber/role/nginx_frontend/nginx_frontend +0 -366
- data/generators/vulcanize/templates/nginx_frontend/config/rubber/rubber-nginx_frontend.yml +0 -22
- data/generators/vulcanize/templates/nginx_frontend/templates.yml +0 -1
- data/generators/vulcanize/templates/resque/config/rubber/deploy-resque-worker-default.rb +0 -38
- data/generators/vulcanize/templates/resque/config/rubber/role/resque_worker_default/monit-resque_worker_default.conf +0 -19
- data/generators/vulcanize/templates/unicorn/config/rubber/deploy-unicorn.rb +0 -43
- data/generators/vulcanize/templates/unicorn/config/rubber/role/nginx_frontend/unicorn_nginx_server.conf +0 -90
- data/generators/vulcanize/templates/unicorn/config/rubber/role/unicorn/logrotate-unicorn +0 -16
- data/generators/vulcanize/templates/unicorn/config/rubber/role/unicorn/monit-unicorn.conf +0 -10
- data/generators/vulcanize/templates/unicorn/config/rubber/role/unicorn/unicorn +0 -327
- data/generators/vulcanize/templates/unicorn/config/rubber/role/unicorn/unicorn.conf +0 -86
- data/generators/vulcanize/templates/unicorn/config/rubber/rubber-unicorn.yml +0 -13
@@ -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
|
@@ -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
|
@@ -94,18 +94,17 @@ namespace :rubber do
|
|
94
94
|
print "Waiting for volume to attach"
|
95
95
|
while true do
|
96
96
|
print "."
|
97
|
-
sleep 2
|
98
97
|
volume = cloud.describe_volumes(vol_id).first
|
99
98
|
break if volume[:status] == "in-use" and volume[:attachment_status] == "attached"
|
99
|
+
sleep 2
|
100
100
|
end
|
101
|
-
sleep 2
|
102
101
|
print "\n"
|
103
102
|
|
104
103
|
# we don't mount/format at this time if we are doing a RAID array
|
105
104
|
if vol_spec['mount'] && vol_spec['filesystem']
|
106
105
|
# then format/mount/etc if we don't have an entry in hosts file
|
107
106
|
task :_setup_volume, :hosts => ic.external_ip do
|
108
|
-
rubber.
|
107
|
+
rubber.sudo_script 'setup_volume', <<-ENDSCRIPT
|
109
108
|
if ! grep -q '#{vol_spec['mount']}' /etc/fstab; then
|
110
109
|
if mount | grep -q '#{vol_spec['mount']}'; then
|
111
110
|
umount '#{vol_spec['mount']}'
|
@@ -114,7 +113,7 @@ namespace :rubber do
|
|
114
113
|
cat /etc/fstab.bak | grep -v '#{vol_spec['mount']}' > /etc/fstab
|
115
114
|
echo '#{vol_spec['device']} #{vol_spec['mount']} #{vol_spec['filesystem']} noatime 0 0 # rubber volume #{vol_id}' >> /etc/fstab
|
116
115
|
|
117
|
-
#{('yes | mkfs -t ' + vol_spec['filesystem'] + ' ' + vol_spec['device']) if created
|
116
|
+
#{('yes | mkfs -t ' + vol_spec['filesystem'] + ' ' + vol_spec['device']) if created}
|
118
117
|
mkdir -p '#{vol_spec['mount']}'
|
119
118
|
mount '#{vol_spec['mount']}'
|
120
119
|
fi
|
@@ -136,7 +135,7 @@ namespace :rubber do
|
|
136
135
|
if ! ic.partitions.include?(part_id)
|
137
136
|
# then format/mount/etc if we don't have an entry in hosts file
|
138
137
|
task :_setup_partition, :hosts => ic.external_ip do
|
139
|
-
rubber.
|
138
|
+
rubber.sudo_script 'setup_partition', <<-ENDSCRIPT
|
140
139
|
if ! fdisk -l 2>&1 | grep -q '#{partition_spec['partition_device']}'; then
|
141
140
|
if grep -q '#{partition_spec['disk_device']}\\b' /etc/fstab; then
|
142
141
|
umount #{partition_spec['disk_device']}
|
@@ -176,7 +175,7 @@ namespace :rubber do
|
|
176
175
|
end
|
177
176
|
# then format/mount/etc if we don't have an entry in hosts file
|
178
177
|
task :_zero_partitions, :hosts => ic.external_ip do
|
179
|
-
rubber.
|
178
|
+
rubber.sudo_script 'zero_partitions', <<-ENDSCRIPT
|
180
179
|
# zero out parition for performance (see amazon DevGuide)
|
181
180
|
echo "Zeroing out raid partitions to improve performance, this way take a while"
|
182
181
|
#{zero_script}
|
@@ -201,7 +200,7 @@ namespace :rubber do
|
|
201
200
|
end
|
202
201
|
|
203
202
|
task :_setup_raid_volume, :hosts => ic.external_ip do
|
204
|
-
rubber.
|
203
|
+
rubber.sudo_script 'setup_raid_volume', <<-ENDSCRIPT
|
205
204
|
if ! grep -q '#{raid_spec['device']}' /etc/fstab; then
|
206
205
|
if mount | grep -q '#{raid_spec['mount']}'; then
|
207
206
|
umount '#{raid_spec['mount']}'
|
data/lib/rubber/tasks/rubber.rb
CHANGED
@@ -252,7 +252,7 @@ namespace :rubber do
|
|
252
252
|
if (init_s3 &&
|
253
253
|
AWS::S3::Bucket.list.find { |b| b.name == backup_bucket })
|
254
254
|
s3objects = AWS::S3::Bucket.find(backup_bucket,
|
255
|
-
:prefix => (file || 'db/'))
|
255
|
+
:prefix => (file || 'db/'))
|
256
256
|
if file
|
257
257
|
puts "trying to fetch #{file} from s3"
|
258
258
|
data = s3objects.detect { |o| file == o.key }
|
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
CHANGED
data/test/environment_test.rb
CHANGED
@@ -3,7 +3,7 @@ gem 'test-unit'
|
|
3
3
|
|
4
4
|
require 'test/unit'
|
5
5
|
require 'tempfile'
|
6
|
-
require 'test_helper'
|
6
|
+
require File.expand_path(File.join(__FILE__, '..', 'test_helper'))
|
7
7
|
|
8
8
|
class EnvironmentTest < Test::Unit::TestCase
|
9
9
|
include Rubber::Configuration
|
@@ -42,6 +42,14 @@ class EnvironmentTest < Test::Unit::TestCase
|
|
42
42
|
assert_equal 'host1val2', e.var2, 'env not retrieving right val for method missing'
|
43
43
|
end
|
44
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
|
+
|
45
53
|
def test_combine
|
46
54
|
env = Rubber::Configuration::Environment
|
47
55
|
assert_equal "new", env.combine("old", "new"), "Last should win for scalar combine"
|
data/test/generator_test.rb
CHANGED
@@ -3,7 +3,7 @@ gem 'test-unit'
|
|
3
3
|
|
4
4
|
require 'test/unit'
|
5
5
|
require 'tempfile'
|
6
|
-
require 'test_helper'
|
6
|
+
require File.expand_path(File.join(__FILE__, '..', 'test_helper'))
|
7
7
|
|
8
8
|
class GeneratorTest < Test::Unit::TestCase
|
9
9
|
include Rubber::Configuration
|
@@ -93,6 +93,14 @@ class GeneratorTest < Test::Unit::TestCase
|
|
93
93
|
assert ! File.exists?(post_file), "post should not have been executed as dest file unchanged"
|
94
94
|
assert_equal "hello", File.read(out_file.path).strip, "transformed contents are incorrect"
|
95
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
|
+
|
96
104
|
FileUtils.rm_f(post_file)
|
97
105
|
gen = Generator.new(nil, nil, nil)
|
98
106
|
gen.no_post = true
|
@@ -178,7 +186,7 @@ class GeneratorTest < Test::Unit::TestCase
|
|
178
186
|
hello
|
179
187
|
SRC
|
180
188
|
|
181
|
-
assert_raises
|
189
|
+
assert_raises do
|
182
190
|
Generator.new(nil, nil, nil).transform(src)
|
183
191
|
end
|
184
192
|
|
@@ -224,7 +232,7 @@ class GeneratorTest < Test::Unit::TestCase
|
|
224
232
|
FileUtils.rm_rf(out_dir)
|
225
233
|
assert ! File.exists?(out_dir)
|
226
234
|
|
227
|
-
g = Generator.new("#{File.dirname(__FILE__)}/fixtures/basic", ['role1'],
|
235
|
+
g = Generator.new("#{File.dirname(__FILE__)}/fixtures/basic", ['role1'], 'host1', :out_dir => out_dir)
|
228
236
|
g.run()
|
229
237
|
assert File.directory?(out_dir), "scoped transform did not create dir"
|
230
238
|
assert_equal ['bar.conf', 'foo.conf'], list_dir(out_dir), "scoped transform did not create correct files"
|
@@ -235,12 +243,12 @@ class GeneratorTest < Test::Unit::TestCase
|
|
235
243
|
FileUtils.rm_rf(out_dir)
|
236
244
|
end
|
237
245
|
|
238
|
-
def
|
246
|
+
def test_ordering_of_additive
|
239
247
|
out_dir = "#{Dir::tmpdir}/test_rubber_ordering"
|
240
248
|
FileUtils.rm_rf(out_dir)
|
241
249
|
assert ! File.exists?(out_dir)
|
242
250
|
|
243
|
-
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)
|
244
252
|
g.run()
|
245
253
|
assert File.directory?(out_dir), "transform did not create dir"
|
246
254
|
assert_equal ['out.conf'], list_dir(out_dir), "transform did not create correct file"
|
@@ -323,4 +331,40 @@ def test_file_pattern
|
|
323
331
|
Generator.new(nil, nil, nil).transform(src)
|
324
332
|
assert ! File.exists?(out_file.path), "transform didn't skip generation of an output file"
|
325
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
|
+
|
326
370
|
end
|
data/test/instance_test.rb
CHANGED
data/test/test_helper.rb
CHANGED
@@ -6,3 +6,9 @@ Rubber::initialize(File.dirname(__FILE__), 'test')
|
|
6
6
|
require 'rubygems'
|
7
7
|
require 'mocha'
|
8
8
|
require 'pp'
|
9
|
+
require 'fakeweb'
|
10
|
+
FakeWeb.allow_net_connect = false
|
11
|
+
|
12
|
+
def fakeweb_fixture(name)
|
13
|
+
return File.read("#{File.dirname(__FILE__)}/fixtures/fakeweb/#{name}")
|
14
|
+
end
|
data/test/util_test.rb
CHANGED
data/test/zerigo_test.rb
ADDED
@@ -0,0 +1,88 @@
|
|
1
|
+
require 'rubygems'
|
2
|
+
gem 'test-unit'
|
3
|
+
|
4
|
+
require 'test/unit'
|
5
|
+
require File.expand_path(File.join(__FILE__, '..', 'test_helper'))
|
6
|
+
require 'rubber/dns'
|
7
|
+
require 'rubber/dns/zerigo'
|
8
|
+
require 'rexml/document'
|
9
|
+
|
10
|
+
class ZerigoTest < Test::Unit::TestCase
|
11
|
+
|
12
|
+
def setup
|
13
|
+
env = Rubber::Configuration::Environment::BoundEnv.new({'dns_providers' => {'zerigo' => {'email' => 'foo@bar.com', 'token' => 'testtoken'}}}, nil, nil)
|
14
|
+
@dns = Rubber::Dns::Zerigo.new(env)
|
15
|
+
FakeWeb.register_uri(:get,
|
16
|
+
"http://foo%40bar.com:testtoken@ns.zerigo.com/api/1.1/zones.xml",
|
17
|
+
:body => fakeweb_fixture('zerigo/get_zones.xml'))
|
18
|
+
@domain = "example1.com"
|
19
|
+
@zone = ::Zerigo::DNS::Zone.find_or_create(@domain)
|
20
|
+
end
|
21
|
+
|
22
|
+
def test_find_records
|
23
|
+
hosts_xml = fakeweb_fixture('zerigo/get_hosts.xml')
|
24
|
+
FakeWeb.register_uri(:get,
|
25
|
+
"http://foo%40bar.com:testtoken@ns.zerigo.com/api/1.1/hosts.xml?zone_id=1",
|
26
|
+
:body => hosts_xml)
|
27
|
+
records = @dns.find_host_records(:host => '*', :domain => 'example1.com')
|
28
|
+
assert_equal 2, records.size
|
29
|
+
assert_equal({:type=>"A", :host=>"host1", :domain=>"example1.com", :id=>1, :data=>"172.16.16.1"}, records.first)
|
30
|
+
|
31
|
+
doc = REXML::Document.new(hosts_xml)
|
32
|
+
doc.root.elements.delete(1)
|
33
|
+
hosts_xml_single = doc.to_s
|
34
|
+
FakeWeb.register_uri(:get,
|
35
|
+
"http://foo%40bar.com:testtoken@ns.zerigo.com/api/1.1/hosts.xml?fqdn=example1.com&zone_id=1",
|
36
|
+
:body => hosts_xml_single)
|
37
|
+
records = @dns.find_host_records(:host => '', :domain => 'example1.com')
|
38
|
+
assert_equal 1, records.size
|
39
|
+
assert_equal '', records.first[:host]
|
40
|
+
|
41
|
+
doc = REXML::Document.new(hosts_xml)
|
42
|
+
doc.root.elements.delete(2)
|
43
|
+
hosts_xml_single = doc.to_s
|
44
|
+
FakeWeb.register_uri(:get,
|
45
|
+
"http://foo%40bar.com:testtoken@ns.zerigo.com/api/1.1/hosts.xml?fqdn=host1.example1.com&zone_id=1",
|
46
|
+
:body => hosts_xml_single)
|
47
|
+
records = @dns.find_host_records(:host => 'host1', :domain => 'example1.com')
|
48
|
+
assert_equal 1, records.size
|
49
|
+
assert_equal 'host1', records.first[:host]
|
50
|
+
end
|
51
|
+
|
52
|
+
def test_create_record
|
53
|
+
params = {:host => 'newhost', :domain => 'example1.com', :data => '1.1.1.1', :type => 'A', :ttl => '333'}
|
54
|
+
dest_params = {'hostname' => 'newhost', 'data' => '1.1.1.1', 'host_type' => 'A', 'ttl' => '333', :zone_id => @zone.id}
|
55
|
+
|
56
|
+
::Zerigo::DNS::Host.expects(:create).with(dest_params)
|
57
|
+
|
58
|
+
@dns.create_host_record(params)
|
59
|
+
end
|
60
|
+
|
61
|
+
def test_destroy_record
|
62
|
+
params = {:host => 'host1', :domain => 'example1.com'}
|
63
|
+
|
64
|
+
FakeWeb.register_uri(:get,
|
65
|
+
"http://foo%40bar.com:testtoken@ns.zerigo.com/api/1.1/hosts.xml?fqdn=host1.example1.com&zone_id=1",
|
66
|
+
:body => fakeweb_fixture('zerigo/host1.xml'))
|
67
|
+
FakeWeb.register_uri(:delete,
|
68
|
+
"http://foo%40bar.com:testtoken@ns.zerigo.com/api/1.1/hosts/1.xml",
|
69
|
+
:body => "")
|
70
|
+
|
71
|
+
@dns.destroy_host_record(params)
|
72
|
+
end
|
73
|
+
|
74
|
+
def test_update_record
|
75
|
+
params = {:host => 'host1', :domain => 'example1.com', :data => "1.1.1.1"}
|
76
|
+
new = {:host => 'host1', :domain => 'example1.com', :data => "1.1.1.2"}
|
77
|
+
|
78
|
+
FakeWeb.register_uri(:get,
|
79
|
+
"http://foo%40bar.com:testtoken@ns.zerigo.com/api/1.1/hosts.xml?fqdn=host1.example1.com&zone_id=1",
|
80
|
+
:body => fakeweb_fixture('zerigo/host1.xml'))
|
81
|
+
FakeWeb.register_uri(:post,
|
82
|
+
"http://foo%40bar.com:testtoken@ns.zerigo.com/api/1.1/hosts/1.xml",
|
83
|
+
:body => "")
|
84
|
+
|
85
|
+
@dns.update_host_record(params, new)
|
86
|
+
end
|
87
|
+
|
88
|
+
end
|