diff options
Diffstat (limited to 'spec/run_oc_pedant.rb')
-rw-r--r-- | spec/run_oc_pedant.rb | 116 |
1 files changed, 58 insertions, 58 deletions
diff --git a/spec/run_oc_pedant.rb b/spec/run_oc_pedant.rb index 9c95b07..0347fbc 100644 --- a/spec/run_oc_pedant.rb +++ b/spec/run_oc_pedant.rb @@ -1,9 +1,9 @@ #!/usr/bin/env ruby -require 'bundler' -require 'bundler/setup' +require "bundler" +require "bundler/setup" -require 'chef_zero/server' -require 'rspec/core' +require "chef_zero/server" +require "rspec/core" # This file runs oc-chef-pedant specs and is invoked by `rake pedant` # and other Rake tasks. Run `rake -T` to list tasks. @@ -29,56 +29,56 @@ DEFAULT_SERVER_OPTIONS = { DEFAULT_LOG_LEVEL = :warn def log_level - return ENV['LOG_LEVEL'].downcase.to_sym if ENV['LOG_LEVEL'] - return :debug if ENV['DEBUG'] + return ENV["LOG_LEVEL"].downcase.to_sym if ENV["LOG_LEVEL"] + return :debug if ENV["DEBUG"] DEFAULT_LOG_LEVEL end -def start_chef_server(opts={}) +def start_chef_server(opts = {}) opts = DEFAULT_SERVER_OPTIONS.merge(opts) opts[:log_level] = log_level - ChefZero::Server.new(opts).tap {|server| server.start_background } + ChefZero::Server.new(opts).tap { |server| server.start_background } end def start_cheffs_server(chef_repo_path) - require 'chef/version' - require 'chef/config' - require 'chef/chef_fs/config' - require 'chef/chef_fs/chef_fs_data_store' - require 'chef_zero/server' + require "chef/version" + require "chef/config" + require "chef/chef_fs/config" + require "chef/chef_fs/chef_fs_data_store" + require "chef_zero/server" Dir.mkdir(chef_repo_path) if !File.exists?(chef_repo_path) # 11.6 and below had a bug where it couldn't create the repo children automatically if Chef::VERSION.to_f < 11.8 - %w(clients cookbooks data_bags environments nodes roles users).each do |child| + %w{clients cookbooks data_bags environments nodes roles users}.each do |child| Dir.mkdir("#{chef_repo_path}/#{child}") if !File.exists?("#{chef_repo_path}/#{child}") end end # Start the new server - Chef::Config.repo_mode = 'hosted_everything' + Chef::Config.repo_mode = "hosted_everything" Chef::Config.chef_repo_path = chef_repo_path Chef::Config.versioned_cookbooks = true chef_fs_config = Chef::ChefFS::Config.new data_store = Chef::ChefFS::ChefFSDataStore.new(chef_fs_config.local_fs, chef_fs_config.chef_config) - data_store = ChefZero::DataStore::V1ToV2Adapter.new(data_store, 'pedant-testorg') - data_store = ChefZero::DataStore::DefaultFacade.new(data_store, 'pedant-testorg', false) - data_store.create(%w(organizations pedant-testorg users), 'pivotal', '{}') - data_store.set(%w(organizations pedant-testorg groups admins), '{ "users": [ "pivotal" ] }') - data_store.set(%w(organizations pedant-testorg groups users), '{ "users": [ "pivotal" ] }') + data_store = ChefZero::DataStore::V1ToV2Adapter.new(data_store, "pedant-testorg") + data_store = ChefZero::DataStore::DefaultFacade.new(data_store, "pedant-testorg", false) + data_store.create(%w{organizations pedant-testorg users}, "pivotal", "{}") + data_store.set(%w{organizations pedant-testorg groups admins}, '{ "users": [ "pivotal" ] }') + data_store.set(%w{organizations pedant-testorg groups users}, '{ "users": [ "pivotal" ] }') start_chef_server(data_store: data_store) end def pedant_args_from_env - args_from_env('PEDANT_OPTS') + args_from_env("PEDANT_OPTS") end def rspec_args_from_env - args_from_env('RSPEC_OPTS') + args_from_env("RSPEC_OPTS") end def args_from_env(key) @@ -89,17 +89,17 @@ end begin tmpdir = nil server = - if ENV['FILE_STORE'] - require 'tmpdir' - require 'chef_zero/data_store/raw_file_store' + if ENV["FILE_STORE"] + require "tmpdir" + require "chef_zero/data_store/raw_file_store" tmpdir = Dir.mktmpdir data_store = ChefZero::DataStore::RawFileStore.new(tmpdir, true) data_store = ChefZero::DataStore::DefaultFacade.new(data_store, false, false) start_chef_server(data_store: data_store) - elsif ENV['CHEF_FS'] - require 'tmpdir' + elsif ENV["CHEF_FS"] + require "tmpdir" tmpdir = Dir.mktmpdir start_cheffs_server(tmpdir) @@ -107,42 +107,42 @@ begin start_chef_server end - require 'rspec/core' - require 'pedant' - require 'pedant/organization' + require "rspec/core" + require "pedant" + require "pedant/organization" # Pedant::Config.rerun = true - Pedant.config.suite = 'api' + Pedant.config.suite = "api" - Pedant.config[:config_file] = 'spec/support/oc_pedant.rb' + Pedant.config[:config_file] = "spec/support/oc_pedant.rb" # Because ChefFS can only ever have one user (pivotal), we can't do most of the # tests that involve multiple - chef_fs_skips = if ENV['CHEF_FS'] - [ '--skip-association', - '--skip-users', - '--skip-organizations', - '--skip-multiuser', - '--skip-user-keys', - - # chef-zero has some non-removable quirks, such as the fact that files - # with 255-character names cannot be stored in local mode. This is - # reserved only for quirks that are *irrevocable* and by design; and - # should barely be used at all. - '--skip-chef-zero-quirks', - ] - else - [] - end + chef_fs_skips = if ENV["CHEF_FS"] + [ "--skip-association", + "--skip-users", + "--skip-organizations", + "--skip-multiuser", + "--skip-user-keys", + + # chef-zero has some non-removable quirks, such as the fact that files + # with 255-character names cannot be stored in local mode. This is + # reserved only for quirks that are *irrevocable* and by design; and + # should barely be used at all. + "--skip-chef-zero-quirks", + ] + else + [] + end # The latest released Chef doesn't do ACLs, Cookbook Artifacts or Policies yet - chef_fs_skips << '--skip-acl' - chef_fs_skips << '--skip-cookbook-artifacts' - chef_fs_skips << '--skip-policies' + chef_fs_skips << "--skip-acl" + chef_fs_skips << "--skip-cookbook-artifacts" + chef_fs_skips << "--skip-policies" # Multi-keys don't work prior to 12.8 unless Gem::Requirement.new(">= 12.8.0").satisfied_by?(Gem::Version.new(Chef::VERSION)) - chef_fs_skips << '--skip-keys' + chef_fs_skips << "--skip-keys" end # These things aren't supported by Chef Zero in any mode of operation: @@ -153,30 +153,30 @@ begin # ...but we're not there yet # Chef Zero does not intend to support validation the way erchef does. - '--skip-validation', + "--skip-validation", # Chef Zero does not intend to support authentication the way erchef does. - '--skip-authentication', + "--skip-authentication", # Chef Zero does not intend to support authorization the way erchef does. - '--skip-authorization', + "--skip-authorization", # Omnibus tests depend on erchef features that are specific to erchef and # bundled in the omnibus package. Currently the only test in this category # is for the search reindexing script. - '--skip-omnibus', + "--skip-omnibus", # USAGs (user-specific association groups) are Authz groups that contain # only one user and represent that user's association with an org. Though # there are good reasons for them, they don't work well in practice and # only the manage console really uses them. Since Chef Zero + Manage is a # quite unusual configuration, we're ignoring them. - '--skip-usags', + "--skip-usags", # Chef 12 features not yet 100% supported by Chef Zero # The universe endpoint is unlikely to ever make sense for Chef Zero - '--skip-universe', + "--skip-universe", ] # The knife tests are very slow and don't give us a lot of extra coverage, |