diff options
author | John Keiser <john@johnkeiser.com> | 2015-11-16 11:47:30 -0800 |
---|---|---|
committer | John Keiser <john@johnkeiser.com> | 2015-11-18 10:53:43 -0800 |
commit | cf9239f7a634473af2fce67bcead762407eea211 (patch) | |
tree | bb978333612d734e638ecff14c188ee087018d2f | |
parent | 905d05ac83e0c80d824e27aecf753faad5f5c02b (diff) | |
download | chef-cf9239f7a634473af2fce67bcead762407eea211.tar.gz |
Run pedant from chef-zero directly instead of having our own
-rw-r--r-- | Gemfile | 2 | ||||
-rw-r--r-- | Rakefile | 5 | ||||
-rw-r--r-- | spec/support/pedant/Gemfile | 3 | ||||
-rw-r--r-- | spec/support/pedant/pedant_config.rb | 129 | ||||
-rw-r--r-- | spec/support/pedant/run_pedant.rb | 63 | ||||
-rw-r--r-- | spec/support/pedant/stickywicket.pem | 27 | ||||
-rw-r--r-- | tasks/external_tests.rb | 2 |
7 files changed, 3 insertions, 228 deletions
@@ -28,7 +28,7 @@ group(:development, :test) do gem 'ruby-shadow', :platforms => :ruby unless RUBY_PLATFORM.downcase.match(/(aix|cygwin)/) # For external tests -# gem 'chef-zero', github: 'chef/chef-zero' + gem 'chef-zero', github: 'chef/chef-zero', branch: 'cd/run-moar-pedant' # gem 'cheffish', github: 'chef/cheffish' # gem 'chef-provisioning'#, github: 'chef/chef-provisioning' # gem 'chef-provisioning-aws', github: 'chef/chef-provisioning-aws' @@ -31,9 +31,7 @@ ChefConfig::PackageTask.new(File.expand_path('..', __FILE__), 'Chef') do |packag package.generate_version_class = true end -task :pedant do - require File.expand_path('spec/support/pedant/run_pedant') -end +task :pedant, :chef_zero_spec task :build_eventlog do Dir.chdir 'ext/win32-eventlog/' do @@ -62,4 +60,3 @@ begin rescue LoadError puts "yard is not available. (sudo) gem install yard to generate yard documentation." end - diff --git a/spec/support/pedant/Gemfile b/spec/support/pedant/Gemfile deleted file mode 100644 index d4224cd439..0000000000 --- a/spec/support/pedant/Gemfile +++ /dev/null @@ -1,3 +0,0 @@ -source "https://rubygems.org" - -gem 'chef-pedant', :github => 'opscode/chef-pedant', :ref => "server-cli-option" diff --git a/spec/support/pedant/pedant_config.rb b/spec/support/pedant/pedant_config.rb deleted file mode 100644 index 3f8219fc59..0000000000 --- a/spec/support/pedant/pedant_config.rb +++ /dev/null @@ -1,129 +0,0 @@ -# Copyright: Copyright (c) 2012 Opscode, Inc. -# License: Apache License, Version 2.0 -# -# 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. - -# This annotated Pedant configuration file details the various -# configuration settings available to you. It is separate from the -# actual Pedant::Config class because not all settings have sane -# defaults, and not all settings are appropriate in all settings. - -################################################################################ -# You MUST specify the address of the server the API requests will be -# sent to. Only specify protocol, hostname, and port. -# NOTE this is assigned in run_pedant.rb, because it's possible 8889 will not be the port chosen. -#chef_server 'http://127.0.0.1:8889' - -# If you are doing development testing, you can specify the address of -# the Solr server. The presence of this parameter will enable tests -# to force commits to Solr, greatly decreasing the amount of time -# needed for testing the search endpoint. This is only an -# optimization for development! If you are testing a "live" Chef -# Server, or otherwise do not have access to the Solr server from your -# testing location, you should not specify a value for this parameter. -# The tests will still run, albeit slower, as they will now need to -# poll for a period to ensure they are querying committed results. -#search_server "http://localhost:8983" - -# Related to the 'search_server' parameter, this specifies the maximum -# amount of time (in seconds) that search endpoint requests should be -# retried before giving up. If not explicitly set, it will default to -# 65 seconds; only set it if you know that your Solr commit interval -# differs significantly from this. -maximum_search_time 0 - -# OSC sends erchef a host header with a port, so this option needs -# # to be enabled for Pedant tests to work correctly -explicit_port_url true - -# We're starting to break tests up into groups based on different -# criteria. The proper API tests (the results of which are viewable -# to OPC customers) should be the only ones run by Pedant embedded in -# OPC installs. There are other specs that help us keep track of API -# cruft that we want to come back and fix later; these shouldn't be -# viewable to customers, but we should be able to run them in -# development and CI environments. If this parameter is missing or -# explicitly `false` only the customer-friendly tests will be run. -# -# This is mainly here for documentation purposes, since the -# command-line `opscode-pedant` utility ultimately determines this -# value. -include_internal false - -# Test users. The five users specified below are required; their -# names (:user, :non_org_user, etc.) are indicative of their role -# within the tests. All users must have a ':name' key. If they have -# a ':create_me' key, Pedant will create these users for you. If you -# are using pre-existing users, you must supply a ':key_file' key, -# which should be the fully-qualified path /on the machine Pedant is -# running on/ to a private key for that user. -key = 'spec/support/pedant/stickywicket.pem' -superuser_name 'admin' -superuser_key key -webui_key key - -# When we updated Chef to RSpec 3 there were gem conflicts with chef-pedant. -# We removed chef as a chef-pedant gem dependency in pedant.gemfile, but this -# caused chef-pedant to fail because it could not query for the chef version -# on the box pedant is running on. X-Chef-Version isn't needed in server -# requests for these tests, so we've disabled it. -ingore_x_chef_version true - -# Set the platform_class -platform_class Pedant::OpenSourcePlatform - -requestors({ - :clients => { - # The the admin user, for the purposes of getting things rolling - :admin => { - :name => "pedant_admin_client", - :create_me => true, - :create_knife => true, - :admin => true - }, - :non_admin => { - :name => 'pedant_client', - :create_me => true, - :create_knife => true - }, - :bad => { - :name => 'bad_client', - :bogus => true - } - }, - :users => { - :admin => { - :name => "admin", - :key_file => key, - :create_me => false, - :create_knife => false, - :admin => true - }, - :non_admin => { - :name => "pedant_non_admin_user", - :create_me => true, - :create_knife => true, - :admin => false - }, - # A user for Knife tests. A knife.rb and key files will be set up - # for this user - :knife_user => { - :name => "knifey", - :create_me => true, - :create_knife => true - } - } -}) - -self[:tags] = [:validation, :authentication, :authorization] -verify_error_messages false diff --git a/spec/support/pedant/run_pedant.rb b/spec/support/pedant/run_pedant.rb deleted file mode 100644 index aac2c2df1a..0000000000 --- a/spec/support/pedant/run_pedant.rb +++ /dev/null @@ -1,63 +0,0 @@ -#!/usr/bin/env ruby -require 'bundler' -require 'bundler/setup' -require 'chef_zero/server' -require 'rspec/core' -require 'chef/chef_fs/chef_fs_data_store' -require 'chef/chef_fs/config' -require 'tmpdir' -require 'fileutils' -require 'chef/version' -require 'chef/mixin/shell_out' - -def start_server(chef_repo_path) - 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| - Dir.mkdir("#{chef_repo_path}/#{child}") if !File.exists?("#{chef_repo_path}/#{child}") - end - end - - # Start the new server - Chef::Config.repo_mode = 'everything' - Chef::Config.chef_repo_path = chef_repo_path - Chef::Config.versioned_cookbooks = true - chef_fs = Chef::ChefFS::Config.new.local_fs - data_store = Chef::ChefFS::ChefFSDataStore.new(chef_fs) - server = ChefZero::Server.new(:port => 8889.upto(9999), :data_store => data_store)#, :log_level => :debug) - server.start_background - server -end - -tmpdir = Dir.mktmpdir -begin - # Create chef repository - chef_repo_path = "#{tmpdir}/repo" - - # Capture setup data into master_chef_repo_path - server = start_server(chef_repo_path) - so = nil - - include Chef::Mixin::ShellOut - - Bundler.with_clean_env do - - shell_out("bundle install --gemfile spec/support/pedant/Gemfile", :live_stream => STDOUT) - - pedant_cmd = "chef-pedant " + - " --config spec/support/pedant/pedant_config.rb" + - " --server '#{server.url}'" + - " --skip-knife --skip-validation --skip-authentication" + - " --skip-authorization --skip-omnibus" - so = shell_out("bundle exec #{pedant_cmd}", :live_stream => STDOUT, :env => {'BUNDLE_GEMFILE' => 'spec/support/pedant/Gemfile'}) - - end - -ensure - server.stop if server && server.running? - FileUtils.remove_entry_secure(tmpdir) if tmpdir -end - -exit(so.exitstatus) diff --git a/spec/support/pedant/stickywicket.pem b/spec/support/pedant/stickywicket.pem deleted file mode 100644 index ff09e73903..0000000000 --- a/spec/support/pedant/stickywicket.pem +++ /dev/null @@ -1,27 +0,0 @@ ------BEGIN RSA PRIVATE KEY----- -MIIEpQIBAAKCAQEApNCkX2k+lFGDWRVhX4uClaVQrumG9XXvk6X7M2izrIg7RzMP -Dk4thhZkpx5gr22By7PZQdMEjWC/Zo8MBjtoJ0GV0jw8npefbU1MGKs2dtpYgo0N -Fq8fX8MdFPu4h2W3g0dMEdhT8icc2H4EjhZmdeUhUn3RIEt2duCgp3YDYnUUZx3j -N7MHcTIdzD58ikr6zQrZzHOv+OOI86Xk9EpyEEQizOLoQxkICNrhqN7ElQDuvXaX -BSBrYDRKH2umBMMcXzvsR/SvkmqxoEESSpIlW8zeKAWQ+znNjDC0tmTg7jZmgSP7 -siKrwo4t4ebjcmjpIoi/JKww/nGN3Uhz1ZOZuwIDAQABAoIBAQCaJQD2s0nyEeKU -uKhfYe155Cl3zbWJcQnmv4AXbr9MiAVY6+oS6Q8ur1bn7kNjDzoruENjiuZhC7E3 -TGZklb8tp+tluyy+7vQOmBKpp8fClSfewekR5CultqhGbb8B8yIVR+NfdUHd4rLZ -z9KWyWB+txPZQQ8L80gSmrfmpzs3IuT7oPvmtBU1Wq9QapC4n/rUohHUpUV1du4G -0wCIF4zQTg6cbYW2YXozwVQvw+P7P3RVEqZt+aZlbVcy0fNr6jNao0hi1KFC9OH2 -VjjU+PioreoA/NU3aZPIUzmJpWtsu31yuOZxXmytAkYooCZgiEQNEHnJlNPv0RmC -6BPMzVoBAoGBAM7yZoSNJpzdP/q1/4+H3zyy7o4I0VTW9u/GqUzhnbjm5poK30X9 -YXh/7WOVV0OoVqdO6ljRKygP3Oggf41ZEbi1C6bbsO57pksBWgx9bD9V35XscZ0J -F1ERe//kMHwVQy74R8/cIuRwm75haLSBj5/fwGbLeeVDglJkCVqPjtuBAoGBAMvh -qsAGG5k9u6voTcXlFwS+B5YjULhK4NSxdJ2BnOxzYzxQ3IYQZMlb2xt8yZYx/ZZK -wjkr9rcAPEQIQZ2A6NUbGq6qCD7sSmg6UAi0CgiqTokQ/Wtag0UDvFMzwerdg/On -37uxffpxpte8z1jYi/MxRaoTYueuc1UVnqofVIM7AoGBALZJzwPzUY/bVAADUJmd -lYZiFsAGBF42/E05MOgH1GaK/ZWy/fkouDLsfK67XaK7JZk6ajLSDLG9R1kxRym6 -y2FoGFtiKPfo8xIenrNhx3gCrG/jVjB9UYyXWiKNXifukr9M8/SkdBfFGWsZYqGd -fmXVMiVaFoVcce8hLxwWWEABAoGBAKcyhKX/HEj6YFqlIoqkydDAylXs1jicZ27l -rF2yum8KXZpMMdzbutuKsdAD8Ql0K6NB4a+jByuiTMn5/11cJxUEqkgM9sArZQW+ -tH2+r+/VQpyTS0/rpXVGj/2nl2K1kI2T4R36e/aTl6CanWweAf9JK/lC9rxKyxg+ -p6SaFuObAoGACP6TKCkp2oymXlKgdUUgPrnsaz2VAw8jD5QHtx10U4wty0C8gxsk -MLe00h09iLPyFmvJpD+MgbxV/r6RrZeVdsKdU/5LG52YgiVSTaizyy+ciEfW7xoQ -CL5EtZd8Cn5OKinBEzzFpELqunlqepIKCIDOcLKz/cjR+3a+E6Zx5Wo= ------END RSA PRIVATE KEY----- diff --git a/tasks/external_tests.rb b/tasks/external_tests.rb index 91fa249824..856d1c502f 100644 --- a/tasks/external_tests.rb +++ b/tasks/external_tests.rb @@ -40,7 +40,7 @@ def bundle_exec_with_chef(test_gem, commands) end EXTERNAL_PROJECTS = { - "chef-zero" => [ "rake spec", "rake pedant" ], + "chef-zero" => [ "rake spec", "rake cheffs" ], "cheffish" => "rake spec", "chef-provisioning" => "rake spec", "chef-provisioning-aws" => "rake spec", |