使用ServerSpec在Chef cookbook上运行集成测试时遇到了一个问题。当我今天尝试运行测试而没有进行任何更改时,我收到以下错误:
TL;博士
/tmp/busser/suites/serverspec/spec_helper.rb:3:in <top (required)>': uninitialized constant SpecInfra (NameError)
> [#] ---- Begin output of kitchen verify '(default)-.+' -p ----
> [#] STDOUT: -----> Starting Kitchen (v1.2.1)
> [#] -----> Verifying <default-CentOS-70>...
> [#] Removing /tmp/busser/suites/serverspec
> [#] Uploading /tmp/busser/suites/serverspec/localhost/nodejs_spec.rb (mode=0644)
> [#] Uploading /tmp/busser/suites/serverspec/spec_helper.rb (mode=0644)
> [#] -----> Running serverspec test suite
> [#] /opt/chef/embedded/bin/ruby -I/tmp/busser/suites/serverspec -I/tmp/busser/gems/gems/rspec-support-3.0.4/lib:/tmp/busser/gems/gems/rspec-core-3.0.4/lib -S /opt/chef/embedded/bin/rspec /tmp/busser/suites/serverspec/localhost/nodejs_spec.rb --color --format documentation
> [#] /tmp/busser/suites/serverspec/spec_helper.rb:3:in `<top (required)>': uninitialized constant SpecInfra (NameError)
> [#] from /opt/chef/embedded/lib/ruby/site_ruby/1.9.1/rubygems/custom_require.rb:36:in `require'
> [#] from /opt/chef/embedded/lib/ruby/site_ruby/1.9.1/rubygems/custom_require.rb:36:in `require'
> [#] from /tmp/busser/suites/serverspec/localhost/nodejs_spec.rb:1:in `<top (required)>'
> [#] from /tmp/busser/gems/gems/rspec-core-3.0.4/lib/rspec/core/configuration.rb:1058:in `load'
> [#] from /tmp/busser/gems/gems/rspec-core-3.0.4/lib/rspec/core/configuration.rb:1058:in `block in load_spec_files'
> [#] from /tmp/busser/gems/gems/rspec-core-3.0.4/lib/rspec/core/configuration.rb:1058:in `each'
> [#] from /tmp/busser/gems/gems/rspec-core-3.0.4/lib/rspec/core/configuration.rb:1058:in `load_spec_files'
> [#] from /tmp/busser/gems/gems/rspec-core-3.0.4/lib/rspec/core/runner.rb:97:in `setup'
> [#] from /tmp/busser/gems/gems/rspec-core-3.0.4/lib/rspec/core/runner.rb:85:in `run'
> [#] from /tmp/busser/gems/gems/rspec-core-3.0.4/lib/rspec/core/runner.rb:70:in `run'
> [#] from /tmp/busser/gems/gems/rspec-core-3.0.4/lib/rspec/core/runner.rb:38:in `invoke'
> [#] from /tmp/busser/gems/gems/rspec-core-3.0.4/exe/rspec:4:in `<top (required)>'
> [#] from /opt/chef/embedded/bin/rspec:23:in `load'
> [#] from /opt/chef/embedded/bin/rspec:23:in `<main>'
> [#] /opt/chef/embedded/bin/ruby -I/tmp/busser/suites/serverspec -I/tmp/busser/gems/gems/rspec-support-3.0.4/lib:/tmp/busser/gems/gems/rspec-core-3.0.4/lib -S /opt/chef/embedded/bin/rspec /tmp/busser/suites/serverspec/localhost/nodejs_spec.rb --color --format documentation failed
> [#] Ruby Script [/tmp/busser/gems/gems/busser-serverspec-0.2.7/lib/busser/runner_plugin/../serverspec/runner.rb /tmp/busser/suites/serverspec] exit code was 1
> [#]
> [#] STDERR: >>>>>> Verify failed on instance <default-CentOS-70>.
> [#] >>>>>> Please see .kitchen/logs/default-CentOS-70.log for more details
> [#] >>>>>> ------Exception-------
> [#] >>>>>> Class: Kitchen::ActionFailed
> [#] >>>>>> Message: SSH exited (1) for command: [sh -c 'BUSSER_ROOT="/tmp/busser" GEM_HOME="/tmp/busser/gems" GEM_PATH="/tmp/busser/gems" GEM_CACHE="/tmp/busser/gems/cache" ; export BUSSER_ROOT GEM_HOME GEM_PATH GEM_CACHE; sudo -E /tmp/busser/bin/busser test']
> [#] >>>>>> ----------------------
有谁知道为什么会这样?
根据评论:
require 'serverspec'
# require 'specinfra' #I've tried both with and without this
include SpecInfra::Helper::Exec
include SpecInfra::Helper::DetectOS
RSpec.configure do |c|
if ENV['ASK_SUDO_PASSWORD']
require 'highline/import'
c.sudo_password = ask("Enter sudo password: ") { |q| q.echo = false }
else
c.sudo_password = ENV['SUDO_PASSWORD']
end
end
该文件符合使用该应用程序的说明,之前未经过修改。
答案 0 :(得分:3)
如果您正在使用serverspec 2+,则需要删除SpecInfra行并替换为set命令:
require 'serverspec'
set :backend, :exec
RSpec.configure do |c|
c.before :all do
c.path = '/sbin:/usr/sbin'
end
end
# etc
在我最新的PR中有关kitchen.ci上的示例回购的更多信息 - https://github.com/test-kitchen/guide-started-git-cookbook/pull/3
答案 1 :(得分:2)
Test Kitchen将尝试安装最新版本的ServerSpec。不幸的是,最近有一个主要版本的ServerSpec可能已经破坏了一些东西,所以你可能需要升级你的测试。
请参阅http://lists.opscode.com/sympa/arc/chef/2014-10/msg00027.html
处的主题答案 2 :(得分:0)
文件/tmp/busser/suites/serverspec/spec_helper.rb
可能引用了常量SpecInfra
,但是你还没有加载任何gem或Ruby文件实际定义该常量,所以常量是未定义的。
我无法在SpecInfra
找到很多文档,但我想你只需要在shell中运行gem install specinfra
来安装gem,然后在{}添加require 'specinfra'
发生错误的文件的顶部。这是解决这些类型错误的常用方法。
我假设spec_helper.rb
是你在某个时候写过的文件,它会被服务器规范复制到服务器上,但我从来没有使用过该工具,所以我没有&#39;我很了解它。您需要确保将gem安装/复制到运行测试的服务器,因此您可能需要将gem添加到serverspec的某个配置文件中。