Initial rubocop support for ChefSpec tests.

Per the mailing list thread, introducing Rubocop as a replacement for Tailor.
Assuming Jenkins likes this, more pedantic patches will follow to make Rubocop
happy. So far this is just spacing issues and adding UTF-8 headers, but more
work will need to be done to remove all of the changes for the .rubocop-todo.yml

Addresses: blueprint rubocop-for-block-storage
Change-Id: Ibb11739e452016c101995a371d031faeeb7e7683
This commit is contained in:
Matt Ray
2014-01-08 14:15:48 -06:00
parent 018d125a51
commit 230b2ed90e
20 changed files with 130 additions and 44 deletions

View File

@@ -1,8 +1,9 @@
# Strainerfile # Strainerfile
rubocop: bundle exec rubocop $SANDBOX/$COOKBOOK/Gemfile rubocop: bundle exec rubocop $SANDBOX/$COOKBOOK/Gemfile --config $SANDBOX/$COOKBOOK/.rubocop.yml
rubocop: bundle exec rubocop $SANDBOX/$COOKBOOK/attributes/ rubocop: bundle exec rubocop $SANDBOX/$COOKBOOK/metadata.rb --config $SANDBOX/$COOKBOOK/.rubocop.yml
rubocop: bundle exec rubocop $SANDBOX/$COOKBOOK/metadata.rb rubocop: bundle exec rubocop $SANDBOX/$COOKBOOK/attributes/ --config $SANDBOX/$COOKBOOK/attributes/.rubocop.yml
rubocop: bundle exec rubocop $SANDBOX/$COOKBOOK/recipes/ rubocop: bundle exec rubocop $SANDBOX/$COOKBOOK/recipes/ --config $SANDBOX/$COOKBOOK/recipes/.rubocop.yml
rubocop: bundle exec rubocop $SANDBOX/$COOKBOOK/spec/ --config $SANDBOX/$COOKBOOK/spec/.rubocop.yml
# rubocop: bundle exec rubocop $SANDBOX/$COOKBOOK # rubocop: bundle exec rubocop $SANDBOX/$COOKBOOK
# may want to add rubocop check for Berksfile and Gemfile # may want to add rubocop check for Berksfile and Gemfile
knife test: bundle exec knife cookbook test $COOKBOOK knife test: bundle exec knife cookbook test $COOKBOOK

View File

@@ -21,6 +21,7 @@ Since there are slight style differences between the coding of attributes, recip
[Gemfile and metadata.rb](.rubocop.yml) [Gemfile and metadata.rb](.rubocop.yml)
[attributes/*.rb](attributes/.rubocop.yml) [attributes/*.rb](attributes/.rubocop.yml)
[recipes/.rubocop.yml](recipes/.rubocop.yml) [recipes/.rubocop.yml](recipes/.rubocop.yml)
[spec/.rubocop.yml](spec/.rubocop.yml)
## Knife ## ## Knife ##

17
spec/.rubocop-todo.yml Normal file
View File

@@ -0,0 +1,17 @@
# This configuration was generated by `rubocop --auto-gen-config`.
# The point is for the user to remove these configuration records
# one by one as the offences are removed from the code base.
HashSyntax:
Enabled: false
MethodLength:
Enabled: false
StringLiterals:
Enabled: false
### in the .rubocop.yml
# embedded attributes make for long lines
LineLength:
Enabled: false

3
spec/.rubocop.yml Normal file
View File

@@ -0,0 +1,3 @@
# embedded attributes make for long lines
LineLength:
Enabled: false

View File

@@ -1,3 +1,7 @@
# encoding: UTF-8
#
# Cookbook Name:: openstack-block-storage
require_relative "spec_helper" require_relative "spec_helper"
describe "openstack-block-storage::api" do describe "openstack-block-storage::api" do

View File

@@ -1,3 +1,7 @@
# encoding: UTF-8
#
# Cookbook Name:: openstack-block-storage
require_relative "spec_helper" require_relative "spec_helper"
describe "openstack-block-storage::api" do describe "openstack-block-storage::api" do

View File

@@ -1,3 +1,7 @@
# encoding: UTF-8
#
# Cookbook Name:: openstack-block-storage
require_relative "spec_helper" require_relative "spec_helper"
describe "openstack-block-storage::api" do describe "openstack-block-storage::api" do

View File

@@ -1,3 +1,7 @@
# encoding: UTF-8
#
# Cookbook Name:: openstack-block-storage
require_relative "spec_helper" require_relative "spec_helper"
describe "openstack-block-storage::cinder-common" do describe "openstack-block-storage::cinder-common" do

View File

@@ -1,3 +1,7 @@
# encoding: UTF-8
#
# Cookbook Name:: openstack-block-storage
require_relative "spec_helper" require_relative "spec_helper"
describe "openstack-block-storage::cinder-common" do describe "openstack-block-storage::cinder-common" do

View File

@@ -1,3 +1,7 @@
# encoding: UTF-8
#
# Cookbook Name:: openstack-block-storage
require_relative "spec_helper" require_relative "spec_helper"
describe "openstack-block-storage::cinder-common" do describe "openstack-block-storage::cinder-common" do

View File

@@ -1,3 +1,7 @@
# encoding: UTF-8
#
# Cookbook Name:: openstack-block-storage
require_relative "spec_helper" require_relative "spec_helper"
describe "openstack-block-storage::default" do describe "openstack-block-storage::default" do

View File

@@ -1,3 +1,7 @@
# encoding: UTF-8
#
# Cookbook Name:: openstack-block-storage
require_relative "spec_helper" require_relative "spec_helper"
describe "openstack-block-storage::identity_registration" do describe "openstack-block-storage::identity_registration" do

View File

@@ -1,3 +1,7 @@
# encoding: UTF-8
#
# Cookbook Name:: openstack-block-storage
require_relative "spec_helper" require_relative "spec_helper"
describe "openstack-block-storage::scheduler" do describe "openstack-block-storage::scheduler" do

View File

@@ -1,3 +1,7 @@
# encoding: UTF-8
#
# Cookbook Name:: openstack-block-storage
require_relative "spec_helper" require_relative "spec_helper"
describe "openstack-block-storage::scheduler" do describe "openstack-block-storage::scheduler" do

View File

@@ -1,3 +1,7 @@
# encoding: UTF-8
#
# Cookbook Name:: openstack-block-storage
require_relative "spec_helper" require_relative "spec_helper"
describe "openstack-block-storage::scheduler" do describe "openstack-block-storage::scheduler" do
@@ -54,40 +58,40 @@ describe "openstack-block-storage::scheduler" do
end end
it "creates cron metering default" do it "creates cron metering default" do
::Chef::Recipe.any_instance.stub(:search). ::Chef::Recipe.any_instance.stub(:search)
with(:node, "roles:os-block-storage-scheduler"). .with(:node, "roles:os-block-storage-scheduler")
and_return([OpenStruct.new(:name => "fauxhai.local")]) .and_return([OpenStruct.new(:name => "fauxhai.local")])
chef_run = ::ChefSpec::Runner.new ::UBUNTU_OPTS do |n| chef_run = ::ChefSpec::Runner.new ::UBUNTU_OPTS do |n|
n.set["openstack"]["metering"] = true n.set["openstack"]["metering"] = true
end end
chef_run.converge "openstack-block-storage::scheduler" chef_run.converge "openstack-block-storage::scheduler"
cron = chef_run.cron "cinder-volume-usage-audit" cron = chef_run.cron "cinder-volume-usage-audit"
bin_str="/usr/bin/cinder-volume-usage-audit > /var/log/cinder/audit.log" bin_str = "/usr/bin/cinder-volume-usage-audit > /var/log/cinder/audit.log"
expect(cron.command).to match(/#{bin_str}/) expect(cron.command).to match(/#{bin_str}/)
crontests = [ [:minute, '00'], [:hour, '*'], [:day, '*'], crontests = [[:minute, '00'], [:hour, '*'], [:day, '*'],
[:weekday, '*'], [:month, '*'], [:user, 'cinder'] ] [:weekday, '*'], [:month, '*'], [:user, 'cinder']]
crontests.each do |k,v| crontests.each do |k, v|
expect(cron.send(k)).to eq v expect(cron.send(k)).to eq v
end end
expect(cron.action).to include :create expect(cron.action).to include :create
end end
it "creates cron metering custom" do it "creates cron metering custom" do
crontests = [ [:minute, '50'], [:hour, '23'], [:day, '6'], crontests = [[:minute, '50'], [:hour, '23'], [:day, '6'],
[:weekday, '5'], [:month, '11'], [:user, 'foobar'] ] [:weekday, '5'], [:month, '11'], [:user, 'foobar']]
::Chef::Recipe.any_instance.stub(:search). ::Chef::Recipe.any_instance.stub(:search)
with(:node, "roles:os-block-storage-scheduler"). .with(:node, "roles:os-block-storage-scheduler")
and_return([OpenStruct.new(:name => "foobar")]) .and_return([OpenStruct.new(:name => "foobar")])
chef_run = ::ChefSpec::Runner.new ::UBUNTU_OPTS do |n| chef_run = ::ChefSpec::Runner.new ::UBUNTU_OPTS do |n|
n.set["openstack"]["metering"] = true n.set["openstack"]["metering"] = true
crontests.each do |k,v| crontests.each do |k, v|
n.set["openstack"]["block-storage"]["cron"][k.to_s] = v n.set["openstack"]["block-storage"]["cron"][k.to_s] = v
end end
n.set["openstack"]["block-storage"]["user"] = "foobar" n.set["openstack"]["block-storage"]["user"] = "foobar"
end end
chef_run.converge "openstack-block-storage::scheduler" chef_run.converge "openstack-block-storage::scheduler"
cron = chef_run.cron "cinder-volume-usage-audit" cron = chef_run.cron "cinder-volume-usage-audit"
crontests.each do |k,v| crontests.each do |k, v|
expect(cron.send(k)).to eq v expect(cron.send(k)).to eq v
end end
expect(cron.action).to include :delete expect(cron.action).to include :delete

View File

@@ -1,3 +1,7 @@
# encoding: UTF-8
#
# Cookbook Name:: openstack-block-storage
require "chefspec" require "chefspec"
require "chef/application" require "chef/application"
require_relative "support/matcher" require_relative "support/matcher"
@@ -20,20 +24,20 @@ require_relative "support/matcher"
} }
def block_storage_stubs def block_storage_stubs
::Chef::Recipe.any_instance.stub(:rabbit_servers). ::Chef::Recipe.any_instance.stub(:rabbit_servers)
and_return "1.1.1.1:5672,2.2.2.2:5672" .and_return "1.1.1.1:5672,2.2.2.2:5672"
::Chef::Recipe.any_instance.stub(:secret). ::Chef::Recipe.any_instance.stub(:secret)
with("secrets", "openstack_identity_bootstrap_token"). .with("secrets", "openstack_identity_bootstrap_token")
and_return "bootstrap-token" .and_return "bootstrap-token"
::Chef::Recipe.any_instance.stub(:db_password).and_return String.new ::Chef::Recipe.any_instance.stub(:db_password).and_return ''
::Chef::Recipe.any_instance.stub(:user_password).and_return String.new ::Chef::Recipe.any_instance.stub(:user_password).and_return ''
::Chef::Recipe.any_instance.stub(:user_password). ::Chef::Recipe.any_instance.stub(:user_password)
with("guest"). .with("guest")
and_return "rabbit-pass" .and_return "rabbit-pass"
::Chef::Recipe.any_instance.stub(:service_password).and_return String.new ::Chef::Recipe.any_instance.stub(:service_password).and_return ''
::Chef::Recipe.any_instance.stub(:service_password). ::Chef::Recipe.any_instance.stub(:service_password)
with("openstack-block-storage"). .with("openstack-block-storage")
and_return "cinder-pass" .and_return "cinder-pass"
::Chef::Application.stub(:fatal!) ::Chef::Application.stub(:fatal!)
end end
@@ -43,7 +47,7 @@ def expect_runs_openstack_common_logging_recipe
end end
end end
def expect_creates_cinder_conf service, user, group, action=:restart def expect_creates_cinder_conf(service, user, group, action = :restart)
describe "cinder.conf" do describe "cinder.conf" do
before do before do
@file = @chef_run.template "/etc/cinder/cinder.conf" @file = @chef_run.template "/etc/cinder/cinder.conf"
@@ -64,7 +68,7 @@ def expect_creates_cinder_conf service, user, group, action=:restart
end end
end end
def expect_creates_policy_json service, user, group, action=:restart def expect_creates_policy_json(service, user, group, action = :restart)
describe "policy.json" do describe "policy.json" do
before do before do
@file = @chef_run.template "/etc/cinder/policy.json" @file = @chef_run.template "/etc/cinder/policy.json"

View File

@@ -1,3 +1,7 @@
# encoding: UTF-8
#
# Cookbook Name:: openstack-block-storage
def upgrade_python_pip(pkgname) def upgrade_python_pip(pkgname)
ChefSpec::Matchers::ResourceMatcher.new(:python_pip, :upgrade, pkgname) ChefSpec::Matchers::ResourceMatcher.new(:python_pip, :upgrade, pkgname)
end end

View File

@@ -1,3 +1,7 @@
# encoding: UTF-8
#
# Cookbook Name:: openstack-block-storage
require_relative "spec_helper" require_relative "spec_helper"
describe "openstack-block-storage::volume" do describe "openstack-block-storage::volume" do

View File

@@ -1,3 +1,7 @@
# encoding: UTF-8
#
# Cookbook Name:: openstack-block-storage
require_relative "spec_helper" require_relative "spec_helper"
describe "openstack-block-storage::volume" do describe "openstack-block-storage::volume" do

View File

@@ -1,3 +1,7 @@
# encoding: UTF-8
#
# Cookbook Name:: openstack-block-storage
require_relative "spec_helper" require_relative "spec_helper"
describe "openstack-block-storage::volume" do describe "openstack-block-storage::volume" do
@@ -60,8 +64,8 @@ describe "openstack-block-storage::volume" do
end end
it "configures netapp dfm password" do it "configures netapp dfm password" do
::Chef::Recipe.any_instance.stub(:service_password).with("netapp"). ::Chef::Recipe.any_instance.stub(:service_password).with("netapp")
and_return "netapp-pass" .and_return "netapp-pass"
chef_run = ::ChefSpec::Runner.new ::UBUNTU_OPTS do |n| chef_run = ::ChefSpec::Runner.new ::UBUNTU_OPTS do |n|
n.set["openstack"]["block-storage"]["volume"]["driver"] = "cinder.volume.drivers.netapp.iscsi.NetAppISCSIDriver" n.set["openstack"]["block-storage"]["volume"]["driver"] = "cinder.volume.drivers.netapp.iscsi.NetAppISCSIDriver"
end end
@@ -72,8 +76,8 @@ describe "openstack-block-storage::volume" do
end end
it "configures rbd password" do it "configures rbd password" do
::Chef::Recipe.any_instance.stub(:service_password).with("rbd"). ::Chef::Recipe.any_instance.stub(:service_password).with("rbd")
and_return "rbd-pass" .and_return "rbd-pass"
chef_run = ::ChefSpec::Runner.new ::UBUNTU_OPTS do |n| chef_run = ::ChefSpec::Runner.new ::UBUNTU_OPTS do |n|
n.set["openstack"]["block-storage"]["volume"]["driver"] = "cinder.volume.drivers.RBDDriver" n.set["openstack"]["block-storage"]["volume"]["driver"] = "cinder.volume.drivers.RBDDriver"
end end