diff --git a/README.md b/README.md index 2b1bfe9..9b6e9aa 100644 --- a/README.md +++ b/README.md @@ -120,7 +120,7 @@ All the exciting stuff is happening in chef-provisioning-crowbar/cookbooks/app/r /$HOME/build_and_test_chef-provisioning-crowbar.sh ```bash -# source the chef-dk env + source the chef-dk env . $HOME/.bash_profile CPC_REPO_PATH= cd ${CPC_REPO_PATH} @@ -134,3 +134,12 @@ cd ${CPC_REPO_PATH}/cookbooks/app/recipes/ # or omit -z to use a chef server indicated elsewhere chef-client ./crowbar_test.rb ``` +## Chef Ready Barclamp + +This workload also installs a small Crowbar barclamp for Chef Integrations. + +At this time, the only purpose of the Chef Integration is +1) provide the target "chef-ready" milestone so that roles can be added before the Chef Provisioning target that are unique to the Chef Provisioning driver +2) to install a SSL Certificate in /etc/chef/trusted_certs so that the Chef Server (assumed to be the Crowbar installed Chef at 192.168.124.10 which is currently hard coded). + +To install the SSL Certificate, you must export the certificate manually and copy the file to `/tftpboot/files/chef/192.168.124.10.crt` and it will be automatically copied to the nodes during bring up. \ No newline at end of file diff --git a/cookbooks/app/recipes/crowbar_test.rb b/cookbooks/app/recipes/crowbar_test.rb index e898f77..4720308 100644 --- a/cookbooks/app/recipes/crowbar_test.rb +++ b/cookbooks/app/recipes/crowbar_test.rb @@ -16,10 +16,10 @@ require 'chef/provisioning' with_driver 'crowbar' -with_chef_server 'https://192.168.124.10', - :client_name => 'metal', - :signing_key_filename => '/etc/chef/client.pem' - +with_chef_server 'https://192.168.124.10:443', + :client_name => 'rack1', + :signing_key_filename => '/home/rob/.chef/client.pem' + # Crowbar these days is defaulting to installing Centos-7.0 # on its slave nodes. # diff --git a/crowbar.yml b/crowbar.yml new file mode 100644 index 0000000..a661b50 --- /dev/null +++ b/crowbar.yml @@ -0,0 +1,45 @@ +# Copyright 2015, RacKN by Rob Hirschfeld +# +# Licensed under the Apache License, Version 2.0 (the "License"); +# you may not use this file except in compliance with the License. +# You may obtain a copy of the License at +# +# http://www.apache.org/licenses/LICENSE-2.0 +# +# Unless required by applicable law or agreed to in writing, software +# distributed under the License is distributed on an "AS IS" BASIS, +# WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. +# See the License for the specific language governing permissions and +# limitations under the License. +# + +barclamp: + name: chef_integration + display: "Chef Integration" + license: "apache2" + copyright: "RackN - Rob Hirschfeld 2015" + os_support: + - centos-6.5 + - redhat-6.5 + - centos-7.0 + - redhat-7.0 + - ubuntu-12.04 + +roles: + - name: chef-ready + description: "Chef Provisioned" + jig: noop + flags: + - milestone + - implicit + requires: + - chef-provisioning + - name: chef-provisioning + description: "prepare node for Chef Server" + jig: script + requires: + - crowbar-installed-node + flags: + - implicit + wants-attribs: + - provisioner-webserver diff --git a/crowbar_engine/barclamp_chef_integration/.gitignore b/crowbar_engine/barclamp_chef_integration/.gitignore new file mode 100644 index 0000000..1dfe31e --- /dev/null +++ b/crowbar_engine/barclamp_chef_integration/.gitignore @@ -0,0 +1,7 @@ +.bundle/ +log/*.log +pkg/ +test/dummy/db/*.sqlite3 +test/dummy/log/*.log +test/dummy/tmp/ +test/dummy/.sass-cache diff --git a/crowbar_engine/barclamp_chef_integration/Gemfile b/crowbar_engine/barclamp_chef_integration/Gemfile new file mode 100644 index 0000000..7c95840 --- /dev/null +++ b/crowbar_engine/barclamp_chef_integration/Gemfile @@ -0,0 +1,17 @@ +source "https://rubygems.org" + +# Declare your gem's dependencies in barclamp_burnin.gemspec. +# Bundler will treat runtime dependencies like base dependencies, and +# development dependencies will be added by default to the :development group. +gemspec + +# jquery-rails is used by the dummy application +# gem "jquery-rails" + +# Declare any dependencies that are still in development here instead of in +# your gemspec. These might include edge Rails or gems from your path or +# Git. Remember to move these dependencies to your gemspec before releasing +# your gem to rubygems.org. + +# To use debugger +# gem 'debugger' diff --git a/crowbar_engine/barclamp_chef_integration/Rakefile b/crowbar_engine/barclamp_chef_integration/Rakefile new file mode 100644 index 0000000..bad970c --- /dev/null +++ b/crowbar_engine/barclamp_chef_integration/Rakefile @@ -0,0 +1,40 @@ +#!/usr/bin/env rake +begin + require 'bundler/setup' +rescue LoadError + puts 'You must `gem install bundler` and `bundle install` to run rake tasks' +end +begin + require 'rdoc/task' +rescue LoadError + require 'rdoc/rdoc' + require 'rake/rdoctask' + RDoc::Task = Rake::RDocTask +end + +RDoc::Task.new(:rdoc) do |rdoc| + rdoc.rdoc_dir = 'rdoc' + rdoc.title = 'BarclampChefIntegration' + rdoc.options << '--line-numbers' + rdoc.rdoc_files.include('README.rdoc') + rdoc.rdoc_files.include('lib/**/*.rb') +end + +APP_RAKEFILE = File.expand_path("../test/dummy/Rakefile", __FILE__) +load 'rails/tasks/engine.rake' + + + +Bundler::GemHelper.install_tasks + +require 'rake/testtask' + +Rake::TestTask.new(:test) do |t| + t.libs << 'lib' + t.libs << 'test' + t.pattern = 'test/**/*_test.rb' + t.verbose = false +end + + +task :default => :test diff --git a/crowbar_engine/barclamp_chef_integration/app/assets/images/barclamp_chef_integration/.gitkeep b/crowbar_engine/barclamp_chef_integration/app/assets/images/barclamp_chef_integration/.gitkeep new file mode 100644 index 0000000..e69de29 diff --git a/crowbar_engine/barclamp_chef_integration/app/assets/javascripts/barclamp_chef_integration/application.js b/crowbar_engine/barclamp_chef_integration/app/assets/javascripts/barclamp_chef_integration/application.js new file mode 100644 index 0000000..9097d83 --- /dev/null +++ b/crowbar_engine/barclamp_chef_integration/app/assets/javascripts/barclamp_chef_integration/application.js @@ -0,0 +1,15 @@ +// This is a manifest file that'll be compiled into application.js, which will include all the files +// listed below. +// +// Any JavaScript/Coffee file within this directory, lib/assets/javascripts, vendor/assets/javascripts, +// or vendor/assets/javascripts of plugins, if any, can be referenced here using a relative path. +// +// It's not advisable to add code directly here, but if you do, it'll appear at the bottom of the +// the compiled file. +// +// WARNING: THE FIRST BLANK LINE MARKS THE END OF WHAT'S TO BE PROCESSED, ANY BLANK LINE SHOULD +// GO AFTER THE REQUIRES BELOW. +// +//= require jquery +//= require jquery_ujs +//= require_tree . diff --git a/crowbar_engine/barclamp_chef_integration/app/assets/stylesheets/barclamp_chef_integration/application.css b/crowbar_engine/barclamp_chef_integration/app/assets/stylesheets/barclamp_chef_integration/application.css new file mode 100644 index 0000000..3192ec8 --- /dev/null +++ b/crowbar_engine/barclamp_chef_integration/app/assets/stylesheets/barclamp_chef_integration/application.css @@ -0,0 +1,13 @@ +/* + * This is a manifest file that'll be compiled into application.css, which will include all the files + * listed below. + * + * Any CSS and SCSS file within this directory, lib/assets/stylesheets, vendor/assets/stylesheets, + * or vendor/assets/stylesheets of plugins, if any, can be referenced here using a relative path. + * + * You're free to add application-wide styles to this file and they'll appear at the top of the + * compiled file, but it's generally better to create a new file per style scope. + * + *= require_self + *= require_tree . + */ diff --git a/crowbar_engine/barclamp_chef_integration/app/controllers/barclamp_chef_integration/application_controller.rb b/crowbar_engine/barclamp_chef_integration/app/controllers/barclamp_chef_integration/application_controller.rb new file mode 100644 index 0000000..4a977c0 --- /dev/null +++ b/crowbar_engine/barclamp_chef_integration/app/controllers/barclamp_chef_integration/application_controller.rb @@ -0,0 +1,19 @@ +# Copyright 2015, RacKN by Rob Hirschfeld +# +# Licensed under the Apache License, Version 2.0 (the "License"); +# you may not use this file except in compliance with the License. +# You may obtain a copy of the License at +# +# http://www.apache.org/licenses/LICENSE-2.0 +# +# Unless required by applicable law or agreed to in writing, software +# distributed under the License is distributed on an "AS IS" BASIS, +# WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. +# See the License for the specific language governing permissions and +# limitations under the License. +# + +module BarclampChefIntegration + class ApplicationController < ActionController::Base + end +end diff --git a/crowbar_engine/barclamp_chef_integration/app/controllers/barclamp_chef_integration/barclamps_controller.rb b/crowbar_engine/barclamp_chef_integration/app/controllers/barclamp_chef_integration/barclamps_controller.rb new file mode 100644 index 0000000..09cecba --- /dev/null +++ b/crowbar_engine/barclamp_chef_integration/app/controllers/barclamp_chef_integration/barclamps_controller.rb @@ -0,0 +1,20 @@ +# Copyright 2015, RackN, Rob Hirschfeld +# +# Licensed under the Apache License, Version 2.0 (the "License"); +# you may not use this file except in compliance with the License. +# You may obtain a copy of the License at +# +# http://www.apache.org/licenses/LICENSE-2.0 +# +# Unless required by applicable law or agreed to in writing, software +# distributed under the License is distributed on an "AS IS" BASIS, +# WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. +# See the License for the specific language governing permissions and +# limitations under the License. +# + +class BarclampChefIntegration::BarclampsController < BarclampsController + def initialize + @service_object = ChefIntegrationService.new logger + end +end diff --git a/crowbar_engine/barclamp_chef_integration/app/helpers/barclamp_chef_integration/application_helper.rb b/crowbar_engine/barclamp_chef_integration/app/helpers/barclamp_chef_integration/application_helper.rb new file mode 100644 index 0000000..15369b2 --- /dev/null +++ b/crowbar_engine/barclamp_chef_integration/app/helpers/barclamp_chef_integration/application_helper.rb @@ -0,0 +1,19 @@ +# Copyright 2015, RacKN by Rob Hirschfeld +# +# Licensed under the Apache License, Version 2.0 (the "License"); +# you may not use this file except in compliance with the License. +# You may obtain a copy of the License at +# +# http://www.apache.org/licenses/LICENSE-2.0 +# +# Unless required by applicable law or agreed to in writing, software +# distributed under the License is distributed on an "AS IS" BASIS, +# WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. +# See the License for the specific language governing permissions and +# limitations under the License. +# + +module BarclampChefIntegration + module ApplicationHelper + end +end diff --git a/crowbar_engine/barclamp_chef_integration/barclamp_chef_integration.gemspec b/crowbar_engine/barclamp_chef_integration/barclamp_chef_integration.gemspec new file mode 100644 index 0000000..e0bd4ac --- /dev/null +++ b/crowbar_engine/barclamp_chef_integration/barclamp_chef_integration.gemspec @@ -0,0 +1,23 @@ +$:.push File.expand_path("../lib", __FILE__) + +# Maintain your gem's version: +require "barclamp_chef_integration/version" + +# Describe your gem and declare its dependencies: +Gem::Specification.new do |s| + s.name = "barclamp_chef_integration" + s.version = BarclampChefIntegration::VERSION + s.authors = ["Rob Hirschfeld"] + s.email = ["rob@rackn.com"] + s.homepage = "" + s.summary = "Chef Integrations for Crowbar" + s.description = "" + + s.files = Dir["{app,config,db,lib}/**/*"] + [ "Rakefile", ] + s.test_files = Dir["test/**/*"] + + s.add_dependency "rails" + # s.add_dependency "jquery-rails" + + # s.add_development_dependency "sqlite3" +end diff --git a/crowbar_engine/barclamp_chef_integration/config/initializers/api.rb b/crowbar_engine/barclamp_chef_integration/config/initializers/api.rb new file mode 100644 index 0000000..ca5a78b --- /dev/null +++ b/crowbar_engine/barclamp_chef_integration/config/initializers/api.rb @@ -0,0 +1,17 @@ +# Copyright 2014, Greg Althaus +# +# Licensed under the Apache License, Version 2.0 (the "License"); +# you may not use this file except in compliance with the License. +# You may obtain a copy of the License at +# +# http://www.apache.org/licenses/LICENSE-2.0 +# +# Unless required by applicable law or agreed to in writing, software +# distributed under the License is distributed on an "AS IS" BASIS, +# WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. +# See the License for the specific language governing permissions and +# limitations under the License. + +bc = Barclamp.table_exists? ? Barclamp.find_by_name("chef_integration") : nil +BarclampChefIntegration::API_VERSION=(bc && bc.api_version || "v1") +BarclampChefIntegration::API_VERSION_ACCEPTS=(bc && bc.api_version_accepts || "v1") diff --git a/crowbar_engine/barclamp_chef_integration/config/locales/en.yml b/crowbar_engine/barclamp_chef_integration/config/locales/en.yml new file mode 100644 index 0000000..3a3d2f9 --- /dev/null +++ b/crowbar_engine/barclamp_chef_integration/config/locales/en.yml @@ -0,0 +1,11 @@ +# Copyright 2015, Rob Hirschfeld +# All Rights Reserved + +en: + barclamp_chef_integration: + node_roles: + common: + roles: + chef-ready: "Chef Ready" + chef-provisioning: "Chef Provisioning Prepared" + attribs: diff --git a/crowbar_engine/barclamp_chef_integration/config/routes.rb b/crowbar_engine/barclamp_chef_integration/config/routes.rb new file mode 100644 index 0000000..d8f79f6 --- /dev/null +++ b/crowbar_engine/barclamp_chef_integration/config/routes.rb @@ -0,0 +1,47 @@ +# Copyright 2014, Greg Althaus +# +# Licensed under the Apache License, Version 2.0 (the "License"); +# you may not use this file except in compliance with the License. +# You may obtain a copy of the License at +# +# http://www.apache.org/licenses/LICENSE-2.0 +# +# Unless required by applicable law or agreed to in writing, software +# distributed under the License is distributed on an "AS IS" BASIS, +# WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. +# See the License for the specific language governing permissions and +# limitations under the License. + +BarclampBurnin::Engine.routes.draw do + + # API routes + scope :defaults => {:format=> 'json'} do + constraints( :api_version => /v[1-9]/ ) do + scope ':api_version' do + + resources :barclamps do + collection do + get :catalog + end + member do + end + end + end + end + end + + # non-API routes + resources :barclamps do + collection do + end + member do + end + end + + +# configure routes for these Burnin barclamps controller actions... +# (other controllers may also need routing configuration!) +# +# initialize + +end diff --git a/crowbar_engine/barclamp_chef_integration/db/seeds.rb b/crowbar_engine/barclamp_chef_integration/db/seeds.rb new file mode 100644 index 0000000..12dfa90 --- /dev/null +++ b/crowbar_engine/barclamp_chef_integration/db/seeds.rb @@ -0,0 +1,3 @@ +source_path = File.expand_path(File.join(__FILE__,"../../../..")) +yml_blob = YAML.load_file(File.join(source_path,"crowbar.yml")) +Barclamp.import("chef_integration",yml_blob,source_path) diff --git a/crowbar_engine/barclamp_chef_integration/lib/barclamp_chef_integration.rb b/crowbar_engine/barclamp_chef_integration/lib/barclamp_chef_integration.rb new file mode 100644 index 0000000..1a66504 --- /dev/null +++ b/crowbar_engine/barclamp_chef_integration/lib/barclamp_chef_integration.rb @@ -0,0 +1,5 @@ +require "barclamp_chef_integration/engine" + +module BarclampChefIntegration + +end diff --git a/crowbar_engine/barclamp_chef_integration/lib/barclamp_chef_integration/engine.rb b/crowbar_engine/barclamp_chef_integration/lib/barclamp_chef_integration/engine.rb new file mode 100644 index 0000000..2e83b6c --- /dev/null +++ b/crowbar_engine/barclamp_chef_integration/lib/barclamp_chef_integration/engine.rb @@ -0,0 +1,5 @@ +module BarclampChefIntegration + class Engine < ::Rails::Engine + isolate_namespace BarclampChefIntegration + end +end diff --git a/crowbar_engine/barclamp_chef_integration/lib/barclamp_chef_integration/version.rb b/crowbar_engine/barclamp_chef_integration/lib/barclamp_chef_integration/version.rb new file mode 100644 index 0000000..211a2a1 --- /dev/null +++ b/crowbar_engine/barclamp_chef_integration/lib/barclamp_chef_integration/version.rb @@ -0,0 +1,3 @@ +module BarclampChefIntegration + VERSION = "0.0.2" +end diff --git a/crowbar_engine/barclamp_chef_integration/lib/tasks/barclamp_chef_integration_tasks.rake b/crowbar_engine/barclamp_chef_integration/lib/tasks/barclamp_chef_integration_tasks.rake new file mode 100644 index 0000000..3df8404 --- /dev/null +++ b/crowbar_engine/barclamp_chef_integration/lib/tasks/barclamp_chef_integration_tasks.rake @@ -0,0 +1,4 @@ +# desc "Explaining what the task does" +# task :barclamp_chef_integration do +# # Task goes here +# end diff --git a/crowbar_engine/barclamp_chef_integration/script/rails b/crowbar_engine/barclamp_chef_integration/script/rails new file mode 100755 index 0000000..f8690c7 --- /dev/null +++ b/crowbar_engine/barclamp_chef_integration/script/rails @@ -0,0 +1,8 @@ +#!/usr/bin/env ruby +# This command will automatically be run when you run "rails" with Rails 3 gems installed from the root of your application. + +ENGINE_ROOT = File.expand_path('../..', __FILE__) +ENGINE_PATH = File.expand_path('../../lib/barclamp_chef_integration/engine', __FILE__) + +require 'rails/all' +require 'rails/engine/commands' diff --git a/crowbar_engine/barclamp_chef_integration/test/barclamp_burnin_test.rb b/crowbar_engine/barclamp_chef_integration/test/barclamp_burnin_test.rb new file mode 100644 index 0000000..e9cf63b --- /dev/null +++ b/crowbar_engine/barclamp_chef_integration/test/barclamp_burnin_test.rb @@ -0,0 +1,7 @@ +require 'test_helper' + +class BarclampBurninTest < ActiveSupport::TestCase + test "truth" do + assert_kind_of Module, BarclampBurnin + end +end diff --git a/crowbar_engine/barclamp_chef_integration/test/dummy/README.rdoc b/crowbar_engine/barclamp_chef_integration/test/dummy/README.rdoc new file mode 100644 index 0000000..3e1c15c --- /dev/null +++ b/crowbar_engine/barclamp_chef_integration/test/dummy/README.rdoc @@ -0,0 +1,261 @@ +== Welcome to Rails + +Rails is a web-application framework that includes everything needed to create +database-backed web applications according to the Model-View-Control pattern. + +This pattern splits the view (also called the presentation) into "dumb" +templates that are primarily responsible for inserting pre-built data in between +HTML tags. The model contains the "smart" domain objects (such as Account, +Product, Person, Post) that holds all the business logic and knows how to +persist themselves to a database. The controller handles the incoming requests +(such as Save New Account, Update Product, Show Post) by manipulating the model +and directing data to the view. + +In Rails, the model is handled by what's called an object-relational mapping +layer entitled Active Record. This layer allows you to present the data from +database rows as objects and embellish these data objects with business logic +methods. You can read more about Active Record in +link:files/vendor/rails/activerecord/README.html. + +The controller and view are handled by the Action Pack, which handles both +layers by its two parts: Action View and Action Controller. These two layers +are bundled in a single package due to their heavy interdependence. This is +unlike the relationship between the Active Record and Action Pack that is much +more separate. Each of these packages can be used independently outside of +Rails. You can read more about Action Pack in +link:files/vendor/rails/actionpack/README.html. + + +== Getting Started + +1. At the command prompt, create a new Rails application: + rails new myapp (where myapp is the application name) + +2. Change directory to myapp and start the web server: + cd myapp; rails server (run with --help for options) + +3. Go to http://localhost:3000/ and you'll see: + "Welcome aboard: You're riding Ruby on Rails!" + +4. Follow the guidelines to start developing your application. You can find +the following resources handy: + +* The Getting Started Guide: http://guides.rubyonrails.org/getting_started.html +* Ruby on Rails Tutorial Book: http://www.railstutorial.org/ + + +== Debugging Rails + +Sometimes your application goes wrong. Fortunately there are a lot of tools that +will help you debug it and get it back on the rails. + +First area to check is the application log files. Have "tail -f" commands +running on the server.log and development.log. Rails will automatically display +debugging and runtime information to these files. Debugging info will also be +shown in the browser on requests from 127.0.0.1. + +You can also log your own messages directly into the log file from your code +using the Ruby logger class from inside your controllers. Example: + + class WeblogController < ActionController::Base + def destroy + @weblog = Weblog.find(params[:id]) + @weblog.destroy + logger.info("#{Time.now} Destroyed Weblog ID ##{@weblog.id}!") + end + end + +The result will be a message in your log file along the lines of: + + Mon Oct 08 14:22:29 +1000 2007 Destroyed Weblog ID #1! + +More information on how to use the logger is at http://www.ruby-doc.org/core/ + +Also, Ruby documentation can be found at http://www.ruby-lang.org/. There are +several books available online as well: + +* Programming Ruby: http://www.ruby-doc.org/docs/ProgrammingRuby/ (Pickaxe) +* Learn to Program: http://pine.fm/LearnToProgram/ (a beginners guide) + +These two books will bring you up to speed on the Ruby language and also on +programming in general. + + +== Debugger + +Debugger support is available through the debugger command when you start your +Mongrel or WEBrick server with --debugger. This means that you can break out of +execution at any point in the code, investigate and change the model, and then, +resume execution! You need to install ruby-debug to run the server in debugging +mode. With gems, use sudo gem install ruby-debug. Example: + + class WeblogController < ActionController::Base + def index + @posts = Post.all + debugger + end + end + +So the controller will accept the action, run the first line, then present you +with a IRB prompt in the server window. Here you can do things like: + + >> @posts.inspect + => "[#nil, "body"=>nil, "id"=>"1"}>, + #"Rails", "body"=>"Only ten..", "id"=>"2"}>]" + >> @posts.first.title = "hello from a debugger" + => "hello from a debugger" + +...and even better, you can examine how your runtime objects actually work: + + >> f = @posts.first + => #nil, "body"=>nil, "id"=>"1"}> + >> f. + Display all 152 possibilities? (y or n) + +Finally, when you're ready to resume execution, you can enter "cont". + + +== Console + +The console is a Ruby shell, which allows you to interact with your +application's domain model. Here you'll have all parts of the application +configured, just like it is when the application is running. You can inspect +domain models, change values, and save to the database. Starting the script +without arguments will launch it in the development environment. + +To start the console, run rails console from the application +directory. + +Options: + +* Passing the -s, --sandbox argument will rollback any modifications + made to the database. +* Passing an environment name as an argument will load the corresponding + environment. Example: rails console production. + +To reload your controllers and models after launching the console run +reload! + +More information about irb can be found at: +link:http://www.rubycentral.org/pickaxe/irb.html + + +== dbconsole + +You can go to the command line of your database directly through rails +dbconsole. You would be connected to the database with the credentials +defined in database.yml. Starting the script without arguments will connect you +to the development database. Passing an argument will connect you to a different +database, like rails dbconsole production. Currently works for MySQL, +PostgreSQL and SQLite 3. + +== Description of Contents + +The default directory structure of a generated Ruby on Rails application: + + |-- app + | |-- assets + | | |-- images + | | |-- javascripts + | | `-- stylesheets + | |-- controllers + | |-- helpers + | |-- mailers + | |-- models + | `-- views + | `-- layouts + |-- config + | |-- environments + | |-- initializers + | `-- locales + |-- db + |-- doc + |-- lib + | |-- assets + | `-- tasks + |-- log + |-- public + |-- script + |-- test + | |-- fixtures + | |-- functional + | |-- integration + | |-- performance + | `-- unit + |-- tmp + | `-- cache + | `-- assets + `-- vendor + |-- assets + | |-- javascripts + | `-- stylesheets + `-- plugins + +app + Holds all the code that's specific to this particular application. + +app/assets + Contains subdirectories for images, stylesheets, and JavaScript files. + +app/controllers + Holds controllers that should be named like weblogs_controller.rb for + automated URL mapping. All controllers should descend from + ApplicationController which itself descends from ActionController::Base. + +app/models + Holds models that should be named like post.rb. Models descend from + ActiveRecord::Base by default. + +app/views + Holds the template files for the view that should be named like + weblogs/index.html.erb for the WeblogsController#index action. All views use + eRuby syntax by default. + +app/views/layouts + Holds the template files for layouts to be used with views. This models the + common header/footer method of wrapping views. In your views, define a layout + using the layout :default and create a file named default.html.erb. + Inside default.html.erb, call <% yield %> to render the view using this + layout. + +app/helpers + Holds view helpers that should be named like weblogs_helper.rb. These are + generated for you automatically when using generators for controllers. + Helpers can be used to wrap functionality for your views into methods. + +config + Configuration files for the Rails environment, the routing map, the database, + and other dependencies. + +db + Contains the database schema in schema.rb. db/migrate contains all the + sequence of Migrations for your schema. + +doc + This directory is where your application documentation will be stored when + generated using rake doc:app + +lib + Application specific libraries. Basically, any kind of custom code that + doesn't belong under controllers, models, or helpers. This directory is in + the load path. + +public + The directory available for the web server. Also contains the dispatchers and the + default HTML files. This should be set as the DOCUMENT_ROOT of your web + server. + +script + Helper scripts for automation and generation. + +test + Unit and functional tests along with fixtures. When using the rails generate + command, template test files will be generated for you and placed in this + directory. + +vendor + External libraries that the application depends on. Also includes the plugins + subdirectory. If the app has frozen rails, those gems also go here, under + vendor/rails/. This directory is in the load path. diff --git a/crowbar_engine/barclamp_chef_integration/test/dummy/Rakefile b/crowbar_engine/barclamp_chef_integration/test/dummy/Rakefile new file mode 100644 index 0000000..3645852 --- /dev/null +++ b/crowbar_engine/barclamp_chef_integration/test/dummy/Rakefile @@ -0,0 +1,7 @@ +#!/usr/bin/env rake +# Add your own tasks in files placed in lib/tasks ending in .rake, +# for example lib/tasks/capistrano.rake, and they will automatically be available to Rake. + +require File.expand_path('../config/application', __FILE__) + +Dummy::Application.load_tasks diff --git a/crowbar_engine/barclamp_chef_integration/test/dummy/app/assets/javascripts/application.js b/crowbar_engine/barclamp_chef_integration/test/dummy/app/assets/javascripts/application.js new file mode 100644 index 0000000..9097d83 --- /dev/null +++ b/crowbar_engine/barclamp_chef_integration/test/dummy/app/assets/javascripts/application.js @@ -0,0 +1,15 @@ +// This is a manifest file that'll be compiled into application.js, which will include all the files +// listed below. +// +// Any JavaScript/Coffee file within this directory, lib/assets/javascripts, vendor/assets/javascripts, +// or vendor/assets/javascripts of plugins, if any, can be referenced here using a relative path. +// +// It's not advisable to add code directly here, but if you do, it'll appear at the bottom of the +// the compiled file. +// +// WARNING: THE FIRST BLANK LINE MARKS THE END OF WHAT'S TO BE PROCESSED, ANY BLANK LINE SHOULD +// GO AFTER THE REQUIRES BELOW. +// +//= require jquery +//= require jquery_ujs +//= require_tree . diff --git a/crowbar_engine/barclamp_chef_integration/test/dummy/app/assets/stylesheets/application.css b/crowbar_engine/barclamp_chef_integration/test/dummy/app/assets/stylesheets/application.css new file mode 100644 index 0000000..3192ec8 --- /dev/null +++ b/crowbar_engine/barclamp_chef_integration/test/dummy/app/assets/stylesheets/application.css @@ -0,0 +1,13 @@ +/* + * This is a manifest file that'll be compiled into application.css, which will include all the files + * listed below. + * + * Any CSS and SCSS file within this directory, lib/assets/stylesheets, vendor/assets/stylesheets, + * or vendor/assets/stylesheets of plugins, if any, can be referenced here using a relative path. + * + * You're free to add application-wide styles to this file and they'll appear at the top of the + * compiled file, but it's generally better to create a new file per style scope. + * + *= require_self + *= require_tree . + */ diff --git a/crowbar_engine/barclamp_chef_integration/test/dummy/app/controllers/application_controller.rb b/crowbar_engine/barclamp_chef_integration/test/dummy/app/controllers/application_controller.rb new file mode 100644 index 0000000..e8065d9 --- /dev/null +++ b/crowbar_engine/barclamp_chef_integration/test/dummy/app/controllers/application_controller.rb @@ -0,0 +1,3 @@ +class ApplicationController < ActionController::Base + protect_from_forgery +end diff --git a/crowbar_engine/barclamp_chef_integration/test/dummy/app/helpers/application_helper.rb b/crowbar_engine/barclamp_chef_integration/test/dummy/app/helpers/application_helper.rb new file mode 100644 index 0000000..de6be79 --- /dev/null +++ b/crowbar_engine/barclamp_chef_integration/test/dummy/app/helpers/application_helper.rb @@ -0,0 +1,2 @@ +module ApplicationHelper +end diff --git a/crowbar_engine/barclamp_chef_integration/test/dummy/app/mailers/.gitkeep b/crowbar_engine/barclamp_chef_integration/test/dummy/app/mailers/.gitkeep new file mode 100644 index 0000000..e69de29 diff --git a/crowbar_engine/barclamp_chef_integration/test/dummy/app/models/.gitkeep b/crowbar_engine/barclamp_chef_integration/test/dummy/app/models/.gitkeep new file mode 100644 index 0000000..e69de29 diff --git a/crowbar_engine/barclamp_chef_integration/test/dummy/app/views/layouts/application.html.erb b/crowbar_engine/barclamp_chef_integration/test/dummy/app/views/layouts/application.html.erb new file mode 100644 index 0000000..4cab268 --- /dev/null +++ b/crowbar_engine/barclamp_chef_integration/test/dummy/app/views/layouts/application.html.erb @@ -0,0 +1,14 @@ + + + + Dummy + <%= stylesheet_link_tag "application", :media => "all" %> + <%= javascript_include_tag "application" %> + <%= csrf_meta_tags %> + + + +<%= yield %> + + + diff --git a/crowbar_engine/barclamp_chef_integration/test/dummy/config.ru b/crowbar_engine/barclamp_chef_integration/test/dummy/config.ru new file mode 100644 index 0000000..1989ed8 --- /dev/null +++ b/crowbar_engine/barclamp_chef_integration/test/dummy/config.ru @@ -0,0 +1,4 @@ +# This file is used by Rack-based servers to start the application. + +require ::File.expand_path('../config/environment', __FILE__) +run Dummy::Application diff --git a/crowbar_engine/barclamp_chef_integration/test/dummy/config/application.rb b/crowbar_engine/barclamp_chef_integration/test/dummy/config/application.rb new file mode 100644 index 0000000..3197f37 --- /dev/null +++ b/crowbar_engine/barclamp_chef_integration/test/dummy/config/application.rb @@ -0,0 +1,59 @@ +require File.expand_path('../boot', __FILE__) + +require 'rails/all' + +Bundler.require(*Rails.groups) +require "barclamp_chef_integration" + +module Dummy + class Application < Rails::Application + # Settings in config/environments/* take precedence over those specified here. + # Application configuration should go into files in config/initializers + # -- all .rb files in that directory are automatically loaded. + + # Custom directories with classes and modules you want to be autoloadable. + # config.autoload_paths += %W(#{config.root}/extras) + + # Only load the plugins named here, in the order given (default is alphabetical). + # :all can be used as a placeholder for all plugins not explicitly named. + # config.plugins = [ :exception_notification, :ssl_requirement, :all ] + + # Activate observers that should always be running. + # config.active_record.observers = :cacher, :garbage_collector, :forum_observer + + # Set Time.zone default to the specified zone and make Active Record auto-convert to this zone. + # Run "rake -D time" for a list of tasks for finding time zone names. Default is UTC. + # config.time_zone = 'Central Time (US & Canada)' + + # The default locale is :en and all translations from config/locales/*.rb,yml are auto loaded. + # config.i18n.load_path += Dir[Rails.root.join('my', 'locales', '*.{rb,yml}').to_s] + # config.i18n.default_locale = :de + + # Configure the default encoding used in templates for Ruby 1.9. + config.encoding = "utf-8" + + # Configure sensitive parameters which will be filtered from the log file. + config.filter_parameters += [:password] + + # Enable escaping HTML in JSON. + config.active_support.escape_html_entities_in_json = true + + # Use SQL instead of Active Record's schema dumper when creating the database. + # This is necessary if your schema can't be completely dumped by the schema dumper, + # like if you have constraints or database-specific column types + # config.active_record.schema_format = :sql + + # Enforce whitelist mode for mass assignment. + # This will create an empty whitelist of attributes available for mass-assignment for all models + # in your app. As such, your models will need to explicitly whitelist or blacklist accessible + # parameters by using an attr_accessible or attr_protected declaration. + config.active_record.whitelist_attributes = true + + # Enable the asset pipeline + config.assets.enabled = true + + # Version of your assets, change this if you want to expire all your assets + config.assets.version = '1.0' + end +end + diff --git a/crowbar_engine/barclamp_chef_integration/test/dummy/config/boot.rb b/crowbar_engine/barclamp_chef_integration/test/dummy/config/boot.rb new file mode 100644 index 0000000..eba0681 --- /dev/null +++ b/crowbar_engine/barclamp_chef_integration/test/dummy/config/boot.rb @@ -0,0 +1,10 @@ +require 'rubygems' +gemfile = File.expand_path('../../../../Gemfile', __FILE__) + +if File.exist?(gemfile) + ENV['BUNDLE_GEMFILE'] = gemfile + require 'bundler' + Bundler.setup +end + +$:.unshift File.expand_path('../../../../lib', __FILE__) \ No newline at end of file diff --git a/crowbar_engine/barclamp_chef_integration/test/dummy/config/database.yml b/crowbar_engine/barclamp_chef_integration/test/dummy/config/database.yml new file mode 100644 index 0000000..51a4dd4 --- /dev/null +++ b/crowbar_engine/barclamp_chef_integration/test/dummy/config/database.yml @@ -0,0 +1,25 @@ +# SQLite version 3.x +# gem install sqlite3 +# +# Ensure the SQLite 3 gem is defined in your Gemfile +# gem 'sqlite3' +development: + adapter: sqlite3 + database: db/development.sqlite3 + pool: 5 + timeout: 5000 + +# Warning: The database defined as "test" will be erased and +# re-generated from your development database when you run "rake". +# Do not set this db to the same as development or production. +test: + adapter: sqlite3 + database: db/test.sqlite3 + pool: 5 + timeout: 5000 + +production: + adapter: sqlite3 + database: db/production.sqlite3 + pool: 5 + timeout: 5000 diff --git a/crowbar_engine/barclamp_chef_integration/test/dummy/config/environment.rb b/crowbar_engine/barclamp_chef_integration/test/dummy/config/environment.rb new file mode 100644 index 0000000..3da5eb9 --- /dev/null +++ b/crowbar_engine/barclamp_chef_integration/test/dummy/config/environment.rb @@ -0,0 +1,5 @@ +# Load the rails application +require File.expand_path('../application', __FILE__) + +# Initialize the rails application +Dummy::Application.initialize! diff --git a/crowbar_engine/barclamp_chef_integration/test/dummy/config/environments/development.rb b/crowbar_engine/barclamp_chef_integration/test/dummy/config/environments/development.rb new file mode 100644 index 0000000..82c74d1 --- /dev/null +++ b/crowbar_engine/barclamp_chef_integration/test/dummy/config/environments/development.rb @@ -0,0 +1,37 @@ +Dummy::Application.configure do + # Settings specified here will take precedence over those in config/application.rb + + # In the development environment your application's code is reloaded on + # every request. This slows down response time but is perfect for development + # since you don't have to restart the web server when you make code changes. + config.cache_classes = false + + # Log error messages when you accidentally call methods on nil. + config.whiny_nils = true + + # Show full error reports and disable caching + config.consider_all_requests_local = true + config.action_controller.perform_caching = false + + # Don't care if the mailer can't send + config.action_mailer.raise_delivery_errors = false + + # Print deprecation notices to the Rails logger + config.active_support.deprecation = :log + + # Only use best-standards-support built into browsers + config.action_dispatch.best_standards_support = :builtin + + # Raise exception on mass assignment protection for Active Record models + config.active_record.mass_assignment_sanitizer = :strict + + # Log the query plan for queries taking more than this (works + # with SQLite, MySQL, and PostgreSQL) + config.active_record.auto_explain_threshold_in_seconds = 0.5 + + # Do not compress assets + config.assets.compress = false + + # Expands the lines which load the assets + config.assets.debug = true +end diff --git a/crowbar_engine/barclamp_chef_integration/test/dummy/config/environments/production.rb b/crowbar_engine/barclamp_chef_integration/test/dummy/config/environments/production.rb new file mode 100644 index 0000000..bdac56a --- /dev/null +++ b/crowbar_engine/barclamp_chef_integration/test/dummy/config/environments/production.rb @@ -0,0 +1,67 @@ +Dummy::Application.configure do + # Settings specified here will take precedence over those in config/application.rb + + # Code is not reloaded between requests + config.cache_classes = true + + # Full error reports are disabled and caching is turned on + config.consider_all_requests_local = false + config.action_controller.perform_caching = true + + # Disable Rails's static asset server (Apache or nginx will already do this) + config.serve_static_assets = false + + # Compress JavaScripts and CSS + config.assets.compress = true + + # Don't fallback to assets pipeline if a precompiled asset is missed + config.assets.compile = false + + # Generate digests for assets URLs + config.assets.digest = true + + # Defaults to nil and saved in location specified by config.assets.prefix + # config.assets.manifest = YOUR_PATH + + # Specifies the header that your server uses for sending files + # config.action_dispatch.x_sendfile_header = "X-Sendfile" # for apache + # config.action_dispatch.x_sendfile_header = 'X-Accel-Redirect' # for nginx + + # Force all access to the app over SSL, use Strict-Transport-Security, and use secure cookies. + # config.force_ssl = true + + # See everything in the log (default is :info) + # config.log_level = :debug + + # Prepend all log lines with the following tags + # config.log_tags = [ :subdomain, :uuid ] + + # Use a different logger for distributed setups + # config.logger = ActiveSupport::TaggedLogging.new(SyslogLogger.new) + + # Use a different cache store in production + # config.cache_store = :mem_cache_store + + # Enable serving of images, stylesheets, and JavaScripts from an asset server + # config.action_controller.asset_host = "http://assets.example.com" + + # Precompile additional assets (application.js, application.css, and all non-JS/CSS are already added) + # config.assets.precompile += %w( search.js ) + + # Disable delivery errors, bad email addresses will be ignored + # config.action_mailer.raise_delivery_errors = false + + # Enable threaded mode + # config.threadsafe! + + # Enable locale fallbacks for I18n (makes lookups for any locale fall back to + # the I18n.default_locale when a translation can not be found) + config.i18n.fallbacks = true + + # Send deprecation notices to registered listeners + config.active_support.deprecation = :notify + + # Log the query plan for queries taking more than this (works + # with SQLite, MySQL, and PostgreSQL) + # config.active_record.auto_explain_threshold_in_seconds = 0.5 +end diff --git a/crowbar_engine/barclamp_chef_integration/test/dummy/config/environments/test.rb b/crowbar_engine/barclamp_chef_integration/test/dummy/config/environments/test.rb new file mode 100644 index 0000000..f1a4814 --- /dev/null +++ b/crowbar_engine/barclamp_chef_integration/test/dummy/config/environments/test.rb @@ -0,0 +1,37 @@ +Dummy::Application.configure do + # Settings specified here will take precedence over those in config/application.rb + + # The test environment is used exclusively to run your application's + # test suite. You never need to work with it otherwise. Remember that + # your test database is "scratch space" for the test suite and is wiped + # and recreated between test runs. Don't rely on the data there! + config.cache_classes = true + + # Configure static asset server for tests with Cache-Control for performance + config.serve_static_assets = true + config.static_cache_control = "public, max-age=3600" + + # Log error messages when you accidentally call methods on nil + config.whiny_nils = true + + # Show full error reports and disable caching + config.consider_all_requests_local = true + config.action_controller.perform_caching = false + + # Raise exceptions instead of rendering exception templates + config.action_dispatch.show_exceptions = false + + # Disable request forgery protection in test environment + config.action_controller.allow_forgery_protection = false + + # Tell Action Mailer not to deliver emails to the real world. + # The :test delivery method accumulates sent emails in the + # ActionMailer::Base.deliveries array. + config.action_mailer.delivery_method = :test + + # Raise exception on mass assignment protection for Active Record models + config.active_record.mass_assignment_sanitizer = :strict + + # Print deprecation notices to the stderr + config.active_support.deprecation = :stderr +end diff --git a/crowbar_engine/barclamp_chef_integration/test/dummy/config/initializers/backtrace_silencers.rb b/crowbar_engine/barclamp_chef_integration/test/dummy/config/initializers/backtrace_silencers.rb new file mode 100644 index 0000000..59385cd --- /dev/null +++ b/crowbar_engine/barclamp_chef_integration/test/dummy/config/initializers/backtrace_silencers.rb @@ -0,0 +1,7 @@ +# Be sure to restart your server when you modify this file. + +# You can add backtrace silencers for libraries that you're using but don't wish to see in your backtraces. +# Rails.backtrace_cleaner.add_silencer { |line| line =~ /my_noisy_library/ } + +# You can also remove all the silencers if you're trying to debug a problem that might stem from framework code. +# Rails.backtrace_cleaner.remove_silencers! diff --git a/crowbar_engine/barclamp_chef_integration/test/dummy/config/initializers/inflections.rb b/crowbar_engine/barclamp_chef_integration/test/dummy/config/initializers/inflections.rb new file mode 100644 index 0000000..5d8d9be --- /dev/null +++ b/crowbar_engine/barclamp_chef_integration/test/dummy/config/initializers/inflections.rb @@ -0,0 +1,15 @@ +# Be sure to restart your server when you modify this file. + +# Add new inflection rules using the following format +# (all these examples are active by default): +# ActiveSupport::Inflector.inflections do |inflect| +# inflect.plural /^(ox)$/i, '\1en' +# inflect.singular /^(ox)en/i, '\1' +# inflect.irregular 'person', 'people' +# inflect.uncountable %w( fish sheep ) +# end +# +# These inflection rules are supported but not enabled by default: +# ActiveSupport::Inflector.inflections do |inflect| +# inflect.acronym 'RESTful' +# end diff --git a/crowbar_engine/barclamp_chef_integration/test/dummy/config/initializers/mime_types.rb b/crowbar_engine/barclamp_chef_integration/test/dummy/config/initializers/mime_types.rb new file mode 100644 index 0000000..72aca7e --- /dev/null +++ b/crowbar_engine/barclamp_chef_integration/test/dummy/config/initializers/mime_types.rb @@ -0,0 +1,5 @@ +# Be sure to restart your server when you modify this file. + +# Add new mime types for use in respond_to blocks: +# Mime::Type.register "text/richtext", :rtf +# Mime::Type.register_alias "text/html", :iphone diff --git a/crowbar_engine/barclamp_chef_integration/test/dummy/config/initializers/secret_token.rb b/crowbar_engine/barclamp_chef_integration/test/dummy/config/initializers/secret_token.rb new file mode 100644 index 0000000..b46e3d9 --- /dev/null +++ b/crowbar_engine/barclamp_chef_integration/test/dummy/config/initializers/secret_token.rb @@ -0,0 +1,7 @@ +# Be sure to restart your server when you modify this file. + +# Your secret key for verifying the integrity of signed cookies. +# If you change this key, all old signed cookies will become invalid! +# Make sure the secret is at least 30 characters and all random, +# no regular words or you'll be exposed to dictionary attacks. +Dummy::Application.config.secret_token = 'f19f667c832ecf4b33b1e7b8ae59623b9a3cd14e523817ee4db25eaea49c184e7e9ae658b8dc380746154fd8aa198b03425271516427203b4c6f5f968d5a53b7' diff --git a/crowbar_engine/barclamp_chef_integration/test/dummy/config/initializers/session_store.rb b/crowbar_engine/barclamp_chef_integration/test/dummy/config/initializers/session_store.rb new file mode 100644 index 0000000..952473f --- /dev/null +++ b/crowbar_engine/barclamp_chef_integration/test/dummy/config/initializers/session_store.rb @@ -0,0 +1,8 @@ +# Be sure to restart your server when you modify this file. + +Dummy::Application.config.session_store :cookie_store, key: '_dummy_session' + +# Use the database for sessions instead of the cookie-based default, +# which shouldn't be used to store highly confidential information +# (create the session table with "rails generate session_migration") +# Dummy::Application.config.session_store :active_record_store diff --git a/crowbar_engine/barclamp_chef_integration/test/dummy/config/initializers/wrap_parameters.rb b/crowbar_engine/barclamp_chef_integration/test/dummy/config/initializers/wrap_parameters.rb new file mode 100644 index 0000000..999df20 --- /dev/null +++ b/crowbar_engine/barclamp_chef_integration/test/dummy/config/initializers/wrap_parameters.rb @@ -0,0 +1,14 @@ +# Be sure to restart your server when you modify this file. +# +# This file contains settings for ActionController::ParamsWrapper which +# is enabled by default. + +# Enable parameter wrapping for JSON. You can disable this by setting :format to an empty array. +ActiveSupport.on_load(:action_controller) do + wrap_parameters format: [:json] +end + +# Disable root element in JSON by default. +ActiveSupport.on_load(:active_record) do + self.include_root_in_json = false +end diff --git a/crowbar_engine/barclamp_chef_integration/test/dummy/config/locales/en.yml b/crowbar_engine/barclamp_chef_integration/test/dummy/config/locales/en.yml new file mode 100644 index 0000000..179c14c --- /dev/null +++ b/crowbar_engine/barclamp_chef_integration/test/dummy/config/locales/en.yml @@ -0,0 +1,5 @@ +# Sample localization file for English. Add more files in this directory for other locales. +# See https://github.com/svenfuchs/rails-i18n/tree/master/rails%2Flocale for starting points. + +en: + hello: "Hello world" diff --git a/crowbar_engine/barclamp_chef_integration/test/dummy/config/routes.rb b/crowbar_engine/barclamp_chef_integration/test/dummy/config/routes.rb new file mode 100644 index 0000000..c84b0fa --- /dev/null +++ b/crowbar_engine/barclamp_chef_integration/test/dummy/config/routes.rb @@ -0,0 +1,4 @@ +Rails.application.routes.draw do + + mount BarclampBurnin::Engine => "/barclamp_chef_integration" +end diff --git a/crowbar_engine/barclamp_chef_integration/test/dummy/lib/assets/.gitkeep b/crowbar_engine/barclamp_chef_integration/test/dummy/lib/assets/.gitkeep new file mode 100644 index 0000000..e69de29 diff --git a/crowbar_engine/barclamp_chef_integration/test/dummy/log/.gitkeep b/crowbar_engine/barclamp_chef_integration/test/dummy/log/.gitkeep new file mode 100644 index 0000000..e69de29 diff --git a/crowbar_engine/barclamp_chef_integration/test/dummy/public/404.html b/crowbar_engine/barclamp_chef_integration/test/dummy/public/404.html new file mode 100644 index 0000000..9a48320 --- /dev/null +++ b/crowbar_engine/barclamp_chef_integration/test/dummy/public/404.html @@ -0,0 +1,26 @@ + + + + The page you were looking for doesn't exist (404) + + + + + +
+

The page you were looking for doesn't exist.

+

You may have mistyped the address or the page may have moved.

+
+ + diff --git a/crowbar_engine/barclamp_chef_integration/test/dummy/public/422.html b/crowbar_engine/barclamp_chef_integration/test/dummy/public/422.html new file mode 100644 index 0000000..83660ab --- /dev/null +++ b/crowbar_engine/barclamp_chef_integration/test/dummy/public/422.html @@ -0,0 +1,26 @@ + + + + The change you wanted was rejected (422) + + + + + +
+

The change you wanted was rejected.

+

Maybe you tried to change something you didn't have access to.

+
+ + diff --git a/crowbar_engine/barclamp_chef_integration/test/dummy/public/500.html b/crowbar_engine/barclamp_chef_integration/test/dummy/public/500.html new file mode 100644 index 0000000..f3648a0 --- /dev/null +++ b/crowbar_engine/barclamp_chef_integration/test/dummy/public/500.html @@ -0,0 +1,25 @@ + + + + We're sorry, but something went wrong (500) + + + + + +
+

We're sorry, but something went wrong.

+
+ + diff --git a/crowbar_engine/barclamp_chef_integration/test/dummy/public/favicon.ico b/crowbar_engine/barclamp_chef_integration/test/dummy/public/favicon.ico new file mode 100644 index 0000000..e69de29 diff --git a/crowbar_engine/barclamp_chef_integration/test/dummy/script/rails b/crowbar_engine/barclamp_chef_integration/test/dummy/script/rails new file mode 100755 index 0000000..f8da2cf --- /dev/null +++ b/crowbar_engine/barclamp_chef_integration/test/dummy/script/rails @@ -0,0 +1,6 @@ +#!/usr/bin/env ruby +# This command will automatically be run when you run "rails" with Rails 3 gems installed from the root of your application. + +APP_PATH = File.expand_path('../../config/application', __FILE__) +require File.expand_path('../../config/boot', __FILE__) +require 'rails/commands' diff --git a/crowbar_engine/barclamp_chef_integration/test/integration/navigation_test.rb b/crowbar_engine/barclamp_chef_integration/test/integration/navigation_test.rb new file mode 100644 index 0000000..97a94c9 --- /dev/null +++ b/crowbar_engine/barclamp_chef_integration/test/integration/navigation_test.rb @@ -0,0 +1,10 @@ +require 'test_helper' + +class NavigationTest < ActionDispatch::IntegrationTest + fixtures :all + + # test "the truth" do + # assert true + # end +end + diff --git a/crowbar_engine/barclamp_chef_integration/test/test_helper.rb b/crowbar_engine/barclamp_chef_integration/test/test_helper.rb new file mode 100644 index 0000000..1e26a31 --- /dev/null +++ b/crowbar_engine/barclamp_chef_integration/test/test_helper.rb @@ -0,0 +1,15 @@ +# Configure Rails Environment +ENV["RAILS_ENV"] = "test" + +require File.expand_path("../dummy/config/environment.rb", __FILE__) +require "rails/test_help" + +Rails.backtrace_cleaner.remove_silencers! + +# Load support files +Dir["#{File.dirname(__FILE__)}/support/**/*.rb"].each { |f| require f } + +# Load fixtures from the engine +if ActiveSupport::TestCase.method_defined?(:fixture_path=) + ActiveSupport::TestCase.fixture_path = File.expand_path("../fixtures", __FILE__) +end diff --git a/lib/chef/provisioning/crowbar_driver/driver.rb b/lib/chef/provisioning/crowbar_driver/driver.rb index 4e3429e..fab34e8 100644 --- a/lib/chef/provisioning/crowbar_driver/driver.rb +++ b/lib/chef/provisioning/crowbar_driver/driver.rb @@ -33,7 +33,7 @@ class Driver < Chef::Provisioning::Driver ALLOCATE_DEPLOYMENT = 'system' READY_DEPLOYMENT = 'ready' - TARGET_NODE_ROLE = "crowbar-installed-node" + TARGET_NODE_ROLE = "chef-ready" API_BASE = "/api/v2" def initialize(driver_url, config) diff --git a/script/roles/chef-provisioning/01-chef-provisioning.sh b/script/roles/chef-provisioning/01-chef-provisioning.sh new file mode 100644 index 0000000..34157a9 --- /dev/null +++ b/script/roles/chef-provisioning/01-chef-provisioning.sh @@ -0,0 +1,25 @@ +#!/bin/bash +# Copyright 2015, RackN by Rob Hirschfeld +# +# Licensed under the Apache License, Version 2.0 (the "License"); +# you may not use this file except in compliance with the License. +# You may obtain a copy of the License at +# +# http://www.apache.org/licenses/LICENSE-2.0 +# +# Unless required by applicable law or agreed to in writing, software +# distributed under the License is distributed on an "AS IS" BASIS, +# WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. +# See the License for the specific language governing permissions and +# limitations under the License. + +# File Sources +webserver=$(read_attribute "crowbar/provisioner/server/webserver") +certs="/etc/chef/trusted_certs" +server="192.168.124.10.crt" + +# copy file from webserver to node +mkdir -p "$certs" +curl -s -f -L -o "$certs/$server" "$webserver/files/chef/$server" + +exit 0