rubber 1.15.0 → 2.0.0.pre1
Sign up to get free protection for your applications and to get access to all the features.
- data/.travis.yml +10 -0
- data/CHANGELOG +68 -1
- data/Gemfile +4 -0
- data/{COPYING → LICENSE} +0 -0
- data/Rakefile +89 -0
- data/bin/rubber +17 -0
- data/lib/rubber.rb +12 -6
- data/lib/rubber/cli.rb +30 -0
- data/lib/rubber/cloud.rb +2 -1
- data/lib/rubber/cloud/aws.rb +58 -298
- data/lib/rubber/cloud/aws_table_store.rb +127 -0
- data/lib/rubber/cloud/fog.rb +313 -0
- data/lib/rubber/cloud/fog_storage.rb +143 -0
- data/lib/rubber/commands/config.rb +70 -0
- data/lib/rubber/commands/cron.rb +127 -0
- data/lib/rubber/commands/util.rb +308 -0
- data/lib/rubber/commands/vulcanize.rb +197 -0
- data/lib/rubber/configuration.rb +20 -9
- data/lib/rubber/dns.rb +2 -1
- data/lib/rubber/dns/base.rb +6 -8
- data/lib/rubber/dns/fog.rb +117 -0
- data/lib/rubber/dns/nettica.rb +6 -1
- data/lib/rubber/dns/zerigo.rb +8 -103
- data/lib/rubber/environment.rb +25 -6
- data/lib/rubber/generator.rb +2 -0
- data/lib/rubber/instance.rb +121 -19
- data/lib/rubber/recipes/rubber.rb +3 -4
- data/lib/rubber/recipes/rubber/deploy.rb +12 -12
- data/lib/rubber/recipes/rubber/instances.rb +30 -31
- data/lib/rubber/recipes/rubber/security_groups.rb +2 -2
- data/lib/rubber/recipes/rubber/setup.rb +139 -42
- data/lib/rubber/recipes/rubber/utils.rb +12 -7
- data/lib/rubber/recipes/rubber/volumes.rb +2 -2
- data/lib/rubber/tag.rb +3 -8
- data/lib/rubber/util.rb +43 -22
- data/lib/rubber/version.rb +4 -0
- data/rubber.gemspec +44 -0
- data/{generators/vulcanize/templates → templates}/apache/config/rubber/deploy-apache.rb +2 -2
- data/{generators/vulcanize/templates → templates}/apache/config/rubber/role/apache/deflate.conf +0 -0
- data/{generators/vulcanize/templates → templates}/apache/config/rubber/role/apache/expires.conf +0 -0
- data/{generators/vulcanize/templates → templates}/apache/config/rubber/role/apache/headers.conf +0 -0
- data/{generators/vulcanize/templates → templates}/apache/config/rubber/role/apache/ports.conf +0 -0
- data/{generators/vulcanize/templates → templates}/apache/config/rubber/role/apache/setenvif.conf +0 -0
- data/{generators/vulcanize/templates → templates}/apache/config/rubber/role/web_tools/tools-apache-vhost.conf +51 -23
- data/{lib/generators/vulcanize/templates → templates}/apache/config/rubber/role/web_tools/tools-apache.auth +1 -1
- data/templates/apache/config/rubber/role/web_tools/tools-index.html +38 -0
- data/{generators/vulcanize/templates → templates}/apache/config/rubber/rubber-apache.yml +0 -0
- data/{generators/vulcanize/templates → templates}/apache/templates.yml +0 -0
- data/{lib/generators/vulcanize/templates → templates}/base/Capfile +6 -0
- data/{lib/generators/vulcanize/templates → templates}/base/config/deploy.rb +13 -3
- data/templates/base/config/rubber/common/crontab +21 -0
- data/{generators/vulcanize/templates → templates}/base/config/rubber/common/rsyslog.conf +0 -0
- data/{generators/vulcanize/templates → templates}/base/config/rubber/common/rubber.profile +4 -4
- data/{lib/generators/vulcanize/templates → templates}/base/config/rubber/deploy-setup.rb +1 -1
- data/{lib/generators/vulcanize/templates → templates}/base/config/rubber/deploy-util.rb +17 -23
- data/{lib/generators/vulcanize/templates → templates}/base/config/rubber/rubber-dns.yml +7 -0
- data/{lib/generators/vulcanize/templates → templates}/base/config/rubber/rubber-rvm.yml +6 -6
- data/{lib/generators/vulcanize/templates → templates}/base/config/rubber/rubber.yml +54 -20
- data/templates/base/script/rubber +8 -0
- data/templates/base/templates.rb +7 -0
- data/templates/base/templates.yml +1 -0
- data/{lib/generators/vulcanize/templates → templates}/cassandra/config/rubber/deploy-cassandra.rb +1 -1
- data/{generators/vulcanize/templates → templates}/cassandra/config/rubber/role/cassandra/cassandra.in.sh +0 -0
- data/{generators/vulcanize/templates → templates}/cassandra/config/rubber/role/cassandra/cassandra.yaml +0 -0
- data/{generators/vulcanize/templates → templates}/cassandra/config/rubber/role/cassandra/log4j-server.properties +0 -0
- data/{generators/vulcanize/templates → templates}/cassandra/config/rubber/rubber-cassandra.yml +0 -0
- data/{generators/vulcanize/templates → templates}/cassandra/templates.yml +0 -0
- data/templates/collectd/config/rubber/deploy-collectd.rb +48 -0
- data/templates/collectd/config/rubber/role/collectd/collectd.conf +69 -0
- data/templates/collectd/config/rubber/role/collectd/filters.conf +35 -0
- data/templates/collectd/config/rubber/role/collectd/thresholds.conf +76 -0
- data/templates/collectd/config/rubber/role/collectd/types.db +5 -0
- data/templates/collectd/config/rubber/role/passenger/collectd-passenger.conf +7 -0
- data/templates/collectd/config/rubber/role/passenger/collectd-passenger.rb.conf +77 -0
- data/{lib/generators/vulcanize/templates/passenger/config/rubber/role/passenger/munin-passenger-sudoers.conf → templates/collectd/config/rubber/role/passenger/passenger-status-sudoers.conf} +1 -1
- data/templates/collectd/config/rubber/role/postgresql/collectd-postgresql.conf +22 -0
- data/templates/collectd/config/rubber/role/postgresql_slave/collectd-postgresql-threshold.conf +23 -0
- data/templates/collectd/config/rubber/rubber-collectd.yml +8 -0
- data/templates/collectd/script/collectd/collectd-runner.rb +107 -0
- data/templates/collectd/script/collectd/role/examples/example_db_query.rb +19 -0
- data/templates/collectd/script/collectd/role/examples/example_simple.rb +1 -0
- data/templates/collectd/script/collectd/role/postgresql_slave/replication_status.rb +31 -0
- data/templates/collectd/script/collectd/role/redis/redis_info.rb +28 -0
- data/templates/collectd/script/collectd/role/resque_worker/global_worker_stats.rb +12 -0
- data/templates/collectd/script/collectd/role/resque_worker/host_worker_stats.rb +70 -0
- data/templates/collectd/script/collectd/role/resque_worker/resque_jobs_processed.rb +8 -0
- data/templates/collectd/templates.yml +2 -0
- data/{generators/vulcanize/templates → templates}/complete_mongrel_mysql/config/rubber/role/haproxy/haproxy-mongrel.conf +0 -0
- data/{generators/vulcanize/templates → templates}/complete_mongrel_mysql/config/rubber/role/nginx/nginx-mongrel.conf +5 -5
- data/{lib/generators/vulcanize/templates → templates}/complete_mongrel_mysql/config/rubber/rubber-complete.yml +1 -1
- data/{lib/generators/vulcanize/templates → templates}/complete_mongrel_mysql/templates.yml +2 -2
- data/{generators/vulcanize/templates → templates}/complete_passenger/config/rubber/role/haproxy/haproxy-passenger.conf +0 -0
- data/{lib/generators/vulcanize/templates → templates}/complete_passenger/config/rubber/rubber-complete.yml +1 -1
- data/{generators/vulcanize/templates → templates}/complete_passenger/templates.rb +0 -0
- data/{generators/vulcanize/templates → templates}/complete_passenger/templates.yml +4 -2
- data/{generators/vulcanize/templates → templates}/complete_passenger_mysql/templates.yml +0 -0
- data/{generators/vulcanize/templates → templates}/complete_passenger_nginx/config/rubber/role/haproxy/haproxy-passenger.conf +0 -0
- data/{generators/vulcanize/templates → templates}/complete_passenger_nginx/config/rubber/rubber-complete.yml +0 -0
- data/{generators/vulcanize/templates → templates}/complete_passenger_nginx/templates.rb +0 -0
- data/{generators/vulcanize/templates → templates}/complete_passenger_nginx/templates.yml +2 -2
- data/{generators/vulcanize/templates → templates}/complete_passenger_nginx_mysql/templates.yml +0 -0
- data/{generators/vulcanize/templates → templates}/complete_passenger_nginx_postgresql/templates.yml +0 -0
- data/{generators/vulcanize/templates → templates}/complete_passenger_postgresql/templates.yml +0 -0
- data/{generators/vulcanize/templates → templates}/cruise/config/rubber/deploy-cruise.rb +0 -0
- data/{generators/vulcanize/templates → templates}/cruise/config/rubber/role/cruise/cruise +0 -0
- data/{generators/vulcanize/templates → templates}/cruise/config/rubber/role/cruise/my.cnf +0 -0
- data/{generators/vulcanize/templates → templates}/cruise/config/rubber/role/cruise/production.rb +0 -0
- data/{generators/vulcanize/templates → templates}/cruise/config/rubber/role/cruise/site_config.rb +1 -1
- data/{generators/vulcanize/templates → templates}/cruise/config/rubber/role/web_tools/cruise-nginx.conf +0 -0
- data/{generators/vulcanize/templates → templates}/cruise/config/rubber/rubber-cruise.yml +6 -0
- data/{generators/vulcanize/templates → templates}/cruise/templates.yml +0 -0
- data/templates/elasticsearch/config/rubber/deploy-elasticsearch.rb +47 -0
- data/templates/elasticsearch/config/rubber/role/elasticsearch/elasticsearch-upstart.conf +23 -0
- data/templates/elasticsearch/config/rubber/role/elasticsearch/elasticsearch.yml +348 -0
- data/templates/elasticsearch/config/rubber/role/elasticsearch/logging.yml +48 -0
- data/templates/elasticsearch/config/rubber/rubber-elasticsearch.yml +12 -0
- data/templates/elasticsearch/templates.yml +2 -0
- data/templates/graphite/config/rubber/deploy-graphite.rb +255 -0
- data/templates/graphite/config/rubber/role/collectd/graphite-collectd.conf +19 -0
- data/templates/graphite/config/rubber/role/graphite_server/carbon.conf +232 -0
- data/templates/graphite/config/rubber/role/graphite_server/graphite-collectd-ping.conf +11 -0
- data/templates/graphite/config/rubber/role/graphite_server/graphite_server-upstart.conf +16 -0
- data/templates/graphite/config/rubber/role/graphite_server/storage-schemas.conf +19 -0
- data/templates/graphite/config/rubber/role/graphite_web/crontab +8 -0
- data/templates/graphite/config/rubber/role/graphite_web/dashboard.conf +60 -0
- data/templates/graphite/config/rubber/role/graphite_web/graphite-vhost.conf +62 -0
- data/templates/graphite/config/rubber/role/graphite_web/graphite.wsgi +10 -0
- data/templates/graphite/config/rubber/role/graphite_web/local_settings.py +98 -0
- data/templates/graphite/config/rubber/rubber-graphite.yml +20 -0
- data/templates/graphite/templates.yml +1 -0
- data/templates/graylog/config/initializers/graylog.rb +53 -0
- data/templates/graylog/config/rubber/deploy-graylog.rb +118 -0
- data/templates/graylog/config/rubber/role/common/graylog-rsyslog.conf +32 -0
- data/templates/graylog/config/rubber/role/graylog_server/graylog2.conf +67 -0
- data/templates/graylog/config/rubber/role/graylog_server/graylog_server-upstart.conf +22 -0
- data/templates/graylog/config/rubber/role/graylog_web/crontab +9 -0
- data/templates/graylog/config/rubber/role/graylog_web/email.yml +16 -0
- data/templates/graylog/config/rubber/role/graylog_web/general.yml +27 -0
- data/templates/graylog/config/rubber/role/graylog_web/graylog_web-upstart.conf +21 -0
- data/templates/graylog/config/rubber/role/graylog_web/mongoid.yml +28 -0
- data/templates/graylog/config/rubber/rubber-graylog.yml +42 -0
- data/templates/graylog/templates.rb +5 -0
- data/templates/graylog/templates.yml +5 -0
- data/{lib/generators/vulcanize/templates → templates}/haproxy/config/rubber/deploy-haproxy.rb +2 -2
- data/{generators/vulcanize/templates → templates}/haproxy/config/rubber/role/haproxy/haproxy-base.conf +0 -0
- data/{generators/vulcanize/templates → templates}/haproxy/config/rubber/role/haproxy/haproxy-default.conf +0 -0
- data/{generators/vulcanize/templates → templates}/haproxy/config/rubber/role/haproxy/syslog-haproxy.conf +0 -0
- data/{generators/vulcanize/templates → templates}/haproxy/config/rubber/role/haproxy/syslogd-default.conf +0 -0
- data/{generators/vulcanize/templates → templates}/haproxy/config/rubber/role/web_tools/haproxy-nginx.conf +0 -0
- data/templates/haproxy/config/rubber/role/web_tools/rubber-web-tools-haproxy.html +18 -0
- data/{generators/vulcanize/templates → templates}/haproxy/config/rubber/rubber-haproxy.yml +0 -0
- data/{generators/vulcanize/templates → templates}/haproxy/templates.yml +0 -0
- data/{generators/vulcanize/templates → templates}/jetty/config/rubber/deploy-jetty.rb +0 -0
- data/{generators/vulcanize/templates → templates}/jetty/config/rubber/role/jetty/jetty.sh +0 -0
- data/{generators/vulcanize/templates → templates}/jetty/config/rubber/role/jetty/jetty.xml +0 -0
- data/{generators/vulcanize/templates → templates}/jetty/config/rubber/rubber-jetty.yml +0 -0
- data/{generators/vulcanize/templates → templates}/jetty/templates.yml +0 -0
- data/{generators/vulcanize/templates → templates}/memcached/config/memcached.yml +0 -0
- data/{generators/vulcanize/templates → templates}/memcached/config/rubber/common/memcached.yml +2 -2
- data/{generators/vulcanize/templates → templates}/memcached/config/rubber/role/memcached/memcached.conf +0 -0
- data/{generators/vulcanize/templates → templates}/memcached/config/rubber/rubber-memcached.yml +0 -0
- data/{generators/vulcanize/templates → templates}/memcached/templates.yml +0 -0
- data/{generators/vulcanize/templates → templates}/minimal_mysql/templates.yml +0 -0
- data/{generators/vulcanize/templates → templates}/minimal_nodb/templates.yml +0 -0
- data/{generators/vulcanize/templates → templates}/minimal_passenger_nginx/config/rubber/rubber-complete.yml +0 -0
- data/{generators/vulcanize/templates → templates}/minimal_passenger_nginx/templates.yml +0 -0
- data/{lib/generators/vulcanize/templates → templates}/mongodb/config/rubber/deploy-mongodb.rb +17 -14
- data/templates/mongodb/config/rubber/role/mongodb/mongodb-defaults.conf +5 -0
- data/{lib/generators/vulcanize/templates → templates}/mongodb/config/rubber/role/mongodb/mongodb.conf +4 -1
- data/{generators/vulcanize/templates → templates}/mongodb/config/rubber/rubber-mongodb.yml +0 -0
- data/templates/mongodb/templates.yml +1 -0
- data/{generators/vulcanize/templates → templates}/mongrel/config/rubber/deploy-mongrel.rb +1 -1
- data/{generators/vulcanize/templates → templates}/mongrel/config/rubber/role/mongrel/mongrel_cluster.yml +3 -3
- data/{lib/generators/vulcanize/templates → templates}/mongrel/config/rubber/rubber-mongrel.yml +1 -1
- data/{generators/vulcanize/templates → templates}/mongrel/templates.yml +0 -0
- data/{lib/generators/vulcanize/templates → templates}/monit/config/rubber/deploy-monit.rb +4 -4
- data/{lib/generators/vulcanize/templates/apache → templates/monit}/config/rubber/role/apache/monit-apache.conf +1 -1
- data/{generators/vulcanize/templates/cassandra → templates/monit}/config/rubber/role/cassandra/monit-cassandra.conf +1 -1
- data/templates/monit/config/rubber/role/elasticsearch/monit-elasticsearch.conf +8 -0
- data/templates/monit/config/rubber/role/graphite_server/monit-graphite_server.conf +8 -0
- data/templates/monit/config/rubber/role/graylog_server/monit-graylog_server.conf +8 -0
- data/templates/monit/config/rubber/role/graylog_web/monit-graylog_web.conf +8 -0
- data/{generators/vulcanize/templates/haproxy → templates/monit}/config/rubber/role/haproxy/monit-haproxy.conf +1 -1
- data/{generators/vulcanize/templates/jetty → templates/monit}/config/rubber/role/jetty/monit-jetty.conf +1 -1
- data/{lib/generators/vulcanize/templates/mongodb/config/rubber/role/mongodb/monit-mongodb.cnf → templates/monit/config/rubber/role/mongodb/monit-mongodb.conf} +2 -2
- data/{generators/vulcanize/templates/mongrel → templates/monit}/config/rubber/role/mongrel/monit-mongrel.conf +4 -4
- data/{generators/vulcanize/templates/monit/config/rubber/common → templates/monit/config/rubber/role/monit}/monit-default.conf +0 -0
- data/{generators/vulcanize/templates/base/config/rubber/common → templates/monit/config/rubber/role/monit}/monit-postfix.conf +0 -0
- data/{generators/vulcanize/templates/monit/config/rubber/common → templates/monit/config/rubber/role/monit}/monit.conf +0 -0
- data/{generators/vulcanize/templates/munin/config/rubber/common → templates/monit/config/rubber/role/munin}/monit-munin.conf +0 -0
- data/{lib/generators/vulcanize/templates/mysql/config/rubber/role/db/monit-mysql.cnf → templates/monit/config/rubber/role/mysql/monit-mysql.conf} +1 -1
- data/{lib/generators/vulcanize/templates/mysql_proxy/config/rubber/common/monit-mysql_proxy.cnf → templates/monit/config/rubber/role/mysql_proxy/monit-mysql_proxy.conf} +1 -1
- data/{generators/vulcanize/templates/nginx → templates/monit}/config/rubber/role/nginx/monit-nginx.conf +1 -1
- data/{generators/vulcanize/templates/passenger_nginx → templates/monit}/config/rubber/role/passenger_nginx/monit-nginx.conf +1 -1
- data/{lib/generators/vulcanize/templates/postgresql/config/rubber/role/db → templates/monit/config/rubber/role/postgresql}/monit-postgresql.conf +1 -1
- data/templates/monit/config/rubber/role/redis/monit-redis.conf +8 -0
- data/templates/monit/config/rubber/role/resque_web/monit-resque_web.conf +10 -0
- data/templates/monit/config/rubber/role/resque_worker/monit-resque_pool.conf +8 -0
- data/{generators/vulcanize/templates/sphinx → templates/monit}/config/rubber/role/sphinx/monit-sphinx.conf +4 -4
- data/{generators/vulcanize/templates → templates}/monit/config/rubber/role/web_tools/monit-admin-nginx.conf +0 -0
- data/templates/monit/config/rubber/role/web_tools/rubber-web-tools-monit.html +19 -0
- data/templates/monit/config/rubber/rubber-monit.yml +11 -0
- data/{generators/vulcanize/templates → templates}/monit/templates.yml +1 -0
- data/templates/munin/config/rubber/deploy-munin.rb +81 -0
- data/{generators/vulcanize/templates/memcached → templates/munin}/config/rubber/role/memcached/memcached_munin_plugin +0 -0
- data/{generators/vulcanize/templates/munin/config/rubber/common → templates/munin/config/rubber/role/munin}/munin-node.conf +0 -0
- data/{generators/vulcanize/templates/munin/config/rubber/common → templates/munin/config/rubber/role/munin}/munin-plugins.conf +0 -0
- data/{generators/vulcanize/templates/mysql → templates/munin}/config/rubber/role/mysql_slave/mysql_slave_munin_plugin +0 -0
- data/{generators/vulcanize/templates/passenger → templates/munin}/config/rubber/role/passenger/munin-passenger-memory.conf +0 -0
- data/{generators/vulcanize/templates/passenger → templates/munin}/config/rubber/role/passenger/munin-passenger-sudoers.conf +0 -0
- data/{generators/vulcanize/templates/passenger → templates/munin}/config/rubber/role/passenger/munin-passenger.conf +0 -0
- data/{generators/vulcanize/templates/passenger_nginx → templates/munin}/config/rubber/role/passenger_nginx/munin-passenger-memory.conf +0 -0
- data/{generators/vulcanize/templates/passenger_nginx → templates/munin}/config/rubber/role/passenger_nginx/munin-passenger-sudoers.conf +0 -0
- data/{generators/vulcanize/templates/passenger_nginx → templates/munin}/config/rubber/role/passenger_nginx/munin-passenger.conf +0 -0
- data/{generators/vulcanize/templates/postgresql/config/rubber/role/db → templates/munin/config/rubber/role/postgresql}/munin-postgresql.conf +0 -0
- data/{generators/vulcanize/templates → templates}/munin/config/rubber/role/web_tools/munin-nginx.conf +0 -0
- data/{lib/generators/vulcanize/templates → templates}/munin/config/rubber/role/web_tools/munin-plugins.conf +3 -3
- data/{generators/vulcanize/templates → templates}/munin/config/rubber/role/web_tools/munin.conf +0 -0
- data/templates/munin/config/rubber/role/web_tools/rubber-web-tools-munin.html +16 -0
- data/templates/munin/config/rubber/rubber-munin.yml +12 -0
- data/{lib/generators/vulcanize/templates → templates}/munin/script/munin/example_mysql_query.rb +1 -1
- data/{lib/generators/vulcanize/templates → templates}/munin/script/munin/example_simple.rb +1 -1
- data/{generators/vulcanize/templates → templates}/munin/templates.yml +1 -0
- data/{generators/vulcanize/templates → templates}/mysql/config/rubber/common/database.yml +3 -3
- data/{lib/generators/vulcanize/templates → templates}/mysql/config/rubber/deploy-mysql.rb +1 -15
- data/{generators/vulcanize/templates → templates}/mysql/config/rubber/role/db/apparmor-mysql.conf +0 -0
- data/{lib/generators/vulcanize/templates → templates}/mysql/config/rubber/role/db/crontab +3 -1
- data/{generators/vulcanize/templates → templates}/mysql/config/rubber/role/db/my.cnf +0 -0
- data/{generators/vulcanize/templates → templates}/mysql/config/rubber/rubber-mysql.yml +9 -10
- data/{generators/vulcanize/templates → templates}/mysql/templates.yml +0 -0
- data/{lib/generators/vulcanize/templates → templates}/mysql_cluster/config/rubber/common/mysql_cluster_migrations.rb +1 -1
- data/{generators/vulcanize/templates → templates}/mysql_cluster/config/rubber/deploy-mysql_cluster.rb +3 -3
- data/{generators/vulcanize/templates → templates}/mysql_cluster/config/rubber/role/mysql_data/my.cnf +0 -0
- data/{generators/vulcanize/templates → templates}/mysql_cluster/config/rubber/role/mysql_mgm/ndb_mgmd.cnf +0 -0
- data/{generators/vulcanize/templates → templates}/mysql_cluster/config/rubber/role/mysql_sql/my.cnf +0 -0
- data/{lib/generators/vulcanize/templates → templates}/mysql_cluster/config/rubber/rubber-mysql_cluster.yml +6 -3
- data/{generators/vulcanize/templates → templates}/mysql_cluster/templates.yml +0 -0
- data/{generators/vulcanize/templates → templates}/mysql_proxy/config/rubber/deploy-mysql_proxy.rb +0 -0
- data/{lib/generators/vulcanize/templates/mysql_proxy/config/rubber/common → templates/mysql_proxy/config/rubber/mysql_proxy}/database.yml +3 -3
- data/{generators/vulcanize/templates/mysql_proxy/config/rubber/common → templates/mysql_proxy/config/rubber/mysql_proxy}/mysql-proxy +0 -0
- data/{generators/vulcanize/templates/mysql_proxy/config/rubber/common → templates/mysql_proxy/config/rubber/mysql_proxy}/mysql-proxy.conf +0 -0
- data/{generators/vulcanize/templates/mysql_proxy/config/rubber/common → templates/mysql_proxy/config/rubber/mysql_proxy}/mysql-proxy.lua +0 -0
- data/{generators/vulcanize/templates → templates}/mysql_proxy/config/rubber/rubber-mysql_proxy.yml +3 -0
- data/{generators/vulcanize/templates → templates}/mysql_proxy/templates.yml +0 -0
- data/{generators/vulcanize/templates → templates}/nginx/config/rubber/deploy-nginx.rb +0 -0
- data/{generators/vulcanize/templates → templates}/nginx/config/rubber/role/nginx/crontab +1 -1
- data/{generators/vulcanize/templates → templates}/nginx/config/rubber/role/nginx/nginx.conf +0 -0
- data/{lib/generators/vulcanize/templates → templates}/nginx/config/rubber/role/web_tools/nginx-tools.conf +8 -5
- data/{generators/vulcanize/templates → templates}/nginx/config/rubber/role/web_tools/tools-index.html +7 -1
- data/{generators/vulcanize/templates → templates}/nginx/config/rubber/role/web_tools/tools-nginx.auth +1 -1
- data/{generators/vulcanize/templates → templates}/nginx/config/rubber/rubber-nginx.yml +0 -0
- data/{generators/vulcanize/templates → templates}/nginx/templates.yml +0 -0
- data/{generators/vulcanize/templates → templates}/passenger/config/rubber/deploy-passenger.rb +0 -0
- data/{generators/vulcanize/templates → templates}/passenger/config/rubber/role/passenger/passenger-apache-vhost.conf +5 -5
- data/{lib/generators/vulcanize/templates → templates}/passenger/config/rubber/role/passenger/passenger.conf +2 -2
- data/{lib/generators/vulcanize/templates → templates}/passenger/config/rubber/rubber-passenger.yml +2 -1
- data/{generators/vulcanize/templates → templates}/passenger/templates.yml +0 -0
- data/{lib/generators/vulcanize/templates → templates}/passenger_nginx/config/rubber/deploy-passenger_nginx.rb +1 -2
- data/{lib/generators/vulcanize/templates → templates}/passenger_nginx/config/rubber/role/passenger_nginx/application.conf +3 -3
- data/{generators/vulcanize/templates → templates}/passenger_nginx/config/rubber/role/passenger_nginx/crontab +1 -1
- data/{generators/vulcanize/templates → templates}/passenger_nginx/config/rubber/role/passenger_nginx/nginx +0 -0
- data/{lib/generators/vulcanize/templates → templates}/passenger_nginx/config/rubber/role/passenger_nginx/nginx.conf +2 -2
- data/{generators/vulcanize/templates → templates}/passenger_nginx/config/rubber/role/passenger_nginx/passenger_nginx.conf +2 -2
- data/{generators/vulcanize/templates → templates}/passenger_nginx/config/rubber/role/web_tools/nginx-tools.conf +8 -5
- data/{lib/generators/vulcanize/templates → templates}/passenger_nginx/config/rubber/role/web_tools/tools-index.html +7 -1
- data/{generators/vulcanize/templates → templates}/passenger_nginx/config/rubber/role/web_tools/tools-nginx.auth +1 -1
- data/{lib/generators/vulcanize/templates → templates}/passenger_nginx/config/rubber/rubber-passenger_nginx.yml +1 -1
- data/{generators/vulcanize/templates → templates}/passenger_nginx/templates.yml +0 -0
- data/{lib/generators/vulcanize/templates → templates}/postgresql/config/rubber/common/database.yml +2 -2
- data/{lib/generators/vulcanize/templates → templates}/postgresql/config/rubber/deploy-postgresql.rb +27 -47
- data/{generators/vulcanize/templates → templates}/postgresql/config/rubber/role/db/crontab +3 -1
- data/templates/postgresql/config/rubber/role/db/pg_hba.conf +98 -0
- data/{generators/vulcanize/templates → templates}/postgresql/config/rubber/role/db/postgresql-sysctl.conf +0 -0
- data/{lib/generators/vulcanize/templates → templates}/postgresql/config/rubber/role/db/postgresql.conf +50 -20
- data/{lib/generators/vulcanize/templates → templates}/postgresql/config/rubber/role/postgresql_slave/recovery.conf +34 -19
- data/{generators/vulcanize/templates → templates}/postgresql/config/rubber/rubber-postgresql.yml +13 -13
- data/{generators/vulcanize/templates → templates}/postgresql/templates.yml +0 -0
- data/templates/redis/config/rubber/deploy-redis.rb +79 -0
- data/{lib/generators/vulcanize/templates → templates}/redis/config/rubber/role/redis/crontab +3 -1
- data/{generators/vulcanize/templates → templates}/redis/config/rubber/role/redis/redis-sysctl.conf +0 -0
- data/templates/redis/config/rubber/role/redis/redis-upstart.conf +23 -0
- data/{generators/vulcanize/templates → templates}/redis/config/rubber/role/redis/redis.conf +62 -9
- data/templates/redis/config/rubber/rubber-redis.yml +17 -0
- data/{generators/vulcanize/templates → templates}/redis/templates.yml +0 -0
- data/{generators/vulcanize/templates → templates}/resque/config/initializers/resque.rb +0 -0
- data/templates/resque/config/resque-pool.yml +4 -0
- data/templates/resque/config/rubber/common/resque.yml +5 -0
- data/templates/resque/config/rubber/deploy-resque.rb +190 -0
- data/templates/resque/config/rubber/role/resque_web/resque-web-upstart.conf +20 -0
- data/templates/resque/config/rubber/role/resque_worker/resque-pool-upstart.conf +50 -0
- data/templates/resque/config/rubber/role/resque_worker/resque-pool.yml +6 -0
- data/{generators/vulcanize/templates → templates}/resque/config/rubber/rubber-resque.yml +11 -1
- data/templates/resque/lib/tasks/resque.rake +18 -0
- data/templates/resque/templates.rb +2 -0
- data/{generators/vulcanize/templates → templates}/resque/templates.yml +0 -0
- data/{lib/generators/vulcanize/templates → templates}/sphinx/config/rubber/common/sphinx.yml +9 -9
- data/{generators/vulcanize/templates → templates}/sphinx/config/rubber/deploy-sphinx.rb +1 -1
- data/templates/sphinx/config/rubber/role/sphinx/crontab +11 -0
- data/{generators/vulcanize/templates → templates}/sphinx/config/rubber/rubber-sphinx.yml +0 -0
- data/{generators/vulcanize/templates → templates}/sphinx/templates.yml +0 -0
- data/templates/unicorn/config/rubber/deploy-unicorn.rb +35 -0
- data/templates/unicorn/config/rubber/role/nginx/unicorn_nginx.conf +56 -0
- data/templates/unicorn/config/rubber/role/unicorn/unicorn.rb +79 -0
- data/templates/unicorn/config/rubber/rubber-unicorn.yml +5 -0
- data/templates/unicorn/templates.yml +3 -0
- data/test/cloud/aws_table_store_test.rb +172 -0
- data/test/cloud/aws_test.rb +33 -0
- data/test/cloud/fog_storage_test.rb +183 -0
- data/test/cloud/fog_test.rb +34 -0
- data/test/command_test.rb +85 -0
- data/test/dns/fog_test.rb +131 -0
- data/test/environment_test.rb +135 -0
- data/test/fixtures/basic/common/bar.conf +4 -0
- data/test/fixtures/basic/common/foo.conf +4 -0
- data/test/fixtures/basic/host/host1/foo.conf +4 -0
- data/test/fixtures/basic/host/host2/foo.conf +4 -0
- data/test/fixtures/basic/role/role1/foo.conf +4 -0
- data/test/fixtures/basic/role/role2/foo.conf +4 -0
- data/test/fixtures/basic/rubber-extra.yml +1 -0
- data/test/fixtures/basic/rubber.yml +26 -0
- data/test/fixtures/expansion/rubber.yml +34 -0
- data/test/fixtures/generator_order/common/a_first.conf +5 -0
- data/test/fixtures/generator_order/common/z_last.conf +5 -0
- data/test/fixtures/generator_order/host/host1/a_first.conf +5 -0
- data/test/fixtures/generator_order/host/host1/z_last.conf +5 -0
- data/test/fixtures/generator_order/role/role1/a_first.conf +5 -0
- data/test/fixtures/generator_order/role/role1/z_last.conf +5 -0
- data/test/fixtures/generator_order/role/role2/a_first.conf +5 -0
- data/test/fixtures/generator_order/role/role2/z_last.conf +5 -0
- data/test/fixtures/instance_expansion/instance-test.yml +20 -0
- data/test/fixtures/instance_expansion/rubber.yml +1 -0
- data/test/fixtures/nested/rubber.yml +9 -0
- data/test/fixtures/secret/rubber.yml +2 -0
- data/test/fixtures/secret/secret.yml +2 -0
- data/test/generator_test.rb +365 -0
- data/test/instance_test.rb +293 -0
- data/test/test-rails-template.rb +35 -0
- data/test/test_helper.rb +19 -0
- data/test/util_test.rb +79 -0
- metadata +490 -508
- data/VERSION +0 -1
- data/bin/vulcanize +0 -25
- data/generators/vulcanize/USAGE +0 -6
- data/generators/vulcanize/templates/apache/config/rubber/role/apache/monit-apache.conf +0 -7
- data/generators/vulcanize/templates/apache/config/rubber/role/web_tools/tools-apache.auth +0 -7
- data/generators/vulcanize/templates/apache/config/rubber/role/web_tools/tools-index.html +0 -34
- data/generators/vulcanize/templates/base/Capfile +0 -14
- data/generators/vulcanize/templates/base/Rakefile +0 -27
- data/generators/vulcanize/templates/base/config/deploy.rb +0 -56
- data/generators/vulcanize/templates/base/config/rubber/common/crontab +0 -21
- data/generators/vulcanize/templates/base/config/rubber/deploy-setup.rb +0 -96
- data/generators/vulcanize/templates/base/config/rubber/deploy-util.rb +0 -97
- data/generators/vulcanize/templates/base/config/rubber/rubber-dns.yml +0 -78
- data/generators/vulcanize/templates/base/config/rubber/rubber-rvm.yml +0 -39
- data/generators/vulcanize/templates/base/config/rubber/rubber.yml +0 -263
- data/generators/vulcanize/templates/base/lib/tasks/rubber.rake +0 -15
- data/generators/vulcanize/templates/base/script/cron-rake +0 -18
- data/generators/vulcanize/templates/base/script/cron-runner +0 -18
- data/generators/vulcanize/templates/base/script/cron-sh +0 -67
- data/generators/vulcanize/templates/base/templates.rb +0 -11
- data/generators/vulcanize/templates/base/templates.yml +0 -6
- data/generators/vulcanize/templates/cassandra/config/rubber/deploy-cassandra.rb +0 -88
- data/generators/vulcanize/templates/complete_mongrel_mysql/config/rubber/rubber-complete.yml +0 -41
- data/generators/vulcanize/templates/complete_mongrel_mysql/templates.yml +0 -6
- data/generators/vulcanize/templates/complete_passenger/config/rubber/rubber-complete.yml +0 -40
- data/generators/vulcanize/templates/haproxy/config/rubber/deploy-haproxy.rb +0 -45
- data/generators/vulcanize/templates/mongodb/config/rubber/deploy-mongodb.rb +0 -53
- data/generators/vulcanize/templates/mongodb/config/rubber/role/mongodb/mongodb.conf +0 -89
- data/generators/vulcanize/templates/mongodb/config/rubber/role/mongodb/monit-mongodb.cnf +0 -10
- data/generators/vulcanize/templates/mongodb/templates.yml +0 -3
- data/generators/vulcanize/templates/mongrel/config/rubber/rubber-mongrel.yml +0 -9
- data/generators/vulcanize/templates/monit/config/rubber/deploy-monit.rb +0 -33
- data/generators/vulcanize/templates/monit/config/rubber/rubber-monit.yml +0 -6
- data/generators/vulcanize/templates/munin/config/rubber/deploy-munin.rb +0 -46
- data/generators/vulcanize/templates/munin/config/rubber/role/web_tools/munin-plugins.conf +0 -31
- data/generators/vulcanize/templates/munin/config/rubber/rubber-munin.yml +0 -8
- data/generators/vulcanize/templates/munin/script/munin/example_mysql_query.rb +0 -55
- data/generators/vulcanize/templates/munin/script/munin/example_simple.rb +0 -24
- data/generators/vulcanize/templates/mysql/config/rubber/deploy-mysql.rb +0 -169
- data/generators/vulcanize/templates/mysql/config/rubber/role/db/crontab +0 -14
- data/generators/vulcanize/templates/mysql/config/rubber/role/db/monit-mysql.cnf +0 -10
- data/generators/vulcanize/templates/mysql_cluster/config/rubber/common/mysql_cluster_migrations.rb +0 -13
- data/generators/vulcanize/templates/mysql_cluster/config/rubber/role/mysql_sql/monit-mysql_cluster_sql.cnf +0 -10
- data/generators/vulcanize/templates/mysql_cluster/config/rubber/rubber-mysql_cluster.yml +0 -32
- data/generators/vulcanize/templates/mysql_proxy/config/rubber/common/database.yml +0 -16
- data/generators/vulcanize/templates/mysql_proxy/config/rubber/common/monit-mysql_proxy.cnf +0 -10
- data/generators/vulcanize/templates/nginx/config/rubber/role/web_tools/nginx-tools.conf +0 -55
- data/generators/vulcanize/templates/passenger/config/rubber/role/passenger/passenger.conf +0 -41
- data/generators/vulcanize/templates/passenger/config/rubber/rubber-passenger.yml +0 -15
- data/generators/vulcanize/templates/passenger_nginx/config/rubber/deploy-passenger_nginx.rb +0 -86
- data/generators/vulcanize/templates/passenger_nginx/config/rubber/role/passenger_nginx/application.conf +0 -30
- data/generators/vulcanize/templates/passenger_nginx/config/rubber/role/passenger_nginx/nginx.conf +0 -65
- data/generators/vulcanize/templates/passenger_nginx/config/rubber/role/web_tools/tools-index.html +0 -34
- data/generators/vulcanize/templates/passenger_nginx/config/rubber/rubber-passenger_nginx.yml +0 -20
- data/generators/vulcanize/templates/postgresql/config/rubber/common/database.yml +0 -12
- data/generators/vulcanize/templates/postgresql/config/rubber/deploy-postgresql.rb +0 -160
- data/generators/vulcanize/templates/postgresql/config/rubber/role/db/monit-postgresql.conf +0 -10
- data/generators/vulcanize/templates/postgresql/config/rubber/role/db/pg_hba.conf +0 -90
- data/generators/vulcanize/templates/postgresql/config/rubber/role/db/postgresql.conf +0 -544
- data/generators/vulcanize/templates/postgresql/config/rubber/role/postgresql_slave/recovery.conf +0 -120
- data/generators/vulcanize/templates/redis/config/rubber/deploy-redis.rb +0 -88
- data/generators/vulcanize/templates/redis/config/rubber/role/redis/crontab +0 -15
- data/generators/vulcanize/templates/redis/config/rubber/role/redis/monit-redis.conf +0 -8
- data/generators/vulcanize/templates/redis/config/rubber/rubber-redis.yml +0 -13
- data/generators/vulcanize/templates/resque/config/rubber/common/resque.yml +0 -5
- data/generators/vulcanize/templates/resque/config/rubber/deploy-resque.rb +0 -71
- data/generators/vulcanize/templates/resque/config/rubber/role/resque_web/monit-resque_web.conf +0 -14
- data/generators/vulcanize/templates/resque/config/rubber/role/resque_worker/monit-resque_worker.conf +0 -19
- data/generators/vulcanize/templates/resque/script/resque_worker_management.rb +0 -144
- data/generators/vulcanize/templates/resque/templates.rb +0 -1
- data/generators/vulcanize/templates/sphinx/config/rubber/common/sphinx.yml +0 -46
- data/generators/vulcanize/templates/sphinx/config/rubber/role/sphinx/crontab +0 -11
- data/generators/vulcanize/vulcanize_generator.rb +0 -184
- data/lib/generators/vulcanize/USAGE +0 -6
- data/lib/generators/vulcanize/templates/apache/config/rubber/deploy-apache.rb +0 -51
- data/lib/generators/vulcanize/templates/apache/config/rubber/role/apache/deflate.conf +0 -10
- data/lib/generators/vulcanize/templates/apache/config/rubber/role/apache/expires.conf +0 -9
- data/lib/generators/vulcanize/templates/apache/config/rubber/role/apache/headers.conf +0 -6
- data/lib/generators/vulcanize/templates/apache/config/rubber/role/apache/ports.conf +0 -8
- data/lib/generators/vulcanize/templates/apache/config/rubber/role/apache/setenvif.conf +0 -52
- data/lib/generators/vulcanize/templates/apache/config/rubber/role/web_tools/tools-apache-vhost.conf +0 -79
- data/lib/generators/vulcanize/templates/apache/config/rubber/role/web_tools/tools-index.html +0 -34
- data/lib/generators/vulcanize/templates/apache/config/rubber/rubber-apache.yml +0 -6
- data/lib/generators/vulcanize/templates/apache/templates.yml +0 -1
- data/lib/generators/vulcanize/templates/base/Rakefile +0 -27
- data/lib/generators/vulcanize/templates/base/config/rubber/common/crontab +0 -21
- data/lib/generators/vulcanize/templates/base/config/rubber/common/monit-postfix.conf +0 -8
- data/lib/generators/vulcanize/templates/base/config/rubber/common/rsyslog.conf +0 -71
- data/lib/generators/vulcanize/templates/base/config/rubber/common/rubber.profile +0 -13
- data/lib/generators/vulcanize/templates/base/lib/tasks/rubber.rake +0 -15
- data/lib/generators/vulcanize/templates/base/script/cron-rake +0 -18
- data/lib/generators/vulcanize/templates/base/script/cron-runner +0 -18
- data/lib/generators/vulcanize/templates/base/script/cron-sh +0 -67
- data/lib/generators/vulcanize/templates/base/templates.rb +0 -11
- data/lib/generators/vulcanize/templates/base/templates.yml +0 -6
- data/lib/generators/vulcanize/templates/cassandra/config/rubber/role/cassandra/cassandra.in.sh +0 -60
- data/lib/generators/vulcanize/templates/cassandra/config/rubber/role/cassandra/cassandra.yaml +0 -210
- data/lib/generators/vulcanize/templates/cassandra/config/rubber/role/cassandra/log4j-server.properties +0 -45
- data/lib/generators/vulcanize/templates/cassandra/config/rubber/role/cassandra/monit-cassandra.conf +0 -8
- data/lib/generators/vulcanize/templates/cassandra/config/rubber/rubber-cassandra.yml +0 -18
- data/lib/generators/vulcanize/templates/cassandra/templates.yml +0 -1
- data/lib/generators/vulcanize/templates/complete_mongrel_mysql/config/rubber/role/haproxy/haproxy-mongrel.conf +0 -23
- data/lib/generators/vulcanize/templates/complete_mongrel_mysql/config/rubber/role/nginx/nginx-mongrel.conf +0 -113
- data/lib/generators/vulcanize/templates/complete_passenger/config/rubber/role/haproxy/haproxy-passenger.conf +0 -21
- data/lib/generators/vulcanize/templates/complete_passenger/templates.rb +0 -9
- data/lib/generators/vulcanize/templates/complete_passenger/templates.yml +0 -9
- data/lib/generators/vulcanize/templates/complete_passenger_mysql/templates.yml +0 -4
- data/lib/generators/vulcanize/templates/complete_passenger_nginx/config/rubber/role/haproxy/haproxy-passenger.conf +0 -21
- data/lib/generators/vulcanize/templates/complete_passenger_nginx/config/rubber/rubber-complete.yml +0 -38
- data/lib/generators/vulcanize/templates/complete_passenger_nginx/templates.rb +0 -8
- data/lib/generators/vulcanize/templates/complete_passenger_nginx/templates.yml +0 -8
- data/lib/generators/vulcanize/templates/complete_passenger_nginx_mysql/templates.yml +0 -4
- data/lib/generators/vulcanize/templates/complete_passenger_nginx_postgresql/templates.yml +0 -4
- data/lib/generators/vulcanize/templates/complete_passenger_postgresql/templates.yml +0 -4
- data/lib/generators/vulcanize/templates/cruise/config/rubber/deploy-cruise.rb +0 -72
- data/lib/generators/vulcanize/templates/cruise/config/rubber/role/cruise/cruise +0 -40
- data/lib/generators/vulcanize/templates/cruise/config/rubber/role/cruise/my.cnf +0 -165
- data/lib/generators/vulcanize/templates/cruise/config/rubber/role/cruise/production.rb +0 -8
- data/lib/generators/vulcanize/templates/cruise/config/rubber/role/cruise/site_config.rb +0 -76
- data/lib/generators/vulcanize/templates/cruise/config/rubber/role/web_tools/cruise-nginx.conf +0 -11
- data/lib/generators/vulcanize/templates/cruise/config/rubber/rubber-cruise.yml +0 -18
- data/lib/generators/vulcanize/templates/cruise/templates.yml +0 -1
- data/lib/generators/vulcanize/templates/haproxy/config/rubber/role/haproxy/haproxy-base.conf +0 -26
- data/lib/generators/vulcanize/templates/haproxy/config/rubber/role/haproxy/haproxy-default.conf +0 -8
- data/lib/generators/vulcanize/templates/haproxy/config/rubber/role/haproxy/monit-haproxy.conf +0 -8
- data/lib/generators/vulcanize/templates/haproxy/config/rubber/role/haproxy/syslog-haproxy.conf +0 -11
- data/lib/generators/vulcanize/templates/haproxy/config/rubber/role/haproxy/syslogd-default.conf +0 -21
- data/lib/generators/vulcanize/templates/haproxy/config/rubber/role/web_tools/haproxy-nginx.conf +0 -10
- data/lib/generators/vulcanize/templates/haproxy/config/rubber/rubber-haproxy.yml +0 -7
- data/lib/generators/vulcanize/templates/haproxy/templates.yml +0 -1
- data/lib/generators/vulcanize/templates/jetty/config/rubber/deploy-jetty.rb +0 -59
- data/lib/generators/vulcanize/templates/jetty/config/rubber/role/jetty/jetty.sh +0 -589
- data/lib/generators/vulcanize/templates/jetty/config/rubber/role/jetty/jetty.xml +0 -199
- data/lib/generators/vulcanize/templates/jetty/config/rubber/role/jetty/monit-jetty.conf +0 -8
- data/lib/generators/vulcanize/templates/jetty/config/rubber/rubber-jetty.yml +0 -10
- data/lib/generators/vulcanize/templates/jetty/templates.yml +0 -1
- data/lib/generators/vulcanize/templates/memcached/config/memcached.yml +0 -28
- data/lib/generators/vulcanize/templates/memcached/config/rubber/common/memcached.yml +0 -14
- data/lib/generators/vulcanize/templates/memcached/config/rubber/role/memcached/memcached.conf +0 -52
- data/lib/generators/vulcanize/templates/memcached/config/rubber/role/memcached/memcached_munin_plugin +0 -249
- data/lib/generators/vulcanize/templates/memcached/config/rubber/rubber-memcached.yml +0 -7
- data/lib/generators/vulcanize/templates/memcached/templates.yml +0 -1
- data/lib/generators/vulcanize/templates/minimal_mysql/templates.yml +0 -7
- data/lib/generators/vulcanize/templates/minimal_nodb/templates.yml +0 -6
- data/lib/generators/vulcanize/templates/minimal_passenger_nginx/config/rubber/rubber-complete.yml +0 -37
- data/lib/generators/vulcanize/templates/minimal_passenger_nginx/templates.yml +0 -4
- data/lib/generators/vulcanize/templates/mongodb/config/rubber/rubber-mongodb.yml +0 -8
- data/lib/generators/vulcanize/templates/mongodb/templates.yml +0 -3
- data/lib/generators/vulcanize/templates/mongrel/config/rubber/deploy-mongrel.rb +0 -75
- data/lib/generators/vulcanize/templates/mongrel/config/rubber/role/mongrel/mongrel_cluster.yml +0 -12
- data/lib/generators/vulcanize/templates/mongrel/config/rubber/role/mongrel/monit-mongrel.conf +0 -20
- data/lib/generators/vulcanize/templates/mongrel/templates.yml +0 -1
- data/lib/generators/vulcanize/templates/monit/config/rubber/common/monit-default.conf +0 -15
- data/lib/generators/vulcanize/templates/monit/config/rubber/common/monit.conf +0 -252
- data/lib/generators/vulcanize/templates/monit/config/rubber/role/web_tools/monit-admin-nginx.conf +0 -11
- data/lib/generators/vulcanize/templates/monit/config/rubber/rubber-monit.yml +0 -6
- data/lib/generators/vulcanize/templates/monit/templates.yml +0 -1
- data/lib/generators/vulcanize/templates/munin/config/rubber/common/monit-munin.conf +0 -8
- data/lib/generators/vulcanize/templates/munin/config/rubber/common/munin-node.conf +0 -48
- data/lib/generators/vulcanize/templates/munin/config/rubber/common/munin-plugins.conf +0 -11
- data/lib/generators/vulcanize/templates/munin/config/rubber/deploy-munin.rb +0 -46
- data/lib/generators/vulcanize/templates/munin/config/rubber/role/web_tools/munin-nginx.conf +0 -8
- data/lib/generators/vulcanize/templates/munin/config/rubber/role/web_tools/munin.conf +0 -116
- data/lib/generators/vulcanize/templates/munin/config/rubber/rubber-munin.yml +0 -8
- data/lib/generators/vulcanize/templates/munin/templates.yml +0 -1
- data/lib/generators/vulcanize/templates/mysql/config/rubber/common/database.yml +0 -12
- data/lib/generators/vulcanize/templates/mysql/config/rubber/role/db/apparmor-mysql.conf +0 -46
- data/lib/generators/vulcanize/templates/mysql/config/rubber/role/db/my.cnf +0 -163
- data/lib/generators/vulcanize/templates/mysql/config/rubber/role/mysql_slave/mysql_slave_munin_plugin +0 -51
- data/lib/generators/vulcanize/templates/mysql/config/rubber/rubber-mysql.yml +0 -47
- data/lib/generators/vulcanize/templates/mysql/templates.yml +0 -1
- data/lib/generators/vulcanize/templates/mysql_cluster/config/rubber/deploy-mysql_cluster.rb +0 -177
- data/lib/generators/vulcanize/templates/mysql_cluster/config/rubber/role/mysql_data/my.cnf +0 -15
- data/lib/generators/vulcanize/templates/mysql_cluster/config/rubber/role/mysql_mgm/ndb_mgmd.cnf +0 -39
- data/lib/generators/vulcanize/templates/mysql_cluster/config/rubber/role/mysql_sql/monit-mysql_cluster_sql.cnf +0 -10
- data/lib/generators/vulcanize/templates/mysql_cluster/config/rubber/role/mysql_sql/my.cnf +0 -23
- data/lib/generators/vulcanize/templates/mysql_cluster/templates.yml +0 -1
- data/lib/generators/vulcanize/templates/mysql_proxy/config/rubber/common/mysql-proxy +0 -154
- data/lib/generators/vulcanize/templates/mysql_proxy/config/rubber/common/mysql-proxy.conf +0 -10
- data/lib/generators/vulcanize/templates/mysql_proxy/config/rubber/common/mysql-proxy.lua +0 -5
- data/lib/generators/vulcanize/templates/mysql_proxy/config/rubber/deploy-mysql_proxy.rb +0 -52
- data/lib/generators/vulcanize/templates/mysql_proxy/config/rubber/rubber-mysql_proxy.yml +0 -11
- data/lib/generators/vulcanize/templates/mysql_proxy/templates.yml +0 -1
- data/lib/generators/vulcanize/templates/nginx/config/rubber/deploy-nginx.rb +0 -45
- data/lib/generators/vulcanize/templates/nginx/config/rubber/role/nginx/crontab +0 -9
- data/lib/generators/vulcanize/templates/nginx/config/rubber/role/nginx/monit-nginx.conf +0 -7
- data/lib/generators/vulcanize/templates/nginx/config/rubber/role/nginx/nginx.conf +0 -42
- data/lib/generators/vulcanize/templates/nginx/config/rubber/role/web_tools/tools-index.html +0 -30
- data/lib/generators/vulcanize/templates/nginx/config/rubber/role/web_tools/tools-nginx.auth +0 -7
- data/lib/generators/vulcanize/templates/nginx/config/rubber/rubber-nginx.yml +0 -10
- data/lib/generators/vulcanize/templates/nginx/templates.yml +0 -1
- data/lib/generators/vulcanize/templates/passenger/config/rubber/deploy-passenger.rb +0 -51
- data/lib/generators/vulcanize/templates/passenger/config/rubber/role/passenger/munin-passenger-memory.conf +0 -34
- data/lib/generators/vulcanize/templates/passenger/config/rubber/role/passenger/munin-passenger.conf +0 -47
- data/lib/generators/vulcanize/templates/passenger/config/rubber/role/passenger/passenger-apache-vhost.conf +0 -48
- data/lib/generators/vulcanize/templates/passenger/templates.yml +0 -3
- data/lib/generators/vulcanize/templates/passenger_nginx/config/rubber/role/passenger_nginx/crontab +0 -8
- data/lib/generators/vulcanize/templates/passenger_nginx/config/rubber/role/passenger_nginx/monit-nginx.conf +0 -7
- data/lib/generators/vulcanize/templates/passenger_nginx/config/rubber/role/passenger_nginx/munin-passenger-memory.conf +0 -34
- data/lib/generators/vulcanize/templates/passenger_nginx/config/rubber/role/passenger_nginx/munin-passenger-sudoers.conf +0 -8
- data/lib/generators/vulcanize/templates/passenger_nginx/config/rubber/role/passenger_nginx/munin-passenger.conf +0 -47
- data/lib/generators/vulcanize/templates/passenger_nginx/config/rubber/role/passenger_nginx/nginx +0 -101
- data/lib/generators/vulcanize/templates/passenger_nginx/config/rubber/role/passenger_nginx/passenger_nginx.conf +0 -30
- data/lib/generators/vulcanize/templates/passenger_nginx/config/rubber/role/web_tools/nginx-tools.conf +0 -55
- data/lib/generators/vulcanize/templates/passenger_nginx/config/rubber/role/web_tools/tools-nginx.auth +0 -7
- data/lib/generators/vulcanize/templates/passenger_nginx/templates.yml +0 -1
- data/lib/generators/vulcanize/templates/postgresql/config/rubber/role/db/crontab +0 -14
- data/lib/generators/vulcanize/templates/postgresql/config/rubber/role/db/munin-postgresql.conf +0 -7
- data/lib/generators/vulcanize/templates/postgresql/config/rubber/role/db/pg_hba.conf +0 -90
- data/lib/generators/vulcanize/templates/postgresql/config/rubber/role/db/postgresql-sysctl.conf +0 -6
- data/lib/generators/vulcanize/templates/postgresql/config/rubber/rubber-postgresql.yml +0 -45
- data/lib/generators/vulcanize/templates/postgresql/templates.yml +0 -1
- data/lib/generators/vulcanize/templates/redis/config/rubber/deploy-redis.rb +0 -88
- data/lib/generators/vulcanize/templates/redis/config/rubber/role/redis/monit-redis.conf +0 -8
- data/lib/generators/vulcanize/templates/redis/config/rubber/role/redis/redis-sysctl.conf +0 -7
- data/lib/generators/vulcanize/templates/redis/config/rubber/role/redis/redis.conf +0 -434
- data/lib/generators/vulcanize/templates/redis/config/rubber/rubber-redis.yml +0 -13
- data/lib/generators/vulcanize/templates/redis/templates.yml +0 -1
- data/lib/generators/vulcanize/templates/resque/config/initializers/resque.rb +0 -15
- data/lib/generators/vulcanize/templates/resque/config/rubber/common/resque.yml +0 -5
- data/lib/generators/vulcanize/templates/resque/config/rubber/deploy-resque.rb +0 -71
- data/lib/generators/vulcanize/templates/resque/config/rubber/role/resque_web/monit-resque_web.conf +0 -14
- data/lib/generators/vulcanize/templates/resque/config/rubber/role/resque_worker/monit-resque_worker.conf +0 -19
- data/lib/generators/vulcanize/templates/resque/config/rubber/rubber-resque.yml +0 -18
- data/lib/generators/vulcanize/templates/resque/script/resque_worker_management.rb +0 -144
- data/lib/generators/vulcanize/templates/resque/templates.rb +0 -1
- data/lib/generators/vulcanize/templates/resque/templates.yml +0 -3
- data/lib/generators/vulcanize/templates/sphinx/config/rubber/deploy-sphinx.rb +0 -112
- data/lib/generators/vulcanize/templates/sphinx/config/rubber/role/sphinx/crontab +0 -11
- data/lib/generators/vulcanize/templates/sphinx/config/rubber/role/sphinx/monit-sphinx.conf +0 -13
- data/lib/generators/vulcanize/templates/sphinx/config/rubber/rubber-sphinx.yml +0 -6
- data/lib/generators/vulcanize/templates/sphinx/templates.yml +0 -1
- data/lib/generators/vulcanize/vulcanize_generator.rb +0 -184
- data/lib/rubber/tasks/rubber.rb +0 -281
@@ -0,0 +1,79 @@
|
|
1
|
+
<%
|
2
|
+
@path = "#{Rubber.root}/config/unicorn.rb"
|
3
|
+
%>
|
4
|
+
worker_processes 2
|
5
|
+
working_directory "<%= Rubber.root %>"
|
6
|
+
|
7
|
+
# This loads the application in the master process before forking
|
8
|
+
# worker processes
|
9
|
+
# Read more about it here:
|
10
|
+
# http://unicorn.bogomips.org/Unicorn/Configurator.html
|
11
|
+
preload_app true
|
12
|
+
|
13
|
+
timeout 30
|
14
|
+
|
15
|
+
# This is where we specify the socket.
|
16
|
+
# We will point the upstream Nginx module to this socket later on
|
17
|
+
listen "/var/run/unicorn.sock", :backlog => 64
|
18
|
+
|
19
|
+
pid "/var/run/unicorn.pid"
|
20
|
+
|
21
|
+
# Set the path of the log files inside the log folder of the testapp
|
22
|
+
stderr_path "<%= Rubber.root %>/log/unicorn.stderr.log"
|
23
|
+
stdout_path "<%= Rubber.root %>/log/unicorn.stdout.log"
|
24
|
+
|
25
|
+
before_fork do |server, worker|
|
26
|
+
##
|
27
|
+
# When sent a USR2, Unicorn will suffix its pidfile with .oldbin and
|
28
|
+
# immediately start loading up a new version of itself (loaded with a new
|
29
|
+
# version of our app). When this new Unicorn is completely loaded
|
30
|
+
# it will begin spawning workers. The first worker spawned will check to
|
31
|
+
# see if an .oldbin pidfile exists. If so, this means we've just booted up
|
32
|
+
# a new Unicorn and need to tell the old one that it can now die. To do so
|
33
|
+
# we send it a QUIT.
|
34
|
+
#
|
35
|
+
# Using this method we get 0 downtime deploys.
|
36
|
+
old_pid = "/var/run/unicorn.pid.oldbin"
|
37
|
+
if File.exists?(old_pid) && server.pid != old_pid
|
38
|
+
begin
|
39
|
+
Process.kill("QUIT", File.read(old_pid).to_i)
|
40
|
+
rescue Errno::ENOENT, Errno::ESRCH
|
41
|
+
# someone else did our job for us
|
42
|
+
end
|
43
|
+
end
|
44
|
+
|
45
|
+
# This option works in together with preload_app true setting
|
46
|
+
# What is does is prevent the master process from holding
|
47
|
+
# the database connection
|
48
|
+
defined?(ActiveRecord::Base) and
|
49
|
+
ActiveRecord::Base.connection.disconnect!
|
50
|
+
end
|
51
|
+
|
52
|
+
|
53
|
+
after_fork do |server, worker|
|
54
|
+
# Unicorn master is started as root, which is fine, but let's
|
55
|
+
# drop the workers to www-data:www-data
|
56
|
+
begin
|
57
|
+
uid, gid = Process.euid, Process.egid
|
58
|
+
user, group = '#{rubber_env.app_user}', '#{rubber_env.app_user}'
|
59
|
+
target_uid = Etc.getpwnam(user).uid
|
60
|
+
target_gid = Etc.getgrnam(group).gid
|
61
|
+
worker.tmp.chown(target_uid, target_gid)
|
62
|
+
if uid != target_uid || gid != target_gid
|
63
|
+
Process.initgroups(user, target_gid)
|
64
|
+
Process::GID.change_privilege(target_gid)
|
65
|
+
Process::UID.change_privilege(target_uid)
|
66
|
+
end
|
67
|
+
rescue => e
|
68
|
+
if RAILS_ENV == 'development'
|
69
|
+
STDERR.puts "couldn't change user, oh well"
|
70
|
+
else
|
71
|
+
raise e
|
72
|
+
end
|
73
|
+
end
|
74
|
+
|
75
|
+
# Here we are establishing the connection after forking worker
|
76
|
+
# processes
|
77
|
+
defined?(ActiveRecord::Base) and
|
78
|
+
ActiveRecord::Base.establish_connection
|
79
|
+
end
|
@@ -0,0 +1,172 @@
|
|
1
|
+
require File.expand_path(File.join(__FILE__, '../..', 'test_helper'))
|
2
|
+
require 'rubber/cloud/aws_table_store'
|
3
|
+
|
4
|
+
class AwsTableStoreTest < Test::Unit::TestCase
|
5
|
+
|
6
|
+
context "aws table store" do
|
7
|
+
|
8
|
+
setup do
|
9
|
+
@provider = ::Fog::AWS::SimpleDB.new(:aws_access_key_id => 'XXX',
|
10
|
+
:aws_secret_access_key => 'YYY')
|
11
|
+
@table = 'mytable'
|
12
|
+
@provider.create_domain(@table)
|
13
|
+
@table_store = Rubber::Cloud::AwsTableStore.new(@provider, @table)
|
14
|
+
end
|
15
|
+
|
16
|
+
should "require a table" do
|
17
|
+
|
18
|
+
assert_raise do
|
19
|
+
Rubber::Cloud::AwsTableStore.new(@provider, nil)
|
20
|
+
end
|
21
|
+
|
22
|
+
assert_raise do
|
23
|
+
Rubber::Cloud::AwsTableStore.new(@provider, "")
|
24
|
+
end
|
25
|
+
|
26
|
+
assert Rubber::Cloud::AwsTableStore.new(@provider, @table)
|
27
|
+
end
|
28
|
+
|
29
|
+
context "ensure_table" do
|
30
|
+
|
31
|
+
should "created table if not there" do
|
32
|
+
assert_raises { @provider.domain_metadata('sometable') }
|
33
|
+
@table_store = Rubber::Cloud::AwsTableStore.new(@provider, 'sometable')
|
34
|
+
assert @provider.domain_metadata('sometable')
|
35
|
+
end
|
36
|
+
|
37
|
+
should "still work if table already exists" do
|
38
|
+
@provider.create_domain('sometable')
|
39
|
+
assert @provider.domain_metadata('sometable')
|
40
|
+
@table_store = Rubber::Cloud::AwsTableStore.new(@provider, 'sometable')
|
41
|
+
assert @provider.domain_metadata('sometable')
|
42
|
+
end
|
43
|
+
|
44
|
+
end
|
45
|
+
|
46
|
+
context 'encode and decode' do
|
47
|
+
|
48
|
+
setup do
|
49
|
+
@data = [123, "foo", {'foo' => 'bar'}, ["foo", "bar"]]
|
50
|
+
end
|
51
|
+
|
52
|
+
should 'roundtrip' do
|
53
|
+
@data.each do |d|
|
54
|
+
assert_equal d, @table_store.decode(@table_store.encode(d))
|
55
|
+
end
|
56
|
+
end
|
57
|
+
|
58
|
+
should 'decode_attributes' do
|
59
|
+
d = {'"foo"' => ['["bar"]']}
|
60
|
+
assert_equal({'"foo"' => "bar"}, @table_store.decode_attributes(d))
|
61
|
+
end
|
62
|
+
|
63
|
+
end
|
64
|
+
|
65
|
+
context 'put' do
|
66
|
+
|
67
|
+
should 'put data' do
|
68
|
+
@table_store.put('mykey', {'foo' => 'bar'})
|
69
|
+
assert_equal({'foo' => ['["bar"]']},
|
70
|
+
@provider.get_attributes(@table, 'mykey',
|
71
|
+
'AttributeName' => ['foo']).body['Attributes'])
|
72
|
+
end
|
73
|
+
|
74
|
+
should 'overwrite data' do
|
75
|
+
@table_store.put('mykey', {'foo' => 'bar'})
|
76
|
+
@table_store.put('mykey', {'foo' => 'baz'})
|
77
|
+
assert_equal({'foo' => ['["baz"]']},
|
78
|
+
@provider.get_attributes(@table, 'mykey',
|
79
|
+
'AttributeName' => ['foo']).body['Attributes'])
|
80
|
+
end
|
81
|
+
|
82
|
+
end
|
83
|
+
|
84
|
+
context 'get' do
|
85
|
+
|
86
|
+
should 'get data' do
|
87
|
+
@table_store.put('mykey', {'foo' => 'bar', 'baz' => 2})
|
88
|
+
assert_equal({'foo' => 'bar', 'baz' => 2}, @table_store.get('mykey'))
|
89
|
+
assert_equal({'foo' => 'bar', 'baz' => 2}, @table_store.get('mykey', ['foo', 'baz']))
|
90
|
+
assert_equal({'baz' => 2}, @table_store.get('mykey', ['baz']))
|
91
|
+
end
|
92
|
+
|
93
|
+
end
|
94
|
+
|
95
|
+
context 'delete' do
|
96
|
+
|
97
|
+
should 'delete data' do
|
98
|
+
@table_store.put('mykey', {'foo' => 'bar', 'baz' => 2})
|
99
|
+
@table_store.delete('mykey')
|
100
|
+
assert_equal({}, @table_store.get('mykey'))
|
101
|
+
end
|
102
|
+
|
103
|
+
should 'delete partial data' do
|
104
|
+
@table_store.put('mykey', {'foo' => 'bar', 'baz' => 2})
|
105
|
+
@table_store.delete('mykey', ['foo'])
|
106
|
+
assert_equal({'baz' => 2}, @table_store.get('mykey'))
|
107
|
+
end
|
108
|
+
|
109
|
+
end
|
110
|
+
|
111
|
+
# no fog mocks for select, so use mocha
|
112
|
+
context 'find' do
|
113
|
+
|
114
|
+
should 'find all with no params' do
|
115
|
+
response = mock('fog response') do
|
116
|
+
expects(:body).twice().returns({'Items' => {}})
|
117
|
+
end
|
118
|
+
|
119
|
+
@provider.expects(:select).with("select * from `#{@table}` limit 200", {}).returns(response)
|
120
|
+
assert_equal({}, @table_store.find())
|
121
|
+
end
|
122
|
+
|
123
|
+
should 'find with key' do
|
124
|
+
response = mock('fog response') do
|
125
|
+
expects(:body).twice().returns({'Items' => {}})
|
126
|
+
end
|
127
|
+
|
128
|
+
@provider.expects(:select).with("select * from `#{@table}` where ItemName = 'foo' limit 200", {}).returns(response)
|
129
|
+
assert_equal({}, @table_store.find('foo'))
|
130
|
+
end
|
131
|
+
|
132
|
+
should 'find with attributes' do
|
133
|
+
response = mock('fog response') do
|
134
|
+
expects(:body).twice().returns({'Items' => {}})
|
135
|
+
end
|
136
|
+
|
137
|
+
@provider.expects(:select).with("select foo, bar from `#{@table}` limit 200", {}).returns(response)
|
138
|
+
assert_equal({}, @table_store.find(nil, ['foo', 'bar']))
|
139
|
+
end
|
140
|
+
|
141
|
+
should 'find with limit' do
|
142
|
+
response = mock('fog response') do
|
143
|
+
expects(:body).twice().returns({'Items' => {}})
|
144
|
+
end
|
145
|
+
|
146
|
+
@provider.expects(:select).with("select * from `#{@table}` limit 5", {}).returns(response)
|
147
|
+
assert_equal({}, @table_store.find(nil, nil, :limit => 5))
|
148
|
+
end
|
149
|
+
|
150
|
+
should 'find with offset' do
|
151
|
+
response = mock('fog response') do
|
152
|
+
expects(:body).twice().returns({'Items' => {}})
|
153
|
+
end
|
154
|
+
|
155
|
+
@provider.expects(:select).with("select * from `#{@table}` limit 200", {'NextToken' => 'blah'}).returns(response)
|
156
|
+
assert_equal({}, @table_store.find(nil, nil, :offset => 'blah'))
|
157
|
+
end
|
158
|
+
|
159
|
+
should 'add next_offset' do
|
160
|
+
response = mock('fog response') do
|
161
|
+
expects(:body).twice().returns({'Items' => {}, 'NextToken' => 'blah'})
|
162
|
+
end
|
163
|
+
|
164
|
+
@provider.stubs(:select).returns(response)
|
165
|
+
resp = @table_store.find()
|
166
|
+
assert_equal 'blah', resp.next_offset
|
167
|
+
end
|
168
|
+
|
169
|
+
end
|
170
|
+
|
171
|
+
end
|
172
|
+
end
|
@@ -0,0 +1,33 @@
|
|
1
|
+
require File.expand_path(File.join(__FILE__, '../..', 'test_helper'))
|
2
|
+
require 'rubber/cloud/aws'
|
3
|
+
require 'ostruct'
|
4
|
+
|
5
|
+
class AwsTest < Test::Unit::TestCase
|
6
|
+
|
7
|
+
context "aws" do
|
8
|
+
|
9
|
+
setup do
|
10
|
+
env = {'access_key' => "XXX", 'secret_access_key' => "YYY", 'region' => "us-east-1"}
|
11
|
+
env = Rubber::Configuration::Environment::BoundEnv.new(env, nil, nil)
|
12
|
+
@cloud = Rubber::Cloud::Aws.new(env, nil)
|
13
|
+
end
|
14
|
+
|
15
|
+
should "instantiate" do
|
16
|
+
assert @cloud.compute_provider
|
17
|
+
assert @cloud.storage_provider
|
18
|
+
end
|
19
|
+
|
20
|
+
should "provide storage" do
|
21
|
+
assert @cloud.storage('mybucket')
|
22
|
+
end
|
23
|
+
|
24
|
+
should "provide table store" do
|
25
|
+
assert @cloud.table_store('somekey')
|
26
|
+
end
|
27
|
+
|
28
|
+
should "create instance" do
|
29
|
+
assert @cloud.create_instance('', '', '', '')
|
30
|
+
end
|
31
|
+
|
32
|
+
end
|
33
|
+
end
|
@@ -0,0 +1,183 @@
|
|
1
|
+
require File.expand_path(File.join(__FILE__, '../..', 'test_helper'))
|
2
|
+
require 'rubber/cloud/fog_storage'
|
3
|
+
require 'ostruct'
|
4
|
+
|
5
|
+
class FogStorageTest < Test::Unit::TestCase
|
6
|
+
|
7
|
+
context "fog storage" do
|
8
|
+
|
9
|
+
setup do
|
10
|
+
@provider = Fog::Storage.new(:provider => 'AWS',
|
11
|
+
:aws_access_key_id => 'XXX',
|
12
|
+
:aws_secret_access_key => 'YYY')
|
13
|
+
@bucket = 'mybucket'
|
14
|
+
@provider.put_bucket(@bucket)
|
15
|
+
@storage = Rubber::Cloud::FogStorage.new(@provider, @bucket)
|
16
|
+
end
|
17
|
+
|
18
|
+
should "require a bucket" do
|
19
|
+
|
20
|
+
assert_raise do
|
21
|
+
Rubber::Cloud::FogStorage.new(@provider, nil)
|
22
|
+
end
|
23
|
+
|
24
|
+
assert_raise do
|
25
|
+
Rubber::Cloud::FogStorage.new(@provider, "")
|
26
|
+
end
|
27
|
+
|
28
|
+
end
|
29
|
+
|
30
|
+
context "ensure_bucket" do
|
31
|
+
|
32
|
+
should "created bucket if not there" do
|
33
|
+
assert @provider.directories.get('somebucket').nil?
|
34
|
+
@storage = Rubber::Cloud::FogStorage.new(@provider, 'somebucket')
|
35
|
+
@storage.ensure_bucket
|
36
|
+
assert @provider.directories.get('somebucket')
|
37
|
+
end
|
38
|
+
|
39
|
+
should "still work if bucket already exists" do
|
40
|
+
assert @provider.directories.create(:key => 'somebucket')
|
41
|
+
assert @provider.directories.get('somebucket')
|
42
|
+
@storage = Rubber::Cloud::FogStorage.new(@provider, 'somebucket')
|
43
|
+
@storage.ensure_bucket
|
44
|
+
assert @provider.directories.get('somebucket')
|
45
|
+
end
|
46
|
+
|
47
|
+
end
|
48
|
+
|
49
|
+
context 'storing a file' do
|
50
|
+
|
51
|
+
should 'require a key' do
|
52
|
+
assert_raise do
|
53
|
+
@storage.store(nil, "data")
|
54
|
+
end
|
55
|
+
end
|
56
|
+
|
57
|
+
should "store a file path" do
|
58
|
+
@storage.store("filename", "data")
|
59
|
+
|
60
|
+
assert_equal("data", @provider.get_object(@bucket, 'filename').body)
|
61
|
+
end
|
62
|
+
|
63
|
+
should "singlepart files under 5 mb" do
|
64
|
+
@provider.expects(:initiate_multipart_upload).never
|
65
|
+
data = 'a' * (5 * 10**6 - 1)
|
66
|
+
|
67
|
+
@storage.store('filename', data)
|
68
|
+
|
69
|
+
assert_equal data, @provider.get_object(@bucket, 'filename').body
|
70
|
+
end
|
71
|
+
|
72
|
+
should "multipart files over 5 mb" do
|
73
|
+
@storage.expects(:singlepart_store).never
|
74
|
+
data = 'a' * (5 * 10**6 + 1)
|
75
|
+
|
76
|
+
#FIXME: Fog mock for initiate_multipart_upload isn't implemented. Remove mocks when it is
|
77
|
+
@provider.expects(:initiate_multipart_upload).returns(OpenStruct.new(:body => {'UploadId' => 'fake-upload-id'}))
|
78
|
+
@provider.expects(:upload_part).returns(OpenStruct.new(:headers => {'ETag' => 'fake-etag'}))
|
79
|
+
@provider.expects(:complete_multipart_upload)
|
80
|
+
|
81
|
+
io = Tempfile.new('s3-helper-test')
|
82
|
+
io.unlink
|
83
|
+
io.write(data)
|
84
|
+
io.rewind
|
85
|
+
|
86
|
+
@storage.store('filename', io)
|
87
|
+
|
88
|
+
#FIXME: proper assertion when Fog mock supports multipart upload
|
89
|
+
#assert_equal data, @provider.get_object(@bucket, 'filename').body
|
90
|
+
|
91
|
+
end
|
92
|
+
|
93
|
+
end
|
94
|
+
|
95
|
+
|
96
|
+
context 'fetching a file' do
|
97
|
+
|
98
|
+
should 'require a filename' do
|
99
|
+
assert_raise do
|
100
|
+
@storage.fetch(nil)
|
101
|
+
end
|
102
|
+
end
|
103
|
+
|
104
|
+
should "fetch a file with a path" do
|
105
|
+
@provider.put_object(@bucket, 'path/filename', 'some data')
|
106
|
+
|
107
|
+
assert_equal('some data', @storage.fetch("path/filename"))
|
108
|
+
end
|
109
|
+
|
110
|
+
should "return nil for non-existent file" do
|
111
|
+
assert_nil @storage.fetch("path/filename")
|
112
|
+
end
|
113
|
+
|
114
|
+
end
|
115
|
+
|
116
|
+
|
117
|
+
context 'fetching many files' do
|
118
|
+
should "fetch files without a prefix" do
|
119
|
+
@provider.put_object(@bucket, 'path1/file1', 'some data1')
|
120
|
+
@provider.put_object(@bucket, 'path2/file2', 'some data2')
|
121
|
+
|
122
|
+
files = []
|
123
|
+
@storage.walk_tree do |s3_file|
|
124
|
+
files << s3_file
|
125
|
+
end
|
126
|
+
assert_equal 2, files.size
|
127
|
+
assert_equal('path1/file1', files[0].key)
|
128
|
+
assert_equal('some data1', files[0].body)
|
129
|
+
assert_equal('path2/file2', files[1].key)
|
130
|
+
assert_equal('some data2', files[1].body)
|
131
|
+
end
|
132
|
+
|
133
|
+
should "restrict fetched files to a prefix" do
|
134
|
+
@provider.put_object(@bucket, 'path1/file1', 'some data1')
|
135
|
+
@provider.put_object(@bucket, 'path2/file2', 'some data2')
|
136
|
+
|
137
|
+
files = []
|
138
|
+
@storage.walk_tree('path1') do |s3_file|
|
139
|
+
files << s3_file
|
140
|
+
end
|
141
|
+
assert_equal 1, files.size
|
142
|
+
assert_equal('path1/file1', files[0].key)
|
143
|
+
assert_equal('some data1', files[0].body)
|
144
|
+
end
|
145
|
+
|
146
|
+
end
|
147
|
+
|
148
|
+
should "stream a file" do
|
149
|
+
yielded_value = nil
|
150
|
+
@provider.put_object(@bucket, 'path/filename', 'my chunk')
|
151
|
+
|
152
|
+
@storage.fetch("path/filename", {}) { |chunk| yielded_value = chunk }
|
153
|
+
|
154
|
+
assert_equal yielded_value, 'my chunk'
|
155
|
+
end
|
156
|
+
|
157
|
+
should "stream a file for non-existent key" do
|
158
|
+
yielded_value = 'x'
|
159
|
+
|
160
|
+
@storage.fetch("path/filename", {}) { |chunk| yielded_value = chunk }
|
161
|
+
|
162
|
+
assert_equal 'x', yielded_value
|
163
|
+
end
|
164
|
+
|
165
|
+
context 'deleting a file' do
|
166
|
+
should 'require a filename' do
|
167
|
+
assert_raise do
|
168
|
+
@storage.delete(nil)
|
169
|
+
end
|
170
|
+
end
|
171
|
+
|
172
|
+
should 'delete a file' do
|
173
|
+
@provider.put_object(@bucket, 'path/filename', 'some data')
|
174
|
+
assert_equal 1, @provider.get_bucket(@bucket).body['Contents'].size
|
175
|
+
assert_equal 'path/filename', @provider.get_bucket(@bucket).body['Contents'].first['Key']
|
176
|
+
|
177
|
+
@storage.delete('path/filename')
|
178
|
+
assert_equal 0, @provider.get_bucket(@bucket).body['Contents'].size
|
179
|
+
end
|
180
|
+
end
|
181
|
+
|
182
|
+
end
|
183
|
+
end
|