move from bundler to chefdk
- deprecated Gemfile - Updated TESTING.md and README.md - updated Rakefile to use chef exec insted of bundle exec - replaced Runner with SoloRunner in specs Change-Id: If3e3b54c9dbaa8bb51164bc85fd93ff5fc54ec4d
This commit is contained in:
4
Gemfile
4
Gemfile
@@ -1,3 +1,7 @@
|
|||||||
|
## THIS GEMFILE IS DEPRECATED AND WILL BE REMOVED AFTER THE NEXT RELEASE
|
||||||
|
## THERE WON'T BE ANY UPDATES TO THIS FILE DURING THIS RELEASE CYCLE
|
||||||
|
## WE SWITCHED TO CHEFDK AS THE BUNDLE FOR THE NEEDED GEMS
|
||||||
|
|
||||||
# encoding: UTF-8
|
# encoding: UTF-8
|
||||||
source 'https://rubygems.org'
|
source 'https://rubygems.org'
|
||||||
|
|
||||||
|
@@ -253,6 +253,7 @@ License and Author
|
|||||||
| **Author** | Mark Vanderwiel (<vanderwl@us.ibm.com>) |
|
| **Author** | Mark Vanderwiel (<vanderwl@us.ibm.com>) |
|
||||||
| **Author** | Eric Zhou (<zyouzhou@cn.ibm.com>) |
|
| **Author** | Eric Zhou (<zyouzhou@cn.ibm.com>) |
|
||||||
| **Author** | Edwin Wang (<edwin.wang@cn.ibm.com>) |
|
| **Author** | Edwin Wang (<edwin.wang@cn.ibm.com>) |
|
||||||
|
| **Author** | Jan Klare (<j.klare@x-ion.de>) |
|
||||||
| | |
|
| | |
|
||||||
| **Copyright** | Copyright (c) 2012, Rackspace US, Inc. |
|
| **Copyright** | Copyright (c) 2012, Rackspace US, Inc. |
|
||||||
| **Copyright** | Copyright (c) 2012-2013, AT&T Services, Inc. |
|
| **Copyright** | Copyright (c) 2012-2013, AT&T Services, Inc. |
|
||||||
|
21
Rakefile
21
Rakefile
@@ -2,32 +2,25 @@ task default: ["test"]
|
|||||||
|
|
||||||
task :test => [:lint, :style, :unit]
|
task :test => [:lint, :style, :unit]
|
||||||
|
|
||||||
task :bundler_prep do
|
task :berks_prep do
|
||||||
mkdir_p '.bundle'
|
sh %{chef exec berks vendor}
|
||||||
sh %{bundle install --path=.bundle --jobs 1 --retry 3 --verbose}
|
|
||||||
end
|
end
|
||||||
|
|
||||||
task :berks_prep => :bundler_prep do
|
task :lint do
|
||||||
sh %{bundle exec berks vendor}
|
sh %{chef exec foodcritic --epic-fail any --tags ~FC003 --tags ~FC023 .}
|
||||||
end
|
end
|
||||||
|
|
||||||
task :lint => :bundler_prep do
|
task :style do
|
||||||
sh %{bundle exec foodcritic --epic-fail any --tags ~FC003 --tags ~FC023 .}
|
sh %{chef exec rubocop}
|
||||||
end
|
|
||||||
|
|
||||||
task :style => :bundler_prep do
|
|
||||||
sh %{bundle exec rubocop}
|
|
||||||
end
|
end
|
||||||
|
|
||||||
task :unit => :berks_prep do
|
task :unit => :berks_prep do
|
||||||
sh %{bundle exec rspec --format documentation}
|
sh %{chef exec rspec --format documentation}
|
||||||
end
|
end
|
||||||
|
|
||||||
task :clean do
|
task :clean do
|
||||||
rm_rf [
|
rm_rf [
|
||||||
'.bundle',
|
|
||||||
'berks-cookbooks',
|
'berks-cookbooks',
|
||||||
'Gemfile.lock',
|
|
||||||
'Berksfile.lock'
|
'Berksfile.lock'
|
||||||
]
|
]
|
||||||
end
|
end
|
||||||
|
16
TESTING.md
16
TESTING.md
@@ -1,18 +1,18 @@
|
|||||||
# Testing the Cookbook #
|
# Testing the Cookbook #
|
||||||
|
|
||||||
This cookbook uses [bundler](http://gembundler.com/) and [berkshelf](http://berkshelf.com/) to isolate dependencies. Make sure you have `ruby 1.9.x`, `bundler`, `rake`, build essentials and the header files for `gecode` installed before continuing. Make sure that you're using gecode version 3. More info [here](https://github.com/opscode/dep-selector-libgecode/tree/0bad63fea305ede624c58506423ced697dd2545e#using-a-system-gecode-instead).
|
This cookbook uses [chefdk](https://downloads.chef.io/chef-dk/) and [berkshelf](http://berkshelf.com/) to isolate dependencies. Make sure you have chefdk and the header files for `gecode` installed before continuing. Make sure that you're using gecode version 3. More info [here](https://github.com/opscode/dep-selector-libgecode/tree/0bad63fea305ede624c58506423ced697dd2545e#using-a-system-gecode-instead). For more detailed information on what needs to be installed, you can have a quick look into the bootstrap.sh file in this repository, which does install all the needed things to get going on ubuntu trusty. The tests defined in the Rakefile include lint, style and unit. For integration testing please refere to the [openstack-chef-repo](https://github.com/stackforge/openstack-chef-repo).
|
||||||
|
|
||||||
We have three test suites which you can run individually (there are three rake tasks):
|
We have three test suites which you can run either, individually (there are three rake tasks):
|
||||||
|
|
||||||
$ rake lint
|
$ chef exec rake lint
|
||||||
$ rake style
|
$ chef exec rake style
|
||||||
$ rake unit
|
$ chef exec rake unit
|
||||||
|
|
||||||
or altogether:
|
or altogether:
|
||||||
|
|
||||||
$ rake test
|
$ chef exec rake
|
||||||
|
|
||||||
The `rake` tasks will take care of installing the needed gem dependencies and cookbooks with `berkshelf`.
|
The `rake` tasks will take care of installing the needed cookbooks with `berkshelf`.
|
||||||
|
|
||||||
## Rubocop ##
|
## Rubocop ##
|
||||||
|
|
||||||
@@ -27,4 +27,4 @@ The `rake` tasks will take care of installing the needed gem dependencies and co
|
|||||||
|
|
||||||
## Chefspec
|
## Chefspec
|
||||||
|
|
||||||
[ChefSpec](https://github.com/sethvargo/chefspec/) is a unit testing framework for testing Chef cookbooks. ChefSpec makes it easy to write examples and get fast feedback on cookbook changes without the need for virtual machines or cloud servers.
|
[ChefSpec](https://github.com/sethvargo/chefspec) is a unit testing framework for testing Chef cookbooks. ChefSpec makes it easy to write examples and get fast feedback on cookbook changes without the need for virtual machines or cloud servers.
|
||||||
|
@@ -6,7 +6,7 @@ require_relative 'spec_helper'
|
|||||||
|
|
||||||
describe 'openstack-block-storage::api' do
|
describe 'openstack-block-storage::api' do
|
||||||
describe 'suse' do
|
describe 'suse' do
|
||||||
let(:runner) { ChefSpec::Runner.new(SUSE_OPTS) }
|
let(:runner) { ChefSpec::SoloRunner.new(SUSE_OPTS) }
|
||||||
let(:node) { runner.node }
|
let(:node) { runner.node }
|
||||||
let(:chef_run) { runner.converge(described_recipe) }
|
let(:chef_run) { runner.converge(described_recipe) }
|
||||||
|
|
||||||
|
@@ -6,7 +6,7 @@ require_relative 'spec_helper'
|
|||||||
|
|
||||||
describe 'openstack-block-storage::api' do
|
describe 'openstack-block-storage::api' do
|
||||||
describe 'redhat' do
|
describe 'redhat' do
|
||||||
let(:runner) { ChefSpec::Runner.new(REDHAT_OPTS) }
|
let(:runner) { ChefSpec::SoloRunner.new(REDHAT_OPTS) }
|
||||||
let(:node) { runner.node }
|
let(:node) { runner.node }
|
||||||
let(:chef_run) { runner.converge(described_recipe) }
|
let(:chef_run) { runner.converge(described_recipe) }
|
||||||
|
|
||||||
|
@@ -6,7 +6,7 @@ require_relative 'spec_helper'
|
|||||||
|
|
||||||
describe 'openstack-block-storage::api' do
|
describe 'openstack-block-storage::api' do
|
||||||
describe 'ubuntu' do
|
describe 'ubuntu' do
|
||||||
let(:runner) { ChefSpec::Runner.new(UBUNTU_OPTS) }
|
let(:runner) { ChefSpec::SoloRunner.new(UBUNTU_OPTS) }
|
||||||
let(:node) { runner.node }
|
let(:node) { runner.node }
|
||||||
let(:chef_run) { runner.converge(described_recipe) }
|
let(:chef_run) { runner.converge(described_recipe) }
|
||||||
|
|
||||||
|
@@ -6,7 +6,7 @@ require_relative 'spec_helper'
|
|||||||
|
|
||||||
describe 'openstack-block-storage::cinder-common' do
|
describe 'openstack-block-storage::cinder-common' do
|
||||||
describe 'rhel' do
|
describe 'rhel' do
|
||||||
let(:runner) { ChefSpec::Runner.new(REDHAT_OPTS) }
|
let(:runner) { ChefSpec::SoloRunner.new(REDHAT_OPTS) }
|
||||||
let(:node) { runner.node }
|
let(:node) { runner.node }
|
||||||
let(:chef_run) { runner.converge(described_recipe) }
|
let(:chef_run) { runner.converge(described_recipe) }
|
||||||
|
|
||||||
|
@@ -6,7 +6,7 @@ require_relative 'spec_helper'
|
|||||||
|
|
||||||
describe 'openstack-block-storage::cinder-common' do
|
describe 'openstack-block-storage::cinder-common' do
|
||||||
describe 'suse' do
|
describe 'suse' do
|
||||||
let(:runner) { ChefSpec::Runner.new(SUSE_OPTS) }
|
let(:runner) { ChefSpec::SoloRunner.new(SUSE_OPTS) }
|
||||||
let(:node) { runner.node }
|
let(:node) { runner.node }
|
||||||
let(:chef_run) { runner.converge(described_recipe) }
|
let(:chef_run) { runner.converge(described_recipe) }
|
||||||
|
|
||||||
|
@@ -6,7 +6,7 @@ require_relative 'spec_helper'
|
|||||||
|
|
||||||
describe 'openstack-block-storage::cinder-common' do
|
describe 'openstack-block-storage::cinder-common' do
|
||||||
describe 'ubuntu' do
|
describe 'ubuntu' do
|
||||||
let(:runner) { ChefSpec::Runner.new(UBUNTU_OPTS) }
|
let(:runner) { ChefSpec::SoloRunner.new(UBUNTU_OPTS) }
|
||||||
let(:node) { runner.node }
|
let(:node) { runner.node }
|
||||||
let(:chef_run) do
|
let(:chef_run) do
|
||||||
node.set['openstack']['mq']['host'] = '127.0.0.1'
|
node.set['openstack']['mq']['host'] = '127.0.0.1'
|
||||||
|
@@ -3,7 +3,7 @@ require_relative 'spec_helper'
|
|||||||
|
|
||||||
describe 'openstack-block-storage::client' do
|
describe 'openstack-block-storage::client' do
|
||||||
describe 'redhat' do
|
describe 'redhat' do
|
||||||
let(:runner) { ChefSpec::Runner.new(REDHAT_OPTS) }
|
let(:runner) { ChefSpec::SoloRunner.new(REDHAT_OPTS) }
|
||||||
let(:node) { runner.node }
|
let(:node) { runner.node }
|
||||||
let(:chef_run) do
|
let(:chef_run) do
|
||||||
runner.converge(described_recipe)
|
runner.converge(described_recipe)
|
||||||
|
@@ -3,7 +3,7 @@ require_relative 'spec_helper'
|
|||||||
|
|
||||||
describe 'openstack-block-storage::client' do
|
describe 'openstack-block-storage::client' do
|
||||||
describe 'ubuntu' do
|
describe 'ubuntu' do
|
||||||
let(:runner) { ChefSpec::Runner.new(UBUNTU_OPTS) }
|
let(:runner) { ChefSpec::SoloRunner.new(UBUNTU_OPTS) }
|
||||||
let(:node) { runner.node }
|
let(:node) { runner.node }
|
||||||
let(:chef_run) do
|
let(:chef_run) do
|
||||||
runner.converge(described_recipe)
|
runner.converge(described_recipe)
|
||||||
|
@@ -6,7 +6,7 @@ require_relative 'spec_helper'
|
|||||||
|
|
||||||
describe 'openstack-block-storage::identity_registration' do
|
describe 'openstack-block-storage::identity_registration' do
|
||||||
describe 'ubuntu' do
|
describe 'ubuntu' do
|
||||||
let(:runner) { ChefSpec::Runner.new(UBUNTU_OPTS) }
|
let(:runner) { ChefSpec::SoloRunner.new(UBUNTU_OPTS) }
|
||||||
let(:node) { runner.node }
|
let(:node) { runner.node }
|
||||||
let(:chef_run) { runner.converge(described_recipe) }
|
let(:chef_run) { runner.converge(described_recipe) }
|
||||||
|
|
||||||
|
@@ -6,7 +6,7 @@ require_relative 'spec_helper'
|
|||||||
|
|
||||||
describe 'openstack-block-storage::scheduler' do
|
describe 'openstack-block-storage::scheduler' do
|
||||||
describe 'redhat' do
|
describe 'redhat' do
|
||||||
let(:runner) { ChefSpec::Runner.new(REDHAT_OPTS) }
|
let(:runner) { ChefSpec::SoloRunner.new(REDHAT_OPTS) }
|
||||||
let(:node) { runner.node }
|
let(:node) { runner.node }
|
||||||
let(:chef_run) { runner.converge(described_recipe) }
|
let(:chef_run) { runner.converge(described_recipe) }
|
||||||
|
|
||||||
|
@@ -6,7 +6,7 @@ require_relative 'spec_helper'
|
|||||||
|
|
||||||
describe 'openstack-block-storage::scheduler' do
|
describe 'openstack-block-storage::scheduler' do
|
||||||
describe 'suse' do
|
describe 'suse' do
|
||||||
let(:runner) { ChefSpec::Runner.new(SUSE_OPTS) }
|
let(:runner) { ChefSpec::SoloRunner.new(SUSE_OPTS) }
|
||||||
let(:node) { runner.node }
|
let(:node) { runner.node }
|
||||||
let(:chef_run) { runner.converge(described_recipe) }
|
let(:chef_run) { runner.converge(described_recipe) }
|
||||||
|
|
||||||
|
@@ -6,7 +6,7 @@ require_relative 'spec_helper'
|
|||||||
|
|
||||||
describe 'openstack-block-storage::scheduler' do
|
describe 'openstack-block-storage::scheduler' do
|
||||||
describe 'ubuntu' do
|
describe 'ubuntu' do
|
||||||
let(:runner) { ChefSpec::Runner.new(UBUNTU_OPTS) }
|
let(:runner) { ChefSpec::SoloRunner.new(UBUNTU_OPTS) }
|
||||||
let(:node) { runner.node }
|
let(:node) { runner.node }
|
||||||
let(:chef_run) { runner.converge(described_recipe) }
|
let(:chef_run) { runner.converge(described_recipe) }
|
||||||
|
|
||||||
|
@@ -6,7 +6,7 @@ require_relative 'spec_helper'
|
|||||||
|
|
||||||
describe 'openstack-block-storage::volume' do
|
describe 'openstack-block-storage::volume' do
|
||||||
describe 'redhat' do
|
describe 'redhat' do
|
||||||
let(:runner) { ChefSpec::Runner.new(REDHAT_OPTS) }
|
let(:runner) { ChefSpec::SoloRunner.new(REDHAT_OPTS) }
|
||||||
let(:node) { runner.node }
|
let(:node) { runner.node }
|
||||||
let(:chef_run) { runner.converge(described_recipe) }
|
let(:chef_run) { runner.converge(described_recipe) }
|
||||||
|
|
||||||
@@ -107,7 +107,7 @@ describe 'openstack-block-storage::volume' do
|
|||||||
|
|
||||||
describe 'IBM GPFS volume driver' do
|
describe 'IBM GPFS volume driver' do
|
||||||
before do
|
before do
|
||||||
@chef_run = ::ChefSpec::Runner.new ::REDHAT_OPTS do |n|
|
@chef_run = ::ChefSpec::SoloRunner.new ::REDHAT_OPTS do |n|
|
||||||
n.set['openstack']['block-storage']['volume']['driver'] = 'cinder.volume.drivers.ibm.gpfs.GPFSDriver'
|
n.set['openstack']['block-storage']['volume']['driver'] = 'cinder.volume.drivers.ibm.gpfs.GPFSDriver'
|
||||||
n.set['openstack']['block-storage']['gpfs']['gpfs_mount_point_base'] = 'volumes'
|
n.set['openstack']['block-storage']['gpfs']['gpfs_mount_point_base'] = 'volumes'
|
||||||
end
|
end
|
||||||
|
@@ -6,7 +6,7 @@ require_relative 'spec_helper'
|
|||||||
|
|
||||||
describe 'openstack-block-storage::volume' do
|
describe 'openstack-block-storage::volume' do
|
||||||
describe 'suse' do
|
describe 'suse' do
|
||||||
let(:runner) { ChefSpec::Runner.new(SUSE_OPTS) }
|
let(:runner) { ChefSpec::SoloRunner.new(SUSE_OPTS) }
|
||||||
let(:node) { runner.node }
|
let(:node) { runner.node }
|
||||||
let(:chef_run) { runner.converge(described_recipe) }
|
let(:chef_run) { runner.converge(described_recipe) }
|
||||||
|
|
||||||
|
@@ -6,7 +6,7 @@ require_relative 'spec_helper'
|
|||||||
|
|
||||||
describe 'openstack-block-storage::volume' do
|
describe 'openstack-block-storage::volume' do
|
||||||
describe 'ubuntu' do
|
describe 'ubuntu' do
|
||||||
let(:runner) { ChefSpec::Runner.new(UBUNTU_OPTS) }
|
let(:runner) { ChefSpec::SoloRunner.new(UBUNTU_OPTS) }
|
||||||
let(:node) { runner.node }
|
let(:node) { runner.node }
|
||||||
let(:chef_run) { runner.converge(described_recipe) }
|
let(:chef_run) { runner.converge(described_recipe) }
|
||||||
|
|
||||||
|
Reference in New Issue
Block a user