summaryrefslogtreecommitdiffstats
path: root/spec/unit
diff options
context:
space:
mode:
Diffstat (limited to 'spec/unit')
-rwxr-xr-xspec/unit/application/cert_spec.rb14
-rwxr-xr-xspec/unit/application/certificate_spec.rb5
-rwxr-xr-xspec/unit/application/faces_base_spec.rb74
-rwxr-xr-xspec/unit/application/indirection_base_spec.rb2
-rwxr-xr-xspec/unit/application_spec.rb10
-rw-r--r--spec/unit/faces/help_spec.rb112
-rw-r--r--spec/unit/faces_spec.rb1
-rwxr-xr-xspec/unit/interface/action_builder_spec.rb11
-rwxr-xr-xspec/unit/interface/face_collection_spec.rb16
-rwxr-xr-xspec/unit/interface_spec.rb42
-rwxr-xr-xspec/unit/util/command_line_spec.rb12
11 files changed, 225 insertions, 74 deletions
diff --git a/spec/unit/application/cert_spec.rb b/spec/unit/application/cert_spec.rb
index 5b25ab7b8..a1b5eb19a 100755
--- a/spec/unit/application/cert_spec.rb
+++ b/spec/unit/application/cert_spec.rb
@@ -1,7 +1,5 @@
-#!/usr/bin/env ruby
-
+#!/usr/bin/env rspec
require 'spec_helper'
-
require 'puppet/application/cert'
describe Puppet::Application::Cert do
@@ -189,16 +187,6 @@ describe Puppet::Application::Cert do
@cert_app.ca = @ca
end
- it "should SystemExit after printing help message" do
- # Make the help method silent for testing; this is a bit nasty, but we
- # can't identify a cleaner method. Help welcome. --daniel 2011-02-22
- Puppet.features.stubs(:usage?).returns(false)
- @cert_app.stubs(:puts)
-
- @cert_app.command_line.stubs(:args).returns([])
- expect { @cert_app.parse_options }.should raise_error SystemExit
- end
-
%w{list revoke generate sign print verify fingerprint}.each do |cmd|
short = cmd[0,1]
[cmd, "--#{cmd}", "-#{short}"].each do |option|
diff --git a/spec/unit/application/certificate_spec.rb b/spec/unit/application/certificate_spec.rb
index 6153d9538..27d6ac81b 100755
--- a/spec/unit/application/certificate_spec.rb
+++ b/spec/unit/application/certificate_spec.rb
@@ -6,12 +6,15 @@ describe Puppet::Application::Certificate do
# so is this actually a valuable test? --daniel 2011-04-07
subject.command_line.stubs(:args).returns %w{list}
subject.preinit
+ subject.parse_options
subject.should respond_to(:handle_ca_location)
end
it "should accept the ca-location option" do
subject.command_line.stubs(:args).returns %w{--ca-location local list}
- subject.preinit and subject.parse_options and subject.setup
+ subject.preinit
+ subject.parse_options
+ subject.setup
subject.arguments.should == [{ :ca_location => "local" }]
end
end
diff --git a/spec/unit/application/faces_base_spec.rb b/spec/unit/application/faces_base_spec.rb
index b7a11ad56..18bd30295 100755
--- a/spec/unit/application/faces_base_spec.rb
+++ b/spec/unit/application/faces_base_spec.rb
@@ -1,4 +1,4 @@
-#!/usr/bin/env ruby
+#!/usr/bin/env rspec
require 'spec_helper'
require 'puppet/application/faces_base'
@@ -9,13 +9,6 @@ end
describe Puppet::Application::FacesBase do
before :all do
- @dir = Dir.mktmpdir
- $LOAD_PATH.push(@dir)
- FileUtils.mkdir_p(File.join @dir, 'puppet', 'faces')
- File.open(File.join(@dir, 'puppet', 'faces', 'basetest.rb'), 'w') do |f|
- f.puts "Puppet::Faces.define(:basetest, '0.0.1')"
- end
-
Puppet::Faces.define(:basetest, '0.0.1') do
option("--[no-]boolean")
option("--mandatory MANDATORY")
@@ -28,16 +21,9 @@ describe Puppet::Application::FacesBase do
end
end
- after :all do
- FileUtils.remove_entry_secure @dir
- $LOAD_PATH.pop
- end
-
let :app do
app = Puppet::Application::FacesBase::Basetest.new
- app.stubs(:exit)
- app.stubs(:puts)
- app.command_line.stubs(:subcommand_name).returns 'subcommand'
+ app.command_line.stubs(:subcommand_name).returns('subcommand')
Puppet::Util::Log.stubs(:newdestination)
app
end
@@ -51,7 +37,7 @@ describe Puppet::Application::FacesBase do
end
end
- describe "#preinit" do
+ describe "#parse_options" do
before :each do
app.command_line.stubs(:args).returns %w{}
end
@@ -68,6 +54,7 @@ describe Puppet::Application::FacesBase do
Signal.stubs(:trap)
app.command_line.stubs(:args).returns %w{foo}
app.preinit
+ app.parse_options
end
it "should set the faces based on the type" do
@@ -85,54 +72,54 @@ describe Puppet::Application::FacesBase do
end
it "should fail if no action is given" do
- expect { app.preinit }.
- should raise_error ArgumentError, /No action given/
+ expect { app.preinit; app.parse_options }.
+ to raise_error OptionParser::MissingArgument, /No action given/
end
it "should report a sensible error when options with = fail" do
app.command_line.stubs(:args).returns %w{--action=bar foo}
- expect { app.preinit }.
- should raise_error ArgumentError, /Unknown option "--action"/
+ expect { app.preinit; app.parse_options }.
+ to raise_error OptionParser::InvalidOption, /invalid option: --action/
end
it "should fail if an action option is before the action" do
app.command_line.stubs(:args).returns %w{--action foo}
- expect { app.preinit }.
- should raise_error ArgumentError, /Unknown option "--action"/
+ expect { app.preinit; app.parse_options }.
+ to raise_error OptionParser::InvalidOption, /invalid option: --action/
end
it "should fail if an unknown option is before the action" do
app.command_line.stubs(:args).returns %w{--bar foo}
- expect { app.preinit }.
- should raise_error ArgumentError, /Unknown option "--bar"/
+ expect { app.preinit; app.parse_options }.
+ to raise_error OptionParser::InvalidOption, /invalid option: --bar/
end
- it "should not fail if an unknown option is after the action" do
+ it "should fail if an unknown option is after the action" do
app.command_line.stubs(:args).returns %w{foo --bar}
- app.preinit
- app.action.name.should == :foo
- app.face.should_not be_option :bar
- app.action.should_not be_option :bar
+ expect { app.preinit; app.parse_options }.
+ to raise_error OptionParser::InvalidOption, /invalid option: --bar/
end
it "should accept --bar as an argument to a mandatory option after action" do
app.command_line.stubs(:args).returns %w{foo --mandatory --bar}
- app.preinit and app.parse_options
+ app.preinit
+ app.parse_options
app.action.name.should == :foo
app.options.should == { :mandatory => "--bar" }
end
it "should accept --bar as an argument to a mandatory option before action" do
app.command_line.stubs(:args).returns %w{--mandatory --bar foo}
- app.preinit and app.parse_options
+ app.preinit
+ app.parse_options
app.action.name.should == :foo
app.options.should == { :mandatory => "--bar" }
end
it "should not skip when --foo=bar is given" do
app.command_line.stubs(:args).returns %w{--mandatory=bar --bar foo}
- expect { app.preinit }.
- should raise_error ArgumentError, /Unknown option "--bar"/
+ expect { app.preinit; app.parse_options }.
+ to raise_error OptionParser::InvalidOption, /invalid option: --bar/
end
{ "boolean options before" => %w{--trace foo},
@@ -140,7 +127,8 @@ describe Puppet::Application::FacesBase do
}.each do |name, args|
it "should accept global boolean settings #{name} the action" do
app.command_line.stubs(:args).returns args
- app.preinit && app.parse_options
+ app.preinit
+ app.parse_options
Puppet[:trace].should be_true
end
end
@@ -150,7 +138,8 @@ describe Puppet::Application::FacesBase do
}.each do |name, args|
it "should accept global settings with arguments #{name} the action" do
app.command_line.stubs(:args).returns args
- app.preinit && app.parse_options
+ app.preinit
+ app.parse_options
Puppet[:syslogfacility].should == "user1"
end
end
@@ -160,19 +149,25 @@ describe Puppet::Application::FacesBase do
describe "#setup" do
it "should remove the action name from the arguments" do
app.command_line.stubs(:args).returns %w{--mandatory --bar foo}
- app.preinit and app.parse_options and app.setup
+ app.preinit
+ app.parse_options
+ app.setup
app.arguments.should == [{ :mandatory => "--bar" }]
end
it "should pass positional arguments" do
app.command_line.stubs(:args).returns %w{--mandatory --bar foo bar baz quux}
- app.preinit and app.parse_options and app.setup
+ app.preinit
+ app.parse_options
+ app.setup
app.arguments.should == ['bar', 'baz', 'quux', { :mandatory => "--bar" }]
end
end
describe "#main" do
- before do
+ before :each do
+ app.expects(:exit).with(0)
+
app.face = Puppet::Faces[:basetest, '0.0.1']
app.action = app.face.get_action(:foo)
app.format = :pson
@@ -186,6 +181,7 @@ describe Puppet::Application::FacesBase do
it "should use its render method to render any result" do
app.expects(:render).with(app.arguments.length + 1)
+ app.stubs(:puts) # meh. Don't print nil, thanks. --daniel 2011-04-12
app.main
end
end
diff --git a/spec/unit/application/indirection_base_spec.rb b/spec/unit/application/indirection_base_spec.rb
index 10ebe8e3d..98eb3a118 100755
--- a/spec/unit/application/indirection_base_spec.rb
+++ b/spec/unit/application/indirection_base_spec.rb
@@ -13,7 +13,7 @@ face = Puppet::Faces::Indirector.define(:testindirection, '0.0.1') do
end
# REVISIT: This horror is required because we don't allow anything to be
# :current except for if it lives on, and is loaded from, disk. --daniel 2011-03-29
-face.version = :current
+face.instance_variable_set('@version', :current)
Puppet::Faces.register(face)
########################################################################
diff --git a/spec/unit/application_spec.rb b/spec/unit/application_spec.rb
index 740b76f62..a1a46c814 100755
--- a/spec/unit/application_spec.rb
+++ b/spec/unit/application_spec.rb
@@ -357,16 +357,6 @@ describe Puppet::Application do
end
end
-
- it "should exit if OptionParser raises an error" do
- $stderr.stubs(:puts)
- OptionParser.any_instance.stubs(:parse!).raises(OptionParser::ParseError.new("blah blah"))
-
- @app.expects(:exit)
-
- lambda { @app.parse_options }.should_not raise_error
- end
-
end
describe "when calling default setup" do
diff --git a/spec/unit/faces/help_spec.rb b/spec/unit/faces/help_spec.rb
new file mode 100644
index 000000000..cd74a5bf1
--- /dev/null
+++ b/spec/unit/faces/help_spec.rb
@@ -0,0 +1,112 @@
+require 'spec_helper'
+require 'puppet/faces/help'
+
+describe Puppet::Faces[:help, '0.0.1'] do
+ it "should have a help action" do
+ subject.should be_action :help
+ end
+
+ it "should have a default action of help" do
+ pending "REVISIT: we don't support default actions yet"
+ end
+
+ it "should accept a call with no arguments" do
+ expect { subject.help() }.should_not raise_error
+ end
+
+ it "should accept a face name" do
+ expect { subject.help(:help) }.should_not raise_error
+ end
+
+ it "should accept a face and action name" do
+ expect { subject.help(:help, :help) }.should_not raise_error
+ end
+
+ it "should fail if more than a face and action are given" do
+ expect { subject.help(:help, :help, :for_the_love_of_god) }.
+ should raise_error ArgumentError
+ end
+
+ it "should treat :current and 'current' identically" do
+ subject.help(:help, :version => :current).should ==
+ subject.help(:help, :version => 'current')
+ end
+
+ it "should complain when the request version of a face is missing" do
+ expect { subject.help(:huzzah, :bar, :version => '17.0.0') }.
+ should raise_error Puppet::Error
+ end
+
+ it "should find a face by version" do
+ face = Puppet::Faces[:huzzah, :current]
+ subject.help(:huzzah, :version => face.version).
+ should == subject.help(:huzzah, :version => :current)
+ end
+
+ context "when listing subcommands" do
+ subject { Puppet::Faces[:help, :current].help }
+
+ # Check a precondition for the next block; if this fails you have
+ # something odd in your set of faces, and we skip testing things that
+ # matter. --daniel 2011-04-10
+ it "should have at least one face with a summary" do
+ Puppet::Faces.faces.should be_any do |name|
+ Puppet::Faces[name, :current].summary
+ end
+ end
+
+ Puppet::Faces.faces.each do |name|
+ face = Puppet::Faces[name, :current]
+ summary = face.summary
+
+ it { should =~ %r{ #{name} } }
+ it { should =~ %r{ #{name} +#{summary}} } if summary
+ end
+
+ Puppet::Faces[:help, :current].legacy_applications.each do |appname|
+ it { should =~ %r{ #{appname} } }
+
+ summary = Puppet::Faces[:help, :current].horribly_extract_summary_from(appname)
+ summary and it { should =~ %r{ #{summary}\b} }
+ end
+ end
+
+ context "#legacy_applications" do
+ subject { Puppet::Faces[:help, :current].legacy_applications }
+
+ # If we don't, these tests are ... less than useful, because they assume
+ # it. When this breaks you should consider ditching the entire feature
+ # and tests, but if not work out how to fake one. --daniel 2011-04-11
+ it { should have_at_least(1).item }
+
+ # Meh. This is nasty, but we can't control the other list; the specific
+ # bug that caused these to be listed is annoyingly subtle and has a nasty
+ # fix, so better to have a "fail if you do something daft" trigger in
+ # place here, I think. --daniel 2011-04-11
+ %w{faces_base indirection_base}.each do |name|
+ it { should_not include name }
+ end
+ end
+
+ context "help for legacy applications" do
+ subject { Puppet::Faces[:help, :current] }
+ let :appname do subject.legacy_applications.first end
+
+ # This test is purposely generic, so that as we eliminate legacy commands
+ # we don't get into a loop where we either test a face-based replacement
+ # and fail to notice breakage, or where we have to constantly rewrite this
+ # test and all. --daniel 2011-04-11
+ it "should return the legacy help when given the subcommand" do
+ help = subject.help(appname)
+ help.should =~ /puppet-#{appname}/
+ %w{SYNOPSIS USAGE DESCRIPTION OPTIONS COPYRIGHT}.each do |heading|
+ help.should =~ /^#{heading}$/
+ end
+ end
+
+ it "should fail when asked for an action on a legacy command" do
+ expect { subject.help(appname, :whatever) }.
+ to raise_error ArgumentError, /Legacy subcommands don't take actions/
+ end
+ end
+end
diff --git a/spec/unit/faces_spec.rb b/spec/unit/faces_spec.rb
new file mode 100644
index 000000000..b6c49d917
--- /dev/null
+++ b/spec/unit/faces_spec.rb
@@ -0,0 +1 @@
+# You should look at interface_spec.rb
diff --git a/spec/unit/interface/action_builder_spec.rb b/spec/unit/interface/action_builder_spec.rb
index 7d2710942..666575605 100755
--- a/spec/unit/interface/action_builder_spec.rb
+++ b/spec/unit/interface/action_builder_spec.rb
@@ -55,5 +55,16 @@ describe Puppet::Interface::ActionBuilder do
action.should be_option :bar
end
end
+
+ context "inline documentation" do
+ let :face do Puppet::Interface.new(:inline_action_docs, '0.0.1') end
+
+ it "should set the summary" do
+ action = Puppet::Interface::ActionBuilder.build(face, :foo) do
+ summary "this is some text"
+ end
+ action.summary.should == "this is some text"
+ end
+ end
end
end
diff --git a/spec/unit/interface/face_collection_spec.rb b/spec/unit/interface/face_collection_spec.rb
index b83bd50d3..752871035 100755
--- a/spec/unit/interface/face_collection_spec.rb
+++ b/spec/unit/interface/face_collection_spec.rb
@@ -8,9 +8,14 @@ describe Puppet::Interface::FaceCollection do
# To avoid cross-pollution we have to save and restore both the hash
# containing all the interface data, and the array used by require. Restoring
# both means that we don't leak side-effects across the code. --daniel 2011-04-06
+ #
+ # Worse luck, we *also* need to flush $" of anything defining a face,
+ # because otherwise we can cross-pollute from other test files and end up
+ # with no faces loaded, but the require value set true. --daniel 2011-04-10
before :each do
@original_faces = subject.instance_variable_get("@faces").dup
@original_required = $".dup
+ $".delete_if do |path| path =~ %r{/faces/.*\.rb$} end
subject.instance_variable_get("@faces").clear
end
@@ -75,18 +80,14 @@ describe Puppet::Interface::FaceCollection do
end
it "should attempt to load the default faces for the specified version :current" do
- subject.expects(:require).never # except...
subject.expects(:require).with('puppet/faces/fozzie')
subject['fozzie', :current]
end
end
describe "::face?" do
- before :each do
- subject.instance_variable_get("@faces")[:foo]['0.0.1'] = 10
- end
-
it "should return true if the faces specified is registered" do
+ subject.instance_variable_get("@faces")[:foo]['0.0.1'] = 10
subject.face?("foo", '0.0.1').should == true
end
@@ -137,6 +138,11 @@ describe Puppet::Interface::FaceCollection do
subject.face?(:huzzah, :current).should be_true
end
end
+
+ it "should not cause an invalid face to be enumerated later" do
+ subject.face?(:there_is_no_face, :current).should be_false
+ subject.faces.should_not include :there_is_no_face
+ end
end
describe "::register" do
diff --git a/spec/unit/interface_spec.rb b/spec/unit/interface_spec.rb
index ea11b21ba..7e6b7de77 100755
--- a/spec/unit/interface_spec.rb
+++ b/spec/unit/interface_spec.rb
@@ -1,3 +1,4 @@
+require 'spec_helper'
require 'puppet/faces'
require 'puppet/interface'
@@ -16,6 +17,20 @@ describe Puppet::Interface do
Puppet::Interface::FaceCollection.instance_variable_set("@faces", @faces)
end
+ describe "#[]" do
+ it "should fail when no version is requested" do
+ expect { subject[:huzzah] }.should raise_error ArgumentError
+ end
+
+ it "should raise an exception when the requested version is unavailable" do
+ expect { subject[:huzzah, '17.0.0'] }.should raise_error, Puppet::Error
+ end
+
+ it "should raise an exception when the requested face doesn't exist" do
+ expect { subject[:burrble_toot, :current] }.should raise_error, Puppet::Error
+ end
+ end
+
describe "#define" do
it "should register the face" do
face = subject.define(:face_test_register, '0.0.1')
@@ -28,13 +43,36 @@ describe Puppet::Interface do
end
it "should require a version number" do
- expect { subject.define(:no_version) }.should raise_error ArgumentError
+ expect { subject.define(:no_version) }.to raise_error ArgumentError
+ end
+
+ it "should support summary builder and accessor methods" do
+ subject.new(:foo, '1.0.0').should respond_to(:summary).with(0).arguments
+ subject.new(:foo, '1.0.0').should respond_to(:summary=).with(1).arguments
+ end
+
+ it "should set the summary text" do
+ text = "hello, freddy, my little pal"
+ subject.define(:face_test_summary, '1.0.0') do
+ summary text
+ end
+ subject[:face_test_summary, '1.0.0'].summary.should == text
+ end
+
+ it "should support mutating the summary" do
+ text = "hello, freddy, my little pal"
+ subject.define(:face_test_summary, '1.0.0') do
+ summary text
+ end
+ subject[:face_test_summary, '1.0.0'].summary.should == text
+ subject[:face_test_summary, '1.0.0'].summary = text + text
+ subject[:face_test_summary, '1.0.0'].summary.should == text + text
end
end
describe "#initialize" do
it "should require a version number" do
- expect { subject.new(:no_version) }.should raise_error ArgumentError
+ expect { subject.new(:no_version) }.to raise_error ArgumentError
end
it "should require a valid version number" do
diff --git a/spec/unit/util/command_line_spec.rb b/spec/unit/util/command_line_spec.rb
index ca5f0540f..6cf90475b 100755
--- a/spec/unit/util/command_line_spec.rb
+++ b/spec/unit/util/command_line_spec.rb
@@ -99,10 +99,11 @@ describe Puppet::Util::CommandLine do
Puppet::Util.expects(:which).with('puppet-whatever').returns(nil)
commandline.expects(:system).never
- commandline.expects(:usage_message).returns("the usage message")
- commandline.expects(:abort).with{|x| x =~ /the usage message/}.raises("stubbed abort")
+ text = Puppet::Faces[:help, :current].help
+ commandline.expects(:puts).with { |x| x =~ /Unknown Puppet subcommand/ }
+ commandline.expects(:puts).with text
- lambda{ commandline.execute }.should raise_error('stubbed abort')
+ commandline.execute
end
end
end
@@ -111,6 +112,11 @@ describe Puppet::Util::CommandLine do
@core_apps = %w{describe filebucket kick queue resource agent cert apply doc master}
@command_line = Puppet::Util::CommandLine.new("foo", %w{ client --help whatever.pp }, @tty )
end
+ it "should expose available_subcommands as a class method" do
+ @core_apps.each do |command|
+ @command_line.available_subcommands.should include command
+ end
+ end
it 'should be able to find all existing commands' do
@core_apps.each do |command|
@command_line.available_subcommands.should include command