Adoptable Cookbooks List

Looking for a cookbook to adopt? You can now see a list of cookbooks available for adoption!
List of Adoptable Cookbooks

Supermarket Belongs to the Community

Supermarket belongs to the community. While Chef has the responsibility to keep it running and be stewards of its functionality, what it does and how it works is driven by the community. The chef/supermarket repository will continue to be where development of the Supermarket application takes place. Come be part of shaping the direction of Supermarket by opening issues and pull requests or by joining us on the Chef Mailing List.

Select Badges

Select Supported Platforms

RSS

rails_application (14) Versions 0.2.3

Installs/Configures rails_application

Berkshelf/Librarian
Policyfile
Knife
cookbook 'rails_application', '~> 0.2.3'
cookbook 'rails_application', '~> 0.2.3', :supermarket
knife cookbook site install rails_application
knife cookbook site download rails_application
README
Dependencies
Quality

rails_application Cookbook

This cookbooks installs the server-side Rails application. Unlike the official OpsCode cookbooks, this cookbook has all of the possible tweaks externalized in the form of attributes - it was intended that this cookbook is used by a wrapper cookbook that provides the attributes which configure the rails application per the requirements of the actual application.

This cookbook replaces the unicorn process supervisor to be upstart instead of runit, it means that it will work on Ubuntu systems, later versions might allow customizing the process supervisor as well.

Requirements

Tested on Ubuntu 12.04 and depends on several OpsCode official cookbooks that actually do the majority of the work.

packages

This cookbook depends on several OpsCode cookbooks, namely -
  • git
  • ruby
  • nginx
  • unicorn
  • application
  • application_ruby
  • application_nginx
for the rails_application::database_credentials cookbook, you also need -
  • database

Several of the above required minor modifications, all of these have pull requests and tickets with OpsCode, but until these get accepted, forks that include the modifications are available here -

application_ruby cookbook (no pull requests at this time)
OpsCode cookbooks are available at -

Attributes

rails_application::default

<table> <tr> <th>Key</th> <th>Type</th> <th>Description</th> <th>Default</th> </tr> <tr> <td><tt>rails/ruby/version</tt></td> <td>String</td> <td>which ruby version to use, see: ruby cookbook</td> <td><tt>1.9.1</tt></td> </tr> <tr> <td><tt>rails/app/name</tt></td> <td>String</td> <td>how to call the application</td> <td><tt>rails_app</tt></td> </tr> <tr> <td><tt>rails/app/path</tt></td> <td>String</td> <td>where the application is deployed to</td> <td><tt>/var/www/project/{{rails/app/name}}</tt></td> </tr> <tr> <td><tt>rails/app/environment</tt></td> <td>String</td> <td>rails/rack environment name</td> <td><tt>production</tt></td> </tr> <tr> <td><tt>rails/owner</tt></td> <td>String</td> <td>user name to own files and processes</td> <td><tt>deploy</tt></td> </tr> <tr> <td><tt>rails/group</tt></td> <td>String</td> <td>group name to own files and processes</td> <td><tt>deploy</tt></td> </tr> </tr> <tr> <td><tt>rails/packages</tt></td> <td>Array</td> <td>additional packages that need to be installed for the application to work</td> <td><tt>[ ]</tt></td> </tr> <tr> <td><tt>rails/gems</tt></td> <td>Array</td> <td>additional system-wide gems that need to be installed for the application to work</td> <td><tt>[ ]</tt></td> </tr> </table>

Usage

rails_application::default

Just include rails_application in your node's run_list:

{
  "name":"my_node",
  "run_list": [
    "recipe[rails_application]"
  ]
}

Contributing

This cookbook is still a work in progress, you are welcome to help by contributing fixes, documentation and tests.

e.g.

  1. Fork the repository on Github
  2. Create a named feature branch (like add_component_x)
  3. Write you change
  4. Write tests for your change (if applicable)
  5. Run the tests, ensuring they all pass
  6. Submit a Pull Request using Github

License and Authors

License

See LICENSE for full details.

Authors:
Contributors:
  • Daniel github.com/emirikol

Dependent cookbooks

application_nginx >= 0.0.0
application_ruby >= 0.0.0
application >= 2.0.2
unicorn >= 0.0.0
nginx >= 1.2.1
ruby >= 0.0.0
git >= 0.0.0

Contingent cookbooks

There are no cookbooks that are contingent upon this one.

Collaborator Number Metric
            

0.2.3 failed this metric

Failure: Cookbook has 0 collaborators. A cookbook must have at least 2 collaborators to pass this metric.

Contributing File Metric
            

0.2.3 failed this metric

Failure: To pass this metric, your cookbook metadata must include a source url, the source url must be in the form of http://github.com/user/repo, and your repo must contain a CONTRIBUTING.md file

Foodcritic Metric
            

0.2.3 failed this metric

FC007: Ensure recipe dependencies are reflected in cookbook metadata: rails_application/recipes/database_credentials.rb:14
FC007: Ensure recipe dependencies are reflected in cookbook metadata: rails_application/recipes/database_credentials.rb:21
FC053: Metadata uses the unimplemented "recommends" keyword: rails_application/metadata.rb:18
FC064: Ensure issues_url is set in metadata: rails_application/metadata.rb:1
FC065: Ensure source_url is set in metadata: rails_application/metadata.rb:1
FC066: Ensure chef_version is set in metadata: rails_application/metadata.rb:1
FC067: Ensure at least one platform supported in metadata: rails_application/metadata.rb:1
FC069: Ensure standardized license defined in metadata: rails_application/metadata.rb:1
Run with Foodcritic Version 10.3.1 with tags metadata,correctness ~FC031 ~FC045 and failure tags any

License Metric
            

0.2.3 failed this metric

rails_application does not have a valid open source license.
Acceptable licenses include Apache-2.0, apachev2, Apache 2.0, MIT, mit, GPL-2.0, gplv2, GNU Public License 2.0, GPL-3.0, gplv3, GNU Public License 3.0.

No Binaries Metric
            

0.2.3 passed this metric

Publish Metric
            

0.2.3 passed this metric

Supported Platforms Metric
            

0.2.3 failed this metric

rails_application should declare what platform(s) it supports.

Testing File Metric
            

0.2.3 failed this metric

Failure: To pass this metric, your cookbook metadata must include a source url, the source url must be in the form of http://github.com/user/repo, and your repo must contain a TESTING.md file

Version Tag Metric
            

0.2.3 passed this metric