diff options
Diffstat (limited to 'vendor/plugins/rspec/spec')
103 files changed, 9709 insertions, 0 deletions
diff --git a/vendor/plugins/rspec/spec/README.jruby b/vendor/plugins/rspec/spec/README.jruby new file mode 100644 index 000000000..0b31d1877 --- /dev/null +++ b/vendor/plugins/rspec/spec/README.jruby @@ -0,0 +1,14 @@ += Running specs on JRuby = + +svn co http://svn.codehaus.org/jruby/trunk jruby +cd jruby/jruby +ant clean +ant +# put JRuby's bin dir on your PATH +jruby -S gem install rake --no-ri --no-rdoc +jruby -S gem install diff-lcs +cd ../testsuites/rspec +mkdir target +jruby -S rake checkout_code +cd target/rspec +jruby bin/spec spec -c diff --git a/vendor/plugins/rspec/spec/autotest/discover_spec.rb b/vendor/plugins/rspec/spec/autotest/discover_spec.rb new file mode 100644 index 000000000..da5cb1445 --- /dev/null +++ b/vendor/plugins/rspec/spec/autotest/discover_spec.rb @@ -0,0 +1,19 @@ +require File.dirname(__FILE__) + "/../autotest_helper" + +module DiscoveryHelper + def load_discovery + require File.dirname(__FILE__) + "/../../lib/autotest/discover" + end +end + + +class Autotest + describe Rspec, "discovery" do + include DiscoveryHelper + + it "should add the rspec autotest plugin" do + Autotest.should_receive(:add_discovery).and_yield + load_discovery + end + end +end diff --git a/vendor/plugins/rspec/spec/autotest/rspec_spec.rb b/vendor/plugins/rspec/spec/autotest/rspec_spec.rb new file mode 100644 index 000000000..52b5b4885 --- /dev/null +++ b/vendor/plugins/rspec/spec/autotest/rspec_spec.rb @@ -0,0 +1,258 @@ +require File.dirname(__FILE__) + "/../autotest_helper" + +class Autotest + + module AutotestHelper + def rspec_output + <<-HERE +.............PPF + +1) +'false should be false' FAILED +expected: true, + got: false (using ==) +./spec/autotest/rspec_spec.rb:203: + +Finished in 0.158674 seconds + +16 examples, 1 failure, 2 pending + +Pending: +Autotest::Rspec handling failed results should return an array of failed examples and errors (TODO) +Autotest::Rspec tests/specs for a given file should find all the specs for a given file (TODO) +HERE + end + + + def common_setup + @proc = mock Proc + @kernel = mock Kernel + @kernel.stub!(:proc).and_return @proc + + File.stub!(:exists).and_return true + @windows_alt_separator = "\\" + @posix_separator = '/' + + @rspec_output = rspec_output + end + end + + describe Rspec, "rspec_commands" do + it "should contain the various commands, ordered by preference" do + Rspec.new.spec_commands.should == ["bin/spec", "#{Config::CONFIG['bindir']}/spec"] + end + end + + describe Rspec, "selection of rspec command" do + include AutotestHelper + + before :each do + common_setup + @rspec_autotest = Rspec.new(@kernel) + end + + it "should try to find the spec command if it exists in ./bin and use it above everything else" do + File.stub!(:exists?).and_return true + + File.should_receive(:exists?).with("bin/spec").and_return true + @rspec_autotest.spec_command.should == "bin/spec" + end + + it "should otherwise select the default spec command in gem_dir/bin/spec" do + @rspec_autotest.stub!(:spec_commands).and_return ["/foo/spec"] + Config::CONFIG.stub!(:[]).and_return "/foo" + File.should_receive(:exists?).with("/foo/spec").and_return(true) + + @rspec_autotest.spec_command.should == "/foo/spec" + end + + it "should raise an error if no spec command is found at all" do + File.stub!(:exists?).and_return false + + lambda { + @rspec_autotest.spec_command + }.should raise_error(RspecCommandError, "No spec command could be found!") + end + + end + + describe Rspec, "selection of rspec command (windows compatibility issues)" do + include AutotestHelper + + before :each do + common_setup + end + + it "should use the ALT_SEPARATOR if it is non-nil" do + @rspec_autotest = Rspec.new(@kernel, @posix_separator, @windows_alt_separator) + @rspec_autotest.stub!(:spec_commands).and_return [File.join('bin', 'spec')] + @rspec_autotest.spec_command.should == "bin\\spec" + end + + it "should not use the ALT_SEPATOR if it is nil" do + @windows_alt_separator = nil + @rspec_autotest = Rspec.new(@kernel, @posix_separator, @windows_alt_separator) + @rspec_autotest.stub!(:spec_commands).and_return [File.join('bin', 'spec')] + @rspec_autotest.spec_command.should == "bin/spec" + end + end + + describe Rspec, "adding spec.opts --options" do + before :each do + @rspec_autotest = Rspec.new + end + + it "should return the command line option to add spec.opts if the options file exists" do + File.stub!(:exist?).and_return true + @rspec_autotest.add_options_if_present.should == "-O spec/spec.opts " + end + + it "should return an empty string if no spec.opts exists" do + File.stub!(:exist?).and_return false + Rspec.new.add_options_if_present.should == "" + end + end + + describe Rspec do + before :each do + @rspec_autotest = Rspec.new + @rspec_autotest.stub!(:ruby).and_return "ruby" + @rspec_autotest.stub!(:add_options_if_present).and_return "-O spec/spec.opts" + + @ruby = @rspec_autotest.ruby + @spec_command = @rspec_autotest.spec_command + @options = @rspec_autotest.add_options_if_present + @files_to_test = { + :spec => ["file_one", "file_two"] + } + # this is not the inner representation of Autotest! + @rspec_autotest.stub!(:files_to_test).and_return @files_to_test + @files_to_test.stub!(:keys).and_return @files_to_test[:spec] + @to_test = @files_to_test.keys.flatten.join ' ' + end + + it "should make the apropriate test command" do + @rspec_autotest.make_test_cmd(@files_to_test).should == "#{@ruby} -S #{@spec_command} #{@options} #{@to_test}" + end + end + + describe Rspec, "test mappings" do + before :each do + @proc = mock Proc + @kernel = mock Kernel + @kernel.stub!(:proc).and_return @proc + @rspec_autotest = Rspec.new(@kernel) + end + + it "should map all filenames in spec/ which end in .rb" do + @rspec_autotest.test_mappings[%r%^spec/.*\.rb$%].should == @proc + end + + it "should map all names in lib which end in .rb to the corresponding ones in spec/" do + @rspec_autotest.test_mappings[%r%^lib/(.*)\.rb$%].should == @proc + end + + it "should find all files in spec/shares/* and the spec helper in spec/spec_helper" do + @rspec_autotest.test_mappings[%r%^spec/(spec_helper|shared/.*)\.rb$%].should == @proc + end + end + + describe Rspec, "handling results" do + include AutotestHelper + + before :each do + common_setup + @rspec_autotest = Rspec.new(@kernel, @posix_separator, @windows_alt_separator) + @rspec_autotest.stub!(:hook) + + @results = mock String + @results.stub!(:scan).and_return "" + end + + it "should call hook(:red) if there are failures" do + @rspec_autotest.stub!(:consolidate_failures).and_return ["spec/some_spec.rb"] + + @rspec_autotest.should_receive(:hook).with(:red) + @rspec_autotest.handle_results(@results) + end + + it "should call hook(:green) if there are no failures" do + @rspec_autotest.stub!(:consolidate_failures).and_return [] + @rspec_autotest.should_receive(:hook).with(:green) + @rspec_autotest.handle_results(@results) + end + end + + describe Rspec, "handling failed results" do + include AutotestHelper + + before :each do + common_setup + end + + it %(should scan the output into a multi-dimensional array, + consisting of the failing spec's name as the first element, + and the failure as the second) do + @rspec_autotest = Rspec.new + @rspec_autotest.failed_results(@rspec_output).should == [ + [ + "false should be false", + "expected: true,\n got: false (using ==)\n./spec/autotest/rspec_spec.rb:203:" + ] + ] + end + end + + describe Rspec, "specs for a given file" do + before :each do + @lib_file = "lib/something.rb" + @spec_file = "spec/something_spec.rb" + @rspec_autotest = Rspec.new + + @rspec_autotest.instance_variable_set("@files", {@lib_file => Time.now, @spec_file => Time.now}) + @rspec_autotest.stub!(:find_files_to_test).and_return true + end + + it "should find the spec file for a given lib file" do + @rspec_autotest.specs_for_file(@lib_file).should == [@spec_file] + end + + it "should find the spec file if given a spec file" do + @rspec_autotest.specs_for_file(@spec_file).should == [@spec_file] + end + + it "should only find the file if the file is being tracked (in @file)" do + @other_file = "lib/some_non_tracked_file" + @rspec_autotest.specs_for_file(@other_file).should == [] + end + end + + describe Rspec, "consolidating failures" do + include AutotestHelper + + before :each do + common_setup + @rspec_autotest = Rspec.new + + @spec_file = "./spec/autotest/rspec_spec.rb" + @rspec_autotest.instance_variable_set("@files", {@spec_file => Time.now}) + @rspec_autotest.stub!(:find_files_to_test).and_return true + end + + it "should return no failures if no failures were given in the output" do + @rspec_autotest.stub!(:failed_results).and_return [[]] + @rspec_autotest.consolidate_failures(@rspec_autotest.failed_results).should == {} + end + + it "should return a hash with the spec filename => spec name for each failure or error" do + @rspec_autotest.stub!(:failed_results).and_return([ + [ + "false should be false", + "expected: true,\n got: false (using ==)\n./spec/autotest/rspec_spec.rb:203:" + ] + ]) + @rspec_autotest.consolidate_failures(@rspec_autotest.failed_results).should == {@spec_file => ["false should be false"]} + end + + end +end diff --git a/vendor/plugins/rspec/spec/autotest_helper.rb b/vendor/plugins/rspec/spec/autotest_helper.rb new file mode 100644 index 000000000..172bb3a4a --- /dev/null +++ b/vendor/plugins/rspec/spec/autotest_helper.rb @@ -0,0 +1,4 @@ +require 'autotest' +require File.dirname(__FILE__) + "/../lib/autotest/rspec" + + diff --git a/vendor/plugins/rspec/spec/spec/dsl/behaviour_eval_spec.rb b/vendor/plugins/rspec/spec/spec/dsl/behaviour_eval_spec.rb new file mode 100644 index 000000000..c3ed4e282 --- /dev/null +++ b/vendor/plugins/rspec/spec/spec/dsl/behaviour_eval_spec.rb @@ -0,0 +1,79 @@ +require File.dirname(__FILE__) + '/../../spec_helper' + +module Spec + module DSL + describe BehaviourEval do + def count + @count ||= 0 + @count = @count + 1 + @count + end + + before(:all) do + count.should == 1 + end + + before(:all) do + count.should == 2 + end + + before(:each) do + count.should == 3 + end + + before(:each) do + count.should == 4 + end + + it "should run before(:all), before(:each), example, after(:each), after(:all) in order" do + count.should == 5 + end + + after(:each) do + count.should == 7 + end + + after(:each) do + count.should == 6 + end + + after(:all) do + count.should == 9 + end + + after(:all) do + count.should == 8 + end + end + + describe BehaviourEval, "instance methods" do + it "should support pending" do + lambda { + pending("something") + }.should raise_error(Spec::DSL::ExamplePendingError, "something") + end + + it "should have #pending raise a Pending error when its block fails" do + block_ran = false + lambda { + pending("something") do + block_ran = true + raise "something wrong with my example" + end + }.should raise_error(Spec::DSL::ExamplePendingError, "something") + block_ran.should == true + end + + it "should have #pending raise Spec::DSL::PendingFixedError when its block does not fail" do + block_ran = false + lambda { + pending("something") do + block_ran = true + end + }.should raise_error(Spec::DSL::PendingFixedError, "Expected pending 'something' to fail. No Error was raised.") + block_ran.should == true + end + + end + end +end diff --git a/vendor/plugins/rspec/spec/spec/dsl/behaviour_factory_spec.rb b/vendor/plugins/rspec/spec/spec/dsl/behaviour_factory_spec.rb new file mode 100644 index 000000000..91008a660 --- /dev/null +++ b/vendor/plugins/rspec/spec/spec/dsl/behaviour_factory_spec.rb @@ -0,0 +1,48 @@ +require File.dirname(__FILE__) + '/../../spec_helper' + +module Spec + module DSL + describe BehaviourFactory do + it "should create a Spec::DSL::Behaviour by default" do + Spec::DSL::BehaviourFactory.create("behaviour") { + }.should be_an_instance_of(Spec::DSL::Behaviour) + end + + it "should create a Spec::DSL::Behaviour when :behaviour_type => :default" do + Spec::DSL::BehaviourFactory.create("behaviour", :behaviour_type => :default) { + }.should be_an_instance_of(Spec::DSL::Behaviour) + end + + it "should create specified type when :behaviour_type => :something_other_than_default" do + behaviour_class = Class.new do + def initialize(*args, &block); end + end + Spec::DSL::BehaviourFactory.add_behaviour_class(:something_other_than_default, behaviour_class) + Spec::DSL::BehaviourFactory.create("behaviour", :behaviour_type => :something_other_than_default) { + }.should be_an_instance_of(behaviour_class) + end + + it "should type indicated by spec_path" do + behaviour_class = Class.new do + def initialize(*args, &block); end + end + Spec::DSL::BehaviourFactory.add_behaviour_class(:something_other_than_default, behaviour_class) + Spec::DSL::BehaviourFactory.create("behaviour", :spec_path => "./spec/something_other_than_default/some_spec.rb") { + }.should be_an_instance_of(behaviour_class) + end + + it "should type indicated by spec_path (with spec_path generated by caller on windows)" do + behaviour_class = Class.new do + def initialize(*args, &block); end + end + Spec::DSL::BehaviourFactory.add_behaviour_class(:something_other_than_default, behaviour_class) + Spec::DSL::BehaviourFactory.create("behaviour", :spec_path => "./spec\\something_other_than_default\\some_spec.rb") { + }.should be_an_instance_of(behaviour_class) + end + + after(:each) do + Spec::DSL::BehaviourFactory.remove_behaviour_class(:something_other_than_default) + end + end + end +end diff --git a/vendor/plugins/rspec/spec/spec/dsl/behaviour_spec.rb b/vendor/plugins/rspec/spec/spec/dsl/behaviour_spec.rb new file mode 100644 index 000000000..fa6774c65 --- /dev/null +++ b/vendor/plugins/rspec/spec/spec/dsl/behaviour_spec.rb @@ -0,0 +1,661 @@ +require File.dirname(__FILE__) + '/../../spec_helper' + +module Spec + module DSL + class FakeReporter < Spec::Runner::Reporter + attr_reader :added_behaviour + def add_behaviour(description) + @added_behaviour = description + end + end + + describe Behaviour, "class methods" do + before :each do + @reporter = FakeReporter.new(mock("formatter", :null_object => true), mock("backtrace_tweaker", :null_object => true)) + @behaviour = Behaviour.new("example") {} + end + + after :each do + Behaviour.clear_before_and_after! + end + + it "should not run before(:all) or after(:all) on dry run" do + before_all_ran = false + after_all_ran = false + Behaviour.before(:all) { before_all_ran = true } + Behaviour.after(:all) { after_all_ran = true } + @behaviour.it("should") {} + @behaviour.run(@reporter, true) + before_all_ran.should be_false + after_all_ran.should be_false + end + + it "should not run any example if before(:all) fails" do + spec_ran = false + Behaviour.before(:all) { raise NonStandardError } + @behaviour.it("test") {spec_ran = true} + @behaviour.run(@reporter) + spec_ran.should be_false + end + + it "should run after(:all) if before(:all) fails" do + after_all_ran = false + Behaviour.before(:all) { raise NonStandardError } + Behaviour.after(:all) { after_all_ran = true } + @behaviour.run(@reporter) + after_all_ran.should be_true + end + + it "should run after(:all) if before(:each) fails" do + after_all_ran = false + Behaviour.before(:each) { raise NonStandardError } + Behaviour.after(:all) { after_all_ran = true } + @behaviour.run(@reporter) + after_all_ran.should be_true + end + + it "should run after(:all) if any example fails" do + after_all_ran = false + @behaviour.it("should") { raise NonStandardError } + Behaviour.after(:all) { after_all_ran = true } + @behaviour.run(@reporter) + after_all_ran.should be_true + end + + + it "should unregister a given after(:each) block" do + after_all_ran = false + @behaviour.it("example") {} + proc = Proc.new { after_all_ran = true } + Behaviour.after(:each, &proc) + @behaviour.run(@reporter) + after_all_ran.should be_true + + after_all_ran = false + Behaviour.remove_after(:each, &proc) + @behaviour.run(@reporter) + after_all_ran.should be_false + end + + it "should run second after(:each) block even if the first one fails" do + example = @behaviour.it("example") {} + second_after_ran = false + @behaviour.after(:each) do + second_after_ran = true + raise "second" + end + first_after_ran = false + @behaviour.after(:each) do + first_after_ran = true + raise "first" + end + + @reporter.should_receive(:example_finished) do |example, error, location, example_not_implemented| + example.should equal(example) + error.message.should eql("first") + location.should eql("after(:each)") + example_not_implemented.should be_false + end + @behaviour.run(@reporter) + first_after_ran.should be_true + second_after_ran.should be_true + end + + it "should not run second before(:each) if the first one fails" do + @behaviour.it("example") {} + first_before_ran = false + @behaviour.before(:each) do + first_before_ran = true + raise "first" + end + second_before_ran = false + @behaviour.before(:each) do + second_before_ran = true + raise "second" + end + + @reporter.should_receive(:example_finished) do |name, error, location, example_not_implemented| + name.should eql("example") + error.message.should eql("first") + location.should eql("before(:each)") + example_not_implemented.should be_false + end + @behaviour.run(@reporter) + first_before_ran.should be_true + second_before_ran.should be_false + end + + it "should supply before(:all) as description if failure in before(:all)" do + @reporter.should_receive(:example_finished) do |example, error, location| + example.description.should eql("before(:all)") + error.message.should == "in before(:all)" + location.should eql("before(:all)") + end + + Behaviour.before(:all) { raise NonStandardError.new("in before(:all)") } + @behaviour.it("test") {true} + @behaviour.run(@reporter) + end + + it "should provide after(:all) as description if failure in after(:all)" do + @reporter.should_receive(:example_finished) do |example, error, location| + example.description.should eql("after(:all)") + error.message.should eql("in after(:all)") + location.should eql("after(:all)") + end + + Behaviour.after(:all) { raise NonStandardError.new("in after(:all)") } + @behaviour.run(@reporter) + end + end + + describe Behaviour do + before :each do + @reporter = FakeReporter.new(mock("formatter", :null_object => true), mock("backtrace_tweaker", :null_object => true)) + @behaviour = Behaviour.new("example") {} + end + + after :each do + Behaviour.clear_before_and_after! + end + + it "should send reporter add_behaviour" do + @behaviour.run(@reporter) + @reporter.added_behaviour.should == "example" + end + + it "should run example on run" do + example_ran = false + @behaviour.it("should") {example_ran = true} + @behaviour.run(@reporter) + example_ran.should be_true + end + + it "should not run example on dry run" do + example_ran = false + @behaviour.it("should") {example_ran = true} + @behaviour.run(@reporter, true) + example_ran.should be_false + end + + it "should not run before(:all) or after(:all) on dry run" do + before_all_ran = false + after_all_ran = false + @behaviour.before(:all) { before_all_ran = true } + @behaviour.after(:all) { after_all_ran = true } + @behaviour.it("should") {} + @behaviour.run(@reporter, true) + before_all_ran.should be_false + after_all_ran.should be_false + end + + it "should not run any example if before(:all) fails" do + spec_ran = false + @behaviour.before(:all) { raise "help" } + @behaviour.it("test") {spec_ran = true} + @behaviour.run(@reporter) + spec_ran.should be_false + end + + it "should run after(:all) if before(:all) fails" do + after_all_ran = false + @behaviour.before(:all) { raise } + @behaviour.after(:all) { after_all_ran = true } + @behaviour.run(@reporter) + after_all_ran.should be_true + end + + it "should run after(:all) if before(:each) fails" do + after_all_ran = false + @behaviour.before(:each) { raise } + @behaviour.after(:all) { after_all_ran = true } + @behaviour.run(@reporter) + after_all_ran.should be_true + end + + it "should run after(:all) if any example fails" do + after_all_ran = false + @behaviour.it("should") { raise "before all error" } + @behaviour.after(:all) { after_all_ran = true } + @behaviour.run(@reporter) + after_all_ran.should be_true + end + + it "should supply before(:all) as description if failure in before(:all)" do + @reporter.should_receive(:example_finished) do |example, error, location| + example.description.should eql("before(:all)") + error.message.should eql("in before(:all)") + location.should eql("before(:all)") + end + + @behaviour.before(:all) { raise "in before(:all)" } + @behaviour.it("test") {true} + @behaviour.run(@reporter) + end + + it "should provide after(:all) as description if failure in after(:all)" do + @reporter.should_receive(:example_finished) do |example, error, location| + example.description.should eql("after(:all)") + error.message.should eql("in after(:all)") + location.should eql("after(:all)") + end + + @behaviour.after(:all) { raise "in after(:all)" } + @behaviour.run(@reporter) + end + + it "should run before(:all) block only once" do + before_all_run_count_run_count = 0 + @behaviour.before(:all) {before_all_run_count_run_count += 1} + @behaviour.it("test") {true} + @behaviour.it("test2") {true} + @behaviour.run(@reporter) + before_all_run_count_run_count.should == 1 + end + + it "calls spec_inherited class method" do + super_class_before_ran = false + super_class = Class.new do + def self.spec_inherited(mod) + mod.before {setup} + end + + define_method :setup do + super_class_before_ran = true + end + end + @behaviour.inherit super_class + + before_ran = false + @behaviour.before {before_ran = true} + @behaviour.it("test") {true} + @behaviour.run(@reporter) + super_class_before_ran.should be_true + before_ran.should be_true + end + + it "should run after(:all) block only once" do + after_all_run_count = 0 + @behaviour.after(:all) {after_all_run_count += 1} + @behaviour.it("test") {true} + @behaviour.it("test2") {true} + @behaviour.run(@reporter) + after_all_run_count.should == 1 + @reporter.rspec_verify + end + + it "after(:all) should have access to all instance variables defined in before(:all)" do + context_instance_value_in = "Hello there" + context_instance_value_out = "" + @behaviour.before(:all) { @instance_var = context_instance_value_in } + @behaviour.after(:all) { context_instance_value_out = @instance_var } + @behaviour.it("test") {true} + @behaviour.run(@reporter) + context_instance_value_in.should == context_instance_value_out + end + + it "should copy instance variables from before(:all)'s execution context into spec's execution context" do + context_instance_value_in = "Hello there" + context_instance_value_out = "" + @behaviour.before(:all) { @instance_var = context_instance_value_in } + @behaviour.it("test") {context_instance_value_out = @instance_var} + @behaviour.run(@reporter) + context_instance_value_in.should == context_instance_value_out + end + + it "should not add global before callbacks for untargetted behaviours" do + fiddle = [] + + Behaviour.before(:all) { fiddle << "Behaviour.before(:all)" } + Behaviour.prepend_before(:all) { fiddle << "Behaviour.prepend_before(:all)" } + Behaviour.before(:each, :behaviour_type => :special) { fiddle << "Behaviour.before(:each, :behaviour_type => :special)" } + Behaviour.prepend_before(:each, :behaviour_type => :special) { fiddle << "Behaviour.prepend_before(:each, :behaviour_type => :special)" } + Behaviour.before(:all, :behaviour_type => :special) { fiddle << "Behaviour.before(:all, :behaviour_type => :special)" } + Behaviour.prepend_before(:all, :behaviour_type => :special) { fiddle << "Behaviour.prepend_before(:all, :behaviour_type => :special)" } + + behaviour = Behaviour.new("I'm not special", :behaviour_type => :not_special) {} + behaviour.run(@reporter) + fiddle.should == [ + 'Behaviour.prepend_before(:all)', + 'Behaviour.before(:all)', + ] + end + + it "should add global before callbacks for targetted behaviours" do + fiddle = [] + + Behaviour.before(:all) { fiddle << "Behaviour.before(:all)" } + Behaviour.prepend_before(:all) { fiddle << "Behaviour.prepend_before(:all)" } + Behaviour.before(:each, :behaviour_type => :special) { fiddle << "Behaviour.before(:each, :behaviour_type => :special)" } + Behaviour.prepend_before(:each, :behaviour_type => :special) { fiddle << "Behaviour.prepend_before(:each, :behaviour_type => :special)" } + Behaviour.before(:all, :behaviour_type => :special) { fiddle << "Behaviour.before(:all, :behaviour_type => :special)" } + Behaviour.prepend_before(:all, :behaviour_type => :special) { fiddle << "Behaviour.prepend_before(:all, :behaviour_type => :special)" } + + Behaviour.append_before(:behaviour_type => :special) { fiddle << "Behaviour.append_before(:each, :behaviour_type => :special)" } + + behaviour = Behaviour.new("I'm not special", :behaviour_type => :special) {} + behaviour.it("test") {true} + behaviour.run(@reporter) + fiddle.should == [ + 'Behaviour.prepend_before(:all)', + 'Behaviour.before(:all)', + 'Behaviour.prepend_before(:all, :behaviour_type => :special)', + 'Behaviour.before(:all, :behaviour_type => :special)', + 'Behaviour.prepend_before(:each, :behaviour_type => :special)', + 'Behaviour.before(:each, :behaviour_type => :special)', + 'Behaviour.append_before(:each, :behaviour_type => :special)', + ] + end + + it "before callbacks are ordered from global to local" do + fiddle = [] + super_class = Class.new do + define_method :setup do + fiddle << "superclass setup" + end + end + @behaviour.inherit super_class + + Behaviour.prepend_before(:all) { fiddle << "Behaviour.prepend_before(:all)" } + Behaviour.before(:all) { fiddle << "Behaviour.before(:all)" } + @behaviour.prepend_before(:all) { fiddle << "prepend_before(:all)" } + @behaviour.before(:all) { fiddle << "before(:all)" } + @behaviour.prepend_before(:each) { fiddle << "prepend_before(:each)" } + @behaviour.before(:each) { fiddle << "before(:each)" } + @behaviour.it("test") {true} + @behaviour.run(@reporter) + fiddle.should == [ + 'Behaviour.prepend_before(:all)', + 'Behaviour.before(:all)', + 'prepend_before(:all)', + 'before(:all)', + 'prepend_before(:each)', + 'before(:each)' + ] + end + + it "after callbacks are ordered from local to global" do + @reporter.should_receive(:add_behaviour).with any_args() + @reporter.should_receive(:example_finished).with any_args() + + fiddle = [] + super_class = Class.new do + define_method :teardown do + fiddle << "superclass teardown" + end + end + @behaviour.inherit super_class + + @behaviour.after(:each) { fiddle << "after(:each)" } + @behaviour.append_after(:each) { fiddle << "append_after(:each)" } + @behaviour.after(:all) { fiddle << "after(:all)" } + @behaviour.append_after(:all) { fiddle << "append_after(:all)" } + Behaviour.after(:all) { fiddle << "Behaviour.after(:all)" } + Behaviour.append_after(:all) { fiddle << "Behaviour.append_after(:all)" } + @behaviour.it("test") {true} + @behaviour.run(@reporter) + fiddle.should == [ + 'after(:each)', + 'append_after(:each)', + 'after(:all)', + 'append_after(:all)', + 'Behaviour.after(:all)', + 'Behaviour.append_after(:all)' + ] + end + + it "should run superclass teardown method and after block" do + super_class_teardown_ran = false + super_class = Class.new do + define_method :teardown do + super_class_teardown_ran = true + end + end + @behaviour.inherit super_class + + teardown_ran = false + @behaviour.after {teardown_ran = true} + @behaviour.it("test") {true} + @behaviour.run(@reporter) + super_class_teardown_ran.should be_false + teardown_ran.should be_true + @reporter.rspec_verify + end + + it "should have accessible methods from inherited superclass" do + helper_method_ran = false + super_class = Class.new do + define_method :helper_method do + helper_method_ran = true + end + end + @behaviour.inherit super_class + + @behaviour.it("test") {helper_method} + @behaviour.run(@reporter) + helper_method_ran.should be_true + end + + it "should have accessible class methods from inherited superclass" do + class_method_ran = false + super_class = Class.new + (class << super_class; self; end).class_eval do + define_method :class_method do + class_method_ran = true + end + end + @behaviour.inherit super_class + @behaviour.class_method + class_method_ran.should be_true + + lambda {@behaviour.foobar}.should raise_error(NoMethodError) + end + + it "should include inherited class methods" do + class_method_ran = false + super_class = Class.new + class << super_class + def super_class_class_method; end + end + @behaviour.inherit super_class + + @behaviour.methods.should include("super_class_class_method") + end + + it "should have accessible instance methods from included module" do + @reporter.should_receive(:add_behaviour).with any_args() + @reporter.should_receive(:example_finished).with any_args() + + mod1_method_called = false + mod1 = Module.new do + define_method :mod1_method do + mod1_method_called = true + end + end + + mod2_method_called = false + mod2 = Module.new do + define_method :mod2_method do + mod2_method_called = true + end + end + + @behaviour.include mod1, mod2 + + @behaviour.it("test") do + mod1_method + mod2_method + end + @behaviour.run(@reporter) + mod1_method_called.should be_true + mod2_method_called.should be_true + end + + it "should have accessible class methods from included module" do + mod1_method_called = false + mod1 = Module.new do + class_methods = Module.new do + define_method :mod1_method do + mod1_method_called = true + end + end + + metaclass.class_eval do + define_method(:included) do |receiver| + receiver.extend class_methods + end + end + end + + mod2_method_called = false + mod2 = Module.new do + class_methods = Module.new do + define_method :mod2_method do + mod2_method_called = true + end + end + + metaclass.class_eval do + define_method(:included) do |receiver| + receiver.extend class_methods + end + end + end + + @behaviour.include mod1, mod2 + + @behaviour.mod1_method + @behaviour.mod2_method + mod1_method_called.should be_true + mod2_method_called.should be_true + end + + it "should count number of specs" do + @behaviour.it("one") {} + @behaviour.it("two") {} + @behaviour.it("three") {} + @behaviour.it("four") {} + @behaviour.number_of_examples.should == 4 + end + + it "should not match anything when there are no examples" do + @behaviour.should_not be_matches(['context']) + end + + it "should match when one of the examples match" do + example = mock('my example') + example.should_receive(:matches?).and_return(true) + @behaviour.stub!(:examples).and_return([example]) + @behaviour.should be_matches(['jalla']) + end + + it "should include targetted modules included using configuration" do + $included_modules = [] + + mod1 = Module.new do + class << self + def included(mod) + $included_modules << self + end + end + end + + mod2 = Module.new do + class << self + def included(mod) + $included_modules << self + end + end + end + + mod3 = Module.new do + class << self + def included(mod) + $included_modules << self + end + end + end + + begin + Spec::Runner.configuration.include(mod1, mod2) + Spec::Runner.configuration.include(mod3, :behaviour_type => :cat) + + behaviour = Behaviour.new("I'm special", :behaviour_type => :dog) do + end.run(@reporter) + + $included_modules.should include(mod1) + $included_modules.should include(mod2) + $included_modules.should_not include(mod3) + ensure + Spec::Runner.configuration.exclude(mod1, mod2, mod3) + end + end + + it "should include any predicate_matchers included using configuration" do + $included_predicate_matcher_found = false + Spec::Runner.configuration.predicate_matchers[:do_something] = :does_something? + Behaviour.new('example') do + it "should respond to do_something" do + $included_predicate_matcher_found = respond_to?(:do_something) + end + end.run(@reporter) + $included_predicate_matcher_found.should be(true) + end + + it "should use a mock framework set up in config" do + mod = Module.new do + class << self + def included(mod) + $included_module = mod + end + end + end + + begin + $included_module = nil + Spec::Runner.configuration.mock_with mod + + behaviour = Behaviour.new('example') do + end.run(@reporter) + + $included_module.should_not be_nil + ensure + Spec::Runner.configuration.mock_with :rspec + end + end + + end + + class BehaviourSubclass < Behaviour + public :described_type + end + + describe Behaviour, " subclass" do + it "should have access to the described_type" do + BehaviourSubclass.new(Example){}.described_type.should == Example + end + + it "should figure out its behaviour_type based on its name ()" do + BehaviourSubclass.new(Object){}.behaviour_type.should == :subclass + end + + # TODO - add an example about shared behaviours + end + + describe Enumerable do + def each(&block) + ["4", "2", "1"].each(&block) + end + + it "should be included in examples because it is a module" do + map{|e| e.to_i}.should == [4,2,1] + end + end + + describe String do + it "should not be included in examples because it is not a module" do + lambda{self.map}.should raise_error(NoMethodError, /undefined method `map' for/) + end + end + end +end diff --git a/vendor/plugins/rspec/spec/spec/dsl/composite_proc_builder_spec.rb b/vendor/plugins/rspec/spec/spec/dsl/composite_proc_builder_spec.rb new file mode 100644 index 000000000..487677828 --- /dev/null +++ b/vendor/plugins/rspec/spec/spec/dsl/composite_proc_builder_spec.rb @@ -0,0 +1,44 @@ +require File.dirname(__FILE__) + '/../../spec_helper' + +module Spec + module DSL + describe CompositeProcBuilder do + before(:each) do + @klass = Class.new do + attr_reader :an_attribute + + def an_attribute_setter + @an_attribute = :the_value + end + end + + @parent = @klass.new + @builder = CompositeProcBuilder.new {} + end + + it "calls all of its child procs" do + @builder << proc {:proc1} + @builder << proc {:proc2} + @builder.proc.call.should == [:proc1, :proc2] + end + + it "evals procs in the caller's instance" do + the_proc = proc do + @an_attribute = :the_value + end + the_proc.class.should == Proc + @builder << the_proc + @parent.instance_eval &@builder.proc + @parent.an_attribute.should == :the_value + end + + it "binds unbound methods to the parent" do + unbound_method = @klass.instance_method(:an_attribute_setter) + unbound_method.class.should == UnboundMethod + @builder << unbound_method + @parent.instance_eval &@builder.proc + @parent.an_attribute.should == :the_value + end + end + end +end diff --git a/vendor/plugins/rspec/spec/spec/dsl/configuration_spec.rb b/vendor/plugins/rspec/spec/spec/dsl/configuration_spec.rb new file mode 100755 index 000000000..d0377d068 --- /dev/null +++ b/vendor/plugins/rspec/spec/spec/dsl/configuration_spec.rb @@ -0,0 +1,55 @@ +require File.dirname(__FILE__) + '/../../spec_helper.rb' + +module Spec + module DSL + describe Configuration do + before(:each) do + @config = Configuration.new + @behaviour = mock("behaviour") + end + + it "should default mock framework to rspec" do + @config.mock_framework.should =~ /\/plugins\/mock_frameworks\/rspec$/ + end + + it "should let you set rspec mocking explicitly" do + @config.mock_with(:rspec) + @config.mock_framework.should =~ /\/plugins\/mock_frameworks\/rspec$/ + end + + it "should let you set mocha" do + @config.mock_with(:mocha) + @config.mock_framework.should =~ /\/plugins\/mock_frameworks\/mocha$/ + end + + it "should let you set flexmock" do + @config.mock_with(:flexmock) + @config.mock_framework.should =~ /\/plugins\/mock_frameworks\/flexmock$/ + end + + it "should let you set rr" do + @config.mock_with(:rr) + @config.mock_framework.should =~ /\/plugins\/mock_frameworks\/rr$/ + end + + it "should let you set an arbitrary adapter module" do + adapter = Module.new + @config.mock_with(adapter) + @config.mock_framework.should == adapter + end + + it "should let you define modules to be included" do + mod = Module.new + @config.include mod + @config.modules_for(nil).should include(mod) + end + + [:prepend_before, :append_before, :prepend_after, :append_after].each do |m| + it "should delegate ##{m} to Behaviour class" do + Behaviour.should_receive(m).with(:whatever) + @config.__send__(m, :whatever) + end + end + end + end +end diff --git a/vendor/plugins/rspec/spec/spec/dsl/description_spec.rb b/vendor/plugins/rspec/spec/spec/dsl/description_spec.rb new file mode 100755 index 000000000..d9fe4100f --- /dev/null +++ b/vendor/plugins/rspec/spec/spec/dsl/description_spec.rb @@ -0,0 +1,89 @@ +require File.dirname(__FILE__) + '/../../spec_helper' + +module Spec + module DSL + describe Description, " constructed with a single String" do + before(:each) {@description = Description.new("abc")} + + it "should provide that string as its name" do + @description.description.should == "abc" + end + it "should provide nil as its type" do + @description.described_type.should be_nil + end + it "should respond to []" do + @description[:key].should be_nil + end + it "should respond to []=" do + @description[:key] = :value + @description[:key].should == :value + end + it "should return for == when value matches description" do + @description.should == "abc" + end + it "should return for == when value is other description that matches description" do + @description.should == Description.new("abc") + end + end + + describe Description, " constructed with a Type" do + before(:each) {@description = Description.new(Behaviour)} + + it "should provide a String representation of that type (fully qualified) as its name" do + @description.description.should == "Spec::DSL::Behaviour" + end + it "should provide that type (fully qualified) as its type" do + @description.described_type.should == Spec::DSL::Behaviour + end + end + + describe Description, " constructed with a Type and a String" do + before(:each) {@description = Description.new(Behaviour, " behaving")} + + it "should include the type and second String in its name" do + @description.description.should == "Spec::DSL::Behaviour behaving" + end + it "should provide that type (fully qualified) as its type" do + @description.described_type.should == Spec::DSL::Behaviour + end + end + + describe Description, "constructed with a Type and a String not starting with a space" do + before(:each) {@description = Description.new(Behaviour, "behaving")} + + it "should include the type and second String with a space in its name" do + @description.description.should == "Spec::DSL::Behaviour behaving" + end + end + + describe Description, "constructed with a Type and a String starting with a ." do + before(:each) {@description = Description.new(Behaviour, ".behaving")} + + it "should include the type and second String with a space in its name" do + @description.description.should == "Spec::DSL::Behaviour.behaving" + end + end + + describe Description, "constructed with a Type and a String starting with a #" do + before(:each) {@description = Description.new(Behaviour, "#behaving")} + + it "should include the type and second String with a space in its name" do + @description.description.should == "Spec::DSL::Behaviour#behaving" + end + end + + describe Description, " constructed with options" do + before(:each) do + @description = Description.new(Behaviour, :a => "b", :spec_path => "blah") + end + + it "should provide its options" do + @description[:a].should == "b" + end + + it "should wrap spec path using File.expand_path" do + @description[:spec_path].should == File.expand_path("blah") + end + end + end +end diff --git a/vendor/plugins/rspec/spec/spec/dsl/example_class_spec.rb b/vendor/plugins/rspec/spec/spec/dsl/example_class_spec.rb new file mode 100644 index 000000000..474d24e44 --- /dev/null +++ b/vendor/plugins/rspec/spec/spec/dsl/example_class_spec.rb @@ -0,0 +1,24 @@ +require File.dirname(__FILE__) + '/../../spec_helper.rb' + +module Spec + module DSL + describe Example, " class" do + + def run(example) + example.run(@reporter, nil, nil, nil, Object.new) + end + + before do + @reporter = stub("reporter", :example_started => nil, :example_finished => nil) + @example_class = Example.dup + end + + it "should report errors in example" do + error = Exception.new + example = @example_class.new("example") {raise(error)} + @reporter.should_receive(:example_finished).with(equal(example), error, "example", false) + run(example) + end + end + end +end diff --git a/vendor/plugins/rspec/spec/spec/dsl/example_instance_spec.rb b/vendor/plugins/rspec/spec/spec/dsl/example_instance_spec.rb new file mode 100644 index 000000000..67b19604c --- /dev/null +++ b/vendor/plugins/rspec/spec/spec/dsl/example_instance_spec.rb @@ -0,0 +1,160 @@ +require File.dirname(__FILE__) + '/../../spec_helper.rb' + +module Spec + module DSL + describe Example, " instance" do + predicate_matchers[:is_a] = [:is_a?] + + before(:each) do + @reporter = stub("reporter", :example_started => nil, :example_finished => nil) + end + + it "should send reporter example_started" do + example=Example.new("example") {} + @reporter.should_receive(:example_started).with(equal(example)) + example.run(@reporter, nil, nil, false, nil) + end + + it "should report its name for dry run" do + example=Example.new("example") {} + @reporter.should_receive(:example_finished).with(equal(example)) + example.run(@reporter, nil, nil, true, nil) #4th arg indicates dry run + end + + it "should report success" do + example=Example.new("example") {} + @reporter.should_receive(:example_finished).with(equal(example), nil, nil, false) + example.run(@reporter, nil, nil, nil, nil) + end + + it "should report failure due to failure" do + example=Example.new("example") do + (2+2).should == 5 + end + @reporter.should_receive(:example_finished).with(equal(example), is_a(Spec::Expectations::ExpectationNotMetError), "example", false) + example.run(@reporter, nil, nil, nil, nil) + end + + it "should report failure due to error" do + error=NonStandardError.new + example=Example.new("example") do + raise(error) + end + @reporter.should_receive(:example_finished).with(equal(example), error, "example", false) + example.run(@reporter, nil, nil, nil, nil) + end + + it "should run example in scope of supplied object" do + scope_class = Class.new + example=Example.new("should pass") do + self.instance_of?(Example).should == false + self.instance_of?(scope_class).should == true + end + @reporter.should_receive(:example_finished).with(equal(example), nil, nil, false) + example.run(@reporter, nil, nil, nil, scope_class.new) + end + + it "should not run example block if before_each fails" do + example_ran = false + example=Example.new("should pass") {example_ran = true} + before_each = lambda {raise NonStandardError} + example.run(@reporter, before_each, nil, nil, Object.new) + example_ran.should == false + end + + it "should run after_each block if before_each fails" do + after_each_ran = false + example=Example.new("should pass") {} + before_each = lambda {raise NonStandardError} + after_each = lambda {after_each_ran = true} + example.run(@reporter, before_each, after_each, nil, Object.new) + after_each_ran.should == true + end + + it "should run after_each block when example fails" do + example=Example.new("example") do + raise(NonStandardError.new("in body")) + end + after_each=lambda do + raise("in after_each") + end + @reporter.should_receive(:example_finished) do |example, error, location| + example.should equal(example) + location.should eql("example") + error.message.should eql("in body") + end + example.run(@reporter, nil, after_each, nil, nil) + end + + it "should report failure location when in before_each" do + example=Example.new("example") {} + before_each=lambda { raise(NonStandardError.new("in before_each")) } + @reporter.should_receive(:example_finished) do |name, error, location| + name.should equal(example) + error.message.should eql("in before_each") + location.should eql("before(:each)") + end + example.run(@reporter, before_each, nil, nil, nil) + end + + it "should report failure location when in after_each" do + example = Example.new("example") {} + after_each = lambda { raise(NonStandardError.new("in after_each")) } + @reporter.should_receive(:example_finished) do |name, error, location| + name.should equal(example) + error.message.should eql("in after_each") + location.should eql("after(:each)") + end + example.run(@reporter, nil, after_each, nil, nil) + end + + it "should accept an options hash following the example name" do + example = Example.new("name", :key => 'value') + end + + it "should report NO NAME when told to use generated description with --dry-run" do + example = Example.new(:__generate_description) { + 5.should == 5 + } + @reporter.should_receive(:example_finished) do |example, error, location| + example.description.should == "NO NAME (Because of --dry-run)" + end + example.run(@reporter, lambda{}, lambda{}, true, Object.new) + end + + it "should report NO NAME when told to use generated description with no expectations" do + example = Example.new(:__generate_description) {} + @reporter.should_receive(:example_finished) do |example, error, location| + example.description.should == "NO NAME (Because there were no expectations)" + end + example.run(@reporter, lambda{}, lambda{}, false, Object.new) + end + + it "should report NO NAME when told to use generated description and matcher fails" do + example = Example.new(:__generate_description) do + 5.should "" # Has no matches? method.. + end + @reporter.should_receive(:example_finished) do |example, error, location| + example.description.should == "NO NAME (Because of Error raised in matcher)" + end + example.run(@reporter, nil, nil, nil, Object.new) + end + + it "should report generated description when told to and it is available" do + example = Example.new(:__generate_description) { + 5.should == 5 + } + @reporter.should_receive(:example_finished) do |example, error, location| + example.description.should == "should == 5" + end + example.run(@reporter, nil, nil, nil, Object.new) + end + + it "should unregister description_generated callback (lest a memory leak should build up)" do + example = Example.new("something") + Spec::Matchers.should_receive(:unregister_description_generated).with(is_a(Proc)) + example.run(@reporter, nil, nil, nil, Object.new) + end + end + end +end diff --git a/vendor/plugins/rspec/spec/spec/dsl/example_matcher_spec.rb b/vendor/plugins/rspec/spec/spec/dsl/example_matcher_spec.rb new file mode 100644 index 000000000..ea2f2a787 --- /dev/null +++ b/vendor/plugins/rspec/spec/spec/dsl/example_matcher_spec.rb @@ -0,0 +1,91 @@ +require File.dirname(__FILE__) + '/../../spec_helper.rb' + +module Spec + module DSL + module ExampleMatcherSpecHelper + class MatchDescription + def initialize(description) + @description = description + end + + def matches?(matcher) + matcher.matches?(@description) + end + + def failure_message + "expected matcher.matches?(#{@description.inspect}) to return true, got false" + end + + def negative_failure_message + "expected matcher.matches?(#{@description.inspect}) to return false, got true" + end + end + def match_description(description) + MatchDescription.new(description) + end + end + + describe ExampleMatcher do + include ExampleMatcherSpecHelper + + it "should match correct behaviour and example" do + matcher = ExampleMatcher.new("behaviour", "example") + matcher.should match_description("behaviour example") + end + + it "should not match wrong example" do + matcher = ExampleMatcher.new("behaviour", "other example") + matcher.should_not match_description("behaviour example") + end + + it "should not match wrong behaviour" do + matcher = ExampleMatcher.new("other behaviour", "example") + matcher.should_not match_description("behaviour example") + end + + it "should match example only" do + matcher = ExampleMatcher.new("behaviour", "example") + matcher.should match_description("example") + end + + it "should match behaviour only" do + matcher = ExampleMatcher.new("behaviour", "example") + matcher.should match_description("behaviour") + end + + it "should escape regexp chars" do + matcher = ExampleMatcher.new("(con|text)", "[example]") + matcher.should_not match_description("con p") + end + + it "should match when behaviour is modularized" do + matcher = ExampleMatcher.new("MyModule::MyClass", "example") + matcher.should match_description("MyClass example") + end + end + + describe ExampleMatcher, "normal case" do + it "matches when passed in example matches" do + matcher = ExampleMatcher.new("Foo", "bar") + matcher.matches?(["no match", "Foo bar"]).should == true + end + + it "does not match when no passed in examples match" do + matcher = ExampleMatcher.new("Foo", "bar") + matcher.matches?(["no match1", "no match2"]).should == false + end + end + + describe ExampleMatcher, "where description has '::' in it" do + it "matches when passed in example matches" do + matcher = ExampleMatcher.new("Foo::Bar", "baz") + matcher.matches?(["no match", "Foo::Bar baz"]).should == true + end + + it "does not match when no passed in examples match" do + matcher = ExampleMatcher.new("Foo::Bar", "baz") + matcher.matches?(["no match1", "no match2"]).should == false + end + end + end +end diff --git a/vendor/plugins/rspec/spec/spec/dsl/example_should_raise_spec.rb b/vendor/plugins/rspec/spec/spec/dsl/example_should_raise_spec.rb new file mode 100644 index 000000000..a6d582068 --- /dev/null +++ b/vendor/plugins/rspec/spec/spec/dsl/example_should_raise_spec.rb @@ -0,0 +1,137 @@ +require File.dirname(__FILE__) + '/../../spec_helper.rb' + +module Spec + module DSL + describe Example, " declared with {:should_raise => ...}" do + before(:each) do + @reporter = mock("reporter") + @reporter.stub!(:example_started) + end + + def verify_error(error, message=nil) + error.should be_an_instance_of(Spec::Expectations::ExpectationNotMetError) + unless message.nil? + return error.message.should =~ message if Regexp === message + return error.message.should == message + end + end + + it "true} should pass when there is an ExpectationNotMetError" do + example = Spec::DSL:: Example.new("example", :should_raise => true) do + raise Spec::Expectations::ExpectationNotMetError + end + @reporter.should_receive(:example_finished) do |description, error| + error.should be_nil + end + example.run(@reporter, nil, nil, nil, nil) + end + + it "true} should fail if nothing is raised" do + example = Spec::DSL:: Example.new("example", :should_raise => true) {} + @reporter.should_receive(:example_finished) do |example_name, error| + verify_error(error, /example block expected Exception but nothing was raised/) + end + example.run(@reporter, nil, nil, nil, nil) + end + + it "NameError} should pass when there is a NameError" do + example = Spec::DSL:: Example.new("example", :should_raise => NameError) do + raise NameError + end + @reporter.should_receive(:example_finished) do |example_name, error| + error.should be_nil + end + example.run(@reporter, nil, nil, nil, nil) + end + + it "NameError} should fail when there is no error" do + example = Spec::DSL:: Example.new("example", :should_raise => NameError) do + #do nothing + end + @reporter.should_receive(:example_finished) do |example_name, error| + verify_error(error,/example block expected NameError but nothing was raised/) + end + example.run(@reporter, nil, nil, nil, nil) + end + + it "NameError} should fail when there is the wrong error" do + example = Spec::DSL:: Example.new("example", :should_raise => NameError) do + raise RuntimeError + end + @reporter.should_receive(:example_finished) do |example_name, error| + verify_error(error, /example block expected NameError but raised.+RuntimeError/) + end + example.run(@reporter, nil, nil, nil, nil) + end + + it "[NameError]} should pass when there is a NameError" do + example = Spec::DSL:: Example.new("spec", :should_raise => [NameError]) do + raise NameError + end + @reporter.should_receive(:example_finished) do |description, error| + error.should be_nil + end + example.run(@reporter, nil, nil, nil, nil) + end + + it "[NameError]} should fail when there is no error" do + example = Spec::DSL:: Example.new("spec", :should_raise => [NameError]) do + end + @reporter.should_receive(:example_finished) do |description, error| + verify_error(error, /example block expected NameError but nothing was raised/) + end + example.run(@reporter, nil, nil, nil, nil) + end + + it "[NameError]} should fail when there is the wrong error" do + example = Spec::DSL:: Example.new("spec", :should_raise => [NameError]) do + raise RuntimeError + end + @reporter.should_receive(:example_finished) do |description, error| + verify_error(error, /example block expected NameError but raised.+RuntimeError/) + end + example.run(@reporter, nil, nil, nil, nil) + end + + it "[NameError, 'message'} should pass when there is a NameError with the right message" do + example = Spec::DSL:: Example.new("spec", :should_raise => [NameError, 'expected']) do + raise NameError, 'expected' + end + @reporter.should_receive(:example_finished) do |description, error| + error.should be_nil + end + example.run(@reporter, nil, nil, nil, nil) + end + + it "[NameError, 'message'} should pass when there is a NameError with a message matching a regex" do + example = Spec::DSL:: Example.new("spec", :should_raise => [NameError, /xpec/]) do + raise NameError, 'expected' + end + @reporter.should_receive(:example_finished) do |description, error| + error.should be_nil + end + example.run(@reporter, nil, nil, nil, nil) + end + + it "[NameError, 'message'} should fail when there is a NameError with the wrong message" do + example = Spec::DSL:: Example.new("spec", :should_raise => [NameError, 'expected']) do + raise NameError, 'wrong message' + end + @reporter.should_receive(:example_finished) do |description, error| + verify_error(error, /example block expected #<NameError: expected> but raised #<NameError: wrong message>/) + end + example.run(@reporter, nil, nil, nil, nil) + end + + it "[NameError, 'message'} should fail when there is a NameError with a message not matching regexp" do + example = Spec::DSL:: Example.new("spec", :should_raise => [NameError, /exp/]) do + raise NameError, 'wrong message' + end + @reporter.should_receive(:example_finished) do |description, error| + verify_error(error, /example block expected #<NameError: \(\?-mix:exp\)> but raised #<NameError: wrong message>/) + end + example.run(@reporter, nil, nil, nil, nil) + end + end + end +end diff --git a/vendor/plugins/rspec/spec/spec/dsl/predicate_matcher_spec.rb b/vendor/plugins/rspec/spec/spec/dsl/predicate_matcher_spec.rb new file mode 100755 index 000000000..02cd89399 --- /dev/null +++ b/vendor/plugins/rspec/spec/spec/dsl/predicate_matcher_spec.rb @@ -0,0 +1,21 @@ +require File.dirname(__FILE__) + '/../../spec_helper' + +module Spec + module DSL + class Fish + def can_swim?(distance_in_yards) + distance_in_yards < 1000 + end + end + + describe "predicate_matcher[method_on_object] = matcher_method" do + predicate_matchers[:swim] = :can_swim? + it "should match matcher_method if method_on_object returns true" do + swim(100).matches?(Fish.new).should be_true + end + it "should not match matcher_method if method_on_object returns false" do + swim(10000).matches?(Fish.new).should be_false + end + end + end +end diff --git a/vendor/plugins/rspec/spec/spec/dsl/shared_behaviour_spec.rb b/vendor/plugins/rspec/spec/spec/dsl/shared_behaviour_spec.rb new file mode 100644 index 000000000..a4288360c --- /dev/null +++ b/vendor/plugins/rspec/spec/spec/dsl/shared_behaviour_spec.rb @@ -0,0 +1,252 @@ +require File.dirname(__FILE__) + '/../../spec_helper' + +module Spec + module DSL + describe Behaviour, ", with :shared => true" do + + before(:each) do + @formatter = Spec::Mocks::Mock.new("formatter", :null_object => true) + @behaviour = behaviour_class.new("behaviour") {} + end + + after(:each) do + @formatter.rspec_verify + @behaviour_class = nil + $shared_behaviours.clear unless $shared_behaviours.nil? + end + + def behaviour_class + unless @behaviour_class + @behaviour_class = Behaviour.dup + # dup copies the class instance vars + @behaviour_class.instance_variable_set(:@shared_behaviours, nil) + end + @behaviour_class + end + + def make_shared_behaviour(name, opts=nil, &block) + behaviour = behaviour_class.new(name, :shared => true, &block) + behaviour_class.add_shared_behaviour(behaviour) + behaviour + end + + def non_shared_behaviour() + @non_shared_behaviour ||= behaviour_class.new("behaviour") {} + end + + it "should accept an optional options hash" do + lambda { behaviour_class.new("context") {} }.should_not raise_error(Exception) + lambda { behaviour_class.new("context", :shared => true) {} }.should_not raise_error(Exception) + end + + it "should return all shared behaviours" do + b1 = make_shared_behaviour("b1", :shared => true) {} + b2 = make_shared_behaviour("b2", :shared => true) {} + + b1.should_not be(nil) + b2.should_not be(nil) + + behaviour_class.find_shared_behaviour("b1").should equal(b1) + behaviour_class.find_shared_behaviour("b2").should equal(b2) + end + + it "should be shared when configured as shared" do + behaviour = make_shared_behaviour("behaviour") {} + behaviour.should be_shared + end + + it "should not be shared when not configured as shared" do + non_shared_behaviour.should_not be_shared + end + + it "should raise if run when shared" do + behaviour = make_shared_behaviour("context") {} + $example_ran = false + behaviour.it("test") {$example_ran = true} + lambda { behaviour.run(@formatter) }.should raise_error + $example_ran.should be_false + end + + it "should contain examples when shared" do + shared_behaviour = make_shared_behaviour("shared behaviour") {} + shared_behaviour.it("shared example") {} + shared_behaviour.number_of_examples.should == 1 + end + + it "should complain when adding a second shared behaviour with the same description" do + describe "shared behaviour", :shared => true do + end + lambda do + describe "shared behaviour", :shared => true do + end + end.should raise_error(ArgumentError) + end + + it "should NOT complain when adding the same shared behaviour instance again" do + shared_behaviour = behaviour_class.new("shared behaviour", :shared => true) {} + behaviour_class.add_shared_behaviour(shared_behaviour) + behaviour_class.add_shared_behaviour(shared_behaviour) + end + + it "should NOT complain when adding the same shared behaviour again (i.e. file gets reloaded)" do + lambda do + 2.times do + describe "shared behaviour which gets loaded twice", :shared => true do + end + end + end.should_not raise_error(ArgumentError) + end + + it "should NOT complain when adding the same shared behaviour in same file with different absolute path" do + shared_behaviour_1 = behaviour_class.new("shared behaviour", :shared => true) {} + shared_behaviour_2 = behaviour_class.new("shared behaviour", :shared => true) {} + + shared_behaviour_1.description[:spec_path] = "/my/spec/a/../shared.rb" + shared_behaviour_2.description[:spec_path] = "/my/spec/b/../shared.rb" + + behaviour_class.add_shared_behaviour(shared_behaviour_1) + behaviour_class.add_shared_behaviour(shared_behaviour_2) + end + + it "should complain when adding a different shared behaviour with the same name in a different file with the same basename" do + shared_behaviour_1 = behaviour_class.new("shared behaviour", :shared => true) {} + shared_behaviour_2 = behaviour_class.new("shared behaviour", :shared => true) {} + + shared_behaviour_1.description[:spec_path] = "/my/spec/a/shared.rb" + shared_behaviour_2.description[:spec_path] = "/my/spec/b/shared.rb" + + behaviour_class.add_shared_behaviour(shared_behaviour_1) + lambda do + behaviour_class.add_shared_behaviour(shared_behaviour_2) + end.should raise_error(ArgumentError, /already exists/) + end + + it "should add examples to current behaviour when calling it_should_behave_like" do + shared_behaviour = make_shared_behaviour("shared behaviour") {} + shared_behaviour.it("shared example") {} + shared_behaviour.it("shared example 2") {} + + @behaviour.it("example") {} + @behaviour.number_of_examples.should == 1 + @behaviour.it_should_behave_like("shared behaviour") + @behaviour.number_of_examples.should == 3 + end + + it "should run shared examples" do + shared_example_ran = false + shared_behaviour = make_shared_behaviour("shared behaviour") {} + shared_behaviour.it("shared example") { shared_example_ran = true } + + example_ran = false + + @behaviour.it_should_behave_like("shared behaviour") + @behaviour.it("example") {example_ran = true} + @behaviour.run(@formatter) + example_ran.should be_true + shared_example_ran.should be_true + end + + it "should run setup and teardown from shared behaviour" do + shared_setup_ran = false + shared_teardown_ran = false + shared_behaviour = make_shared_behaviour("shared behaviour") {} + shared_behaviour.before { shared_setup_ran = true } + shared_behaviour.after { shared_teardown_ran = true } + shared_behaviour.it("shared example") { shared_example_ran = true } + + example_ran = false + + @behaviour.it_should_behave_like("shared behaviour") + @behaviour.it("example") {example_ran = true} + @behaviour.run(@formatter) + example_ran.should be_true + shared_setup_ran.should be_true + shared_teardown_ran.should be_true + end + + it "should run before(:all) and after(:all) only once from shared behaviour" do + shared_before_all_run_count = 0 + shared_after_all_run_count = 0 + shared_behaviour = make_shared_behaviour("shared behaviour") {} + shared_behaviour.before(:all) { shared_before_all_run_count += 1} + shared_behaviour.after(:all) { shared_after_all_run_count += 1} + shared_behaviour.it("shared example") { shared_example_ran = true } + + example_ran = false + + @behaviour.it_should_behave_like("shared behaviour") + @behaviour.it("example") {example_ran = true} + @behaviour.run(@formatter) + example_ran.should be_true + shared_before_all_run_count.should == 1 + shared_after_all_run_count.should == 1 + end + + it "should include modules, included into shared behaviour, into current behaviour" do + @formatter.should_receive(:add_behaviour).with(any_args) + @formatter.should_receive(:example_finished).twice.with(any_args) + + shared_behaviour = make_shared_behaviour("shared behaviour") {} + shared_behaviour.it("shared example") { shared_example_ran = true } + + mod1_method_called = false + mod1 = Module.new do + define_method :mod1_method do + mod1_method_called = true + end + end + + mod2_method_called = false + mod2 = Module.new do + define_method :mod2_method do + mod2_method_called = true + end + end + + shared_behaviour.include mod2 + + @behaviour.it_should_behave_like("shared behaviour") + @behaviour.include mod1 + + @behaviour.it("test") do + mod1_method + mod2_method + end + @behaviour.run(@formatter) + mod1_method_called.should be_true + mod2_method_called.should be_true + end + + it "should make methods defined in the shared behaviour available in consuming behaviour" do + shared_behaviour = make_shared_behaviour("shared behaviour xyz") do + def a_shared_helper_method + "this got defined in a shared behaviour" + end + end + @behaviour.it_should_behave_like("shared behaviour xyz") + success = false + @behaviour.it("should access a_shared_helper_method") do + a_shared_helper_method + success = true + end + @behaviour.run(@formatter) + success.should be_true + end + + it "should error if told to inherit from a class" do + shared_behaviour = make_shared_behaviour("shared behaviour") {} + shared_behaviour.it("shared example") { shared_example_ran = true } + lambda { shared_behaviour.inherit Object }.should raise_error(ArgumentError) + end + + it "should raise when named shared behaviour can not be found" do + begin + @behaviour.it_should_behave_like("non-existent shared behaviour") + violated + rescue => e + e.message.should == "Shared Behaviour 'non-existent shared behaviour' can not be found" + end + end + end + end +end diff --git a/vendor/plugins/rspec/spec/spec/expectations/differs/default_spec.rb b/vendor/plugins/rspec/spec/spec/expectations/differs/default_spec.rb new file mode 100644 index 000000000..ae5551aaf --- /dev/null +++ b/vendor/plugins/rspec/spec/spec/expectations/differs/default_spec.rb @@ -0,0 +1,107 @@ +require File.dirname(__FILE__) + '/../../../spec_helper.rb' +require File.dirname(__FILE__) + '/../../../../lib/spec/expectations/differs/default' + +module Spec + module Fixtures + class Animal + def initialize(name,species) + @name,@species = name,species + end + + def inspect + <<-EOA +<Animal + name=#{@name}, + species=#{@species} +> + EOA + end + end + end +end + +describe "Diff" do + before(:each) do + @differ = Spec::Expectations::Differs::Default.new + end + + it "should output unified diff of two strings" do + expected="foo\nbar\nzap\nthis\nis\nsoo\nvery\nvery\nequal\ninsert\na\nline\n" + actual="foo\nzap\nbar\nthis\nis\nsoo\nvery\nvery\nequal\ninsert\na\nanother\nline\n" + expected_diff="\n\n@@ -1,6 +1,6 @@\n foo\n-bar\n zap\n+bar\n this\n is\n soo\n@@ -9,5 +9,6 @@\n equal\n insert\n a\n+another\n line\n" + diff = @differ.diff_as_string(expected, actual) + diff.should eql(expected_diff) + end + + it "should output unified diff message of two arrays" do + expected = [ :foo, 'bar', :baz, 'quux', :metasyntactic, 'variable', :delta, 'charlie', :width, 'quite wide' ] + actual = [ :foo, 'bar', :baz, 'quux', :metasyntactic, 'variable', :delta, 'tango' , :width, 'very wide' ] + + expected_diff = <<'EOD' + + +@@ -5,7 +5,7 @@ + :metasyntactic, + "variable", + :delta, +- "charlie", ++ "tango", + :width, +- "quite wide"] ++ "very wide"] +EOD + + + diff = @differ.diff_as_object(expected,actual) + diff.should == expected_diff + end + + it "should output unified diff message of two objects" do + expected = Spec::Fixtures::Animal.new "bob", "giraffe" + actual = Spec::Fixtures::Animal.new "bob", "tortoise" + + expected_diff = <<'EOD' + +@@ -1,5 +1,5 @@ + <Animal + name=bob, +- species=giraffe ++ species=tortoise + > +EOD + + diff = @differ.diff_as_object(expected,actual) + diff.should == expected_diff + end + +end + + +describe "Diff in context format" do + before(:each) do + @differ = Spec::Expectations::Differs::Default.new(:context) + end + + it "should output unified diff message of two objects" do + expected = Spec::Fixtures::Animal.new "bob", "giraffe" + actual = Spec::Fixtures::Animal.new "bob", "tortoise" + + expected_diff = <<'EOD' + +*************** +*** 1,5 **** + <Animal + name=bob, +! species=giraffe + > +--- 1,5 ---- + <Animal + name=bob, +! species=tortoise + > +EOD + + diff = @differ.diff_as_object(expected,actual) + diff.should == expected_diff + end +end diff --git a/vendor/plugins/rspec/spec/spec/expectations/extensions/object_spec.rb b/vendor/plugins/rspec/spec/spec/expectations/extensions/object_spec.rb new file mode 100644 index 000000000..587053293 --- /dev/null +++ b/vendor/plugins/rspec/spec/spec/expectations/extensions/object_spec.rb @@ -0,0 +1,46 @@ +require File.dirname(__FILE__) + '/../../../spec_helper.rb' + +describe Object, "#should" do + before(:each) do + @target = "target" + @matcher = mock("matcher") + @matcher.stub!(:matches?).and_return(true) + @matcher.stub!(:failure_message) + end + + it "should accept and interact with a matcher" do + @matcher.should_receive(:matches?).with(@target).and_return(true) + + @target.should @matcher + end + + it "should ask for a failure_message when matches? returns false" do + @matcher.should_receive(:matches?).with(@target).and_return(false) + @matcher.should_receive(:failure_message).and_return("the failure message") + lambda { + @target.should @matcher + }.should fail_with("the failure message") + end +end + +describe Object, "#should_not" do + before(:each) do + @target = "target" + @matcher = mock("matcher") + end + + it "should accept and interact with a matcher" do + @matcher.should_receive(:matches?).with(@target).and_return(false) + @matcher.stub!(:negative_failure_message) + + @target.should_not @matcher + end + + it "should ask for a negative_failure_message when matches? returns true" do + @matcher.should_receive(:matches?).with(@target).and_return(true) + @matcher.should_receive(:negative_failure_message).and_return("the negative failure message") + lambda { + @target.should_not @matcher + }.should fail_with("the negative failure message") + end +end diff --git a/vendor/plugins/rspec/spec/spec/expectations/fail_with_spec.rb b/vendor/plugins/rspec/spec/spec/expectations/fail_with_spec.rb new file mode 100644 index 000000000..4c369ce3a --- /dev/null +++ b/vendor/plugins/rspec/spec/spec/expectations/fail_with_spec.rb @@ -0,0 +1,71 @@ +require File.dirname(__FILE__) + '/../../spec_helper.rb' + +describe Spec::Expectations, "#fail_with with no diff" do + before(:each) do + @old_differ = Spec::Expectations.differ + Spec::Expectations.differ = nil + end + + it "should handle just a message" do + lambda { + Spec::Expectations.fail_with "the message" + }.should fail_with("the message") + end + + it "should handle an Array" do + lambda { + Spec::Expectations.fail_with ["the message","expected","actual"] + }.should fail_with("the message") + end + + after(:each) do + Spec::Expectations.differ = @old_differ + end +end + +describe Spec::Expectations, "#fail_with with diff" do + before(:each) do + @old_differ = Spec::Expectations.differ + @differ = mock("differ") + Spec::Expectations.differ = @differ + end + + it "should not call differ if no expected/actual" do + lambda { + Spec::Expectations.fail_with "the message" + }.should fail_with("the message") + end + + it "should call differ if expected/actual are presented separately" do + @differ.should_receive(:diff_as_string).and_return("diff") + lambda { + Spec::Expectations.fail_with "the message", "expected", "actual" + }.should fail_with("the message\nDiff:diff") + end + + it "should call differ if expected/actual are not strings" do + @differ.should_receive(:diff_as_object).and_return("diff") + lambda { + Spec::Expectations.fail_with "the message", :expected, :actual + }.should fail_with("the message\nDiff:diff") + end + + it "should not call differ if expected or actual are procs" do + @differ.should_not_receive(:diff_as_string) + @differ.should_not_receive(:diff_as_object) + lambda { + Spec::Expectations.fail_with "the message", lambda {}, lambda {} + }.should fail_with("the message") + end + + it "should call differ if expected/actual are presented in an Array with message" do + @differ.should_receive(:diff_as_string).with("actual","expected").and_return("diff") + lambda { + Spec::Expectations.fail_with(["the message", "expected", "actual"]) + }.should fail_with(/the message\nDiff:diff/) + end + + after(:each) do + Spec::Expectations.differ = @old_differ + end +end diff --git a/vendor/plugins/rspec/spec/spec/matchers/be_close_spec.rb b/vendor/plugins/rspec/spec/spec/matchers/be_close_spec.rb new file mode 100644 index 000000000..d8452d408 --- /dev/null +++ b/vendor/plugins/rspec/spec/spec/matchers/be_close_spec.rb @@ -0,0 +1,39 @@ +require File.dirname(__FILE__) + '/../../spec_helper.rb' +module Spec + module Matchers + describe BeClose do + it "should match when value == target" do + BeClose.new(5.0, 0.5).matches?(5.0).should be_true + end + it "should match when value < (target + delta)" do + BeClose.new(5.0, 0.5).matches?(5.49).should be_true + end + it "should match when value > (target - delta)" do + BeClose.new(5.0, 0.5).matches?(4.51).should be_true + end + it "should not match when value == (target - delta)" do + BeClose.new(5.0, 0.5).matches?(4.5).should be_false + end + it "should not match when value < (target - delta)" do + BeClose.new(5.0, 0.5).matches?(4.49).should be_false + end + it "should not match when value == (target + delta)" do + BeClose.new(5.0, 0.5).matches?(5.5).should be_false + end + it "should not match when value > (target + delta)" do + BeClose.new(5.0, 0.5).matches?(5.51).should be_false + end + it "should provide a useful failure message" do + #given + matcher = BeClose.new(5.0, 0.5) + #when + matcher.matches?(5.51) + #then + matcher.failure_message.should == "expected 5.0 +/- (< 0.5), got 5.51" + end + it "should describe itself" do + BeClose.new(5.0, 0.5).description.should == "be close to 5.0 (within +- 0.5)" + end + end + end +end diff --git a/vendor/plugins/rspec/spec/spec/matchers/be_spec.rb b/vendor/plugins/rspec/spec/spec/matchers/be_spec.rb new file mode 100644 index 000000000..84653873c --- /dev/null +++ b/vendor/plugins/rspec/spec/spec/matchers/be_spec.rb @@ -0,0 +1,209 @@ +require File.dirname(__FILE__) + '/../../spec_helper.rb' + +describe "should be_predicate" do + it "should pass when actual returns true for :predicate?" do + actual = stub("actual", :happy? => true) + actual.should be_happy + end + + it "should pass when actual returns true for :predicates? (present tense)" do + actual = stub("actual", :exists? => true) + actual.should be_exist + end + + it "should fail when actual returns false for :predicate?" do + actual = stub("actual", :happy? => false) + lambda { + actual.should be_happy + }.should fail_with("expected happy? to return true, got false") + end + + it "should fail when actual does not respond to :predicate?" do + lambda { + Object.new.should be_happy + }.should raise_error(NameError) + end +end + +describe "should_not be_predicate" do + it "should pass when actual returns false for :sym?" do + actual = stub("actual", :happy? => false) + actual.should_not be_happy + end + + it "should fail when actual returns true for :sym?" do + actual = stub("actual", :happy? => true) + lambda { + actual.should_not be_happy + }.should fail_with("expected happy? to return false, got true") + end + + it "should fail when actual does not respond to :sym?" do + lambda { + Object.new.should_not be_happy + }.should raise_error(NameError) + end +end + +describe "should be_predicate(*args)" do + it "should pass when actual returns true for :predicate?(*args)" do + actual = mock("actual") + actual.should_receive(:older_than?).with(3).and_return(true) + actual.should be_older_than(3) + end + + it "should fail when actual returns false for :predicate?(*args)" do + actual = mock("actual") + actual.should_receive(:older_than?).with(3).and_return(false) + lambda { + actual.should be_older_than(3) + }.should fail_with("expected older_than?(3) to return true, got false") + end + + it "should fail when actual does not respond to :predicate?" do + lambda { + Object.new.should be_older_than(3) + }.should raise_error(NameError) + end +end + +describe "should_not be_predicate(*args)" do + it "should pass when actual returns false for :predicate?(*args)" do + actual = mock("actual") + actual.should_receive(:older_than?).with(3).and_return(false) + actual.should_not be_older_than(3) + end + + it "should fail when actual returns true for :predicate?(*args)" do + actual = mock("actual") + actual.should_receive(:older_than?).with(3).and_return(true) + lambda { + actual.should_not be_older_than(3) + }.should fail_with("expected older_than?(3) to return false, got true") + end + + it "should fail when actual does not respond to :predicate?" do + lambda { + Object.new.should_not be_older_than(3) + }.should raise_error(NameError) + end +end + +describe "should be_true" do + it "should pass when actual equal(true)" do + true.should be_true + end + + it "should fail when actual equal(false)" do + lambda { + false.should be_true + }.should fail_with("expected true, got false") + end +end + +describe "should be_false" do + it "should pass when actual equal(false)" do + false.should be_false + end + + it "should fail when actual equal(true)" do + lambda { + true.should be_false + }.should fail_with("expected false, got true") + end +end + +describe "should be_nil" do + it "should pass when actual is nil" do + nil.should be_nil + end + + it "should fail when actual is not nil" do + lambda { + :not_nil.should be_nil + }.should fail_with("expected nil, got :not_nil") + end +end + +describe "should_not be_nil" do + it "should pass when actual is not nil" do + :not_nil.should_not be_nil + end + + it "should fail when actual is nil" do + lambda { + nil.should_not be_nil + }.should fail_with("expected not nil, got nil") + end +end + +describe "should be <" do + it "should pass when < operator returns true" do + 3.should be < 4 + end + + it "should fail when < operator returns false" do + lambda { 3.should be < 3 }.should fail_with("expected < 3, got 3") + end +end + +describe "should be <=" do + it "should pass when <= operator returns true" do + 3.should be <= 4 + 4.should be <= 4 + end + + it "should fail when <= operator returns false" do + lambda { 3.should be <= 2 }.should fail_with("expected <= 2, got 3") + end +end + +describe "should be >=" do + it "should pass when >= operator returns true" do + 4.should be >= 4 + 5.should be >= 4 + end + + it "should fail when >= operator returns false" do + lambda { 3.should be >= 4 }.should fail_with("expected >= 4, got 3") + end +end + +describe "should be >" do + it "should pass when > operator returns true" do + 5.should be > 4 + end + + it "should fail when > operator returns false" do + lambda { 3.should be > 4 }.should fail_with("expected > 4, got 3") + end +end + +describe "should be ==" do + it "should pass when == operator returns true" do + 5.should be == 5 + end + + it "should fail when == operator returns false" do + lambda { 3.should be == 4 }.should fail_with("expected == 4, got 3") + end +end + +describe "should be ===" do + it "should pass when === operator returns true" do + Hash.should be === Hash.new + end + + it "should fail when === operator returns false" do + lambda { Hash.should be === "not a hash" }.should fail_with(%[expected === "not a hash", got Hash]) + end +end + +describe "should be(value)" do + it "should pass if actual.equal?(value)" do + 5.should be(5) + end + it "should fail if !actual.equal?(value)" do + lambda { 5.should be(6) }.should fail_with("expected 6, got 5") + end +end diff --git a/vendor/plugins/rspec/spec/spec/matchers/change_spec.rb b/vendor/plugins/rspec/spec/spec/matchers/change_spec.rb new file mode 100644 index 000000000..70e55328e --- /dev/null +++ b/vendor/plugins/rspec/spec/spec/matchers/change_spec.rb @@ -0,0 +1,232 @@ +#Based on patch from Wilson Bilkovich + +require File.dirname(__FILE__) + '/../../spec_helper.rb' +class SomethingExpected + attr_accessor :some_value +end + +describe "should change(actual, message)" do + before(:each) do + @instance = SomethingExpected.new + @instance.some_value = 5 + end + + it "should pass when actual is modified by the block" do + lambda {@instance.some_value = 6}.should change(@instance, :some_value) + end + + it "should fail when actual is not modified by the block" do + lambda do + lambda {}.should change(@instance, :some_value) + end.should fail_with("some_value should have changed, but is still 5") + end +end + +describe "should_not change(actual, message)" do + before(:each) do + @instance = SomethingExpected.new + @instance.some_value = 5 + end + + it "should pass when actual is not modified by the block" do + lambda { }.should_not change(@instance, :some_value) + end + + it "should fail when actual is not modified by the block" do + lambda do + lambda {@instance.some_value = 6}.should_not change(@instance, :some_value) + end.should fail_with("some_value should not have changed, but did change from 5 to 6") + end +end + +describe "should change { block }" do + before(:each) do + @instance = SomethingExpected.new + @instance.some_value = 5 + end + + it "should pass when actual is modified by the block" do + lambda {@instance.some_value = 6}.should change { @instance.some_value } + end + + it "should fail when actual is not modified by the block" do + lambda do + lambda {}.should change{ @instance.some_value } + end.should fail_with("result should have changed, but is still 5") + end + + it "should warn if passed a block using do/end" do + lambda do + lambda {}.should change do + end + end.should raise_error(Spec::Matchers::MatcherError, /block passed to should or should_not/) + end +end + +describe "should_not change { block }" do + before(:each) do + @instance = SomethingExpected.new + @instance.some_value = 5 + end + + it "should pass when actual is modified by the block" do + lambda {}.should_not change{ @instance.some_value } + end + + it "should fail when actual is not modified by the block" do + lambda do + lambda {@instance.some_value = 6}.should_not change { @instance.some_value } + end.should fail_with("result should not have changed, but did change from 5 to 6") + end + + it "should warn if passed a block using do/end" do + lambda do + lambda {}.should_not change do + end + end.should raise_error(Spec::Matchers::MatcherError, /block passed to should or should_not/) + end +end + +describe "should change(actual, message).by(expected)" do + before(:each) do + @instance = SomethingExpected.new + @instance.some_value = 5 + end + + it "should pass when attribute is changed by expected amount" do + lambda { @instance.some_value += 1 }.should change(@instance, :some_value).by(1) + end + + it "should fail when the attribute is changed by unexpected amount" do + lambda do + lambda { @instance.some_value += 2 }.should change(@instance, :some_value).by(1) + end.should fail_with("some_value should have been changed by 1, but was changed by 2") + end + + it "should fail when the attribute is changed by unexpected amount in the opposite direction" do + lambda do + lambda { @instance.some_value -= 1 }.should change(@instance, :some_value).by(1) + end.should fail_with("some_value should have been changed by 1, but was changed by -1") + end +end + +describe "should change{ block }.by(expected)" do + before(:each) do + @instance = SomethingExpected.new + @instance.some_value = 5 + end + + it "should pass when attribute is changed by expected amount" do + lambda { @instance.some_value += 1 }.should change{@instance.some_value}.by(1) + end + + it "should fail when the attribute is changed by unexpected amount" do + lambda do + lambda { @instance.some_value += 2 }.should change{@instance.some_value}.by(1) + end.should fail_with("result should have been changed by 1, but was changed by 2") + end + + it "should fail when the attribute is changed by unexpected amount in the opposite direction" do + lambda do + lambda { @instance.some_value -= 1 }.should change{@instance.some_value}.by(1) + end.should fail_with("result should have been changed by 1, but was changed by -1") + end +end + +describe "should change(actual, message).from(old)" do + before(:each) do + @instance = SomethingExpected.new + @instance.some_value = 'string' + end + + it "should pass when attribute is == to expected value before executing block" do + lambda { @instance.some_value = "astring" }.should change(@instance, :some_value).from("string") + end + + it "should fail when attribute is not == to expected value before executing block" do + lambda do + lambda { @instance.some_value = "knot" }.should change(@instance, :some_value).from("cat") + end.should fail_with("some_value should have initially been \"cat\", but was \"string\"") + end +end + +describe "should change{ block }.from(old)" do + before(:each) do + @instance = SomethingExpected.new + @instance.some_value = 'string' + end + + it "should pass when attribute is == to expected value before executing block" do + lambda { @instance.some_value = "astring" }.should change{@instance.some_value}.from("string") + end + + it "should fail when attribute is not == to expected value before executing block" do + lambda do + lambda { @instance.some_value = "knot" }.should change{@instance.some_value}.from("cat") + end.should fail_with("result should have initially been \"cat\", but was \"string\"") + end +end + +describe "should change(actual, message).to(new)" do + before(:each) do + @instance = SomethingExpected.new + @instance.some_value = 'string' + end + + it "should pass when attribute is == to expected value after executing block" do + lambda { @instance.some_value = "cat" }.should change(@instance, :some_value).to("cat") + end + + it "should fail when attribute is not == to expected value after executing block" do + lambda do + lambda { @instance.some_value = "cat" }.should change(@instance, :some_value).from("string").to("dog") + end.should fail_with("some_value should have been changed to \"dog\", but is now \"cat\"") + end +end + +describe "should change{ block }.to(new)" do + before(:each) do + @instance = SomethingExpected.new + @instance.some_value = 'string' + end + + it "should pass when attribute is == to expected value after executing block" do + lambda { @instance.some_value = "cat" }.should change{@instance.some_value}.to("cat") + end + + it "should fail when attribute is not == to expected value after executing block" do + lambda do + lambda { @instance.some_value = "cat" }.should change{@instance.some_value}.from("string").to("dog") + end.should fail_with("result should have been changed to \"dog\", but is now \"cat\"") + end +end + +describe "should change(actual, message).from(old).to(new)" do + before(:each) do + @instance = SomethingExpected.new + @instance.some_value = 'string' + end + + it "should pass when #to comes before #from" do + lambda { @instance.some_value = "cat" }.should change(@instance, :some_value).to("cat").from("string") + end + + it "should pass when #from comes before #to" do + lambda { @instance.some_value = "cat" }.should change(@instance, :some_value).from("string").to("cat") + end +end + +describe "should change{ block }.from(old).to(new)" do + before(:each) do + @instance = SomethingExpected.new + @instance.some_value = 'string' + end + + it "should pass when #to comes before #from" do + lambda { @instance.some_value = "cat" }.should change{@instance.some_value}.to("cat").from("string") + end + + it "should pass when #from comes before #to" do + lambda { @instance.some_value = "cat" }.should change{@instance.some_value}.from("string").to("cat") + end +end diff --git a/vendor/plugins/rspec/spec/spec/matchers/description_generation_spec.rb b/vendor/plugins/rspec/spec/spec/matchers/description_generation_spec.rb new file mode 100644 index 000000000..d1246ad04 --- /dev/null +++ b/vendor/plugins/rspec/spec/spec/matchers/description_generation_spec.rb @@ -0,0 +1,159 @@ +require File.dirname(__FILE__) + '/../../spec_helper.rb' + +describe "Matchers should be able to generate their own descriptions" do + before(:each) do + @desc = nil + @callback = lambda { |desc| @desc = desc } + Spec::Matchers.description_generated(@callback) + end + + it "should == expected" do + "this".should == "this" + @desc.should == "should == \"this\"" + end + + it "should not == expected" do + "this".should_not == "that" + @desc.should == "should not == \"that\"" + end + + it "should be empty (arbitrary predicate)" do + [].should be_empty + @desc.should == "should be empty" + end + + it "should not be empty (arbitrary predicate)" do + [1].should_not be_empty + @desc.should == "should not be empty" + end + + it "should be true" do + true.should be_true + @desc.should == "should be true" + end + + it "should be false" do + false.should be_false + @desc.should == "should be false" + end + + it "should be nil" do + nil.should be_nil + @desc.should == "should be nil" + end + + it "should be > n" do + 5.should be > 3 + @desc.should == "should be > 3" + end + + it "should be predicate arg1, arg2 and arg3" do + 5.0.should be_between(0,10) + @desc.should == "should be between 0 and 10" + end + + it "should be_few_words predicate should be transformed to 'be few words'" do + 5.should be_kind_of(Fixnum) + @desc.should == "should be kind of Fixnum" + end + + it "should preserve a proper prefix for be predicate" do + 5.should be_a_kind_of(Fixnum) + @desc.should == "should be a kind of Fixnum" + 5.should be_an_instance_of(Fixnum) + @desc.should == "should be an instance of Fixnum" + end + + it "should equal" do + expected = "expected" + expected.should equal(expected) + @desc.should == "should equal \"expected\"" + end + + it "should_not equal" do + 5.should_not equal(37) + @desc.should == "should not equal 37" + end + + it "should eql" do + "string".should eql("string") + @desc.should == "should eql \"string\"" + end + + it "should not eql" do + "a".should_not eql(:a) + @desc.should == "should not eql :a" + end + + it "should have_key" do + {:a => "a"}.should have_key(:a) + @desc.should == "should have key :a" + end + + it "should have n items" do + team.should have(3).players + @desc.should == "should have 3 players" + end + + it "should have at least n items" do + team.should have_at_least(2).players + @desc.should == "should have at least 2 players" + end + + it "should have at most n items" do + team.should have_at_most(4).players + @desc.should == "should have at most 4 players" + end + + it "should include" do + [1,2,3].should include(3) + @desc.should == "should include 3" + end + + it "should match" do + "this string".should match(/this string/) + @desc.should == "should match /this string/" + end + + it "should raise_error" do + lambda { raise }.should raise_error + @desc.should == "should raise Exception" + end + + it "should raise_error with type" do + lambda { raise }.should raise_error(RuntimeError) + @desc.should == "should raise RuntimeError" + end + + it "should raise_error with type and message" do + lambda { raise "there was an error" }.should raise_error(RuntimeError, "there was an error") + @desc.should == "should raise RuntimeError with \"there was an error\"" + end + + it "should respond_to" do + [].should respond_to(:insert) + @desc.should == "should respond to #insert" + end + + it "should throw symbol" do + lambda { throw :what_a_mess }.should throw_symbol + @desc.should == "should throw a Symbol" + end + + it "should throw symbol (with named symbol)" do + lambda { throw :what_a_mess }.should throw_symbol(:what_a_mess) + @desc.should == "should throw :what_a_mess" + end + + def team + Class.new do + def players + [1,2,3] + end + end.new + end + + after(:each) do + Spec::Matchers.unregister_description_generated(@callback) + end +end diff --git a/vendor/plugins/rspec/spec/spec/matchers/eql_spec.rb b/vendor/plugins/rspec/spec/spec/matchers/eql_spec.rb new file mode 100644 index 000000000..3f265d700 --- /dev/null +++ b/vendor/plugins/rspec/spec/spec/matchers/eql_spec.rb @@ -0,0 +1,28 @@ +require File.dirname(__FILE__) + '/../../spec_helper.rb' + +module Spec + module Matchers + describe Eql do + it "should match when actual.eql?(expected)" do + Eql.new(1).matches?(1).should be_true + end + it "should not match when !actual.eql?(expected)" do + Eql.new(1).matches?(2).should be_false + end + it "should describe itself" do + matcher = Eql.new(1) + matcher.description.should == "eql 1" + end + it "should provide message, expected and actual on #failure_message" do + matcher = Eql.new("1") + matcher.matches?(1) + matcher.failure_message.should == ["expected \"1\", got 1 (using .eql?)", "1", 1] + end + it "should provide message, expected and actual on #negative_failure_message" do + matcher = Eql.new(1) + matcher.matches?(1) + matcher.negative_failure_message.should == ["expected 1 not to equal 1 (using .eql?)", 1, 1] + end + end + end +end diff --git a/vendor/plugins/rspec/spec/spec/matchers/equal_spec.rb b/vendor/plugins/rspec/spec/spec/matchers/equal_spec.rb new file mode 100644 index 000000000..7667bdc38 --- /dev/null +++ b/vendor/plugins/rspec/spec/spec/matchers/equal_spec.rb @@ -0,0 +1,28 @@ +require File.dirname(__FILE__) + '/../../spec_helper.rb' + +module Spec + module Matchers + describe Equal do + it "should match when actual.equal?(expected)" do + Equal.new(1).matches?(1).should be_true + end + it "should not match when !actual.equal?(expected)" do + Equal.new("1").matches?("1").should be_false + end + it "should describe itself" do + matcher = Equal.new(1) + matcher.description.should == "equal 1" + end + it "should provide message, expected and actual on #failure_message" do + matcher = Equal.new("1") + matcher.matches?(1) + matcher.failure_message.should == ["expected \"1\", got 1 (using .equal?)", "1", 1] + end + it "should provide message, expected and actual on #negative_failure_message" do + matcher = Equal.new(1) + matcher.matches?(1) + matcher.negative_failure_message.should == ["expected 1 not to equal 1 (using .equal?)", 1, 1] + end + end + end +end diff --git a/vendor/plugins/rspec/spec/spec/matchers/exist_spec.rb b/vendor/plugins/rspec/spec/spec/matchers/exist_spec.rb new file mode 100644 index 000000000..fcbdd9556 --- /dev/null +++ b/vendor/plugins/rspec/spec/spec/matchers/exist_spec.rb @@ -0,0 +1,48 @@ +require File.dirname(__FILE__) + '/../../spec_helper.rb' + +# NOTE - this was initially handled by an explicit matcher, but is now +# handled by a default set of predicate_matchers. + +class Substance + def initialize exists, description + @exists = exists + @description = description + end + def exist? + @exists + end + def inspect + @description + end +end + +describe "should exist" do + before(:each) do + @real = Substance.new true, 'something real' + @imaginary = Substance.new false, 'something imaginary' + end + + it "should pass if target exists" do + @real.should exist + end + + it "should fail if target does not exist" do + lambda { @imaginary.should exist }. + should fail + end +end + +describe "should_not exist" do + before(:each) do + @real = Substance.new true, 'something real' + @imaginary = Substance.new false, 'something imaginary' + end + it "should pass if target doesn't exist" do + @imaginary.should_not exist + end + it "should fail if target does exist" do + lambda { @real.should_not exist }. + should fail + end +end + diff --git a/vendor/plugins/rspec/spec/spec/matchers/handler_spec.rb b/vendor/plugins/rspec/spec/spec/matchers/handler_spec.rb new file mode 100644 index 000000000..9f04c6bed --- /dev/null +++ b/vendor/plugins/rspec/spec/spec/matchers/handler_spec.rb @@ -0,0 +1,88 @@ +require File.dirname(__FILE__) + '/../../spec_helper.rb' + +module ExampleExpectations + + class ArbitraryMatcher + def initialize(*args, &block) + if args.last.is_a? Hash + @expected = args.last[:expected] + end + if block_given? + @expected = block.call + end + @block = block + end + + def matches?(target) + @target = target + return @expected == target + end + + def with(new_value) + @expected = new_value + self + end + + def failure_message + "expected #{@expected}, got #{@target}" + end + + def negative_failure_message + "expected not #{@expected}, got #{@target}" + end + end + + class PositiveOnlyMatcher < ArbitraryMatcher + undef negative_failure_message + end + + def arbitrary_matcher(*args, &block) + ArbitraryMatcher.new(*args, &block) + end + + def positive_only_matcher(*args, &block) + PositiveOnlyMatcher.new(*args, &block) + end + +end + +module Spec + module Expectations + describe ExpectationMatcherHandler, ".handle_matcher" do + it "should ask the matcher if it matches" do + matcher = mock("matcher") + actual = Object.new + matcher.should_receive(:matches?).with(actual).and_return(true) + ExpectationMatcherHandler.handle_matcher(actual, matcher) + end + end + + describe ExpectationMatcherHandler do + include ExampleExpectations + + it "should handle submitted args" do + 5.should arbitrary_matcher(:expected => 5) + 5.should arbitrary_matcher(:expected => "wrong").with(5) + lambda { 5.should arbitrary_matcher(:expected => 4) }.should fail_with("expected 4, got 5") + lambda { 5.should arbitrary_matcher(:expected => 5).with(4) }.should fail_with("expected 4, got 5") + 5.should_not arbitrary_matcher(:expected => 4) + 5.should_not arbitrary_matcher(:expected => 5).with(4) + lambda { 5.should_not arbitrary_matcher(:expected => 5) }.should fail_with("expected not 5, got 5") + lambda { 5.should_not arbitrary_matcher(:expected => 4).with(5) }.should fail_with("expected not 5, got 5") + end + + it "should handle the submitted block" do + 5.should arbitrary_matcher { 5 } + 5.should arbitrary_matcher(:expected => 4) { 5 } + 5.should arbitrary_matcher(:expected => 4).with(5) { 3 } + end + + it "should explain when matcher does not support should_not" do + lambda { + 5.should_not positive_only_matcher(:expected => 5) + }.should fail_with(/Matcher does not support should_not.\n/) + end + + end + end +end diff --git a/vendor/plugins/rspec/spec/spec/matchers/has_spec.rb b/vendor/plugins/rspec/spec/spec/matchers/has_spec.rb new file mode 100644 index 000000000..47f048ebf --- /dev/null +++ b/vendor/plugins/rspec/spec/spec/matchers/has_spec.rb @@ -0,0 +1,37 @@ +require File.dirname(__FILE__) + '/../../spec_helper.rb' + +describe "should have_sym(*args)" do + it "should pass if #has_sym?(*args) returns true" do + {:a => "A"}.should have_key(:a) + end + + it "should fail if #has_sym?(*args) returns false" do + lambda { + {:b => "B"}.should have_key(:a) + }.should fail_with("expected #has_key?(:a) to return true, got false") + end + + it "should fail if target does not respond to #has_sym?" do + lambda { + Object.new.should have_key(:a) + }.should raise_error(NoMethodError) + end +end + +describe "should_not have_sym(*args)" do + it "should pass if #has_sym?(*args) returns false" do + {:a => "A"}.should_not have_key(:b) + end + + it "should fail if #has_sym?(*args) returns true" do + lambda { + {:a => "A"}.should_not have_key(:a) + }.should fail_with("expected #has_key?(:a) to return false, got true") + end + + it "should fail if target does not respond to #has_sym?" do + lambda { + Object.new.should have_key(:a) + }.should raise_error(NoMethodError) + end +end diff --git a/vendor/plugins/rspec/spec/spec/matchers/have_spec.rb b/vendor/plugins/rspec/spec/spec/matchers/have_spec.rb new file mode 100644 index 000000000..84a75d98e --- /dev/null +++ b/vendor/plugins/rspec/spec/spec/matchers/have_spec.rb @@ -0,0 +1,272 @@ +require File.dirname(__FILE__) + '/../../spec_helper.rb' + +module HaveSpecHelper + def create_collection_owner_with(n) + owner = Spec::Expectations::Helper::CollectionOwner.new + (1..n).each do |n| + owner.add_to_collection_with_length_method(n) + owner.add_to_collection_with_size_method(n) + end + owner + end +end + +describe "should have(n).items" do + include HaveSpecHelper + + it "should pass if target has a collection of items with n members" do + owner = create_collection_owner_with(3) + owner.should have(3).items_in_collection_with_length_method + owner.should have(3).items_in_collection_with_size_method + end + + it "should convert :no to 0" do + owner = create_collection_owner_with(0) + owner.should have(:no).items_in_collection_with_length_method + owner.should have(:no).items_in_collection_with_size_method + end + + it "should fail if target has a collection of items with < n members" do + owner = create_collection_owner_with(3) + lambda { + owner.should have(4).items_in_collection_with_length_method + }.should fail_with("expected 4 items_in_collection_with_length_method, got 3") + lambda { + owner.should have(4).items_in_collection_with_size_method + }.should fail_with("expected 4 items_in_collection_with_size_method, got 3") + end + + it "should fail if target has a collection of items with > n members" do + owner = create_collection_owner_with(3) + lambda { + owner.should have(2).items_in_collection_with_length_method + }.should fail_with("expected 2 items_in_collection_with_length_method, got 3") + lambda { + owner.should have(2).items_in_collection_with_size_method + }.should fail_with("expected 2 items_in_collection_with_size_method, got 3") + end +end + +describe "should have(n).items where result responds to items but returns something other than a collection" do + it "should provide a meaningful error" do + owner = Class.new do + def items + Object.new + end + end.new + lambda do + owner.should have(3).items + end.should raise_error("expected items to be a collection but it does not respond to #length or #size") + end +end + +describe "should_not have(n).items" do + include HaveSpecHelper + + it "should pass if target has a collection of items with < n members" do + owner = create_collection_owner_with(3) + owner.should_not have(4).items_in_collection_with_length_method + owner.should_not have(4).items_in_collection_with_size_method + end + + it "should pass if target has a collection of items with > n members" do + owner = create_collection_owner_with(3) + owner.should_not have(2).items_in_collection_with_length_method + owner.should_not have(2).items_in_collection_with_size_method + end + + it "should fail if target has a collection of items with n members" do + owner = create_collection_owner_with(3) + lambda { + owner.should_not have(3).items_in_collection_with_length_method + }.should fail_with("expected target not to have 3 items_in_collection_with_length_method, got 3") + lambda { + owner.should_not have(3).items_in_collection_with_size_method + }.should fail_with("expected target not to have 3 items_in_collection_with_size_method, got 3") + end +end + +describe "should have_exactly(n).items" do + include HaveSpecHelper + + it "should pass if target has a collection of items with n members" do + owner = create_collection_owner_with(3) + owner.should have_exactly(3).items_in_collection_with_length_method + owner.should have_exactly(3).items_in_collection_with_size_method + end + + it "should convert :no to 0" do + owner = create_collection_owner_with(0) + owner.should have_exactly(:no).items_in_collection_with_length_method + owner.should have_exactly(:no).items_in_collection_with_size_method + end + + it "should fail if target has a collection of items with < n members" do + owner = create_collection_owner_with(3) + lambda { + owner.should have_exactly(4).items_in_collection_with_length_method + }.should fail_with("expected 4 items_in_collection_with_length_method, got 3") + lambda { + owner.should have_exactly(4).items_in_collection_with_size_method + }.should fail_with("expected 4 items_in_collection_with_size_method, got 3") + end + + it "should fail if target has a collection of items with > n members" do + owner = create_collection_owner_with(3) + lambda { + owner.should have_exactly(2).items_in_collection_with_length_method + }.should fail_with("expected 2 items_in_collection_with_length_method, got 3") + lambda { + owner.should have_exactly(2).items_in_collection_with_size_method + }.should fail_with("expected 2 items_in_collection_with_size_method, got 3") + end +end + +describe "should have_at_least(n).items" do + include HaveSpecHelper + + it "should pass if target has a collection of items with n members" do + owner = create_collection_owner_with(3) + owner.should have_at_least(3).items_in_collection_with_length_method + owner.should have_at_least(3).items_in_collection_with_size_method + end + + it "should pass if target has a collection of items with > n members" do + owner = create_collection_owner_with(3) + owner.should have_at_least(2).items_in_collection_with_length_method + owner.should have_at_least(2).items_in_collection_with_size_method + end + + it "should fail if target has a collection of items with < n members" do + owner = create_collection_owner_with(3) + lambda { + owner.should have_at_least(4).items_in_collection_with_length_method + }.should fail_with("expected at least 4 items_in_collection_with_length_method, got 3") + lambda { + owner.should have_at_least(4).items_in_collection_with_size_method + }.should fail_with("expected at least 4 items_in_collection_with_size_method, got 3") + end + + it "should provide educational negative failure messages" do + #given + owner = create_collection_owner_with(3) + length_matcher = have_at_least(3).items_in_collection_with_length_method + size_matcher = have_at_least(3).items_in_collection_with_size_method + + #when + length_matcher.matches?(owner) + size_matcher.matches?(owner) + + #then + length_matcher.negative_failure_message.should == <<-EOF +Isn't life confusing enough? +Instead of having to figure out the meaning of this: + should_not have_at_least(3).items_in_collection_with_length_method +We recommend that you use this instead: + should have_at_most(2).items_in_collection_with_length_method +EOF + + size_matcher.negative_failure_message.should == <<-EOF +Isn't life confusing enough? +Instead of having to figure out the meaning of this: + should_not have_at_least(3).items_in_collection_with_size_method +We recommend that you use this instead: + should have_at_most(2).items_in_collection_with_size_method +EOF + end +end + +describe "should have_at_most(n).items" do + include HaveSpecHelper + + it "should pass if target has a collection of items with n members" do + owner = create_collection_owner_with(3) + owner.should have_at_most(3).items_in_collection_with_length_method + owner.should have_at_most(3).items_in_collection_with_size_method + end + + it "should fail if target has a collection of items with > n members" do + owner = create_collection_owner_with(3) + lambda { + owner.should have_at_most(2).items_in_collection_with_length_method + }.should fail_with("expected at most 2 items_in_collection_with_length_method, got 3") + lambda { + owner.should have_at_most(2).items_in_collection_with_size_method + }.should fail_with("expected at most 2 items_in_collection_with_size_method, got 3") + end + + it "should pass if target has a collection of items with < n members" do + owner = create_collection_owner_with(3) + owner.should have_at_most(4).items_in_collection_with_length_method + owner.should have_at_most(4).items_in_collection_with_size_method + end + + it "should provide educational negative failure messages" do + #given + owner = create_collection_owner_with(3) + length_matcher = have_at_most(3).items_in_collection_with_length_method + size_matcher = have_at_most(3).items_in_collection_with_size_method + + #when + length_matcher.matches?(owner) + size_matcher.matches?(owner) + + #then + length_matcher.negative_failure_message.should == <<-EOF +Isn't life confusing enough? +Instead of having to figure out the meaning of this: + should_not have_at_most(3).items_in_collection_with_length_method +We recommend that you use this instead: + should have_at_least(4).items_in_collection_with_length_method +EOF + + size_matcher.negative_failure_message.should == <<-EOF +Isn't life confusing enough? +Instead of having to figure out the meaning of this: + should_not have_at_most(3).items_in_collection_with_size_method +We recommend that you use this instead: + should have_at_least(4).items_in_collection_with_size_method +EOF + end +end + +describe "have(n).items(args, block)" do + it "should pass args to target" do + target = mock("target") + target.should_receive(:items).with("arg1","arg2").and_return([1,2,3]) + target.should have(3).items("arg1","arg2") + end + + it "should pass block to target" do + target = mock("target") + block = lambda { 5 } + target.should_receive(:items).with("arg1","arg2", block).and_return([1,2,3]) + target.should have(3).items("arg1","arg2", block) + end +end + +describe "have(n).items where target IS a collection" do + it "should reference the number of items IN the collection" do + [1,2,3].should have(3).items + end + + it "should reference the number of items IN the collection" do + lambda { [1,2,3].should have(7).items }.should fail_with("expected 7 items, got 3") + end +end + +describe "have(n).characters where target IS a String" do + it "should pass if the length is correct" do + "this string".should have(11).characters + end + + it "should fail if the length is incorrect" do + lambda { "this string".should have(12).characters }.should fail_with("expected 12 characters, got 11") + end +end + +describe "have(n).things on an object which is not a collection nor contains one" do + it "should fail" do + lambda { Object.new.should have(2).things }.should raise_error(NoMethodError, /undefined method `things' for #<Object:/) + end +end diff --git a/vendor/plugins/rspec/spec/spec/matchers/include_spec.rb b/vendor/plugins/rspec/spec/spec/matchers/include_spec.rb new file mode 100644 index 000000000..f1057f3fd --- /dev/null +++ b/vendor/plugins/rspec/spec/spec/matchers/include_spec.rb @@ -0,0 +1,45 @@ +require File.dirname(__FILE__) + '/../../spec_helper.rb' + +describe "should include(expected)" do + it "should pass if target includes expected" do + [1,2,3].should include(3) + "abc".should include("a") + end + + it "should fail if target does not include expected" do + lambda { + [1,2,3].should include(4) + }.should fail_with("expected [1, 2, 3] to include 4") + lambda { + "abc".should include("d") + }.should fail_with("expected \"abc\" to include \"d\"") + end +end + +describe "should include(with, multiple, args)" do + it "should pass if target includes all items" do + [1,2,3].should include(1,2,3) + end + + it "should fail if target does not include any one of the items" do + lambda { + [1,2,3].should include(1,2,4) + }.should fail_with("expected [1, 2, 3] to include 1, 2 and 4") + end +end + +describe "should_not include(expected)" do + it "should pass if target does not include expected" do + [1,2,3].should_not include(4) + "abc".should_not include("d") + end + + it "should fail if target includes expected" do + lambda { + [1,2,3].should_not include(3) + }.should fail_with("expected [1, 2, 3] not to include 3") + lambda { + "abc".should_not include("c") + }.should fail_with("expected \"abc\" not to include \"c\"") + end +end diff --git a/vendor/plugins/rspec/spec/spec/matchers/match_spec.rb b/vendor/plugins/rspec/spec/spec/matchers/match_spec.rb new file mode 100644 index 000000000..b8aa06b07 --- /dev/null +++ b/vendor/plugins/rspec/spec/spec/matchers/match_spec.rb @@ -0,0 +1,37 @@ +require File.dirname(__FILE__) + '/../../spec_helper.rb' + +describe "should match(expected)" do + it "should pass when target (String) matches expected (Regexp)" do + "string".should match(/tri/) + end + + it "should fail when target (String) matches expected (Regexp)" do + lambda { + "string".should match(/rings/) + }.should fail + end + + it "should provide message, expected and actual on failure" do + matcher = match(/rings/) + matcher.matches?("string") + matcher.failure_message.should == ["expected \"string\" to match /rings/", /rings/, "string"] + end +end + +describe "should_not match(expected)" do + it "should pass when target (String) matches expected (Regexp)" do + "string".should_not match(/rings/) + end + + it "should fail when target (String) matches expected (Regexp)" do + lambda { + "string".should_not match(/tri/) + }.should fail + end + + it "should provide message, expected and actual on failure" do + matcher = match(/tri/) + matcher.matches?("string") + matcher.negative_failure_message.should == ["expected \"string\" not to match /tri/", /tri/, "string"] + end +end diff --git a/vendor/plugins/rspec/spec/spec/matchers/matcher_methods_spec.rb b/vendor/plugins/rspec/spec/spec/matchers/matcher_methods_spec.rb new file mode 100644 index 000000000..80cc9855a --- /dev/null +++ b/vendor/plugins/rspec/spec/spec/matchers/matcher_methods_spec.rb @@ -0,0 +1,78 @@ +require File.dirname(__FILE__) + '/../../spec_helper.rb' + +module Spec + module Matchers + context %Q{The Spec::Matchers module gets included in the execution context of every spec. +This module should provide the following methods, each of which returns a Matcher object.} do + it "be_true" do + be_true.should be_an_instance_of(Be) + end + it "be_false" do + be_false.should be_an_instance_of(Be) + end + it "be_nil" do + be_nil.should be_an_instance_of(Be) + end + it "be_arbitrary_predicate" do + be_arbitrary_predicate.should be_an_instance_of(Be) + end + it "be_close" do + be_close(1,2).should be_an_instance_of(BeClose) + end + it "change" do + change("target", :message).should be_an_instance_of(Change) + end + it "eql" do + eql(:expected).should be_an_instance_of(Eql) + end + it "equal" do + equal(:expected).should be_an_instance_of(Equal) + end + it "have" do + have(0).should be_an_instance_of(Have) + end + it "have_exactly" do + have_exactly(0).should be_an_instance_of(Have) + end + it "have_at_least" do + have_at_least(0).should be_an_instance_of(Have) + end + it "have_at_most" do + have_at_most(0).should be_an_instance_of(Have) + end + it "include" do + include(:value).should be_an_instance_of(Include) + end + it "match" do + match(:value).should be_an_instance_of(Match) + end + it "raise_error" do + raise_error.should be_an_instance_of(RaiseError) + raise_error(NoMethodError).should be_an_instance_of(RaiseError) + raise_error(NoMethodError, "message").should be_an_instance_of(RaiseError) + end + it "satisfy" do + satisfy{}.should be_an_instance_of(Satisfy) + end + it "throw_symbol" do + throw_symbol.should be_an_instance_of(ThrowSymbol) + throw_symbol(:sym).should be_an_instance_of(ThrowSymbol) + end + it "respond_to" do + respond_to(:sym).should be_an_instance_of(RespondTo) + end + end + + describe "Spec::Matchers#method_missing" do + it "should convert be_xyz to Be(:be_xyz)" do + Be.should_receive(:new).with(:be_whatever) + be_whatever + end + + it "should convert have_xyz to Has(:have_xyz)" do + Has.should_receive(:new).with(:have_whatever) + have_whatever + end + end + end +end diff --git a/vendor/plugins/rspec/spec/spec/matchers/mock_constraint_matchers_spec.rb b/vendor/plugins/rspec/spec/spec/matchers/mock_constraint_matchers_spec.rb new file mode 100644 index 000000000..bde48686a --- /dev/null +++ b/vendor/plugins/rspec/spec/spec/matchers/mock_constraint_matchers_spec.rb @@ -0,0 +1,24 @@ +require File.dirname(__FILE__) + '/../../spec_helper.rb' + +describe "The anything() mock argument constraint matcher" do + specify { anything.should == Object.new } + specify { anything.should == Class } + specify { anything.should == 1 } + specify { anything.should == "a string" } + specify { anything.should == :a_symbol } +end + +describe "The boolean() mock argument constraint matcher" do + specify { boolean.should == true } + specify { boolean.should == false } + specify { boolean.should_not == Object.new } + specify { boolean.should_not == Class } + specify { boolean.should_not == 1 } + specify { boolean.should_not == "a string" } + specify { boolean.should_not == :a_symbol } +end + +describe "The an_instance_of() mock argument constraint matcher" do + # NOTE - this is implemented as a predicate_matcher - see behaviour.rb + specify { an_instance_of(String).should == "string" } +end diff --git a/vendor/plugins/rspec/spec/spec/matchers/operator_matcher_spec.rb b/vendor/plugins/rspec/spec/spec/matchers/operator_matcher_spec.rb new file mode 100644 index 000000000..eaadc8fc8 --- /dev/null +++ b/vendor/plugins/rspec/spec/spec/matchers/operator_matcher_spec.rb @@ -0,0 +1,158 @@ +require File.dirname(__FILE__) + '/../../spec_helper.rb' + +require 'spec/expectations/differs/default' + +describe "should ==" do + + it "should delegate message to target" do + subject = "apple" + subject.should_receive(:==).with("apple").and_return(true) + subject.should == "apple" + end + + it "should fail when target.==(actual) returns false" do + subject = "apple" + Spec::Expectations.should_receive(:fail_with).with(%[expected: "orange",\n got: "apple" (using ==)], "orange", "apple") + subject.should == "orange" + end + +end + +describe "should_not ==" do + + it "should delegate message to target" do + subject = "orange" + subject.should_receive(:==).with("apple").and_return(false) + subject.should_not == "apple" + end + + it "should fail when target.==(actual) returns false" do + subject = "apple" + Spec::Expectations.should_receive(:fail_with).with(%[expected not: == "apple",\n got: "apple"], "apple", "apple") + subject.should_not == "apple" + end + +end + +describe "should ===" do + + it "should delegate message to target" do + subject = "apple" + subject.should_receive(:===).with("apple").and_return(true) + subject.should === "apple" + end + + it "should fail when target.===(actual) returns false" do + subject = "apple" + subject.should_receive(:===).with("orange").and_return(false) + Spec::Expectations.should_receive(:fail_with).with(%[expected: "orange",\n got: "apple" (using ===)], "orange", "apple") + subject.should === "orange" + end + +end + +describe "should_not ===" do + + it "should delegate message to target" do + subject = "orange" + subject.should_receive(:===).with("apple").and_return(false) + subject.should_not === "apple" + end + + it "should fail when target.===(actual) returns false" do + subject = "apple" + subject.should_receive(:===).with("apple").and_return(true) + Spec::Expectations.should_receive(:fail_with).with(%[expected not: === "apple",\n got: "apple"], "apple", "apple") + subject.should_not === "apple" + end + +end + +describe "should =~" do + + it "should delegate message to target" do + subject = "foo" + subject.should_receive(:=~).with(/oo/).and_return(true) + subject.should =~ /oo/ + end + + it "should fail when target.=~(actual) returns false" do + subject = "fu" + subject.should_receive(:=~).with(/oo/).and_return(false) + Spec::Expectations.should_receive(:fail_with).with(%[expected: /oo/,\n got: "fu" (using =~)], /oo/, "fu") + subject.should =~ /oo/ + end + +end + +describe "should_not =~" do + + it "should delegate message to target" do + subject = "fu" + subject.should_receive(:=~).with(/oo/).and_return(false) + subject.should_not =~ /oo/ + end + + it "should fail when target.=~(actual) returns false" do + subject = "foo" + subject.should_receive(:=~).with(/oo/).and_return(true) + Spec::Expectations.should_receive(:fail_with).with(%[expected not: =~ /oo/,\n got: "foo"], /oo/, "foo") + subject.should_not =~ /oo/ + end + +end + +describe "should >" do + + it "should pass if > passes" do + 4.should > 3 + end + + it "should fail if > fails" do + Spec::Expectations.should_receive(:fail_with).with(%[expected: > 5,\n got: 4], 5, 4) + 4.should > 5 + end + +end + +describe "should >=" do + + it "should pass if >= passes" do + 4.should > 3 + 4.should >= 4 + end + + it "should fail if > fails" do + Spec::Expectations.should_receive(:fail_with).with(%[expected: >= 5,\n got: 4], 5, 4) + 4.should >= 5 + end + +end + +describe "should <" do + + it "should pass if < passes" do + 4.should < 5 + end + + it "should fail if > fails" do + Spec::Expectations.should_receive(:fail_with).with(%[expected: < 3,\n got: 4], 3, 4) + 4.should < 3 + end + +end + +describe "should <=" do + + it "should pass if <= passes" do + 4.should <= 5 + 4.should <= 4 + end + + it "should fail if > fails" do + Spec::Expectations.should_receive(:fail_with).with(%[expected: <= 3,\n got: 4], 3, 4) + 4.should <= 3 + end + +end + diff --git a/vendor/plugins/rspec/spec/spec/matchers/raise_error_spec.rb b/vendor/plugins/rspec/spec/spec/matchers/raise_error_spec.rb new file mode 100644 index 000000000..f33fba903 --- /dev/null +++ b/vendor/plugins/rspec/spec/spec/matchers/raise_error_spec.rb @@ -0,0 +1,185 @@ +require File.dirname(__FILE__) + '/../../spec_helper.rb' + +describe "should raise_error" do + it "should pass if anything is raised" do + lambda {raise}.should raise_error + end + + it "should fail if nothing is raised" do + lambda { + lambda {}.should raise_error + }.should fail_with("expected Exception but nothing was raised") + end +end + +describe "should_not raise_error" do + it "should pass if nothing is raised" do + lambda {}.should_not raise_error + end + + it "should fail if anything is raised" do + lambda { + lambda {raise}.should_not raise_error + }.should fail_with("expected no Exception, got RuntimeError") + end +end + +describe "should raise_error(message)" do + it "should pass if RuntimeError is raised with the right message" do + lambda {raise 'blah'}.should raise_error('blah') + end + it "should pass if any other error is raised with the right message" do + lambda {raise NameError.new('blah')}.should raise_error('blah') + end + it "should fail if RuntimeError error is raised with the wrong message" do + lambda do + lambda {raise 'blarg'}.should raise_error('blah') + end.should fail_with("expected Exception with \"blah\", got #<RuntimeError: blarg>") + end + it "should fail if any other error is raised with the wrong message" do + lambda do + lambda {raise NameError.new('blarg')}.should raise_error('blah') + end.should fail_with("expected Exception with \"blah\", got #<NameError: blarg>") + end +end + +describe "should_not raise_error(message)" do + it "should pass if RuntimeError error is raised with the different message" do + lambda {raise 'blarg'}.should_not raise_error('blah') + end + it "should pass if any other error is raised with the wrong message" do + lambda {raise NameError.new('blarg')}.should_not raise_error('blah') + end + it "should fail if RuntimeError is raised with message" do + lambda do + lambda {raise 'blah'}.should_not raise_error('blah') + end.should fail_with(%Q|expected no Exception with "blah", got #<RuntimeError: blah>|) + end + it "should fail if any other error is raised with message" do + lambda do + lambda {raise NameError.new('blah')}.should_not raise_error('blah') + end.should fail_with(%Q|expected no Exception with "blah", got #<NameError: blah>|) + end +end + +describe "should raise_error(NamedError)" do + it "should pass if named error is raised" do + lambda { non_existent_method }.should raise_error(NameError) + end + + it "should fail if nothing is raised" do + lambda { + lambda { }.should raise_error(NameError) + }.should fail_with("expected NameError but nothing was raised") + end + + it "should fail if another error is raised" do + lambda { + lambda { raise }.should raise_error(NameError) + }.should fail_with("expected NameError, got RuntimeError") + end +end + +describe "should_not raise_error(NamedError)" do + it "should pass if nothing is raised" do + lambda { }.should_not raise_error(NameError) + end + + it "should pass if another error is raised" do + lambda { raise }.should_not raise_error(NameError) + end + + it "should fail if named error is raised" do + lambda { + lambda { non_existent_method }.should_not raise_error(NameError) + }.should fail_with(/expected no NameError, got #<NameError: undefined/) + end +end + +describe "should raise_error(NamedError, error_message) with String" do + it "should pass if named error is raised with same message" do + lambda { raise "example message" }.should raise_error(RuntimeError, "example message") + end + + it "should fail if nothing is raised" do + lambda { + lambda {}.should raise_error(RuntimeError, "example message") + }.should fail_with("expected RuntimeError with \"example message\" but nothing was raised") + end + + it "should fail if incorrect error is raised" do + lambda { + lambda { raise }.should raise_error(NameError, "example message") + }.should fail_with("expected NameError with \"example message\", got RuntimeError") + end + + it "should fail if correct error is raised with incorrect message" do + lambda { + lambda { raise RuntimeError.new("not the example message") }.should raise_error(RuntimeError, "example message") + }.should fail_with(/expected RuntimeError with \"example message\", got #<RuntimeError: not the example message/) + end +end + +describe "should_not raise_error(NamedError, error_message) with String" do + it "should pass if nothing is raised" do + lambda {}.should_not raise_error(RuntimeError, "example message") + end + + it "should pass if a different error is raised" do + lambda { raise }.should_not raise_error(NameError, "example message") + end + + it "should pass if same error is raised with different message" do + lambda { raise RuntimeError.new("not the example message") }.should_not raise_error(RuntimeError, "example message") + end + + it "should fail if named error is raised with same message" do + lambda { + lambda { raise "example message" }.should_not raise_error(RuntimeError, "example message") + }.should fail_with("expected no RuntimeError with \"example message\", got #<RuntimeError: example message>") + end +end + +describe "should raise_error(NamedError, error_message) with Regexp" do + it "should pass if named error is raised with matching message" do + lambda { raise "example message" }.should raise_error(RuntimeError, /ample mess/) + end + + it "should fail if nothing is raised" do + lambda { + lambda {}.should raise_error(RuntimeError, /ample mess/) + }.should fail_with("expected RuntimeError with message matching /ample mess/ but nothing was raised") + end + + it "should fail if incorrect error is raised" do + lambda { + lambda { raise }.should raise_error(NameError, /ample mess/) + }.should fail_with("expected NameError with message matching /ample mess/, got RuntimeError") + end + + it "should fail if correct error is raised with incorrect message" do + lambda { + lambda { raise RuntimeError.new("not the example message") }.should raise_error(RuntimeError, /less than ample mess/) + }.should fail_with("expected RuntimeError with message matching /less than ample mess/, got #<RuntimeError: not the example message>") + end +end + +describe "should_not raise_error(NamedError, error_message) with Regexp" do + it "should pass if nothing is raised" do + lambda {}.should_not raise_error(RuntimeError, /ample mess/) + end + + it "should pass if a different error is raised" do + lambda { raise }.should_not raise_error(NameError, /ample mess/) + end + + it "should pass if same error is raised with non-matching message" do + lambda { raise RuntimeError.new("non matching message") }.should_not raise_error(RuntimeError, /ample mess/) + end + + it "should fail if named error is raised with matching message" do + lambda { + lambda { raise "example message" }.should_not raise_error(RuntimeError, /ample mess/) + }.should fail_with("expected no RuntimeError with message matching /ample mess/, got #<RuntimeError: example message>") + end +end diff --git a/vendor/plugins/rspec/spec/spec/matchers/respond_to_spec.rb b/vendor/plugins/rspec/spec/spec/matchers/respond_to_spec.rb new file mode 100644 index 000000000..2cdbbcd63 --- /dev/null +++ b/vendor/plugins/rspec/spec/spec/matchers/respond_to_spec.rb @@ -0,0 +1,54 @@ +require File.dirname(__FILE__) + '/../../spec_helper.rb' + +describe "should respond_to(:sym)" do + + it "should pass if target responds to :sym" do + Object.new.should respond_to(:methods) + end + + it "should fail target does not respond to :sym" do + lambda { + Object.new.should respond_to(:some_method) + }.should fail_with("expected target to respond to :some_method") + end + +end + +describe "should respond_to(message1, message2)" do + + it "should pass if target responds to both messages" do + Object.new.should respond_to('methods', 'inspect') + end + + it "should fail target does not respond to first message" do + lambda { + Object.new.should respond_to('method_one', 'inspect') + }.should fail_with('expected target to respond to "method_one"') + end + + it "should fail target does not respond to second message" do + lambda { + Object.new.should respond_to('inspect', 'method_one') + }.should fail_with('expected target to respond to "method_one"') + end + + it "should fail target does not respond to either message" do + lambda { + Object.new.should respond_to('method_one', 'method_two') + }.should fail_with('expected target to respond to "method_one", "method_two"') + end +end + +describe "should_not respond_to(:sym)" do + + it "should pass if target does not respond to :sym" do + Object.new.should_not respond_to(:some_method) + end + + it "should fail target responds to :sym" do + lambda { + Object.new.should_not respond_to(:methods) + }.should fail_with("expected target not to respond to :methods") + end + +end diff --git a/vendor/plugins/rspec/spec/spec/matchers/satisfy_spec.rb b/vendor/plugins/rspec/spec/spec/matchers/satisfy_spec.rb new file mode 100644 index 000000000..7e8d6f972 --- /dev/null +++ b/vendor/plugins/rspec/spec/spec/matchers/satisfy_spec.rb @@ -0,0 +1,36 @@ +require File.dirname(__FILE__) + '/../../spec_helper.rb' + +describe "should satisfy { block }" do + it "should pass if block returns true" do + true.should satisfy { |val| val } + true.should satisfy do |val| + val + end + end + + it "should fail if block returns false" do + lambda { + false.should satisfy { |val| val } + }.should fail_with("expected false to satisfy block") + lambda do + false.should satisfy do |val| + val + end + end.should fail_with("expected false to satisfy block") + end +end + +describe "should_not satisfy { block }" do + it "should pass if block returns false" do + false.should_not satisfy { |val| val } + false.should_not satisfy do |val| + val + end + end + + it "should fail if block returns true" do + lambda { + true.should_not satisfy { |val| val } + }.should fail_with("expected true not to satisfy block") + end +end diff --git a/vendor/plugins/rspec/spec/spec/matchers/throw_symbol_spec.rb b/vendor/plugins/rspec/spec/spec/matchers/throw_symbol_spec.rb new file mode 100644 index 000000000..1548ec6f0 --- /dev/null +++ b/vendor/plugins/rspec/spec/spec/matchers/throw_symbol_spec.rb @@ -0,0 +1,51 @@ +require File.dirname(__FILE__) + '/../../spec_helper.rb' + +module Spec + module Matchers + describe ThrowSymbol, "(constructed with no Symbol)" do + before(:each) { @matcher = ThrowSymbol.new } + + it "should match if any Symbol is thrown" do + @matcher.matches?(lambda{ throw :sym }).should be_true + end + it "should not match if no Symbol is thrown" do + @matcher.matches?(lambda{ }).should be_false + end + it "should provide a failure message" do + @matcher.matches?(lambda{}) + @matcher.failure_message.should == "expected a Symbol but nothing was thrown" + end + it "should provide a negative failure message" do + @matcher.matches?(lambda{ throw :sym}) + @matcher.negative_failure_message.should == "expected no Symbol, got :sym" + end + end + + describe ThrowSymbol, "(constructed with a Symbol)" do + before(:each) { @matcher = ThrowSymbol.new(:sym) } + + it "should match if correct Symbol is thrown" do + @matcher.matches?(lambda{ throw :sym }).should be_true + end + it "should not match no Symbol is thrown" do + @matcher.matches?(lambda{ }).should be_false + end + it "should not match if correct Symbol is thrown" do + @matcher.matches?(lambda{ throw :other_sym }).should be_false + @matcher.failure_message.should == "expected :sym, got :other_sym" + end + it "should provide a failure message when no Symbol is thrown" do + @matcher.matches?(lambda{}) + @matcher.failure_message.should == "expected :sym but nothing was thrown" + end + it "should provide a failure message when wrong Symbol is thrown" do + @matcher.matches?(lambda{ throw :other_sym }) + @matcher.failure_message.should == "expected :sym, got :other_sym" + end + it "should provide a negative failure message" do + @matcher.matches?(lambda{ throw :sym }) + @matcher.negative_failure_message.should == "expected :sym not to be thrown" + end + end + end +end diff --git a/vendor/plugins/rspec/spec/spec/mocks/any_number_of_times_spec.rb b/vendor/plugins/rspec/spec/spec/mocks/any_number_of_times_spec.rb new file mode 100644 index 000000000..3f50dcfc5 --- /dev/null +++ b/vendor/plugins/rspec/spec/spec/mocks/any_number_of_times_spec.rb @@ -0,0 +1,29 @@ +require File.dirname(__FILE__) + '/../../spec_helper.rb' + +module Spec + module Mocks + + describe "AnyNumberOfTimes" do + before(:each) do + @mock = Mock.new("test mock") + end + + it "should pass if any number of times method is called many times" do + @mock.should_receive(:random_call).any_number_of_times + (1..10).each do + @mock.random_call + end + end + + it "should pass if any number of times method is called once" do + @mock.should_receive(:random_call).any_number_of_times + @mock.random_call + end + + it "should pass if any number of times method is not called" do + @mock.should_receive(:random_call).any_number_of_times + end + end + + end +end diff --git a/vendor/plugins/rspec/spec/spec/mocks/argument_expectation_spec.rb b/vendor/plugins/rspec/spec/spec/mocks/argument_expectation_spec.rb new file mode 100644 index 000000000..2bebbdd4f --- /dev/null +++ b/vendor/plugins/rspec/spec/spec/mocks/argument_expectation_spec.rb @@ -0,0 +1,23 @@ +require File.dirname(__FILE__) + '/../../spec_helper.rb' + +module Spec + module Mocks + describe ArgumentExpectation do + it "should consider an object that responds to #matches? and #description to be a matcher" do + argument_expecatation = Spec::Mocks::ArgumentExpectation.new([]) + obj = mock("matcher") + obj.should_receive(:respond_to?).with(:matches?).and_return(true) + obj.should_receive(:respond_to?).with(:description).and_return(true) + argument_expecatation.is_matcher?(obj).should be_true + end + + it "should NOT consider an object that only responds to #matches? to be a matcher" do + argument_expecatation = Spec::Mocks::ArgumentExpectation.new([]) + obj = mock("matcher") + obj.should_receive(:respond_to?).with(:matches?).and_return(true) + obj.should_receive(:respond_to?).with(:description).and_return(false) + argument_expecatation.is_matcher?(obj).should be_false + end + end + end +end diff --git a/vendor/plugins/rspec/spec/spec/mocks/at_least_spec.rb b/vendor/plugins/rspec/spec/spec/mocks/at_least_spec.rb new file mode 100644 index 000000000..01b133dc3 --- /dev/null +++ b/vendor/plugins/rspec/spec/spec/mocks/at_least_spec.rb @@ -0,0 +1,97 @@ +require File.dirname(__FILE__) + '/../../spec_helper.rb' + +module Spec + module Mocks + describe "at_least" do + before(:each) do + @mock = Mock.new("test mock") + end + + it "should fail if method is never called" do + @mock.should_receive(:random_call).at_least(4).times + lambda do + @mock.rspec_verify + end.should raise_error(MockExpectationError) + end + + it "should fail when called less than n times" do + @mock.should_receive(:random_call).at_least(4).times + @mock.random_call + @mock.random_call + @mock.random_call + lambda do + @mock.rspec_verify + end.should raise_error(MockExpectationError) + end + + it "should fail when at least once method is never called" do + @mock.should_receive(:random_call).at_least(:once) + lambda do + @mock.rspec_verify + end.should raise_error(MockExpectationError) + end + + it "should fail when at least twice method is called once" do + @mock.should_receive(:random_call).at_least(:twice) + @mock.random_call + lambda do + @mock.rspec_verify + end.should raise_error(MockExpectationError) + end + + it "should fail when at least twice method is never called" do + @mock.should_receive(:random_call).at_least(:twice) + lambda do + @mock.rspec_verify + end.should raise_error(MockExpectationError) + end + + it "should pass when at least n times method is called exactly n times" do + @mock.should_receive(:random_call).at_least(4).times + @mock.random_call + @mock.random_call + @mock.random_call + @mock.random_call + @mock.rspec_verify + end + + it "should pass when at least n times method is called n plus 1 times" do + @mock.should_receive(:random_call).at_least(4).times + @mock.random_call + @mock.random_call + @mock.random_call + @mock.random_call + @mock.random_call + @mock.rspec_verify + end + + it "should pass when at least once method is called once" do + @mock.should_receive(:random_call).at_least(:once) + @mock.random_call + @mock.rspec_verify + end + + it "should pass when at least once method is called twice" do + @mock.should_receive(:random_call).at_least(:once) + @mock.random_call + @mock.random_call + @mock.rspec_verify + end + + it "should pass when at least twice method is called three times" do + @mock.should_receive(:random_call).at_least(:twice) + @mock.random_call + @mock.random_call + @mock.random_call + @mock.rspec_verify + end + + it "should pass when at least twice method is called twice" do + @mock.should_receive(:random_call).at_least(:twice) + @mock.random_call + @mock.random_call + @mock.rspec_verify + end + end + end +end diff --git a/vendor/plugins/rspec/spec/spec/mocks/at_most_spec.rb b/vendor/plugins/rspec/spec/spec/mocks/at_most_spec.rb new file mode 100644 index 000000000..f3c5e2150 --- /dev/null +++ b/vendor/plugins/rspec/spec/spec/mocks/at_most_spec.rb @@ -0,0 +1,93 @@ +require File.dirname(__FILE__) + '/../../spec_helper.rb' + +module Spec + module Mocks + describe "at_most" do + before(:each) do + @mock = Mock.new("test mock") + end + + it "should fail when at most n times method is called n plus 1 times" do + @mock.should_receive(:random_call).at_most(4).times + @mock.random_call + @mock.random_call + @mock.random_call + @mock.random_call + @mock.random_call + lambda do + @mock.rspec_verify + end.should raise_error(MockExpectationError) + end + + it "should fail when at most once method is called twice" do + @mock.should_receive(:random_call).at_most(:once) + @mock.random_call + @mock.random_call + lambda do + @mock.rspec_verify + end.should raise_error(MockExpectationError) + end + + it "should fail when at most twice method is called three times" do + @mock.should_receive(:random_call).at_most(:twice) + @mock.random_call + @mock.random_call + @mock.random_call + lambda do + @mock.rspec_verify + end.should raise_error(MockExpectationError) + end + + it "should pass when at most n times method is called exactly n times" do + @mock.should_receive(:random_call).at_most(4).times + @mock.random_call + @mock.random_call + @mock.random_call + @mock.random_call + @mock.rspec_verify + end + + it "should pass when at most n times method is called less than n times" do + @mock.should_receive(:random_call).at_most(4).times + @mock.random_call + @mock.random_call + @mock.random_call + @mock.rspec_verify + end + + it "should pass when at most n times method is never called" do + @mock.should_receive(:random_call).at_most(4).times + @mock.rspec_verify + end + + it "should pass when at most once method is called once" do + @mock.should_receive(:random_call).at_most(:once) + @mock.random_call + @mock.rspec_verify + end + + it "should pass when at most once method is never called" do + @mock.should_receive(:random_call).at_most(:once) + @mock.rspec_verify + end + + it "should pass when at most twice method is called once" do + @mock.should_receive(:random_call).at_most(:twice) + @mock.random_call + @mock.rspec_verify + end + + it "should pass when at most twice method is called twice" do + @mock.should_receive(:random_call).at_most(:twice) + @mock.random_call + @mock.random_call + @mock.rspec_verify + end + + it "should pass when at most twice method is never called" do + @mock.should_receive(:random_call).at_most(:twice) + @mock.rspec_verify + end + end + end +end diff --git a/vendor/plugins/rspec/spec/spec/mocks/bug_report_10260_spec.rb b/vendor/plugins/rspec/spec/spec/mocks/bug_report_10260_spec.rb new file mode 100644 index 000000000..2f7b5803d --- /dev/null +++ b/vendor/plugins/rspec/spec/spec/mocks/bug_report_10260_spec.rb @@ -0,0 +1,8 @@ +require File.dirname(__FILE__) + '/../../spec_helper.rb' + +describe "An RSpec Mock" do + it "should hide internals in its inspect representation" do + m = mock('cup') + m.inspect.should =~ /#<Spec::Mocks::Mock:0x[a-f0-9.]+ @name="cup">/ + end +end diff --git a/vendor/plugins/rspec/spec/spec/mocks/bug_report_11545_spec.rb b/vendor/plugins/rspec/spec/spec/mocks/bug_report_11545_spec.rb new file mode 100644 index 000000000..8a334afa5 --- /dev/null +++ b/vendor/plugins/rspec/spec/spec/mocks/bug_report_11545_spec.rb @@ -0,0 +1,31 @@ +require File.dirname(__FILE__) + '/../../spec_helper.rb' + +class LiarLiarPantsOnFire + def respond_to?(sym) + true + end + + def self.respond_to?(sym) + true + end +end + +describe 'should_receive' do + before(:each) do + @liar = LiarLiarPantsOnFire.new + end + + it "should work when object lies about responding to a method" do + @liar.should_receive(:something) + @liar.something + end + + it 'should work when class lies about responding to a method' do + LiarLiarPantsOnFire.should_receive(:something) + LiarLiarPantsOnFire.something + end + + it 'should cleanup after itself' do + LiarLiarPantsOnFire.metaclass.instance_methods.should_not include("something") + end +end diff --git a/vendor/plugins/rspec/spec/spec/mocks/bug_report_7611_spec.rb b/vendor/plugins/rspec/spec/spec/mocks/bug_report_7611_spec.rb new file mode 100644 index 000000000..6c9705bcc --- /dev/null +++ b/vendor/plugins/rspec/spec/spec/mocks/bug_report_7611_spec.rb @@ -0,0 +1,19 @@ +require File.dirname(__FILE__) + '/../../spec_helper.rb' + +module Bug7611 + class Foo + end + + class Bar < Foo + end + + describe "A Partial Mock" do + it "should respect subclasses" do + Foo.stub!(:new).and_return(Object.new) + end + + it "should" do + Bar.new.class.should == Bar + end + end +end diff --git a/vendor/plugins/rspec/spec/spec/mocks/bug_report_7805_spec.rb b/vendor/plugins/rspec/spec/spec/mocks/bug_report_7805_spec.rb new file mode 100644 index 000000000..f7edfac17 --- /dev/null +++ b/vendor/plugins/rspec/spec/spec/mocks/bug_report_7805_spec.rb @@ -0,0 +1,22 @@ +require File.dirname(__FILE__) + '/../../spec_helper.rb' + +module Bug7805 + #This is really a duplicate of 8302 + + describe "Stubs should correctly restore module methods" do + it "1 - stub the open method" do + File.stub!(:open).and_return("something") + File.open.should == "something" + end + it "2 - use File.open to create example.txt" do + filename = "#{File.dirname(__FILE__)}/example-#{Time.new.to_i}.txt" + File.exist?(filename).should be_false + file = File.open(filename,'w') + file.close + File.exist?(filename).should be_true + File.delete(filename) + File.exist?(filename).should be_false + end + end + +end diff --git a/vendor/plugins/rspec/spec/spec/mocks/bug_report_8165_spec.rb b/vendor/plugins/rspec/spec/spec/mocks/bug_report_8165_spec.rb new file mode 100644 index 000000000..785546dca --- /dev/null +++ b/vendor/plugins/rspec/spec/spec/mocks/bug_report_8165_spec.rb @@ -0,0 +1,31 @@ +require File.dirname(__FILE__) + '/../../spec_helper.rb' + +describe "An object where respond_to? is true and does not have method" do + # When should_receive(:sym) is sent to any object, the Proxy sends + # respond_to?(:sym) to that object to see if the method should be proxied. + # + # If respond_to? itself is proxied, then when the Proxy sends respond_to? + # to the object, the proxy is invoked and responds yes (if so set in the spec). + # When the object does NOT actually respond to :sym, an exception is thrown + # when trying to proxy it. + # + # The fix was to keep track of whether :respond_to? had been proxied and, if + # so, call the munged copy of :respond_to? on the object. + + it "should not raise an exception" do + obj = Object.new + obj.should_receive(:respond_to?).with(:foobar).and_return(true) + obj.should_receive(:foobar).and_return(:baz) + obj.respond_to?(:foobar).should be_true + obj.foobar.should == :baz + end + + it "should not raise an exception" do + obj = mock("obj") + obj.should_receive(:respond_to?).with(:foobar).and_return(true) + obj.should_receive(:foobar).and_return(:baz) + obj.respond_to?(:foobar).should be_true + obj.foobar.should == :baz + end + +end diff --git a/vendor/plugins/rspec/spec/spec/mocks/bug_report_8302_spec.rb b/vendor/plugins/rspec/spec/spec/mocks/bug_report_8302_spec.rb new file mode 100644 index 000000000..a41df43d8 --- /dev/null +++ b/vendor/plugins/rspec/spec/spec/mocks/bug_report_8302_spec.rb @@ -0,0 +1,26 @@ +require File.dirname(__FILE__) + '/../../spec_helper.rb' + +module Bug8302 + class Foo + def Foo.class_method(arg) + end + + def instance_bar(arg) + end + end + + describe "Bug report 8302:" do + it "class method is not restored correctly when proxied" do + Foo.should_not_receive(:class_method).with(Array.new) + Foo.rspec_verify + Foo.class_method(Array.new) + end + + it "instance method is not restored correctly when proxied" do + foo = Foo.new + foo.should_not_receive(:instance_bar).with(Array.new) + foo.rspec_verify + foo.instance_bar(Array.new) + end + end +end diff --git a/vendor/plugins/rspec/spec/spec/mocks/failing_mock_argument_constraints_spec.rb b/vendor/plugins/rspec/spec/spec/mocks/failing_mock_argument_constraints_spec.rb new file mode 100644 index 000000000..f3c396283 --- /dev/null +++ b/vendor/plugins/rspec/spec/spec/mocks/failing_mock_argument_constraints_spec.rb @@ -0,0 +1,114 @@ +require File.dirname(__FILE__) + '/../../spec_helper.rb' + +module Spec + module Mocks + describe "failing MockArgumentConstraints" do + before(:each) do + @mock = mock("test mock") + @reporter = Mock.new("reporter", :null_object => true) + end + + after(:each) do + @mock.rspec_reset + end + + it "should reject non boolean" do + @mock.should_receive(:random_call).with(boolean()) + lambda do + @mock.random_call("false") + end.should raise_error(MockExpectationError) + end + + it "should reject non numeric" do + @mock.should_receive(:random_call).with(an_instance_of(Numeric)) + lambda do + @mock.random_call("1") + end.should raise_error(MockExpectationError) + end + + it "should reject non string" do + @mock.should_receive(:random_call).with(an_instance_of(String)) + lambda do + @mock.random_call(123) + end.should raise_error(MockExpectationError) + end + + it "should reject goose when expecting a duck" do + @mock.should_receive(:random_call).with(duck_type(:abs, :div)) + lambda { @mock.random_call("I don't respond to :abs or :div") }.should raise_error(MockExpectationError) + end + + it "should fail if regexp does not match submitted string" do + @mock.should_receive(:random_call).with(/bcd/) + lambda { @mock.random_call("abc") }.should raise_error(MockExpectationError) + end + + it "should fail if regexp does not match submitted regexp" do + @mock.should_receive(:random_call).with(/bcd/) + lambda { @mock.random_call(/bcde/) }.should raise_error(MockExpectationError) + end + + it "should fail for a hash w/ wrong values" do + @mock.should_receive(:random_call).with(:a => "b", :c => "d") + lambda do + @mock.random_call(:a => "b", :c => "e") + end.should raise_error(MockExpectationError, /Mock 'test mock' expected :random_call with \(\{(:a=>\"b\", :c=>\"d\"|:c=>\"d\", :a=>\"b\")\}\) but received it with \(\{(:a=>\"b\", :c=>\"e\"|:c=>\"e\", :a=>\"b\")\}\)/) + end + + it "should fail for a hash w/ wrong keys" do + @mock.should_receive(:random_call).with(:a => "b", :c => "d") + lambda do + @mock.random_call("a" => "b", "c" => "d") + end.should raise_error(MockExpectationError, /Mock 'test mock' expected :random_call with \(\{(:a=>\"b\", :c=>\"d\"|:c=>\"d\", :a=>\"b\")\}\) but received it with \(\{(\"a\"=>\"b\", \"c\"=>\"d\"|\"c\"=>\"d\", \"a\"=>\"b\")\}\)/) + end + + it "should match against a Matcher" do + lambda do + @mock.should_receive(:msg).with(equal(3)) + @mock.msg(37) + end.should raise_error(MockExpectationError, "Mock 'test mock' expected :msg with (equal 3) but received it with (37)") + end + + it "should fail no_args with one arg" do + lambda do + @mock.should_receive(:msg).with(no_args) + @mock.msg(37) + end.should raise_error(MockExpectationError, "Mock 'test mock' expected :msg with (no args) but received it with (37)") + end + end + + describe "failing deprecated MockArgumentConstraints" do + before(:each) do + @mock = mock("test mock") + @reporter = Mock.new("reporter", :null_object => true) + end + + after(:each) do + @mock.rspec_reset + end + + it "should reject non boolean" do + @mock.should_receive(:random_call).with(:boolean) + lambda do + @mock.random_call("false") + end.should raise_error(MockExpectationError) + end + + it "should reject non numeric" do + @mock.should_receive(:random_call).with(:numeric) + lambda do + @mock.random_call("1") + end.should raise_error(MockExpectationError) + end + + it "should reject non string" do + @mock.should_receive(:random_call).with(:string) + lambda do + @mock.random_call(123) + end.should raise_error(MockExpectationError) + end + + + end + end +end diff --git a/vendor/plugins/rspec/spec/spec/mocks/mock_ordering_spec.rb b/vendor/plugins/rspec/spec/spec/mocks/mock_ordering_spec.rb new file mode 100644 index 000000000..919da2970 --- /dev/null +++ b/vendor/plugins/rspec/spec/spec/mocks/mock_ordering_spec.rb @@ -0,0 +1,84 @@ +require File.dirname(__FILE__) + '/../../spec_helper' + +module Spec + module Mocks + + describe "Mock ordering" do + + before do + @mock = mock("test mock") + end + + after do + @mock.rspec_reset + end + + it "should pass two calls in order" do + @mock.should_receive(:one).ordered + @mock.should_receive(:two).ordered + @mock.one + @mock.two + @mock.rspec_verify + end + + it "should pass three calls in order" do + @mock.should_receive(:one).ordered + @mock.should_receive(:two).ordered + @mock.should_receive(:three).ordered + @mock.one + @mock.two + @mock.three + @mock.rspec_verify + end + + it "should fail if second call comes first" do + @mock.should_receive(:one).ordered + @mock.should_receive(:two).ordered + lambda do + @mock.two + end.should raise_error(MockExpectationError, "Mock 'test mock' received :two out of order") + end + + it "should fail if third call comes first" do + @mock.should_receive(:one).ordered + @mock.should_receive(:two).ordered + @mock.should_receive(:three).ordered + @mock.one + lambda do + @mock.three + end.should raise_error(MockExpectationError, "Mock 'test mock' received :three out of order") + end + + it "should fail if third call comes second" do + @mock.should_receive(:one).ordered + @mock.should_receive(:two).ordered + @mock.should_receive(:three).ordered + @mock.one + lambda do + @mock.three + end.should raise_error(MockExpectationError, "Mock 'test mock' received :three out of order") + end + + it "should ignore order of non ordered calls" do + @mock.should_receive(:ignored_0) + @mock.should_receive(:ordered_1).ordered + @mock.should_receive(:ignored_1) + @mock.should_receive(:ordered_2).ordered + @mock.should_receive(:ignored_2) + @mock.should_receive(:ignored_3) + @mock.should_receive(:ordered_3).ordered + @mock.should_receive(:ignored_4) + @mock.ignored_3 + @mock.ordered_1 + @mock.ignored_0 + @mock.ordered_2 + @mock.ignored_4 + @mock.ignored_2 + @mock.ordered_3 + @mock.ignored_1 + @mock.rspec_verify + end + + end + end +end diff --git a/vendor/plugins/rspec/spec/spec/mocks/mock_space_spec.rb b/vendor/plugins/rspec/spec/spec/mocks/mock_space_spec.rb new file mode 100644 index 000000000..23ffd01bc --- /dev/null +++ b/vendor/plugins/rspec/spec/spec/mocks/mock_space_spec.rb @@ -0,0 +1,54 @@ +require File.dirname(__FILE__) + '/../../spec_helper.rb' +require 'spec/mocks' + +module Spec + module Mocks + describe Space do + before :each do + @space = Space.new + klazz = Class.new do + def rspec_verify + @verified = true + end + def verified? + @verified + end + def rspec_reset + @reset = true + end + def reset? + @reset + end + end + @m1 = klazz.new + @m2 = klazz.new + end + it "should verify all mocks within" do + @space.add(@m1) + @space.add(@m2) + @space.verify_all + @m1.should be_verified + @m2.should be_verified + end + it "should reset all mocks within" do + @space.add(m1 = mock("mock1")) + @space.add(m2 = mock("mock2")) + m1.should_receive(:rspec_reset) + m2.should_receive(:rspec_reset) + @space.reset_all + end + it "should clear internal mocks on reset_all" do + @space.add(m = mock("mock")) + @space.reset_all + @space.instance_eval { mocks.empty? }.should be_true + end + it "should only add an instance once" do + @space.add(m1 = mock("mock1")) + @space.add(m1) + m1.should_receive(:rspec_verify) + @space.verify_all + end + end + end +end + diff --git a/vendor/plugins/rspec/spec/spec/mocks/mock_spec.rb b/vendor/plugins/rspec/spec/spec/mocks/mock_spec.rb new file mode 100644 index 000000000..bfe36ed57 --- /dev/null +++ b/vendor/plugins/rspec/spec/spec/mocks/mock_spec.rb @@ -0,0 +1,377 @@ +require File.dirname(__FILE__) + '/../../spec_helper' + +module Spec + module Mocks + describe "a Mock expectation" do + + before do + @mock = mock("test mock") + end + + after do + @mock.rspec_reset + end + + it "should report line number of expectation of unreceived message" do + @mock.should_receive(:wont_happen).with("x", 3) + #NOTE - this test is quite ticklish because it specifies that + #the above statement appears on line 12 of this file. + + begin + @mock.rspec_verify + violated + rescue MockExpectationError => e + e.backtrace[0].should match(/mock_spec\.rb:16/) + end + + end + + it "should pass when not receiving message specified as not to be received" do + @mock.should_not_receive(:not_expected) + @mock.rspec_verify + end + + it "should pass when receiving message specified as not to be received with different args" do + @mock.should_not_receive(:message).with("unwanted text") + @mock.should_receive(:message).with("other text") + @mock.message "other text" + @mock.rspec_verify + end + + it "should fail when receiving message specified as not to be received" do + @mock.should_not_receive(:not_expected) + @mock.not_expected + begin + @mock.rspec_verify + violated + rescue MockExpectationError => e + e.message.should == "Mock 'test mock' expected :not_expected with (any args) 0 times, but received it once" + end + end + + it "should fail when receiving message specified as not to be received with args" do + @mock.should_not_receive(:not_expected).with("unexpected text") + @mock.not_expected("unexpected text") + begin + @mock.rspec_verify + violated + rescue MockExpectationError => e + e.message.should == "Mock 'test mock' expected :not_expected with (\"unexpected text\") 0 times, but received it once" + end + end + + it "should pass when receiving message specified as not to be received with wrong args" do + @mock.should_not_receive(:not_expected).with("unexpected text") + @mock.not_expected "really unexpected text" + @mock.rspec_verify + end + + it "should allow block to calculate return values" do + @mock.should_receive(:something).with("a","b","c").and_return { |a,b,c| c+b+a } + @mock.something("a","b","c").should == "cba" + @mock.rspec_verify + end + + it "should allow parameter as return value" do + @mock.should_receive(:something).with("a","b","c").and_return("booh") + @mock.something("a","b","c").should == "booh" + @mock.rspec_verify + end + + it "should return nil if no return value set" do + @mock.should_receive(:something).with("a","b","c") + @mock.something("a","b","c").should be_nil + @mock.rspec_verify + end + + it "should raise exception if args dont match when method called" do + @mock.should_receive(:something).with("a","b","c").and_return("booh") + begin + @mock.something("a","d","c") + violated + rescue MockExpectationError => e + e.message.should == "Mock 'test mock' expected :something with (\"a\", \"b\", \"c\") but received it with (\"a\", \"d\", \"c\")" + end + end + + it "should fail if unexpected method called" do + begin + @mock.something("a","b","c") + violated + rescue MockExpectationError => e + e.message.should == "Mock 'test mock' received unexpected message :something with (\"a\", \"b\", \"c\")" + end + end + + it "should use block for expectation if provided" do + @mock.should_receive(:something) do | a, b | + a.should == "a" + b.should == "b" + "booh" + end + @mock.something("a", "b").should == "booh" + @mock.rspec_verify + end + + it "should fail if expectation block fails" do + @mock.should_receive(:something) {| bool | bool.should be_true} + begin + @mock.something false + rescue MockExpectationError => e + e.message.should match(/Mock 'test mock' received :something but passed block failed with: expected true, got false/) + end + end + + it "should fail when method defined as never is received" do + @mock.should_receive(:not_expected).never + begin + @mock.not_expected + rescue MockExpectationError => e + e.message.should == "Mock 'test mock' expected :not_expected 0 times, but received it 1 times" + end + end + + it "should raise when told to" do + @mock.should_receive(:something).and_raise(RuntimeError) + lambda do + @mock.something + end.should raise_error(RuntimeError) + end + + it "should raise passed an Exception instance" do + error = RuntimeError.new("error message") + @mock.should_receive(:something).and_raise(error) + begin + @mock.something + rescue RuntimeError => e + e.message.should eql("error message") + end + end + + it "should raise RuntimeError with passed message" do + @mock.should_receive(:something).and_raise("error message") + begin + @mock.something + rescue RuntimeError => e + e.message.should eql("error message") + end + end + + it "should not raise when told to if args dont match" do + @mock.should_receive(:something).with(2).and_raise(RuntimeError) + lambda do + @mock.something 1 + end.should raise_error(MockExpectationError) + end + + it "should throw when told to" do + @mock.should_receive(:something).and_throw(:blech) + lambda do + @mock.something + end.should throw_symbol(:blech) + end + + it "should raise when explicit return and block constrained" do + lambda do + @mock.should_receive(:fruit) do |colour| + :strawberry + end.and_return :apple + end.should raise_error(AmbiguousReturnError) + end + + it "should ignore args on any args" do + @mock.should_receive(:something).at_least(:once).with(any_args) + @mock.something + @mock.something 1 + @mock.something "a", 2 + @mock.something [], {}, "joe", 7 + @mock.rspec_verify + end + + it "should fail on no args if any args received" do + @mock.should_receive(:something).with(no_args()) + begin + @mock.something 1 + rescue MockExpectationError => e + e.message.should == "Mock 'test mock' expected :something with (no args) but received it with (1)" + end + end + + it "should fail when args are expected but none are received" do + @mock.should_receive(:something).with(1) + begin + @mock.something + rescue MockExpectationError => e + e.message.should == "Mock 'test mock' expected :something with (1) but received it with (no args)" + end + end + + it "should yield 0 args to blocks that take a variable number of arguments" do + @mock.should_receive(:yield_back).with(no_args()).once.and_yield + a = nil + @mock.yield_back {|*a|} + a.should == [] + @mock.rspec_verify + end + + it "should yield one arg to blocks that take a variable number of arguments" do + @mock.should_receive(:yield_back).with(no_args()).once.and_yield(99) + a = nil + @mock.yield_back {|*a|} + a.should == [99] + @mock.rspec_verify + end + + it "should yield many args to blocks that take a variable number of arguments" do + @mock.should_receive(:yield_back).with(no_args()).once.and_yield(99, 27, "go") + a = nil + @mock.yield_back {|*a|} + a.should == [99, 27, "go"] + @mock.rspec_verify + end + + it "should yield single value" do + @mock.should_receive(:yield_back).with(no_args()).once.and_yield(99) + a = nil + @mock.yield_back {|a|} + a.should == 99 + @mock.rspec_verify + end + + it "should yield two values" do + @mock.should_receive(:yield_back).with(no_args()).once.and_yield('wha', 'zup') + a, b = nil + @mock.yield_back {|a,b|} + a.should == 'wha' + b.should == 'zup' + @mock.rspec_verify + end + + it "should fail when calling yielding method with wrong arity" do + @mock.should_receive(:yield_back).with(no_args()).once.and_yield('wha', 'zup') + begin + @mock.yield_back {|a|} + rescue MockExpectationError => e + e.message.should == "Mock 'test mock' yielded |\"wha\", \"zup\"| to block with arity of 1" + end + end + + it "should fail when calling yielding method without block" do + @mock.should_receive(:yield_back).with(no_args()).once.and_yield('wha', 'zup') + begin + @mock.yield_back + rescue MockExpectationError => e + e.message.should == "Mock 'test mock' asked to yield |\"wha\", \"zup\"| but no block was passed" + end + end + + it "should be able to mock send" do + @mock.should_receive(:send).with(any_args) + @mock.send 'hi' + @mock.rspec_verify + end + + it "should be able to raise from method calling yielding mock" do + @mock.should_receive(:yield_me).and_yield 44 + + lambda do + @mock.yield_me do |x| + raise "Bang" + end + end.should raise_error(StandardError) + + @mock.rspec_verify + end + + # TODO - this is failing, but not if you run the file w/ --reverse - weird!!!!!! + # specify "should clear expectations after verify" do + # @mock.should_receive(:foobar) + # @mock.foobar + # @mock.rspec_verify + # begin + # @mock.foobar + # rescue MockExpectationError => e + # e.message.should == "Mock 'test mock' received unexpected message :foobar with (no args)" + # end + # end + + it "should restore objects to their original state on rspec_reset" do + mock = mock("this is a mock") + mock.should_receive(:blah) + mock.rspec_reset + mock.rspec_verify #should throw if reset didn't work + end + + end + + describe "a mock message receiving a block" do + before(:each) do + @mock = mock("mock") + @calls = 0 + end + + def add_call + @calls = @calls + 1 + end + + it "should call the block after #should_receive" do + @mock.should_receive(:foo) { add_call } + + @mock.foo + + @calls.should == 1 + end + + it "should call the block after #once" do + @mock.should_receive(:foo).once { add_call } + + @mock.foo + + @calls.should == 1 + end + + it "should call the block after #twice" do + @mock.should_receive(:foo).twice { add_call } + + @mock.foo + @mock.foo + + @calls.should == 2 + end + + it "should call the block after #times" do + @mock.should_receive(:foo).exactly(10).times { add_call } + + (1..10).each { @mock.foo } + + @calls.should == 10 + end + + it "should call the block after #any_number_of_times" do + @mock.should_receive(:foo).any_number_of_times { add_call } + + (1..7).each { @mock.foo } + + @calls.should == 7 + end + + it "should call the block after #with" do + @mock.should_receive(:foo).with(:arg) { add_call } + + @mock.foo(:arg) + + @calls.should == 1 + end + + it "should call the block after #ordered" do + @mock.should_receive(:foo).ordered { add_call } + @mock.should_receive(:bar).ordered { add_call } + + @mock.foo + @mock.bar + + @calls.should == 2 + end + end + end +end diff --git a/vendor/plugins/rspec/spec/spec/mocks/multiple_return_value_spec.rb b/vendor/plugins/rspec/spec/spec/mocks/multiple_return_value_spec.rb new file mode 100644 index 000000000..6e082abba --- /dev/null +++ b/vendor/plugins/rspec/spec/spec/mocks/multiple_return_value_spec.rb @@ -0,0 +1,113 @@ +require File.dirname(__FILE__) + '/../../spec_helper' + +module Spec + module Mocks + describe "a Mock expectation with multiple return values and no specified count" do + before(:each) do + @mock = Mock.new("mock") + @return_values = ["1",2,Object.new] + @mock.should_receive(:message).and_return(@return_values[0],@return_values[1],@return_values[2]) + end + + it "should return values in order to consecutive calls" do + @mock.message.should == @return_values[0] + @mock.message.should == @return_values[1] + @mock.message.should == @return_values[2] + @mock.rspec_verify + end + + it "should complain when there are too few calls" do + third = Object.new + @mock.message.should == @return_values[0] + @mock.message.should == @return_values[1] + lambda { @mock.rspec_verify }.should raise_error(MockExpectationError, "Mock 'mock' expected :message with (any args) 3 times, but received it twice") + end + + it "should complain when there are too many calls" do + third = Object.new + @mock.message.should == @return_values[0] + @mock.message.should == @return_values[1] + @mock.message.should == @return_values[2] + @mock.message.should == @return_values[2] + lambda { @mock.rspec_verify }.should raise_error(MockExpectationError, "Mock 'mock' expected :message with (any args) 3 times, but received it 4 times") + end + end + + describe "a Mock expectation with multiple return values with a specified count equal to the number of values" do + before(:each) do + @mock = Mock.new("mock") + @return_values = ["1",2,Object.new] + @mock.should_receive(:message).exactly(3).times.and_return(@return_values[0],@return_values[1],@return_values[2]) + end + + it "should return values in order to consecutive calls" do + @mock.message.should == @return_values[0] + @mock.message.should == @return_values[1] + @mock.message.should == @return_values[2] + @mock.rspec_verify + end + + it "should complain when there are too few calls" do + third = Object.new + @mock.message.should == @return_values[0] + @mock.message.should == @return_values[1] + lambda { @mock.rspec_verify }.should raise_error(MockExpectationError, "Mock 'mock' expected :message with (any args) 3 times, but received it twice") + end + + it "should complain when there are too many calls" do + third = Object.new + @mock.message.should == @return_values[0] + @mock.message.should == @return_values[1] + @mock.message.should == @return_values[2] + @mock.message.should == @return_values[2] + lambda { @mock.rspec_verify }.should raise_error(MockExpectationError, "Mock 'mock' expected :message with (any args) 3 times, but received it 4 times") + end + end + + describe "a Mock expectation with multiple return values specifying at_least less than the number of values" do + before(:each) do + @mock = Mock.new("mock") + @mock.should_receive(:message).at_least(:twice).with(:no_args).and_return(11, 22) + end + + it "should use last return value for subsequent calls" do + @mock.message.should equal(11) + @mock.message.should equal(22) + @mock.message.should equal(22) + @mock.rspec_verify + end + + it "should fail when called less than the specified number" do + @mock.message.should equal(11) + lambda { @mock.rspec_verify }.should raise_error(MockExpectationError, "Mock 'mock' expected :message with (no args) twice, but received it once") + end + end + describe "a Mock expectation with multiple return values with a specified count larger than the number of values" do + before(:each) do + @mock = Mock.new("mock") + @mock.should_receive(:message).exactly(3).times.and_return(11, 22) + end + + it "should use last return value for subsequent calls" do + @mock.message.should equal(11) + @mock.message.should equal(22) + @mock.message.should equal(22) + @mock.rspec_verify + end + + it "should fail when called less than the specified number" do + @mock.message.should equal(11) + lambda { @mock.rspec_verify }.should raise_error(MockExpectationError, "Mock 'mock' expected :message with (any args) 3 times, but received it once") + end + + it "should fail when called greater than the specified number" do + @mock.message.should equal(11) + @mock.message.should equal(22) + @mock.message.should equal(22) + @mock.message.should equal(22) + lambda { @mock.rspec_verify }.should raise_error(MockExpectationError, "Mock 'mock' expected :message with (any args) 3 times, but received it 4 times") + end + end + end +end + diff --git a/vendor/plugins/rspec/spec/spec/mocks/null_object_mock_spec.rb b/vendor/plugins/rspec/spec/spec/mocks/null_object_mock_spec.rb new file mode 100644 index 000000000..57e8ca31c --- /dev/null +++ b/vendor/plugins/rspec/spec/spec/mocks/null_object_mock_spec.rb @@ -0,0 +1,40 @@ +require File.dirname(__FILE__) + '/../../spec_helper.rb' + +module Spec + module Mocks + describe "a mock acting as a NullObject" do + before(:each) do + @mock = Mock.new("null_object", :null_object => true) + end + + it "should allow explicit expectation" do + @mock.should_receive(:something) + @mock.something + end + + it "should fail verification when explicit exception not met" do + lambda do + @mock.should_receive(:something) + @mock.rspec_verify + end.should raise_error(MockExpectationError) + end + + it "should ignore unexpected methods" do + @mock.random_call("a", "d", "c") + @mock.rspec_verify + end + + it "should expected message with different args first" do + @mock.should_receive(:message).with(:expected_arg) + @mock.message(:unexpected_arg) + @mock.message(:expected_arg) + end + + it "should expected message with different args second" do + @mock.should_receive(:message).with(:expected_arg) + @mock.message(:expected_arg) + @mock.message(:unexpected_arg) + end + end + end +end diff --git a/vendor/plugins/rspec/spec/spec/mocks/once_counts_spec.rb b/vendor/plugins/rspec/spec/spec/mocks/once_counts_spec.rb new file mode 100644 index 000000000..2c15d5c2e --- /dev/null +++ b/vendor/plugins/rspec/spec/spec/mocks/once_counts_spec.rb @@ -0,0 +1,53 @@ +require File.dirname(__FILE__) + '/../../spec_helper.rb' + +module Spec + module Mocks + describe "OnceCounts" do + before(:each) do + @mock = mock("test mock") + end + + it "once should fail when called once with wrong args" do + @mock.should_receive(:random_call).once.with("a", "b", "c") + lambda do + @mock.random_call("d", "e", "f") + end.should raise_error(MockExpectationError) + @mock.rspec_reset + end + + it "once should fail when called twice" do + @mock.should_receive(:random_call).once + @mock.random_call + @mock.random_call + lambda do + @mock.rspec_verify + end.should raise_error(MockExpectationError) + end + + it "once should fail when not called" do + @mock.should_receive(:random_call).once + lambda do + @mock.rspec_verify + end.should raise_error(MockExpectationError) + end + + it "once should pass when called once" do + @mock.should_receive(:random_call).once + @mock.random_call + @mock.rspec_verify + end + + it "once should pass when called once with specified args" do + @mock.should_receive(:random_call).once.with("a", "b", "c") + @mock.random_call("a", "b", "c") + @mock.rspec_verify + end + + it "once should pass when called once with unspecified args" do + @mock.should_receive(:random_call).once + @mock.random_call("a", "b", "c") + @mock.rspec_verify + end + end + end +end diff --git a/vendor/plugins/rspec/spec/spec/mocks/options_hash_spec.rb b/vendor/plugins/rspec/spec/spec/mocks/options_hash_spec.rb new file mode 100644 index 000000000..a1ec9ddf4 --- /dev/null +++ b/vendor/plugins/rspec/spec/spec/mocks/options_hash_spec.rb @@ -0,0 +1,33 @@ +require File.dirname(__FILE__) + '/../../spec_helper.rb' + +module Spec + module Mocks + describe "calling :should_receive with an options hash" do + it "should report the file and line submitted with :expected_from" do + spec = Spec::DSL::Example.new "spec" do + mock = Spec::Mocks::Mock.new("a mock") + mock.should_receive(:message, :expected_from => "/path/to/blah.ext:37") + mock.rspec_verify + end + reporter = mock("reporter", :null_object => true) + reporter.should_receive(:example_finished) do |spec, error| + error.backtrace.detect {|line| line =~ /\/path\/to\/blah.ext:37/}.should_not be_nil + end + spec.run(reporter, nil, nil, nil, Object.new) + end + + it "should use the message supplied with :message" do + spec = Spec::DSL::Example.new "spec" do + mock = Spec::Mocks::Mock.new("a mock") + mock.should_receive(:message, :message => "recebi nada") + mock.rspec_verify + end + reporter = mock("reporter", :null_object => true) + reporter.should_receive(:example_finished) do |spec, error| + error.message.should == "recebi nada" + end + spec.run(reporter, nil, nil, nil, Object.new) + end + end + end +end diff --git a/vendor/plugins/rspec/spec/spec/mocks/partial_mock_spec.rb b/vendor/plugins/rspec/spec/spec/mocks/partial_mock_spec.rb new file mode 100644 index 000000000..c45b9054c --- /dev/null +++ b/vendor/plugins/rspec/spec/spec/mocks/partial_mock_spec.rb @@ -0,0 +1,84 @@ +require File.dirname(__FILE__) + '/../../spec_helper.rb' + +module Spec + module Mocks + describe "using a Partial Mock," do + before(:each) do + @object = Object.new + end + + it "should name the class in the failure message" do + @object.should_receive(:foo) + lambda do + @object.rspec_verify + end.should raise_error(Spec::Mocks::MockExpectationError, /Object/) + end + + it "should not conflict with @options in the object" do + @object.instance_eval { @options = Object.new } + @object.should_receive(:blah) + @object.blah + end + + it "should_not_receive should mock out the method" do + @object.should_not_receive(:fuhbar) + @object.fuhbar + lambda do + @object.rspec_verify + end.should raise_error(Spec::Mocks::MockExpectationError) + end + + it "should_not_receive should return a negative message expectation" do + @object.should_not_receive(:foobar).should be_kind_of(NegativeMessageExpectation) + end + + it "should_receive should mock out the method" do + @object.should_receive(:foobar).with(:test_param).and_return(1) + @object.foobar(:test_param).should equal(1) + end + + it "should_receive should handle a hash" do + @object.should_receive(:foobar).with(:key => "value").and_return(1) + @object.foobar(:key => "value").should equal(1) + end + + it "should_receive should handle an inner hash" do + hash = {:a => {:key => "value"}} + @object.should_receive(:foobar).with(:key => "value").and_return(1) + @object.foobar(hash[:a]).should equal(1) + end + + it "should_receive should return a message expectation" do + @object.should_receive(:foobar).should be_kind_of(MessageExpectation) + @object.foobar + end + + it "should_receive should verify method was called" do + @object.should_receive(:foobar).with(:test_param).and_return(1) + lambda do + @object.rspec_verify + end.should raise_error(Spec::Mocks::MockExpectationError) + end + + it "should_receive should also take a String argument" do + @object.should_receive('foobar') + @object.foobar + end + + it "should_not_receive should also take a String argument" do + @object.should_not_receive('foobar') + @object.foobar + lambda do + @object.rspec_verify + end.should raise_error(Spec::Mocks::MockExpectationError) + end + + it "should use report nil in the error message" do + @this_will_resolve_to_nil.should_receive(:foobar) + lambda do + @this_will_resolve_to_nil.rspec_verify + end.should raise_error(Spec::Mocks::MockExpectationError, /NilClass.*expected :foobar with/) + end + end + end +end diff --git a/vendor/plugins/rspec/spec/spec/mocks/partial_mock_using_mocks_directly_spec.rb b/vendor/plugins/rspec/spec/spec/mocks/partial_mock_using_mocks_directly_spec.rb new file mode 100644 index 000000000..c857d8380 --- /dev/null +++ b/vendor/plugins/rspec/spec/spec/mocks/partial_mock_using_mocks_directly_spec.rb @@ -0,0 +1,66 @@ +require File.dirname(__FILE__) + '/../../spec_helper.rb' + +module Spec +module Mocks +describe "PartialMockUsingMocksDirectly" do + before(:each) do + + klass=Class.new + klass.class_eval do + def existing_method + :original_value + end + end + @obj = klass.new + + end + + # See http://rubyforge.org/tracker/index.php?func=detail&aid=10263&group_id=797&atid=3149 + # specify "should clear expectations on verify" do + # @obj.should_receive(:msg) + # @obj.msg + # @obj.rspec_verify + # lambda do + # @obj.msg + # end.should raise_error(NoMethodError) + # + # end + it "should fail when expected message is not received" do + @obj.should_receive(:msg) + lambda do + @obj.rspec_verify + end.should raise_error(MockExpectationError) + + end + it "should fail when message is received with incorrect args" do + @obj.should_receive(:msg).with(:correct_arg) + lambda do + @obj.msg(:incorrect_arg) + end.should raise_error(MockExpectationError) + @obj.msg(:correct_arg) + + end + it "should pass when expected message is received" do + @obj.should_receive(:msg) + @obj.msg + @obj.rspec_verify + + end + it "should pass when message is received with correct args" do + @obj.should_receive(:msg).with(:correct_arg) + @obj.msg(:correct_arg) + @obj.rspec_verify + + end + it "should revert to original method if existed" do + @obj.existing_method.should equal(:original_value) + @obj.should_receive(:existing_method).and_return(:mock_value) + @obj.existing_method.should equal(:mock_value) + @obj.rspec_verify + @obj.existing_method.should equal(:original_value) + + end + +end +end +end diff --git a/vendor/plugins/rspec/spec/spec/mocks/passing_mock_argument_constraints_spec.rb b/vendor/plugins/rspec/spec/spec/mocks/passing_mock_argument_constraints_spec.rb new file mode 100644 index 000000000..2d631bde5 --- /dev/null +++ b/vendor/plugins/rspec/spec/spec/mocks/passing_mock_argument_constraints_spec.rb @@ -0,0 +1,148 @@ +require File.dirname(__FILE__) + '/../../spec_helper.rb' + +module Spec + module Mocks + describe "mock argument constraints", :shared => true do + before(:each) do + @mock = Mock.new("test mock") + end + + after(:each) do + @mock.rspec_verify + end + end + + describe Methods, "handling argument constraints with DEPRECATED symbols" do + it_should_behave_like "mock argument constraints" + + it "should accept true as boolean" do + @mock.should_receive(:random_call).with(:boolean) + @mock.random_call(true) + end + + it "should accept false as boolean" do + @mock.should_receive(:random_call).with(:boolean) + @mock.random_call(false) + end + + it "should accept fixnum as numeric" do + @mock.should_receive(:random_call).with(:numeric) + @mock.random_call(1) + end + + it "should accept float as numeric" do + @mock.should_receive(:random_call).with(:numeric) + @mock.random_call(1.5) + end + + it "should accept string as anything" do + @mock.should_receive(:random_call).with("a", :anything, "c") + @mock.random_call("a", "whatever", "c") + end + + it "should match string" do + @mock.should_receive(:random_call).with(:string) + @mock.random_call("a string") + end + + it "should match no args against any_args" do + @mock.should_receive(:random_call).with(:any_args) + @mock.random_call("a string") + end + end + + describe Methods, "handling argument constraints" do + it_should_behave_like "mock argument constraints" + + it "should accept true as boolean()" do + @mock.should_receive(:random_call).with(boolean()) + @mock.random_call(true) + end + + it "should accept false as boolean()" do + @mock.should_receive(:random_call).with(boolean()) + @mock.random_call(false) + end + + it "should accept fixnum as an_instance_of(Numeric)" do + @mock.should_receive(:random_call).with(an_instance_of(Numeric)) + @mock.random_call(1) + end + + it "should accept float as an_instance_of(Numeric)" do + @mock.should_receive(:random_call).with(an_instance_of(Numeric)) + @mock.random_call(1.5) + end + + it "should accept string as anything()" do + @mock.should_receive(:random_call).with("a", anything(), "c") + @mock.random_call("a", "whatever", "c") + end + + it "should match duck type with one method" do + @mock.should_receive(:random_call).with(duck_type(:length)) + @mock.random_call([]) + end + + it "should match duck type with two methods" do + @mock.should_receive(:random_call).with(duck_type(:abs, :div)) + @mock.random_call(1) + end + + it "should match no args against any_args()" do + @mock.should_receive(:random_call).with(any_args) + @mock.random_call() + end + + it "should match one arg against any_args()" do + @mock.should_receive(:random_call).with(any_args) + @mock.random_call("a string") + end + + it "should match no args against no_args()" do + @mock.should_receive(:random_call).with(no_args) + @mock.random_call() + end + end + + describe Methods, "handling non-constraint arguments" do + + it "should match non special symbol (can be removed when deprecated symbols are removed)" do + @mock.should_receive(:random_call).with(:some_symbol) + @mock.random_call(:some_symbol) + end + + it "should match string against regexp" do + @mock.should_receive(:random_call).with(/bcd/) + @mock.random_call("abcde") + end + + it "should match regexp against regexp" do + @mock.should_receive(:random_call).with(/bcd/) + @mock.random_call(/bcd/) + end + + it "should match against a hash submitted and received by value" do + @mock.should_receive(:random_call).with(:a => "a", :b => "b") + @mock.random_call(:a => "a", :b => "b") + end + + it "should match against a hash submitted by reference and received by value" do + opts = {:a => "a", :b => "b"} + @mock.should_receive(:random_call).with(opts) + @mock.random_call(:a => "a", :b => "b") + end + + it "should match against a hash submitted by value and received by reference" do + opts = {:a => "a", :b => "b"} + @mock.should_receive(:random_call).with(:a => "a", :b => "b") + @mock.random_call(opts) + end + + it "should match against a Matcher" do + @mock.should_receive(:msg).with(equal(37)) + @mock.msg(37) + end + end + end +end diff --git a/vendor/plugins/rspec/spec/spec/mocks/precise_counts_spec.rb b/vendor/plugins/rspec/spec/spec/mocks/precise_counts_spec.rb new file mode 100644 index 000000000..ba3898943 --- /dev/null +++ b/vendor/plugins/rspec/spec/spec/mocks/precise_counts_spec.rb @@ -0,0 +1,52 @@ +require File.dirname(__FILE__) + '/../../spec_helper.rb' + +module Spec + module Mocks + describe "PreciseCounts" do + before(:each) do + @mock = mock("test mock") + end + + it "should fail when exactly n times method is called less than n times" do + @mock.should_receive(:random_call).exactly(3).times + @mock.random_call + @mock.random_call + lambda do + @mock.rspec_verify + end.should raise_error(MockExpectationError) + end + + it "should fail when exactly n times method is never called" do + @mock.should_receive(:random_call).exactly(3).times + lambda do + @mock.rspec_verify + end.should raise_error(MockExpectationError) + end + + it "should pass if exactly n times method is called exactly n times" do + @mock.should_receive(:random_call).exactly(3).times + @mock.random_call + @mock.random_call + @mock.random_call + @mock.rspec_verify + end + + it "should pass multiple calls with different args and counts" do + @mock.should_receive(:random_call).twice.with(1) + @mock.should_receive(:random_call).once.with(2) + @mock.random_call(1) + @mock.random_call(2) + @mock.random_call(1) + @mock.rspec_verify + end + + it "should pass mutiple calls with different args" do + @mock.should_receive(:random_call).once.with(1) + @mock.should_receive(:random_call).once.with(2) + @mock.random_call(1) + @mock.random_call(2) + @mock.rspec_verify + end + end + end +end diff --git a/vendor/plugins/rspec/spec/spec/mocks/record_messages_spec.rb b/vendor/plugins/rspec/spec/spec/mocks/record_messages_spec.rb new file mode 100644 index 000000000..ec247726d --- /dev/null +++ b/vendor/plugins/rspec/spec/spec/mocks/record_messages_spec.rb @@ -0,0 +1,26 @@ +require File.dirname(__FILE__) + '/../../spec_helper' + +module Spec + module Mocks + describe "a mock" do + before(:each) do + @mock = mock("mock", :null_object => true) + end + it "should answer false for received_message? when no messages received" do + @mock.received_message?(:message).should be_false + end + it "should answer true for received_message? when message received" do + @mock.message + @mock.received_message?(:message).should be_true + end + it "should answer true for received_message? when message received with correct args" do + @mock.message 1,2,3 + @mock.received_message?(:message, 1,2,3).should be_true + end + it "should answer false for received_message? when message received with incorrect args" do + @mock.message 1,2,3 + @mock.received_message?(:message, 1,2).should be_false + end + end + end +end diff --git a/vendor/plugins/rspec/spec/spec/mocks/stub_spec.rb b/vendor/plugins/rspec/spec/spec/mocks/stub_spec.rb new file mode 100644 index 000000000..dc6fff89b --- /dev/null +++ b/vendor/plugins/rspec/spec/spec/mocks/stub_spec.rb @@ -0,0 +1,159 @@ +require File.dirname(__FILE__) + '/../../spec_helper.rb' + +module Spec + module Mocks + describe "A method stub" do + before(:each) do + @class = Class.new do + def self.existing_class_method + :original_value + end + + def existing_instance_method + :original_value + end + end + @obj = @class.new + end + + it "should allow for a mock expectation to temporarily replace a method stub on a mock" do + mock = Spec::Mocks::Mock.new("a mock") + mock.stub!(:msg).and_return(:stub_value) + mock.should_receive(:msg).with(:arg).and_return(:mock_value) + mock.msg(:arg).should equal(:mock_value) + mock.msg.should equal(:stub_value) + mock.msg.should equal(:stub_value) + mock.rspec_verify + end + + it "should allow for a mock expectation to temporarily replace a method stub on a non-mock" do + @obj.stub!(:msg).and_return(:stub_value) + @obj.should_receive(:msg).with(:arg).and_return(:mock_value) + @obj.msg(:arg).should equal(:mock_value) + @obj.msg.should equal(:stub_value) + @obj.msg.should equal(:stub_value) + @obj.rspec_verify + end + + it "should ignore when expected message is not received" do + @obj.stub!(:msg) + lambda do + @obj.rspec_verify + end.should_not raise_error + end + + it "should clear itself on rspec_verify" do + @obj.stub!(:this_should_go).and_return(:blah) + @obj.this_should_go.should == :blah + @obj.rspec_verify + lambda do + @obj.this_should_go + end.should raise_error + end + + it "should ignore when expected message is received" do + @obj.stub!(:msg) + @obj.msg + @obj.rspec_verify + end + + it "should ignore when message is received with args" do + @obj.stub!(:msg) + @obj.msg(:an_arg) + @obj.rspec_verify + end + + it "should not support with" do + lambda do + Spec::Mocks::Mock.new("a mock").stub!(:msg).with(:arg) + end.should raise_error(NoMethodError) + end + + it "should return expected value when expected message is received" do + @obj.stub!(:msg).and_return(:return_value) + @obj.msg.should equal(:return_value) + @obj.rspec_verify + end + + it "should return values in order to consecutive calls" do + return_values = ["1",2,Object.new] + @obj.stub!(:msg).and_return(return_values[0],return_values[1],return_values[2]) + @obj.msg.should == return_values[0] + @obj.msg.should == return_values[1] + @obj.msg.should == return_values[2] + end + + it "should keep returning last value in consecutive calls" do + return_values = ["1",2,Object.new] + @obj.stub!(:msg).and_return(return_values[0],return_values[1],return_values[2]) + @obj.msg.should == return_values[0] + @obj.msg.should == return_values[1] + @obj.msg.should == return_values[2] + @obj.msg.should == return_values[2] + @obj.msg.should == return_values[2] + end + + it "should revert to original instance method if existed" do + @obj.existing_instance_method.should equal(:original_value) + @obj.stub!(:existing_instance_method).and_return(:mock_value) + @obj.existing_instance_method.should equal(:mock_value) + @obj.rspec_verify + # TODO JRUBY: This causes JRuby to fail with: + # NativeException in 'Stub should revert to original instance method if existed' + # java.lang.ArrayIndexOutOfBoundsException: 0 + # org.jruby.internal.runtime.methods.IterateCallable.internalCall(IterateCallable.java:63) + # org.jruby.internal.runtime.methods.AbstractCallable.call(AbstractCallable.java:64) + # org.jruby.runtime.ThreadContext.yieldInternal(ThreadContext.java:574) + # org.jruby.runtime.ThreadContext.yieldSpecificBlock(ThreadContext.java:549) + # org.jruby.runtime.Block.call(Block.java:158) + # org.jruby.RubyProc.call(RubyProc.java:118) + # org.jruby.internal.runtime.methods.ProcMethod.internalCall(ProcMethod.java:69) + # org.jruby.internal.runtime.methods.AbstractMethod.call(AbstractMethod.java:58) + # org.jruby.RubyObject.callMethod(RubyObject.java:379) + # org.jruby.RubyObject.callMethod(RubyObject.java:331) + # org.jruby.evaluator.EvaluationState.evalInternal(EvaluationState.java:472) + # org.jruby.evaluator.EvaluationState.evalInternal(EvaluationState.java:462) + # org.jruby.evaluator.EvaluationState.evalInternal(EvaluationState.java:390) + # org.jruby.evaluator.EvaluationState.eval(EvaluationState.java:133) + @obj.existing_instance_method.should equal(:original_value) + end + + it "should revert to original class method if existed" do + @class.existing_class_method.should equal(:original_value) + @class.stub!(:existing_class_method).and_return(:mock_value) + @class.existing_class_method.should equal(:mock_value) + @class.rspec_verify + @class.existing_class_method.should equal(:original_value) + end + + it "should clear itself on rspec_verify" do + @obj.stub!(:this_should_go).and_return(:blah) + @obj.this_should_go.should == :blah + @obj.rspec_verify + lambda do + @obj.this_should_go + end.should raise_error + end + + it "should support yielding" do + @obj.stub!(:method_that_yields).and_yield(:yielded_value) + current_value = :value_before + @obj.method_that_yields {|val| current_value = val} + current_value.should == :yielded_value + @obj.rspec_verify + end + + it "should throw when told to" do + @mock.stub!(:something).and_throw(:blech) + lambda do + @mock.something + end.should throw_symbol(:blech) + end + + it "should support overriding w/ a new stub" do + @stub.stub!(:existing_instance_method).and_return(:updated_stub_value) + @stub.existing_instance_method.should == :updated_stub_value + end + end + end +end diff --git a/vendor/plugins/rspec/spec/spec/mocks/twice_counts_spec.rb b/vendor/plugins/rspec/spec/spec/mocks/twice_counts_spec.rb new file mode 100644 index 000000000..d07e45736 --- /dev/null +++ b/vendor/plugins/rspec/spec/spec/mocks/twice_counts_spec.rb @@ -0,0 +1,67 @@ +require File.dirname(__FILE__) + '/../../spec_helper.rb' + +module Spec + module Mocks + describe "TwiceCounts" do + before(:each) do + @mock = mock("test mock") + end + + it "twice should fail when call count is higher than expected" do + @mock.should_receive(:random_call).twice + @mock.random_call + @mock.random_call + @mock.random_call + lambda do + @mock.rspec_verify + end.should raise_error(MockExpectationError) + end + + it "twice should fail when call count is lower than expected" do + @mock.should_receive(:random_call).twice + @mock.random_call + lambda do + @mock.rspec_verify + end.should raise_error(MockExpectationError) + end + + it "twice should fail when called twice with wrong args on the first call" do + @mock.should_receive(:random_call).twice.with("1", 1) + lambda do + @mock.random_call(1, "1") + end.should raise_error(MockExpectationError) + @mock.rspec_reset + end + + it "twice should fail when called twice with wrong args on the second call" do + @mock.should_receive(:random_call).twice.with("1", 1) + @mock.random_call("1", 1) + lambda do + @mock.random_call(1, "1") + end.should raise_error(MockExpectationError) + @mock.rspec_reset + end + + it "twice should pass when called twice" do + @mock.should_receive(:random_call).twice + @mock.random_call + @mock.random_call + @mock.rspec_verify + end + + it "twice should pass when called twice with specified args" do + @mock.should_receive(:random_call).twice.with("1", 1) + @mock.random_call("1", 1) + @mock.random_call("1", 1) + @mock.rspec_verify + end + + it "twice should pass when called twice with unspecified args" do + @mock.should_receive(:random_call).twice + @mock.random_call("1") + @mock.random_call(1) + @mock.rspec_verify + end + end + end +end diff --git a/vendor/plugins/rspec/spec/spec/package/bin_spec_spec.rb b/vendor/plugins/rspec/spec/spec/package/bin_spec_spec.rb new file mode 100644 index 000000000..6eac5e8cb --- /dev/null +++ b/vendor/plugins/rspec/spec/spec/package/bin_spec_spec.rb @@ -0,0 +1,12 @@ +require "#{File.dirname(__FILE__)}/../../spec_helper" + +describe "The bin/spec script" do + it "should have no warnings" do + spec_path = "#{File.dirname(__FILE__)}/../../../bin/spec" + output = nil + IO.popen("ruby -w #{spec_path} --help 2>&1") do |io| + output = io.read + end + output.should_not =~ /warning/n + end +end diff --git a/vendor/plugins/rspec/spec/spec/runner/behaviour_runner_spec.rb b/vendor/plugins/rspec/spec/spec/runner/behaviour_runner_spec.rb new file mode 100644 index 000000000..ff4890633 --- /dev/null +++ b/vendor/plugins/rspec/spec/spec/runner/behaviour_runner_spec.rb @@ -0,0 +1,229 @@ +require File.dirname(__FILE__) + '/../../spec_helper.rb' + +module Spec + module Runner + describe BehaviourRunner, "#add_behaviour affecting passed in behaviour" do + before do + @err = StringIO.new('') + @out = StringIO.new('') + @options = Options.new(@err,@out) + @runner = BehaviourRunner.new(@options) + class << @runner + attr_reader :behaviours + end + + @behaviour = ::Spec::DSL::Behaviour.new("A Behaviour") do + it "runs 1" do + end + it "runs 2" do + end + end + end + + it "removes examples not selected from Behaviour when options.examples is set" do + @options.examples << "A Behaviour runs 1" + + @behaviour.number_of_examples.should == 2 + + @runner.add_behaviour @behaviour + @behaviour.number_of_examples.should == 1 + @behaviour.examples.first.send(:description).should == "runs 1" + end + + it "keeps all examples when options.examples is nil" do + @options.examples = nil + @behaviour.number_of_examples.should == 2 + + @runner.add_behaviour @behaviour + @behaviour.number_of_examples.should == 2 + @behaviour.examples.collect {|example| example.send(:description) }.should == ['runs 1', 'runs 2'] + end + + it "keeps all examples when options.examples is empty" do + @options.examples = [] + @behaviour.number_of_examples.should == 2 + + @runner.add_behaviour @behaviour + @behaviour.number_of_examples.should == 2 + @behaviour.examples.collect {|example| example.send(:description) }.should == ['runs 1', 'runs 2'] + end + end + + describe BehaviourRunner, "#add_behaviour affecting behaviours" do + before do + @err = StringIO.new('') + @out = StringIO.new('') + @options = Options.new(@err,@out) + @runner = BehaviourRunner.new(@options) + class << @runner + attr_reader :behaviours + end + end + + it "adds behaviour when behaviour has examples and is not shared" do + @behaviour = ::Spec::DSL::Behaviour.new("A Behaviour") do + it "uses this behaviour" do + end + end + + @behaviour.should_not be_shared + @behaviour.number_of_examples.should be > 0 + @runner.add_behaviour @behaviour + + @runner.behaviours.length.should == 1 + end + + it "does not add the behaviour when number_of_examples is 0" do + @behaviour = ::Spec::DSL::Behaviour.new("A Behaviour") do + end + @behaviour.number_of_examples.should == 0 + @runner.add_behaviour @behaviour + + @runner.behaviours.should be_empty + end + + it "does not add the behaviour when behaviour is shared" do + @behaviour = ::Spec::DSL::Behaviour.new("A Behaviour", :shared => true) do + it "does not use this behaviour" do + end + end + @behaviour.should be_shared + @runner.add_behaviour @behaviour + + @runner.behaviours.should be_empty + end + end + + describe BehaviourRunner do + before do + @err = StringIO.new('') + @out = StringIO.new('') + @options = Options.new(@err,@out) + end + + it "should only run behaviours with at least one example" do + desired_behaviour = mock("desired behaviour") + desired_behaviour.should_receive(:run) + desired_behaviour.should_receive(:retain_examples_matching!) + desired_behaviour.should_receive(:number_of_examples).twice.and_return(1) + desired_behaviour.should_receive(:shared?).and_return(false) + desired_behaviour.should_receive(:set_sequence_numbers).with(0, anything) + + other_behaviour = mock("other behaviour") + other_behaviour.should_receive(:run).never + other_behaviour.should_receive(:retain_examples_matching!) + other_behaviour.should_receive(:number_of_examples).and_return(0) + + reporter = mock("reporter") + @options.reporter = reporter + @options.examples = ["desired behaviour legal spec"] + + runner = Spec::Runner::BehaviourRunner.new(@options) + runner.add_behaviour(desired_behaviour) + runner.add_behaviour(other_behaviour) + reporter.should_receive(:start) + reporter.should_receive(:end) + reporter.should_receive(:dump) + runner.run([], false) + end + + it "should dump even if Interrupt exception is occurred" do + behaviour = Spec::DSL::Behaviour.new("behaviour") do + it "no error" do + end + + it "should interrupt" do + raise Interrupt + end + end + + reporter = mock("reporter") + reporter.should_receive(:start) + reporter.should_receive(:add_behaviour) + reporter.should_receive(:example_started).twice + reporter.should_receive(:example_finished).twice + reporter.should_receive(:rspec_verify) + reporter.should_receive(:rspec_reset) + reporter.should_receive(:end) + reporter.should_receive(:dump) + + @options.reporter = reporter + runner = Spec::Runner::BehaviourRunner.new(@options) + runner.add_behaviour(behaviour) + runner.run([], false) + end + + it "should heckle when options have heckle_runner" do + behaviour = mock("behaviour", :null_object => true) + behaviour.should_receive(:number_of_examples).twice.and_return(1) + behaviour.should_receive(:run).and_return(0) + behaviour.should_receive(:shared?).and_return(false) + + reporter = mock("reporter") + reporter.should_receive(:start).with(1) + reporter.should_receive(:end) + reporter.should_receive(:dump).and_return(0) + + heckle_runner = mock("heckle_runner") + heckle_runner.should_receive(:heckle_with) + + @options.reporter = reporter + @options.heckle_runner = heckle_runner + + runner = Spec::Runner::BehaviourRunner.new(@options) + runner.add_behaviour(behaviour) + runner.run([], false) + end + + it "should run examples backwards if options.reverse is true" do + @options.reverse = true + + reporter = mock("reporter") + reporter.should_receive(:start).with(3) + reporter.should_receive(:end) + reporter.should_receive(:dump).and_return(0) + @options.reporter = reporter + + runner = Spec::Runner::BehaviourRunner.new(@options) + b1 = mock("b1") + b1.should_receive(:number_of_examples).twice.and_return(1) + b1.should_receive(:shared?).and_return(false) + b1.should_receive(:set_sequence_numbers).with(12, true).and_return(18) + + b2 = mock("b2") + b2.should_receive(:number_of_examples).twice.and_return(2) + b2.should_receive(:shared?).and_return(false) + b2.should_receive(:set_sequence_numbers).with(0, true).and_return(12) + b2.should_receive(:run) do + b1.should_receive(:run) + end + + runner.add_behaviour(b1) + runner.add_behaviour(b2) + + runner.run([], false) + end + + it "should yield global configuration" do + Spec::Runner.configure do |config| + config.should equal(Spec::Runner.configuration) + end + end + + it "should pass its Description to the reporter" do + behaviour = Spec::DSL::Behaviour.new("behaviour") do + it "should" do + end + end + + reporter = mock("reporter", :null_object => true) + reporter.should_receive(:add_behaviour).with(an_instance_of(Spec::DSL::Description)) + + @options.reporter = reporter + runner = Spec::Runner::BehaviourRunner.new(@options) + runner.add_behaviour(behaviour) + runner.run([], false) + end + end + end +end diff --git a/vendor/plugins/rspec/spec/spec/runner/command_line_spec.rb b/vendor/plugins/rspec/spec/spec/runner/command_line_spec.rb new file mode 100644 index 000000000..d78626399 --- /dev/null +++ b/vendor/plugins/rspec/spec/spec/runner/command_line_spec.rb @@ -0,0 +1,33 @@ +require File.dirname(__FILE__) + '/../../spec_helper.rb' + +describe "CommandLine" do + it "should run directory" do + file = File.dirname(__FILE__) + '/../../../examples' + err = StringIO.new + out = StringIO.new + Spec::Runner::CommandLine.run([file], err, out, false, true) + + out.rewind + out.read.should =~ /78 examples, 0 failures, 3 pending/n + end + + it "should run file" do + file = File.dirname(__FILE__) + '/../../../failing_examples/predicate_example.rb' + err = StringIO.new + out = StringIO.new + Spec::Runner::CommandLine.run([file], err, out, false, true) + + out.rewind + out.read.should =~ /2 examples, 1 failure/n + end + + it "should raise when file does not exist" do + file = File.dirname(__FILE__) + '/doesntexist' + err = StringIO.new + out = StringIO.new + + lambda { + Spec::Runner::CommandLine.run([file], err, out, false, true) + }.should raise_error + end +end diff --git a/vendor/plugins/rspec/spec/spec/runner/context_matching_spec.rb b/vendor/plugins/rspec/spec/spec/runner/context_matching_spec.rb new file mode 100644 index 000000000..ad8017b64 --- /dev/null +++ b/vendor/plugins/rspec/spec/spec/runner/context_matching_spec.rb @@ -0,0 +1,27 @@ +require File.dirname(__FILE__) + '/../../spec_helper.rb' + +module Spec + module DSL + describe Behaviour do + + before(:each) do + @formatter = Spec::Mocks::Mock.new("formatter") + @behaviour = Behaviour.new("behaviour") {} + end + + it "should retain examples that don't match" do + @behaviour.it("example1") {} + @behaviour.it("example2") {} + @behaviour.retain_examples_matching!(["behaviour"]) + @behaviour.number_of_examples.should == 2 + end + + it "should remove examples that match" do + @behaviour.it("example1") {} + @behaviour.it("example2") {} + @behaviour.retain_examples_matching!(["behaviour example1"]) + @behaviour.number_of_examples.should == 1 + end + end + end +end diff --git a/vendor/plugins/rspec/spec/spec/runner/drb_command_line_spec.rb b/vendor/plugins/rspec/spec/spec/runner/drb_command_line_spec.rb new file mode 100644 index 000000000..d2d68499d --- /dev/null +++ b/vendor/plugins/rspec/spec/spec/runner/drb_command_line_spec.rb @@ -0,0 +1,84 @@ +require File.dirname(__FILE__) + '/../../spec_helper.rb' + +module Spec + module Runner + describe DrbCommandLine, "without running local server" do + + unless Config::CONFIG['ruby_install_name'] == 'jruby' + it "should print error when there is no running local server" do + err = StringIO.new + out = StringIO.new + DrbCommandLine.run(['--version'], err, out, false) + + err.rewind + err.read.should =~ /No server is running/ + end + end + end + + describe DrbCommandLine, "with local server" do + + unless Config::CONFIG['ruby_install_name'] == 'jruby' + before(:all) do + DRb.start_service("druby://localhost:8989", Spec::Runner::CommandLine) + $drb_example_file_counter = 0 + end + + before(:each) do + create_dummy_spec_file + $drb_example_file_counter = $drb_example_file_counter + 1 + end + + after(:each) do + File.delete(@dummy_spec_filename) + end + + after(:all) do + DRb.stop_service + end + + it "should run against local server" do + out = run_spec_via_druby(['--version']) + out.should =~ /RSpec/n + end + + it "should output green colorized text when running with --colour option" do + out = run_spec_via_druby(["--colour", @dummy_spec_filename]) + out.should =~ /\e\[32m/n + end + + it "should output red colorized text when running with -c option" do + out = run_spec_via_druby(["-c", @dummy_spec_filename]) + out.should =~ /\e\[31m/n + end + + def create_dummy_spec_file + @dummy_spec_filename = File.expand_path(File.dirname(__FILE__)) + "/_dummy_spec#{$drb_example_file_counter}.rb" + File.open(@dummy_spec_filename, 'w') do |f| + f.write %{ + describe "DUMMY CONTEXT for 'DrbCommandLine with -c option'" do + it "should be output with green bar" do + true.should be_true + end + + it "should be output with red bar" do + violated("I want to see a red bar!") + end + end + } + end + end + + def run_spec_via_druby(args) + err, out = StringIO.new, StringIO.new + out.instance_eval do + def tty?; true end + end + Spec::Runner::DrbCommandLine.run(args, err, out, false, true) + out.rewind; out.read + end + end + + end + end +end diff --git a/vendor/plugins/rspec/spec/spec/runner/empty_file.txt b/vendor/plugins/rspec/spec/spec/runner/empty_file.txt new file mode 100644 index 000000000..e69de29bb --- /dev/null +++ b/vendor/plugins/rspec/spec/spec/runner/empty_file.txt diff --git a/vendor/plugins/rspec/spec/spec/runner/examples.txt b/vendor/plugins/rspec/spec/spec/runner/examples.txt new file mode 100644 index 000000000..2fcbd355d --- /dev/null +++ b/vendor/plugins/rspec/spec/spec/runner/examples.txt @@ -0,0 +1,2 @@ +Sir, if you were my husband, I would poison your drink. +Madam, if you were my wife, I would drink it.
\ No newline at end of file diff --git a/vendor/plugins/rspec/spec/spec/runner/execution_context_spec.rb b/vendor/plugins/rspec/spec/spec/runner/execution_context_spec.rb new file mode 100644 index 000000000..82e7447c1 --- /dev/null +++ b/vendor/plugins/rspec/spec/spec/runner/execution_context_spec.rb @@ -0,0 +1,31 @@ +require File.dirname(__FILE__) + '/../../spec_helper.rb' + +describe "ExecutionContext" do + + it "should provide duck_type()" do + dt = duck_type(:length) + dt.should be_an_instance_of(Spec::Mocks::DuckTypeArgConstraint) + dt.matches?([]).should be_true + end + + it "should violate when violated()" do + lambda do + violated + end.should raise_error(Spec::Expectations::ExpectationNotMetError) + end + + it "should provide mock()" do + mock("thing").should be_an_instance_of(Spec::Mocks::Mock) + end + + it "should provide stub()" do + thing_stub = stub("thing").should be_an_instance_of(Spec::Mocks::Mock) + end + + it "should add method stubs to stub()" do + thing_stub = stub("thing", :a => "A", :b => "B") + thing_stub.a.should == "A" + thing_stub.b.should == "B" + end + +end diff --git a/vendor/plugins/rspec/spec/spec/runner/extensions/bug_report_10577_spec.rb b/vendor/plugins/rspec/spec/spec/runner/extensions/bug_report_10577_spec.rb new file mode 100644 index 000000000..c4da69f4d --- /dev/null +++ b/vendor/plugins/rspec/spec/spec/runner/extensions/bug_report_10577_spec.rb @@ -0,0 +1,35 @@ +require File.dirname(__FILE__) + '/../../../spec_helper.rb' +require 'delegate' + +module Bug10577 + class OCI8 + def describe(name) + "Hello, #{name}" + end + + def something(name) + "Something, #{name}" + end + end + + class OCI8AutoRecover < DelegateClass(OCI8) + def initialize + @connection = OCI8.new + super(@connection) + end + end + + class OCI8AutoRecover + def describe(name) + @connection.describe(name) + end + end + + describe Kernel do + it "should not mask a delegate class' describe method" do + bugger = OCI8AutoRecover.new + bugger.describe('aslak').should == "Hello, aslak" + bugger.something('aslak').should == "Something, aslak" + end + end +end diff --git a/vendor/plugins/rspec/spec/spec/runner/extensions/kernel_spec.rb b/vendor/plugins/rspec/spec/spec/runner/extensions/kernel_spec.rb new file mode 100644 index 000000000..6b253a06a --- /dev/null +++ b/vendor/plugins/rspec/spec/spec/runner/extensions/kernel_spec.rb @@ -0,0 +1,36 @@ +require File.dirname(__FILE__) + '/../../../spec_helper.rb' + +describe Kernel, "when extended by rspec" do + it "should respond to :describe" do + Object.new.should respond_to(:describe) + Object.new.should respond_to(:context) + end +end + +describe Kernel, " when creating behaviours with describe" do + + it "should fail when no block given" do + lambda { describe "foo" }.should raise_error(ArgumentError) + end + + it "should fail when no description given" do + lambda { describe do; end }.should raise_error(ArgumentError) + end +end + +describe Kernel, "#respond_to" do + before(:each) do + @kernel_impersonator = Class.new do + include Kernel + end.new + end + + it "should return a Spec::Matchers::RespondTo" do + @kernel_impersonator.respond_to.should be_an_instance_of(Spec::Matchers::RespondTo) + end + + it "should pass the submitted names to the RespondTo instance" do + Spec::Matchers::RespondTo.should_receive(:new).with(:a,'b','c?') + @kernel_impersonator.respond_to(:a,'b','c?') + end +end diff --git a/vendor/plugins/rspec/spec/spec/runner/failed.txt b/vendor/plugins/rspec/spec/spec/runner/failed.txt new file mode 100644 index 000000000..07c5442cf --- /dev/null +++ b/vendor/plugins/rspec/spec/spec/runner/failed.txt @@ -0,0 +1,3 @@ +heckler_spec.rb +command_line_spec.rb +reporter_spec.rb
\ No newline at end of file diff --git a/vendor/plugins/rspec/spec/spec/runner/formatter/failing_behaviours_formatter_spec.rb b/vendor/plugins/rspec/spec/spec/runner/formatter/failing_behaviours_formatter_spec.rb new file mode 100644 index 000000000..de3246c54 --- /dev/null +++ b/vendor/plugins/rspec/spec/spec/runner/formatter/failing_behaviours_formatter_spec.rb @@ -0,0 +1,40 @@ +require File.dirname(__FILE__) + '/../../../spec_helper.rb' + +module Spec + module Runner + module Formatter + describe "FailingBehavioursFormatter" do + before(:each) do + @io = StringIO.new + @formatter = FailingBehavioursFormatter.new(@io) + end + + def description(s) + Spec::DSL::Description.new(s) + end + + it "should add example name for each failure" do + @formatter.add_behaviour(description("b 1")) + @formatter.example_failed("e 1", nil, Reporter::Failure.new(nil, RuntimeError.new)) + @formatter.add_behaviour(description("b 2")) + @formatter.example_failed("e 2", nil, Reporter::Failure.new(nil, RuntimeError.new)) + @formatter.example_failed("e 3", nil, Reporter::Failure.new(nil, RuntimeError.new)) + @io.string.should eql(<<-EOF +b 1 +b 2 +EOF +) + end + + it "should remove druby url, which is used by Spec::Distributed" do + @formatter.add_behaviour("something something (druby://99.99.99.99:99)") + @formatter.example_failed("e 1", nil, Reporter::Failure.new(nil, RuntimeError.new)) + @io.string.should eql(<<-EOF +something something +EOF +) + end + end + end + end +end diff --git a/vendor/plugins/rspec/spec/spec/runner/formatter/failing_examples_formatter_spec.rb b/vendor/plugins/rspec/spec/spec/runner/formatter/failing_examples_formatter_spec.rb new file mode 100644 index 000000000..396e4b16e --- /dev/null +++ b/vendor/plugins/rspec/spec/spec/runner/formatter/failing_examples_formatter_spec.rb @@ -0,0 +1,28 @@ +require File.dirname(__FILE__) + '/../../../spec_helper.rb' + +module Spec + module Runner + module Formatter + describe "FailingExamplesFormatter" do + before(:each) do + @io = StringIO.new + @formatter = FailingExamplesFormatter.new(@io) + end + + it "should add example name for each failure" do + @formatter.add_behaviour("b 1") + @formatter.example_failed(DSL::Example.new("e 1"), nil, Reporter::Failure.new(nil, RuntimeError.new)) + @formatter.add_behaviour("b 2") + @formatter.example_failed(DSL::Example.new("e 2"), nil, Reporter::Failure.new(nil, RuntimeError.new)) + @formatter.example_failed(DSL::Example.new("e 3"), nil, Reporter::Failure.new(nil, RuntimeError.new)) + @io.string.should eql(<<-EOF +b 1 e 1 +b 2 e 2 +b 2 e 3 +EOF +) + end + end + end + end +end diff --git a/vendor/plugins/rspec/spec/spec/runner/formatter/html_formatted-1.8.4.html b/vendor/plugins/rspec/spec/spec/runner/formatter/html_formatted-1.8.4.html new file mode 100644 index 000000000..c6976ca5f --- /dev/null +++ b/vendor/plugins/rspec/spec/spec/runner/formatter/html_formatted-1.8.4.html @@ -0,0 +1,366 @@ +<?xml version="1.0" encoding="iso-8859-1"?> +<!DOCTYPE html + PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" + "http://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd"> + +<html xmlns="http://www.w3.org/1999/xhtml" xml:lang="en" lang="en"> +<head> + <title>RSpec results</title> + <meta http-equiv="Content-Type" content="text/html; charset=iso-8859-1" /> + <meta http-equiv="Expires" content="-1" /> + <meta http-equiv="Pragma" content="no-cache" /> + <style type="text/css"> + body { + margin: 0; + padding: 0; + background: #fff; + font-size: 80%; + } + </style> +</head> +<body> +<div class="rspec-report"> + <script type="text/javascript"> + // <![CDATA[ +function moveProgressBar(percentDone) { + document.getElementById("rspec-header").style.width = percentDone +"%"; +} +function makeRed(element_id) { + document.getElementById(element_id).style.background = '#C40D0D'; + document.getElementById(element_id).style.color = '#FFFFFF'; +} + +function makeYellow(element_id) { + if (element_id == "rspec-header" && document.getElementById(element_id).style.background != '#C40D0D') + { + document.getElementById(element_id).style.background = '#FAF834'; + document.getElementById(element_id).style.color = '#000000'; + } + else + { + document.getElementById(element_id).style.background = '#FAF834'; + document.getElementById(element_id).style.color = '#000000'; + } +} + + // ]]> + </script> + <style type="text/css"> +#rspec-header { + background: #65C400; color: #fff; +} + +.rspec-report h1 { + margin: 0px 10px 0px 10px; + padding: 10px; + font-family: "Lucida Grande", Helvetica, sans-serif; + font-size: 1.8em; +} + +#summary { + margin: 0; padding: 5px 10px; + font-family: "Lucida Grande", Helvetica, sans-serif; + text-align: right; + position: absolute; + top: 0px; + right: 0px; +} + +#summary p { + margin: 0 0 0 2px; +} + +#summary #totals { + font-size: 1.2em; +} + +.behaviour { + margin: 0 10px 5px; + background: #fff; +} + +dl { + margin: 0; padding: 0 0 5px; + font: normal 11px "Lucida Grande", Helvetica, sans-serif; +} + +dt { + padding: 3px; + background: #65C400; + color: #fff; + font-weight: bold; +} + +dd { + margin: 5px 0 5px 5px; + padding: 3px 3px 3px 18px; +} + +dd.spec.passed { + border-left: 5px solid #65C400; + border-bottom: 1px solid #65C400; + background: #DBFFB4; color: #3D7700; +} + +dd.spec.failed { + border-left: 5px solid #C20000; + border-bottom: 1px solid #C20000; + color: #C20000; background: #FFFBD3; +} + +dd.spec.not_implemented { + border-left: 5px solid #FAF834; + border-bottom: 1px solid #FAF834; + background: #FCFB98; color: #131313; +} + +dd.spec.pending_fixed { + border-left: 5px solid #0000C2; + border-bottom: 1px solid #0000C2; + color: #0000C2; background: #D3FBFF; +} + +.backtrace { + color: #000; + font-size: 12px; +} + +a { + color: #BE5C00; +} + +/* Ruby code, style similar to vibrant ink */ +.ruby { + font-size: 12px; + font-family: monospace; + color: white; + background-color: black; + padding: 0.1em 0 0.2em 0; +} + +.ruby .keyword { color: #FF6600; } +.ruby .constant { color: #339999; } +.ruby .attribute { color: white; } +.ruby .global { color: white; } +.ruby .module { color: white; } +.ruby .class { color: white; } +.ruby .string { color: #66FF00; } +.ruby .ident { color: white; } +.ruby .method { color: #FFCC00; } +.ruby .number { color: white; } +.ruby .char { color: white; } +.ruby .comment { color: #9933CC; } +.ruby .symbol { color: white; } +.ruby .regex { color: #44B4CC; } +.ruby .punct { color: white; } +.ruby .escape { color: white; } +.ruby .interp { color: white; } +.ruby .expr { color: white; } + +.ruby .offending { background-color: gray; } +.ruby .linenum { + width: 75px; + padding: 0.1em 1em 0.2em 0; + color: #000000; + background-color: #FFFBD3; +} + + </style> + +<div id="rspec-header"> + <h1>RSpec Results</h1> + + <div id="summary"> + <p id="totals"> </p> + <p id="duration"> </p> + </div> +</div> + +<div class="results"> +<div class="behaviour"> + <dl> + <dt id="behaviour_1">Mocker</dt> + <script type="text/javascript">moveProgressBar('5.8');</script> + <dd class="spec passed"><span class="passed_spec_name">should be able to call mock()</span></dd> + <script type="text/javascript">makeRed('rspec-header');</script> + <script type="text/javascript">makeRed('behaviour_1');</script> + <script type="text/javascript">moveProgressBar('11.7');</script> + <dd class="spec failed"> + <span class="failed_spec_name">should fail when expected message not received</span> + <div class="failure" id="failure_1"> + <div class="message"><pre>Mock 'poke me' expected :poke with (any args) once, but received it 0 times</pre></div> + <div class="backtrace"><pre>./failing_examples/mocking_example.rb:13: +./spec/spec/runner/formatter/html_formatter_spec.rb:17: +./spec/spec/runner/formatter/html_formatter_spec.rb:13:</pre></div> + <pre class="ruby"><code><span class="linenum">11</span> <span class="ident">it</span> <span class="punct">"</span><span class="string">should fail when expected message not received</span><span class="punct">"</span> <span class="keyword">do</span> +<span class="linenum">12</span> <span class="ident">mock</span> <span class="punct">=</span> <span class="ident">mock</span><span class="punct">("</span><span class="string">poke me</span><span class="punct">")</span> +<span class="offending"><span class="linenum">13</span> <span class="ident">mock</span><span class="punct">.</span><span class="ident">should_receive</span><span class="punct">(</span><span class="symbol">:poke</span><span class="punct">)</span></span> +<span class="linenum">14</span> <span class="keyword">end</span> +<span class="linenum">15</span> </code></pre> + </div> + </dd> + <script type="text/javascript">moveProgressBar('17.6');</script> + <dd class="spec failed"> + <span class="failed_spec_name">should fail when messages are received out of order</span> + <div class="failure" id="failure_2"> + <div class="message"><pre>Mock 'one two three' received :three out of order</pre></div> + <div class="backtrace"><pre>./failing_examples/mocking_example.rb:22: +./spec/spec/runner/formatter/html_formatter_spec.rb:17: +./spec/spec/runner/formatter/html_formatter_spec.rb:13:</pre></div> + <pre class="ruby"><code><span class="linenum">20</span> <span class="ident">mock</span><span class="punct">.</span><span class="ident">should_receive</span><span class="punct">(</span><span class="symbol">:three</span><span class="punct">).</span><span class="ident">ordered</span> +<span class="linenum">21</span> <span class="ident">mock</span><span class="punct">.</span><span class="ident">one</span> +<span class="offending"><span class="linenum">22</span> <span class="ident">mock</span><span class="punct">.</span><span class="ident">three</span></span> +<span class="linenum">23</span> <span class="ident">mock</span><span class="punct">.</span><span class="ident">two</span> +<span class="linenum">24</span> <span class="keyword">end</span></code></pre> + </div> + </dd> + <script type="text/javascript">moveProgressBar('23.5');</script> + <dd class="spec failed"> + <span class="failed_spec_name">should get yelled at when sending unexpected messages</span> + <div class="failure" id="failure_3"> + <div class="message"><pre>Mock 'don't talk to me' expected :any_message_at_all with (any args) 0 times, but received it once</pre></div> + <div class="backtrace"><pre>./failing_examples/mocking_example.rb:28: +./spec/spec/runner/formatter/html_formatter_spec.rb:17: +./spec/spec/runner/formatter/html_formatter_spec.rb:13:</pre></div> + <pre class="ruby"><code><span class="linenum">26</span> <span class="ident">it</span> <span class="punct">"</span><span class="string">should get yelled at when sending unexpected messages</span><span class="punct">"</span> <span class="keyword">do</span> +<span class="linenum">27</span> <span class="ident">mock</span> <span class="punct">=</span> <span class="ident">mock</span><span class="punct">("</span><span class="string">don't talk to me</span><span class="punct">")</span> +<span class="offending"><span class="linenum">28</span> <span class="ident">mock</span><span class="punct">.</span><span class="ident">should_not_receive</span><span class="punct">(</span><span class="symbol">:any_message_at_all</span><span class="punct">)</span></span> +<span class="linenum">29</span> <span class="ident">mock</span><span class="punct">.</span><span class="ident">any_message_at_all</span> +<span class="linenum">30</span> <span class="keyword">end</span></code></pre> + </div> + </dd> + <script type="text/javascript">moveProgressBar('29.4');</script> + <dd class="spec pending_fixed"> + <span class="failed_spec_name">has a bug we need to fix</span> + <div class="failure" id="failure_4"> + <div class="message"><pre>Expected pending 'here is the bug' to fail. No Error was raised.</pre></div> + <div class="backtrace"><pre>./failing_examples/mocking_example.rb:33: +./spec/spec/runner/formatter/html_formatter_spec.rb:17: +./spec/spec/runner/formatter/html_formatter_spec.rb:13:</pre></div> + <pre class="ruby"><code><span class="linenum">31</span> +<span class="linenum">32</span> <span class="ident">it</span> <span class="punct">"</span><span class="string">has a bug we need to fix</span><span class="punct">"</span> <span class="keyword">do</span> +<span class="offending"><span class="linenum">33</span> <span class="ident">pending</span> <span class="punct">"</span><span class="string">here is the bug</span><span class="punct">"</span> <span class="keyword">do</span></span> +<span class="linenum">34</span> <span class="comment"># Actually, no. It's fixed. This will fail because it passes :-)</span> +<span class="linenum">35</span> <span class="ident">mock</span> <span class="punct">=</span> <span class="ident">mock</span><span class="punct">("</span><span class="string">Bug</span><span class="punct">")</span></code></pre> + </div> + </dd> + </dl> +</div> +<div class="behaviour"> + <dl> + <dt id="behaviour_2">Running specs with --diff</dt> + <script type="text/javascript">makeRed('behaviour_2');</script> + <script type="text/javascript">moveProgressBar('35.2');</script> + <dd class="spec failed"> + <span class="failed_spec_name">should print diff of different strings</span> + <div class="failure" id="failure_5"> + <div class="message"><pre>expected: "RSpec is a\nbehaviour driven development\nframework for Ruby\n", + got: "RSpec is a\nbehavior driven development\nframework for Ruby\n" (using ==) +Diff: +@@ -1,4 +1,4 @@ + RSpec is a +-behavior driven development ++behaviour driven development + framework for Ruby +</pre></div> + <div class="backtrace"><pre>./failing_examples/diffing_spec.rb:13: +./spec/spec/runner/formatter/html_formatter_spec.rb:17: +./spec/spec/runner/formatter/html_formatter_spec.rb:13:</pre></div> + <pre class="ruby"><code><span class="linenum">11</span><span class="ident">framework</span> <span class="keyword">for</span> <span class="constant">Ruby</span> +<span class="linenum">12</span><span class="constant">EOF</span> +<span class="offending"><span class="linenum">13</span> <span class="ident">usa</span><span class="punct">.</span><span class="ident">should</span> <span class="punct">==</span> <span class="ident">uk</span></span> +<span class="linenum">14</span> <span class="keyword">end</span></code></pre> + </div> + </dd> + <script type="text/javascript">moveProgressBar('41.1');</script> + <dd class="spec failed"> + <span class="failed_spec_name">should print diff of different objects' pretty representation</span> + <div class="failure" id="failure_6"> + <div class="message"><pre>expected <Animal +name=bob, +species=tortoise +> +, got <Animal +name=bob, +species=giraffe +> + (using .eql?) +Diff: +@@ -1,5 +1,5 @@ + <Animal + name=bob, +-species=giraffe ++species=tortoise + > +</pre></div> + <div class="backtrace"><pre>./failing_examples/diffing_spec.rb:34: +./spec/spec/runner/formatter/html_formatter_spec.rb:17: +./spec/spec/runner/formatter/html_formatter_spec.rb:13:</pre></div> + <pre class="ruby"><code><span class="linenum">32</span> <span class="ident">expected</span> <span class="punct">=</span> <span class="constant">Animal</span><span class="punct">.</span><span class="ident">new</span> <span class="punct">"</span><span class="string">bob</span><span class="punct">",</span> <span class="punct">"</span><span class="string">giraffe</span><span class="punct">"</span> +<span class="linenum">33</span> <span class="ident">actual</span> <span class="punct">=</span> <span class="constant">Animal</span><span class="punct">.</span><span class="ident">new</span> <span class="punct">"</span><span class="string">bob</span><span class="punct">",</span> <span class="punct">"</span><span class="string">tortoise</span><span class="punct">"</span> +<span class="offending"><span class="linenum">34</span> <span class="ident">expected</span><span class="punct">.</span><span class="ident">should</span> <span class="ident">eql</span><span class="punct">(</span><span class="ident">actual</span><span class="punct">)</span></span> +<span class="linenum">35</span> <span class="keyword">end</span> +<span class="linenum">36</span><span class="keyword">end</span></code></pre> + </div> + </dd> + </dl> +</div> +<div class="behaviour"> + <dl> + <dt id="behaviour_3">A consumer of a stub</dt> + <script type="text/javascript">moveProgressBar('47.0');</script> + <dd class="spec passed"><span class="passed_spec_name">should be able to stub methods on any Object</span></dd> + </dl> +</div> +<div class="behaviour"> + <dl> + <dt id="behaviour_4">A stubbed method on a class</dt> + <script type="text/javascript">moveProgressBar('52.9');</script> + <dd class="spec passed"><span class="passed_spec_name">should return the stubbed value</span></dd> + <script type="text/javascript">moveProgressBar('58.8');</script> + <dd class="spec passed"><span class="passed_spec_name">should revert to the original method after each spec</span></dd> + <script type="text/javascript">moveProgressBar('64.7');</script> + <dd class="spec passed"><span class="passed_spec_name">can stub! and mock the same message</span></dd> + </dl> +</div> +<div class="behaviour"> + <dl> + <dt id="behaviour_5">A mock</dt> + <script type="text/javascript">moveProgressBar('70.5');</script> + <dd class="spec passed"><span class="passed_spec_name">can stub!</span></dd> + <script type="text/javascript">moveProgressBar('76.4');</script> + <dd class="spec passed"><span class="passed_spec_name">can stub! and mock</span></dd> + <script type="text/javascript">moveProgressBar('82.3');</script> + <dd class="spec passed"><span class="passed_spec_name">can stub! and mock the same message</span></dd> + </dl> +</div> +<div class="behaviour"> + <dl> + <dt id="behaviour_6">pending example (using pending method)</dt> + <script type="text/javascript">makeYellow('behaviour_6');</script> + <script type="text/javascript">moveProgressBar('88.2');</script> + <dd class="spec not_implemented"><span class="not_implemented_spec_name">should be reported as "PENDING: for some reason"</span></dd> + </dl> +</div> +<div class="behaviour"> + <dl> + <dt id="behaviour_7">pending example (with no block)</dt> + <script type="text/javascript">makeYellow('behaviour_7');</script> + <script type="text/javascript">moveProgressBar('94.1');</script> + <dd class="spec not_implemented"><span class="not_implemented_spec_name">should be reported as "PENDING: Not Yet Implemented"</span></dd> + </dl> +</div> +<div class="behaviour"> + <dl> + <dt id="behaviour_8">pending example (with block for pending)</dt> + <script type="text/javascript">makeYellow('behaviour_8');</script> + <script type="text/javascript">moveProgressBar('100.0');</script> + <dd class="spec not_implemented"><span class="not_implemented_spec_name">should have a failing block, passed to pending, reported as "PENDING: for some reason"</span></dd> + </dl> +</div> +<script type="text/javascript">document.getElementById('duration').innerHTML = "Finished in <strong>x seconds</strong>";</script> +<script type="text/javascript">document.getElementById('totals').innerHTML = "17 examples, 6 failures, 3 pending";</script> +</div> +</div> +</body> +</html> diff --git a/vendor/plugins/rspec/spec/spec/runner/formatter/html_formatted-1.8.5-jruby.html b/vendor/plugins/rspec/spec/spec/runner/formatter/html_formatted-1.8.5-jruby.html new file mode 100644 index 000000000..4f399d505 --- /dev/null +++ b/vendor/plugins/rspec/spec/spec/runner/formatter/html_formatted-1.8.5-jruby.html @@ -0,0 +1,376 @@ +<?xml version="1.0" encoding="iso-8859-1"?> +<!DOCTYPE html + PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" + "http://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd"> + +<html xmlns="http://www.w3.org/1999/xhtml" xml:lang="en" lang="en"> +<head> + <title>RSpec results</title> + <meta http-equiv="Content-Type" content="text/html; charset=iso-8859-1" /> + <meta http-equiv="Expires" content="-1" /> + <meta http-equiv="Pragma" content="no-cache" /> + <style type="text/css"> + body { + margin: 0; + padding: 0; + background: #fff; + font-size: 80%; + } + </style> +</head> +<body> + +<div class="rspec-report"> + <script type="text/javascript"> + // <![CDATA[ +function moveProgressBar(percentDone) { + document.getElementById("rspec-header").style.width = percentDone +"%"; +} +function makeRed(element_id) { + document.getElementById(element_id).style.background = '#C40D0D'; + document.getElementById(element_id).style.color = '#FFFFFF'; +} + +function makeYellow(element_id) { + if (element_id == "rspec-header" && document.getElementById(element_id).style.background != '#C40D0D') + { + document.getElementById(element_id).style.background = '#FAF834'; + document.getElementById(element_id).style.color = '#000000'; + } + else + { + document.getElementById(element_id).style.background = '#FAF834'; + document.getElementById(element_id).style.color = '#000000'; + } +} + + // ]]> + </script> + <style type="text/css"> +#rspec-header { + background: #65C400; color: #fff; +} + +.rspec-report h1 { + margin: 0px 10px 0px 10px; + padding: 10px; + font-family: "Lucida Grande", Helvetica, sans-serif; + font-size: 1.8em; +} + +#summary { + margin: 0; padding: 5px 10px; + font-family: "Lucida Grande", Helvetica, sans-serif; + text-align: right; + position: absolute; + top: 0px; + right: 0px; +} + +#summary p { + margin: 0 0 0 2px; +} + +#summary #totals { + font-size: 1.2em; +} + +.behaviour { + margin: 0 10px 5px; + background: #fff; +} + +dl { + margin: 0; padding: 0 0 5px; + font: normal 11px "Lucida Grande", Helvetica, sans-serif; +} + +dt { + padding: 3px; + background: #65C400; + color: #fff; + font-weight: bold; +} + +dd { + margin: 5px 0 5px 5px; + padding: 3px 3px 3px 18px; +} + +dd.spec.passed { + border-left: 5px solid #65C400; + border-bottom: 1px solid #65C400; + background: #DBFFB4; color: #3D7700; +} + +dd.spec.failed { + border-left: 5px solid #C20000; + border-bottom: 1px solid #C20000; + color: #C20000; background: #FFFBD3; +} + +dd.spec.not_implemented { + border-left: 5px solid #FAF834; + border-bottom: 1px solid #FAF834; + background: #FCFB98; color: #131313; +} + +dd.spec.pending_fixed { + border-left: 5px solid #0000C2; + border-bottom: 1px solid #0000C2; + color: #0000C2; background: #D3FBFF; +} + +.backtrace { + color: #000; + font-size: 12px; +} + +a { + color: #BE5C00; +} + +/* Ruby code, style similar to vibrant ink */ +.ruby { + font-size: 12px; + font-family: monospace; + color: white; + background-color: black; + padding: 0.1em 0 0.2em 0; +} + +.ruby .keyword { color: #FF6600; } +.ruby .constant { color: #339999; } +.ruby .attribute { color: white; } +.ruby .global { color: white; } +.ruby .module { color: white; } +.ruby .class { color: white; } +.ruby .string { color: #66FF00; } +.ruby .ident { color: white; } +.ruby .method { color: #FFCC00; } +.ruby .number { color: white; } +.ruby .char { color: white; } +.ruby .comment { color: #9933CC; } +.ruby .symbol { color: white; } +.ruby .regex { color: #44B4CC; } +.ruby .punct { color: white; } +.ruby .escape { color: white; } +.ruby .interp { color: white; } +.ruby .expr { color: white; } + +.ruby .offending { background-color: gray; } +.ruby .linenum { + width: 75px; + padding: 0.1em 1em 0.2em 0; + color: #000000; + background-color: #FFFBD3; +} + + </style> + +<div id="rspec-header"> + <h1>RSpec Results</h1> + + <div id="summary"> + <p id="totals"> </p> + <p id="duration"> </p> + </div> +</div> + +<div class="results"> + +<div class="behaviour"> + <dl> + <dt id="behaviour_1">Mocker</dt> + <script type="text/javascript">moveProgressBar('5.8');</script> + <dd class="spec passed"><span class="passed_spec_name">should be able to call mock()</span></dd> + <script type="text/javascript">makeRed('rspec-header');</script> + <script type="text/javascript">makeRed('behaviour_1');</script> + <script type="text/javascript">moveProgressBar('11.7');</script> + <dd class="spec failed"> + <span class="failed_spec_name">should fail when expected message not received</span> + <div class="failure" id="failure_1"> + <div class="message"><pre>Mock 'poke me' expected :poke with (any args) once, but received it 0 times</pre></div> + <div class="backtrace"><pre>./failing_examples/mocking_example.rb:13: +./spec/spec/runner/formatter/html_formatter_spec.rb:17: +./spec/spec/runner/formatter/html_formatter_spec.rb:13:</pre></div> + <pre class="ruby"><code><span class="linenum">11</span> it "should fail when expected message not received" do +<span class="linenum">12</span> mock = mock("poke me") +<span class="offending"><span class="linenum">13</span> mock.should_receive(:poke)</span> +<span class="linenum">14</span> end +<span class="linenum">15</span> +<span class="linenum">16</span><span class="comment"># gem install syntax to get syntax highlighting</span></code></pre> + </div> + </dd> + <script type="text/javascript">moveProgressBar('17.6');</script> + <dd class="spec failed"> + <span class="failed_spec_name">should fail when messages are received out of order</span> + <div class="failure" id="failure_2"> + <div class="message"><pre>Mock 'one two three' received :three out of order</pre></div> + <div class="backtrace"><pre>./failing_examples/mocking_example.rb:22: +./spec/spec/runner/formatter/html_formatter_spec.rb:17: +./spec/spec/runner/formatter/html_formatter_spec.rb:13:</pre></div> + <pre class="ruby"><code><span class="linenum">20</span> mock.should_receive(:three).ordered +<span class="linenum">21</span> mock.one +<span class="offending"><span class="linenum">22</span> mock.three</span> +<span class="linenum">23</span> mock.two +<span class="linenum">24</span> end +<span class="linenum">25</span><span class="comment"># gem install syntax to get syntax highlighting</span></code></pre> + </div> + </dd> + <script type="text/javascript">moveProgressBar('23.5');</script> + <dd class="spec failed"> + <span class="failed_spec_name">should get yelled at when sending unexpected messages</span> + <div class="failure" id="failure_3"> + <div class="message"><pre>Mock 'don't talk to me' expected :any_message_at_all with (any args) 0 times, but received it once</pre></div> + <div class="backtrace"><pre>./failing_examples/mocking_example.rb:28: +./spec/spec/runner/formatter/html_formatter_spec.rb:17: +./spec/spec/runner/formatter/html_formatter_spec.rb:13:</pre></div> + <pre class="ruby"><code><span class="linenum">26</span> it "should get yelled at when sending unexpected messages" do +<span class="linenum">27</span> mock = mock("don't talk to me") +<span class="offending"><span class="linenum">28</span> mock.should_not_receive(:any_message_at_all)</span> +<span class="linenum">29</span> mock.any_message_at_all +<span class="linenum">30</span> end +<span class="linenum">31</span><span class="comment"># gem install syntax to get syntax highlighting</span></code></pre> + </div> + </dd> + <script type="text/javascript">moveProgressBar('29.4');</script> + <dd class="spec pending_fixed"> + <span class="failed_spec_name">has a bug we need to fix</span> + <div class="failure" id="failure_4"> + <div class="message"><pre>Expected pending 'here is the bug' to fail. No Error was raised.</pre></div> + <div class="backtrace"><pre>./failing_examples/mocking_example.rb:33: +./spec/spec/runner/formatter/html_formatter_spec.rb:17: +./spec/spec/runner/formatter/html_formatter_spec.rb:13:</pre></div> + <pre class="ruby"><code><span class="linenum">31</span> +<span class="linenum">32</span> it "has a bug we need to fix" do +<span class="offending"><span class="linenum">33</span> pending "here is the bug" do</span> +<span class="linenum">34</span> # Actually, no. It's fixed. This will fail because it passes :-) +<span class="linenum">35</span> mock = mock("Bug") +<span class="linenum">36</span><span class="comment"># gem install syntax to get syntax highlighting</span></code></pre> + </div> + </dd> + </dl> +</div> +<div class="behaviour"> + <dl> + <dt id="behaviour_2">Running specs with --diff</dt> + <script type="text/javascript">makeRed('behaviour_2');</script> + <script type="text/javascript">moveProgressBar('35.2');</script> + <dd class="spec failed"> + <span class="failed_spec_name">should print diff of different strings</span> + <div class="failure" id="failure_5"> + <div class="message"><pre>expected: "RSpec is a\nbehaviour driven development\nframework for Ruby\n", + got: "RSpec is a\nbehavior driven development\nframework for Ruby\n" (using ==) +Diff: +@@ -1,4 +1,4 @@ + RSpec is a +-behavior driven development ++behaviour driven development + framework for Ruby +</pre></div> + <div class="backtrace"><pre>./failing_examples/diffing_spec.rb:13:in `==' +./failing_examples/diffing_spec.rb:13: +./spec/spec/runner/formatter/html_formatter_spec.rb:17: +./spec/spec/runner/formatter/html_formatter_spec.rb:13:</pre></div> + <pre class="ruby"><code><span class="linenum">11</span>framework for Ruby +<span class="linenum">12</span>EOF +<span class="offending"><span class="linenum">13</span> usa.should == uk</span> +<span class="linenum">14</span> end +<span class="linenum">15</span> +<span class="linenum">16</span><span class="comment"># gem install syntax to get syntax highlighting</span></code></pre> + </div> + </dd> + <script type="text/javascript">moveProgressBar('41.1');</script> + <dd class="spec failed"> + <span class="failed_spec_name">should print diff of different objects' pretty representation</span> + <div class="failure" id="failure_6"> + <div class="message"><pre>expected <Animal +name=bob, +species=tortoise +> +, got <Animal +name=bob, +species=giraffe +> + (using .eql?) +Diff: +@@ -1,5 +1,5 @@ + <Animal + name=bob, +-species=giraffe ++species=tortoise + > +</pre></div> + <div class="backtrace"><pre>./failing_examples/diffing_spec.rb:34: +./spec/spec/runner/formatter/html_formatter_spec.rb:17: +./spec/spec/runner/formatter/html_formatter_spec.rb:13:</pre></div> + <pre class="ruby"><code><span class="linenum">32</span> expected = Animal.new "bob", "giraffe" +<span class="linenum">33</span> actual = Animal.new "bob", "tortoise" +<span class="offending"><span class="linenum">34</span> expected.should eql(actual)</span> +<span class="linenum">35</span> end +<span class="linenum">36</span>end +<span class="linenum">37</span><span class="comment"># gem install syntax to get syntax highlighting</span></code></pre> + </div> + </dd> + </dl> +</div> +<div class="behaviour"> + <dl> + <dt id="behaviour_3">A consumer of a stub</dt> + <script type="text/javascript">moveProgressBar('47.0');</script> + <dd class="spec passed"><span class="passed_spec_name">should be able to stub methods on any Object</span></dd> + </dl> +</div> +<div class="behaviour"> + <dl> + <dt id="behaviour_4">A stubbed method on a class</dt> + <script type="text/javascript">moveProgressBar('52.9');</script> + <dd class="spec passed"><span class="passed_spec_name">should return the stubbed value</span></dd> + <script type="text/javascript">moveProgressBar('58.8');</script> + <dd class="spec passed"><span class="passed_spec_name">should revert to the original method after each spec</span></dd> + <script type="text/javascript">moveProgressBar('64.7');</script> + <dd class="spec passed"><span class="passed_spec_name">can stub! and mock the same message</span></dd> + </dl> +</div> +<div class="behaviour"> + <dl> + <dt id="behaviour_5">A mock</dt> + <script type="text/javascript">moveProgressBar('70.5');</script> + <dd class="spec passed"><span class="passed_spec_name">can stub!</span></dd> + <script type="text/javascript">moveProgressBar('76.4');</script> + <dd class="spec passed"><span class="passed_spec_name">can stub! and mock</span></dd> + <script type="text/javascript">moveProgressBar('82.3');</script> + <dd class="spec passed"><span class="passed_spec_name">can stub! and mock the same message</span></dd> + </dl> +</div> +<div class="behaviour"> + <dl> + <dt id="behaviour_6">pending example (using pending method)</dt> + <script type="text/javascript">makeYellow('behaviour_6');</script> + <script type="text/javascript">moveProgressBar('88.2');</script> + <dd class="spec not_implemented"><span class="not_implemented_spec_name">should be reported as "PENDING: for some reason"</span></dd> + </dl> +</div> +<div class="behaviour"> + <dl> + <dt id="behaviour_7">pending example (with no block)</dt> + <script type="text/javascript">makeYellow('behaviour_7');</script> + <script type="text/javascript">moveProgressBar('94.1');</script> + <dd class="spec not_implemented"><span class="not_implemented_spec_name">should be reported as "PENDING: Not Yet Implemented"</span></dd> + </dl> +</div> +<div class="behaviour"> + <dl> + <dt id="behaviour_8">pending example (with block for pending)</dt> + <script type="text/javascript">makeYellow('behaviour_8');</script> + <script type="text/javascript">moveProgressBar('100.0');</script> + <dd class="spec not_implemented"><span class="not_implemented_spec_name">should have a failing block, passed to pending, reported as "PENDING: for some reason"</span></dd> + </dl> +</div> +<script type="text/javascript">document.getElementById('duration').innerHTML = "Finished in <strong>x seconds</strong>";</script> +<script type="text/javascript">document.getElementById('totals').innerHTML = "17 examples, 6 failures, 3 pending";</script> +</div> +</div> +</body> +</html> diff --git a/vendor/plugins/rspec/spec/spec/runner/formatter/html_formatted-1.8.5.html b/vendor/plugins/rspec/spec/spec/runner/formatter/html_formatted-1.8.5.html new file mode 100644 index 000000000..e7630ddde --- /dev/null +++ b/vendor/plugins/rspec/spec/spec/runner/formatter/html_formatted-1.8.5.html @@ -0,0 +1,372 @@ +<?xml version="1.0" encoding="iso-8859-1"?> +<!DOCTYPE html + PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" + "http://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd"> + +<html xmlns="http://www.w3.org/1999/xhtml" xml:lang="en" lang="en"> +<head> + <title>RSpec results</title> + <meta http-equiv="Content-Type" content="text/html; charset=iso-8859-1" /> + <meta http-equiv="Expires" content="-1" /> + <meta http-equiv="Pragma" content="no-cache" /> + <style type="text/css"> + body { + margin: 0; + padding: 0; + background: #fff; + font-size: 80%; + } + </style> +</head> +<body> +<div class="rspec-report"> + <script type="text/javascript"> + // <![CDATA[ +function moveProgressBar(percentDone) { + document.getElementById("rspec-header").style.width = percentDone +"%"; +} +function makeRed(element_id) { + document.getElementById(element_id).style.background = '#C40D0D'; + document.getElementById(element_id).style.color = '#FFFFFF'; +} + +function makeYellow(element_id) { + if (element_id == "rspec-header" && document.getElementById(element_id).style.background != '#C40D0D') + { + document.getElementById(element_id).style.background = '#FAF834'; + document.getElementById(element_id).style.color = '#000000'; + } + else + { + document.getElementById(element_id).style.background = '#FAF834'; + document.getElementById(element_id).style.color = '#000000'; + } +} + + // ]]> + </script> + <style type="text/css"> +#rspec-header { + background: #65C400; color: #fff; +} + +.rspec-report h1 { + margin: 0px 10px 0px 10px; + padding: 10px; + font-family: "Lucida Grande", Helvetica, sans-serif; + font-size: 1.8em; +} + +#summary { + margin: 0; padding: 5px 10px; + font-family: "Lucida Grande", Helvetica, sans-serif; + text-align: right; + position: absolute; + top: 0px; + right: 0px; +} + +#summary p { + margin: 0 0 0 2px; +} + +#summary #totals { + font-size: 1.2em; +} + +.behaviour { + margin: 0 10px 5px; + background: #fff; +} + +dl { + margin: 0; padding: 0 0 5px; + font: normal 11px "Lucida Grande", Helvetica, sans-serif; +} + +dt { + padding: 3px; + background: #65C400; + color: #fff; + font-weight: bold; +} + +dd { + margin: 5px 0 5px 5px; + padding: 3px 3px 3px 18px; +} + +dd.spec.passed { + border-left: 5px solid #65C400; + border-bottom: 1px solid #65C400; + background: #DBFFB4; color: #3D7700; +} + +dd.spec.failed { + border-left: 5px solid #C20000; + border-bottom: 1px solid #C20000; + color: #C20000; background: #FFFBD3; +} + +dd.spec.not_implemented { + border-left: 5px solid #FAF834; + border-bottom: 1px solid #FAF834; + background: #FCFB98; color: #131313; +} + +dd.spec.pending_fixed { + border-left: 5px solid #0000C2; + border-bottom: 1px solid #0000C2; + color: #0000C2; background: #D3FBFF; +} + +.backtrace { + color: #000; + font-size: 12px; +} + +a { + color: #BE5C00; +} + +/* Ruby code, style similar to vibrant ink */ +.ruby { + font-size: 12px; + font-family: monospace; + color: white; + background-color: black; + padding: 0.1em 0 0.2em 0; +} + +.ruby .keyword { color: #FF6600; } +.ruby .constant { color: #339999; } +.ruby .attribute { color: white; } +.ruby .global { color: white; } +.ruby .module { color: white; } +.ruby .class { color: white; } +.ruby .string { color: #66FF00; } +.ruby .ident { color: white; } +.ruby .method { color: #FFCC00; } +.ruby .number { color: white; } +.ruby .char { color: white; } +.ruby .comment { color: #9933CC; } +.ruby .symbol { color: white; } +.ruby .regex { color: #44B4CC; } +.ruby .punct { color: white; } +.ruby .escape { color: white; } +.ruby .interp { color: white; } +.ruby .expr { color: white; } + +.ruby .offending { background-color: gray; } +.ruby .linenum { + width: 75px; + padding: 0.1em 1em 0.2em 0; + color: #000000; + background-color: #FFFBD3; +} + + </style> + +<div id="rspec-header"> + <h1>RSpec Results</h1> + + <div id="summary"> + <p id="totals"> </p> + <p id="duration"> </p> + </div> +</div> + +<div class="results"> +<div class="behaviour"> + <dl> + <dt id="behaviour_1">Mocker</dt> + <script type="text/javascript">moveProgressBar('5.8');</script> + <dd class="spec passed"><span class="passed_spec_name">should be able to call mock()</span></dd> + <script type="text/javascript">makeRed('rspec-header');</script> + <script type="text/javascript">makeRed('behaviour_1');</script> + <script type="text/javascript">moveProgressBar('11.7');</script> + <dd class="spec failed"> + <span class="failed_spec_name">should fail when expected message not received</span> + <div class="failure" id="failure_1"> + <div class="message"><pre>Mock 'poke me' expected :poke with (any args) once, but received it 0 times</pre></div> + <div class="backtrace"><pre>./failing_examples/mocking_example.rb:13: +./spec/spec/runner/formatter/html_formatter_spec.rb:17: +./spec/spec/runner/formatter/html_formatter_spec.rb:13:in `chdir' +./spec/spec/runner/formatter/html_formatter_spec.rb:13:</pre></div> + <pre class="ruby"><code><span class="linenum">11</span> <span class="ident">it</span> <span class="punct">"</span><span class="string">should fail when expected message not received</span><span class="punct">"</span> <span class="keyword">do</span> +<span class="linenum">12</span> <span class="ident">mock</span> <span class="punct">=</span> <span class="ident">mock</span><span class="punct">("</span><span class="string">poke me</span><span class="punct">")</span> +<span class="offending"><span class="linenum">13</span> <span class="ident">mock</span><span class="punct">.</span><span class="ident">should_receive</span><span class="punct">(</span><span class="symbol">:poke</span><span class="punct">)</span></span> +<span class="linenum">14</span> <span class="keyword">end</span> +<span class="linenum">15</span> </code></pre> + </div> + </dd> + <script type="text/javascript">moveProgressBar('17.6');</script> + <dd class="spec failed"> + <span class="failed_spec_name">should fail when messages are received out of order</span> + <div class="failure" id="failure_2"> + <div class="message"><pre>Mock 'one two three' received :three out of order</pre></div> + <div class="backtrace"><pre>./failing_examples/mocking_example.rb:22: +./spec/spec/runner/formatter/html_formatter_spec.rb:17: +./spec/spec/runner/formatter/html_formatter_spec.rb:13:in `chdir' +./spec/spec/runner/formatter/html_formatter_spec.rb:13:</pre></div> + <pre class="ruby"><code><span class="linenum">20</span> <span class="ident">mock</span><span class="punct">.</span><span class="ident">should_receive</span><span class="punct">(</span><span class="symbol">:three</span><span class="punct">).</span><span class="ident">ordered</span> +<span class="linenum">21</span> <span class="ident">mock</span><span class="punct">.</span><span class="ident">one</span> +<span class="offending"><span class="linenum">22</span> <span class="ident">mock</span><span class="punct">.</span><span class="ident">three</span></span> +<span class="linenum">23</span> <span class="ident">mock</span><span class="punct">.</span><span class="ident">two</span> +<span class="linenum">24</span> <span class="keyword">end</span></code></pre> + </div> + </dd> + <script type="text/javascript">moveProgressBar('23.5');</script> + <dd class="spec failed"> + <span class="failed_spec_name">should get yelled at when sending unexpected messages</span> + <div class="failure" id="failure_3"> + <div class="message"><pre>Mock 'don't talk to me' expected :any_message_at_all with (any args) 0 times, but received it once</pre></div> + <div class="backtrace"><pre>./failing_examples/mocking_example.rb:28: +./spec/spec/runner/formatter/html_formatter_spec.rb:17: +./spec/spec/runner/formatter/html_formatter_spec.rb:13:in `chdir' +./spec/spec/runner/formatter/html_formatter_spec.rb:13:</pre></div> + <pre class="ruby"><code><span class="linenum">26</span> <span class="ident">it</span> <span class="punct">"</span><span class="string">should get yelled at when sending unexpected messages</span><span class="punct">"</span> <span class="keyword">do</span> +<span class="linenum">27</span> <span class="ident">mock</span> <span class="punct">=</span> <span class="ident">mock</span><span class="punct">("</span><span class="string">don't talk to me</span><span class="punct">")</span> +<span class="offending"><span class="linenum">28</span> <span class="ident">mock</span><span class="punct">.</span><span class="ident">should_not_receive</span><span class="punct">(</span><span class="symbol">:any_message_at_all</span><span class="punct">)</span></span> +<span class="linenum">29</span> <span class="ident">mock</span><span class="punct">.</span><span class="ident">any_message_at_all</span> +<span class="linenum">30</span> <span class="keyword">end</span></code></pre> + </div> + </dd> + <script type="text/javascript">moveProgressBar('29.4');</script> + <dd class="spec pending_fixed"> + <span class="failed_spec_name">has a bug we need to fix</span> + <div class="failure" id="failure_4"> + <div class="message"><pre>Expected pending 'here is the bug' to fail. No Error was raised.</pre></div> + <div class="backtrace"><pre>./failing_examples/mocking_example.rb:33: +./spec/spec/runner/formatter/html_formatter_spec.rb:17: +./spec/spec/runner/formatter/html_formatter_spec.rb:13:in `chdir' +./spec/spec/runner/formatter/html_formatter_spec.rb:13:</pre></div> + <pre class="ruby"><code><span class="linenum">31</span> +<span class="linenum">32</span> <span class="ident">it</span> <span class="punct">"</span><span class="string">has a bug we need to fix</span><span class="punct">"</span> <span class="keyword">do</span> +<span class="offending"><span class="linenum">33</span> <span class="ident">pending</span> <span class="punct">"</span><span class="string">here is the bug</span><span class="punct">"</span> <span class="keyword">do</span></span> +<span class="linenum">34</span> <span class="comment"># Actually, no. It's fixed. This will fail because it passes :-)</span> +<span class="linenum">35</span> <span class="ident">mock</span> <span class="punct">=</span> <span class="ident">mock</span><span class="punct">("</span><span class="string">Bug</span><span class="punct">")</span></code></pre> + </div> + </dd> + </dl> +</div> +<div class="behaviour"> + <dl> + <dt id="behaviour_2">Running specs with --diff</dt> + <script type="text/javascript">makeRed('behaviour_2');</script> + <script type="text/javascript">moveProgressBar('35.2');</script> + <dd class="spec failed"> + <span class="failed_spec_name">should print diff of different strings</span> + <div class="failure" id="failure_5"> + <div class="message"><pre>expected: "RSpec is a\nbehaviour driven development\nframework for Ruby\n", + got: "RSpec is a\nbehavior driven development\nframework for Ruby\n" (using ==) +Diff: +@@ -1,4 +1,4 @@ + RSpec is a +-behavior driven development ++behaviour driven development + framework for Ruby +</pre></div> + <div class="backtrace"><pre>./failing_examples/diffing_spec.rb:13: +./spec/spec/runner/formatter/html_formatter_spec.rb:17: +./spec/spec/runner/formatter/html_formatter_spec.rb:13:in `chdir' +./spec/spec/runner/formatter/html_formatter_spec.rb:13:</pre></div> + <pre class="ruby"><code><span class="linenum">11</span><span class="ident">framework</span> <span class="keyword">for</span> <span class="constant">Ruby</span> +<span class="linenum">12</span><span class="constant">EOF</span> +<span class="offending"><span class="linenum">13</span> <span class="ident">usa</span><span class="punct">.</span><span class="ident">should</span> <span class="punct">==</span> <span class="ident">uk</span></span> +<span class="linenum">14</span> <span class="keyword">end</span></code></pre> + </div> + </dd> + <script type="text/javascript">moveProgressBar('41.1');</script> + <dd class="spec failed"> + <span class="failed_spec_name">should print diff of different objects' pretty representation</span> + <div class="failure" id="failure_6"> + <div class="message"><pre>expected <Animal +name=bob, +species=tortoise +> +, got <Animal +name=bob, +species=giraffe +> + (using .eql?) +Diff: +@@ -1,5 +1,5 @@ + <Animal + name=bob, +-species=giraffe ++species=tortoise + > +</pre></div> + <div class="backtrace"><pre>./failing_examples/diffing_spec.rb:34: +./spec/spec/runner/formatter/html_formatter_spec.rb:17: +./spec/spec/runner/formatter/html_formatter_spec.rb:13:in `chdir' +./spec/spec/runner/formatter/html_formatter_spec.rb:13:</pre></div> + <pre class="ruby"><code><span class="linenum">32</span> <span class="ident">expected</span> <span class="punct">=</span> <span class="constant">Animal</span><span class="punct">.</span><span class="ident">new</span> <span class="punct">"</span><span class="string">bob</span><span class="punct">",</span> <span class="punct">"</span><span class="string">giraffe</span><span class="punct">"</span> +<span class="linenum">33</span> <span class="ident">actual</span> <span class="punct">=</span> <span class="constant">Animal</span><span class="punct">.</span><span class="ident">new</span> <span class="punct">"</span><span class="string">bob</span><span class="punct">",</span> <span class="punct">"</span><span class="string">tortoise</span><span class="punct">"</span> +<span class="offending"><span class="linenum">34</span> <span class="ident">expected</span><span class="punct">.</span><span class="ident">should</span> <span class="ident">eql</span><span class="punct">(</span><span class="ident">actual</span><span class="punct">)</span></span> +<span class="linenum">35</span> <span class="keyword">end</span> +<span class="linenum">36</span><span class="keyword">end</span></code></pre> + </div> + </dd> + </dl> +</div> +<div class="behaviour"> + <dl> + <dt id="behaviour_3">A consumer of a stub</dt> + <script type="text/javascript">moveProgressBar('47.0');</script> + <dd class="spec passed"><span class="passed_spec_name">should be able to stub methods on any Object</span></dd> + </dl> +</div> +<div class="behaviour"> + <dl> + <dt id="behaviour_4">A stubbed method on a class</dt> + <script type="text/javascript">moveProgressBar('52.9');</script> + <dd class="spec passed"><span class="passed_spec_name">should return the stubbed value</span></dd> + <script type="text/javascript">moveProgressBar('58.8');</script> + <dd class="spec passed"><span class="passed_spec_name">should revert to the original method after each spec</span></dd> + <script type="text/javascript">moveProgressBar('64.7');</script> + <dd class="spec passed"><span class="passed_spec_name">can stub! and mock the same message</span></dd> + </dl> +</div> +<div class="behaviour"> + <dl> + <dt id="behaviour_5">A mock</dt> + <script type="text/javascript">moveProgressBar('70.5');</script> + <dd class="spec passed"><span class="passed_spec_name">can stub!</span></dd> + <script type="text/javascript">moveProgressBar('76.4');</script> + <dd class="spec passed"><span class="passed_spec_name">can stub! and mock</span></dd> + <script type="text/javascript">moveProgressBar('82.3');</script> + <dd class="spec passed"><span class="passed_spec_name">can stub! and mock the same message</span></dd> + </dl> +</div> +<div class="behaviour"> + <dl> + <dt id="behaviour_6">pending example (using pending method)</dt> + <script type="text/javascript">makeYellow('behaviour_6');</script> + <script type="text/javascript">moveProgressBar('88.2');</script> + <dd class="spec not_implemented"><span class="not_implemented_spec_name">should be reported as "PENDING: for some reason"</span></dd> + </dl> +</div> +<div class="behaviour"> + <dl> + <dt id="behaviour_7">pending example (with no block)</dt> + <script type="text/javascript">makeYellow('behaviour_7');</script> + <script type="text/javascript">moveProgressBar('94.1');</script> + <dd class="spec not_implemented"><span class="not_implemented_spec_name">should be reported as "PENDING: Not Yet Implemented"</span></dd> + </dl> +</div> +<div class="behaviour"> + <dl> + <dt id="behaviour_8">pending example (with block for pending)</dt> + <script type="text/javascript">makeYellow('behaviour_8');</script> + <script type="text/javascript">moveProgressBar('100.0');</script> + <dd class="spec not_implemented"><span class="not_implemented_spec_name">should have a failing block, passed to pending, reported as "PENDING: for some reason"</span></dd> + </dl> +</div> +<script type="text/javascript">document.getElementById('duration').innerHTML = "Finished in <strong>x seconds</strong>";</script> +<script type="text/javascript">document.getElementById('totals').innerHTML = "17 examples, 6 failures, 3 pending";</script> +</div> +</div> +</body> +</html> diff --git a/vendor/plugins/rspec/spec/spec/runner/formatter/html_formatted-1.8.6.html b/vendor/plugins/rspec/spec/spec/runner/formatter/html_formatted-1.8.6.html new file mode 100644 index 000000000..e7630ddde --- /dev/null +++ b/vendor/plugins/rspec/spec/spec/runner/formatter/html_formatted-1.8.6.html @@ -0,0 +1,372 @@ +<?xml version="1.0" encoding="iso-8859-1"?> +<!DOCTYPE html + PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" + "http://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd"> + +<html xmlns="http://www.w3.org/1999/xhtml" xml:lang="en" lang="en"> +<head> + <title>RSpec results</title> + <meta http-equiv="Content-Type" content="text/html; charset=iso-8859-1" /> + <meta http-equiv="Expires" content="-1" /> + <meta http-equiv="Pragma" content="no-cache" /> + <style type="text/css"> + body { + margin: 0; + padding: 0; + background: #fff; + font-size: 80%; + } + </style> +</head> +<body> +<div class="rspec-report"> + <script type="text/javascript"> + // <![CDATA[ +function moveProgressBar(percentDone) { + document.getElementById("rspec-header").style.width = percentDone +"%"; +} +function makeRed(element_id) { + document.getElementById(element_id).style.background = '#C40D0D'; + document.getElementById(element_id).style.color = '#FFFFFF'; +} + +function makeYellow(element_id) { + if (element_id == "rspec-header" && document.getElementById(element_id).style.background != '#C40D0D') + { + document.getElementById(element_id).style.background = '#FAF834'; + document.getElementById(element_id).style.color = '#000000'; + } + else + { + document.getElementById(element_id).style.background = '#FAF834'; + document.getElementById(element_id).style.color = '#000000'; + } +} + + // ]]> + </script> + <style type="text/css"> +#rspec-header { + background: #65C400; color: #fff; +} + +.rspec-report h1 { + margin: 0px 10px 0px 10px; + padding: 10px; + font-family: "Lucida Grande", Helvetica, sans-serif; + font-size: 1.8em; +} + +#summary { + margin: 0; padding: 5px 10px; + font-family: "Lucida Grande", Helvetica, sans-serif; + text-align: right; + position: absolute; + top: 0px; + right: 0px; +} + +#summary p { + margin: 0 0 0 2px; +} + +#summary #totals { + font-size: 1.2em; +} + +.behaviour { + margin: 0 10px 5px; + background: #fff; +} + +dl { + margin: 0; padding: 0 0 5px; + font: normal 11px "Lucida Grande", Helvetica, sans-serif; +} + +dt { + padding: 3px; + background: #65C400; + color: #fff; + font-weight: bold; +} + +dd { + margin: 5px 0 5px 5px; + padding: 3px 3px 3px 18px; +} + +dd.spec.passed { + border-left: 5px solid #65C400; + border-bottom: 1px solid #65C400; + background: #DBFFB4; color: #3D7700; +} + +dd.spec.failed { + border-left: 5px solid #C20000; + border-bottom: 1px solid #C20000; + color: #C20000; background: #FFFBD3; +} + +dd.spec.not_implemented { + border-left: 5px solid #FAF834; + border-bottom: 1px solid #FAF834; + background: #FCFB98; color: #131313; +} + +dd.spec.pending_fixed { + border-left: 5px solid #0000C2; + border-bottom: 1px solid #0000C2; + color: #0000C2; background: #D3FBFF; +} + +.backtrace { + color: #000; + font-size: 12px; +} + +a { + color: #BE5C00; +} + +/* Ruby code, style similar to vibrant ink */ +.ruby { + font-size: 12px; + font-family: monospace; + color: white; + background-color: black; + padding: 0.1em 0 0.2em 0; +} + +.ruby .keyword { color: #FF6600; } +.ruby .constant { color: #339999; } +.ruby .attribute { color: white; } +.ruby .global { color: white; } +.ruby .module { color: white; } +.ruby .class { color: white; } +.ruby .string { color: #66FF00; } +.ruby .ident { color: white; } +.ruby .method { color: #FFCC00; } +.ruby .number { color: white; } +.ruby .char { color: white; } +.ruby .comment { color: #9933CC; } +.ruby .symbol { color: white; } +.ruby .regex { color: #44B4CC; } +.ruby .punct { color: white; } +.ruby .escape { color: white; } +.ruby .interp { color: white; } +.ruby .expr { color: white; } + +.ruby .offending { background-color: gray; } +.ruby .linenum { + width: 75px; + padding: 0.1em 1em 0.2em 0; + color: #000000; + background-color: #FFFBD3; +} + + </style> + +<div id="rspec-header"> + <h1>RSpec Results</h1> + + <div id="summary"> + <p id="totals"> </p> + <p id="duration"> </p> + </div> +</div> + +<div class="results"> +<div class="behaviour"> + <dl> + <dt id="behaviour_1">Mocker</dt> + <script type="text/javascript">moveProgressBar('5.8');</script> + <dd class="spec passed"><span class="passed_spec_name">should be able to call mock()</span></dd> + <script type="text/javascript">makeRed('rspec-header');</script> + <script type="text/javascript">makeRed('behaviour_1');</script> + <script type="text/javascript">moveProgressBar('11.7');</script> + <dd class="spec failed"> + <span class="failed_spec_name">should fail when expected message not received</span> + <div class="failure" id="failure_1"> + <div class="message"><pre>Mock 'poke me' expected :poke with (any args) once, but received it 0 times</pre></div> + <div class="backtrace"><pre>./failing_examples/mocking_example.rb:13: +./spec/spec/runner/formatter/html_formatter_spec.rb:17: +./spec/spec/runner/formatter/html_formatter_spec.rb:13:in `chdir' +./spec/spec/runner/formatter/html_formatter_spec.rb:13:</pre></div> + <pre class="ruby"><code><span class="linenum">11</span> <span class="ident">it</span> <span class="punct">"</span><span class="string">should fail when expected message not received</span><span class="punct">"</span> <span class="keyword">do</span> +<span class="linenum">12</span> <span class="ident">mock</span> <span class="punct">=</span> <span class="ident">mock</span><span class="punct">("</span><span class="string">poke me</span><span class="punct">")</span> +<span class="offending"><span class="linenum">13</span> <span class="ident">mock</span><span class="punct">.</span><span class="ident">should_receive</span><span class="punct">(</span><span class="symbol">:poke</span><span class="punct">)</span></span> +<span class="linenum">14</span> <span class="keyword">end</span> +<span class="linenum">15</span> </code></pre> + </div> + </dd> + <script type="text/javascript">moveProgressBar('17.6');</script> + <dd class="spec failed"> + <span class="failed_spec_name">should fail when messages are received out of order</span> + <div class="failure" id="failure_2"> + <div class="message"><pre>Mock 'one two three' received :three out of order</pre></div> + <div class="backtrace"><pre>./failing_examples/mocking_example.rb:22: +./spec/spec/runner/formatter/html_formatter_spec.rb:17: +./spec/spec/runner/formatter/html_formatter_spec.rb:13:in `chdir' +./spec/spec/runner/formatter/html_formatter_spec.rb:13:</pre></div> + <pre class="ruby"><code><span class="linenum">20</span> <span class="ident">mock</span><span class="punct">.</span><span class="ident">should_receive</span><span class="punct">(</span><span class="symbol">:three</span><span class="punct">).</span><span class="ident">ordered</span> +<span class="linenum">21</span> <span class="ident">mock</span><span class="punct">.</span><span class="ident">one</span> +<span class="offending"><span class="linenum">22</span> <span class="ident">mock</span><span class="punct">.</span><span class="ident">three</span></span> +<span class="linenum">23</span> <span class="ident">mock</span><span class="punct">.</span><span class="ident">two</span> +<span class="linenum">24</span> <span class="keyword">end</span></code></pre> + </div> + </dd> + <script type="text/javascript">moveProgressBar('23.5');</script> + <dd class="spec failed"> + <span class="failed_spec_name">should get yelled at when sending unexpected messages</span> + <div class="failure" id="failure_3"> + <div class="message"><pre>Mock 'don't talk to me' expected :any_message_at_all with (any args) 0 times, but received it once</pre></div> + <div class="backtrace"><pre>./failing_examples/mocking_example.rb:28: +./spec/spec/runner/formatter/html_formatter_spec.rb:17: +./spec/spec/runner/formatter/html_formatter_spec.rb:13:in `chdir' +./spec/spec/runner/formatter/html_formatter_spec.rb:13:</pre></div> + <pre class="ruby"><code><span class="linenum">26</span> <span class="ident">it</span> <span class="punct">"</span><span class="string">should get yelled at when sending unexpected messages</span><span class="punct">"</span> <span class="keyword">do</span> +<span class="linenum">27</span> <span class="ident">mock</span> <span class="punct">=</span> <span class="ident">mock</span><span class="punct">("</span><span class="string">don't talk to me</span><span class="punct">")</span> +<span class="offending"><span class="linenum">28</span> <span class="ident">mock</span><span class="punct">.</span><span class="ident">should_not_receive</span><span class="punct">(</span><span class="symbol">:any_message_at_all</span><span class="punct">)</span></span> +<span class="linenum">29</span> <span class="ident">mock</span><span class="punct">.</span><span class="ident">any_message_at_all</span> +<span class="linenum">30</span> <span class="keyword">end</span></code></pre> + </div> + </dd> + <script type="text/javascript">moveProgressBar('29.4');</script> + <dd class="spec pending_fixed"> + <span class="failed_spec_name">has a bug we need to fix</span> + <div class="failure" id="failure_4"> + <div class="message"><pre>Expected pending 'here is the bug' to fail. No Error was raised.</pre></div> + <div class="backtrace"><pre>./failing_examples/mocking_example.rb:33: +./spec/spec/runner/formatter/html_formatter_spec.rb:17: +./spec/spec/runner/formatter/html_formatter_spec.rb:13:in `chdir' +./spec/spec/runner/formatter/html_formatter_spec.rb:13:</pre></div> + <pre class="ruby"><code><span class="linenum">31</span> +<span class="linenum">32</span> <span class="ident">it</span> <span class="punct">"</span><span class="string">has a bug we need to fix</span><span class="punct">"</span> <span class="keyword">do</span> +<span class="offending"><span class="linenum">33</span> <span class="ident">pending</span> <span class="punct">"</span><span class="string">here is the bug</span><span class="punct">"</span> <span class="keyword">do</span></span> +<span class="linenum">34</span> <span class="comment"># Actually, no. It's fixed. This will fail because it passes :-)</span> +<span class="linenum">35</span> <span class="ident">mock</span> <span class="punct">=</span> <span class="ident">mock</span><span class="punct">("</span><span class="string">Bug</span><span class="punct">")</span></code></pre> + </div> + </dd> + </dl> +</div> +<div class="behaviour"> + <dl> + <dt id="behaviour_2">Running specs with --diff</dt> + <script type="text/javascript">makeRed('behaviour_2');</script> + <script type="text/javascript">moveProgressBar('35.2');</script> + <dd class="spec failed"> + <span class="failed_spec_name">should print diff of different strings</span> + <div class="failure" id="failure_5"> + <div class="message"><pre>expected: "RSpec is a\nbehaviour driven development\nframework for Ruby\n", + got: "RSpec is a\nbehavior driven development\nframework for Ruby\n" (using ==) +Diff: +@@ -1,4 +1,4 @@ + RSpec is a +-behavior driven development ++behaviour driven development + framework for Ruby +</pre></div> + <div class="backtrace"><pre>./failing_examples/diffing_spec.rb:13: +./spec/spec/runner/formatter/html_formatter_spec.rb:17: +./spec/spec/runner/formatter/html_formatter_spec.rb:13:in `chdir' +./spec/spec/runner/formatter/html_formatter_spec.rb:13:</pre></div> + <pre class="ruby"><code><span class="linenum">11</span><span class="ident">framework</span> <span class="keyword">for</span> <span class="constant">Ruby</span> +<span class="linenum">12</span><span class="constant">EOF</span> +<span class="offending"><span class="linenum">13</span> <span class="ident">usa</span><span class="punct">.</span><span class="ident">should</span> <span class="punct">==</span> <span class="ident">uk</span></span> +<span class="linenum">14</span> <span class="keyword">end</span></code></pre> + </div> + </dd> + <script type="text/javascript">moveProgressBar('41.1');</script> + <dd class="spec failed"> + <span class="failed_spec_name">should print diff of different objects' pretty representation</span> + <div class="failure" id="failure_6"> + <div class="message"><pre>expected <Animal +name=bob, +species=tortoise +> +, got <Animal +name=bob, +species=giraffe +> + (using .eql?) +Diff: +@@ -1,5 +1,5 @@ + <Animal + name=bob, +-species=giraffe ++species=tortoise + > +</pre></div> + <div class="backtrace"><pre>./failing_examples/diffing_spec.rb:34: +./spec/spec/runner/formatter/html_formatter_spec.rb:17: +./spec/spec/runner/formatter/html_formatter_spec.rb:13:in `chdir' +./spec/spec/runner/formatter/html_formatter_spec.rb:13:</pre></div> + <pre class="ruby"><code><span class="linenum">32</span> <span class="ident">expected</span> <span class="punct">=</span> <span class="constant">Animal</span><span class="punct">.</span><span class="ident">new</span> <span class="punct">"</span><span class="string">bob</span><span class="punct">",</span> <span class="punct">"</span><span class="string">giraffe</span><span class="punct">"</span> +<span class="linenum">33</span> <span class="ident">actual</span> <span class="punct">=</span> <span class="constant">Animal</span><span class="punct">.</span><span class="ident">new</span> <span class="punct">"</span><span class="string">bob</span><span class="punct">",</span> <span class="punct">"</span><span class="string">tortoise</span><span class="punct">"</span> +<span class="offending"><span class="linenum">34</span> <span class="ident">expected</span><span class="punct">.</span><span class="ident">should</span> <span class="ident">eql</span><span class="punct">(</span><span class="ident">actual</span><span class="punct">)</span></span> +<span class="linenum">35</span> <span class="keyword">end</span> +<span class="linenum">36</span><span class="keyword">end</span></code></pre> + </div> + </dd> + </dl> +</div> +<div class="behaviour"> + <dl> + <dt id="behaviour_3">A consumer of a stub</dt> + <script type="text/javascript">moveProgressBar('47.0');</script> + <dd class="spec passed"><span class="passed_spec_name">should be able to stub methods on any Object</span></dd> + </dl> +</div> +<div class="behaviour"> + <dl> + <dt id="behaviour_4">A stubbed method on a class</dt> + <script type="text/javascript">moveProgressBar('52.9');</script> + <dd class="spec passed"><span class="passed_spec_name">should return the stubbed value</span></dd> + <script type="text/javascript">moveProgressBar('58.8');</script> + <dd class="spec passed"><span class="passed_spec_name">should revert to the original method after each spec</span></dd> + <script type="text/javascript">moveProgressBar('64.7');</script> + <dd class="spec passed"><span class="passed_spec_name">can stub! and mock the same message</span></dd> + </dl> +</div> +<div class="behaviour"> + <dl> + <dt id="behaviour_5">A mock</dt> + <script type="text/javascript">moveProgressBar('70.5');</script> + <dd class="spec passed"><span class="passed_spec_name">can stub!</span></dd> + <script type="text/javascript">moveProgressBar('76.4');</script> + <dd class="spec passed"><span class="passed_spec_name">can stub! and mock</span></dd> + <script type="text/javascript">moveProgressBar('82.3');</script> + <dd class="spec passed"><span class="passed_spec_name">can stub! and mock the same message</span></dd> + </dl> +</div> +<div class="behaviour"> + <dl> + <dt id="behaviour_6">pending example (using pending method)</dt> + <script type="text/javascript">makeYellow('behaviour_6');</script> + <script type="text/javascript">moveProgressBar('88.2');</script> + <dd class="spec not_implemented"><span class="not_implemented_spec_name">should be reported as "PENDING: for some reason"</span></dd> + </dl> +</div> +<div class="behaviour"> + <dl> + <dt id="behaviour_7">pending example (with no block)</dt> + <script type="text/javascript">makeYellow('behaviour_7');</script> + <script type="text/javascript">moveProgressBar('94.1');</script> + <dd class="spec not_implemented"><span class="not_implemented_spec_name">should be reported as "PENDING: Not Yet Implemented"</span></dd> + </dl> +</div> +<div class="behaviour"> + <dl> + <dt id="behaviour_8">pending example (with block for pending)</dt> + <script type="text/javascript">makeYellow('behaviour_8');</script> + <script type="text/javascript">moveProgressBar('100.0');</script> + <dd class="spec not_implemented"><span class="not_implemented_spec_name">should have a failing block, passed to pending, reported as "PENDING: for some reason"</span></dd> + </dl> +</div> +<script type="text/javascript">document.getElementById('duration').innerHTML = "Finished in <strong>x seconds</strong>";</script> +<script type="text/javascript">document.getElementById('totals').innerHTML = "17 examples, 6 failures, 3 pending";</script> +</div> +</div> +</body> +</html> diff --git a/vendor/plugins/rspec/spec/spec/runner/formatter/html_formatter_spec.rb b/vendor/plugins/rspec/spec/spec/runner/formatter/html_formatter_spec.rb new file mode 100644 index 000000000..fad3aed1a --- /dev/null +++ b/vendor/plugins/rspec/spec/spec/runner/formatter/html_formatter_spec.rb @@ -0,0 +1,56 @@ +require File.dirname(__FILE__) + '/../../../spec_helper.rb' + +describe "HtmlFormatter" do + ['--diff', '--dry-run'].each do |opt| + it "should produce HTML identical to the one we designed manually with #{opt}" do + root = File.expand_path(File.dirname(__FILE__) + '/../../../..') + suffix = PLATFORM == 'java' ? '-jruby' : '' + expected_file = File.dirname(__FILE__) + "/html_formatted-#{VERSION}#{suffix}.html" + raise "There is no HTML file with expected content for this platform: #{expected_file}" unless File.file?(expected_file) + expected_html = File.read(expected_file) + raise "There should be no absolute paths in html_formatted.html!!" if (expected_html =~ /\/Users/n || expected_html =~ /\/home/n) + + Dir.chdir(root) do + args = ['failing_examples/mocking_example.rb', 'failing_examples/diffing_spec.rb', 'examples/stubbing_example.rb', 'examples/pending_example.rb', '--format', 'html', opt] + err = StringIO.new + out = StringIO.new + Spec::Runner::CommandLine.run( + args, + err, + out, + false + ) + + seconds = /\d+\.\d+ seconds/ + html = out.string.gsub seconds, 'x seconds' + expected_html.gsub! seconds, 'x seconds' + + if opt == '--diff' + # Uncomment this line temporarily in order to overwrite the expected with actual. + # Use with care!!! + # File.open(expected_file, 'w') {|io| io.write(html)} + + doc = Hpricot(html) + backtraces = doc.search("div.backtrace").collect {|e| e.at("/pre").inner_html} + doc.search("div.backtrace").remove + + expected_doc = Hpricot(expected_html) + expected_backtraces = expected_doc.search("div.backtrace").collect {|e| e.at("/pre").inner_html} + expected_doc.search("div.backtrace").remove + + doc.inner_html.should == expected_doc.inner_html + + expected_backtraces.each_with_index do |expected_line, i| + expected_path, expected_line_number, expected_suffix = expected_line.split(':') + actual_path, actual_line_number, actual_suffix = backtraces[i].split(':') + File.expand_path(actual_path).should == File.expand_path(expected_path) + actual_line_number.should == expected_line_number + end + else + html.should =~ /This was a dry-run/m + end + end + end + end + +end diff --git a/vendor/plugins/rspec/spec/spec/runner/formatter/progress_bar_formatter_dry_run_spec.rb b/vendor/plugins/rspec/spec/spec/runner/formatter/progress_bar_formatter_dry_run_spec.rb new file mode 100644 index 000000000..170fc441a --- /dev/null +++ b/vendor/plugins/rspec/spec/spec/runner/formatter/progress_bar_formatter_dry_run_spec.rb @@ -0,0 +1,20 @@ +require File.dirname(__FILE__) + '/../../../spec_helper.rb' + +module Spec + module Runner + module Formatter + describe ProgressBarFormatter, "dry run" do + before(:each) do + @io = StringIO.new + @formatter = ProgressBarFormatter.new(@io) + @formatter.dry_run = true + end + + it "should not produce summary on dry run" do + @formatter.dump_summary(3, 2, 1, 0) + @io.string.should eql("") + end + end + end + end +end diff --git a/vendor/plugins/rspec/spec/spec/runner/formatter/progress_bar_formatter_failure_dump_spec.rb b/vendor/plugins/rspec/spec/spec/runner/formatter/progress_bar_formatter_failure_dump_spec.rb new file mode 100644 index 000000000..04e3d9785 --- /dev/null +++ b/vendor/plugins/rspec/spec/spec/runner/formatter/progress_bar_formatter_failure_dump_spec.rb @@ -0,0 +1,36 @@ +require File.dirname(__FILE__) + '/../../../spec_helper.rb' + +module Spec + module Runner + module Formatter + describe "ProgressBarFormatter failure dump with NoisyBacktraceTweaker" do + before(:each) do + @io = StringIO.new + @reporter = Reporter.new([ProgressBarFormatter.new(@io)], NoisyBacktraceTweaker.new) + @reporter.add_behaviour(Spec::DSL::Description.new("context")) + end + + it "should end with line break" do + error=Spec::Expectations::ExpectationNotMetError.new("message") + set_backtrace(error) + @reporter.example_finished("spec", error, "spec") + @reporter.dump + @io.string.should match(/\n\z/) + end + + it "should include context and spec name in backtrace if error in spec" do + error=RuntimeError.new("message") + set_backtrace(error) + @reporter.example_finished("spec", error, "spec") + @reporter.dump + @io.string.should match(/RuntimeError in 'context spec'/) + end + + def set_backtrace(error) + error.set_backtrace(["/a/b/c/d/e.rb:34:in `whatever'"]) + end + + end + end + end +end diff --git a/vendor/plugins/rspec/spec/spec/runner/formatter/progress_bar_formatter_spec.rb b/vendor/plugins/rspec/spec/spec/runner/formatter/progress_bar_formatter_spec.rb new file mode 100644 index 000000000..50fc12689 --- /dev/null +++ b/vendor/plugins/rspec/spec/spec/runner/formatter/progress_bar_formatter_spec.rb @@ -0,0 +1,111 @@ +require File.dirname(__FILE__) + '/../../../spec_helper.rb' + +module Spec + module Runner + module Formatter + describe ProgressBarFormatter do + before(:each) do + @io = StringIO.new + @formatter = ProgressBarFormatter.new(@io) + end + + it "should produce line break on start dump" do + @formatter.start_dump + @io.string.should eql("\n") + end + + it "should produce standard summary without pending when pending has a 0 count" do + @formatter.dump_summary(3, 2, 1, 0) + @io.string.should eql("\nFinished in 3 seconds\n\n2 examples, 1 failure\n") + end + + it "should produce standard summary" do + @formatter.example_pending("behaviour", "example", "message") + @io.rewind + @formatter.dump_summary(3, 2, 1, 1) + @io.string.should eql(%Q| +Finished in 3 seconds + +2 examples, 1 failure, 1 pending + +Pending: +behaviour example (message) +|) + end + + it "should push green dot for passing spec" do + @io.should_receive(:tty?).and_return(true) + @formatter.colour = true + @formatter.example_passed("spec") + @io.string.should == "\e[32m.\e[0m" + end + + it "should push red F for failure spec" do + @io.should_receive(:tty?).and_return(true) + @formatter.colour = true + @formatter.example_failed("spec", 98, Reporter::Failure.new("c s", Spec::Expectations::ExpectationNotMetError.new)) + @io.string.should eql("\e[31mF\e[0m") + end + + it "should push magenta F for error spec" do + @io.should_receive(:tty?).and_return(true) + @formatter.colour = true + @formatter.example_failed("spec", 98, Reporter::Failure.new("c s", RuntimeError.new)) + @io.string.should eql("\e[35mF\e[0m") + end + + it "should push blue F for fixed pending spec" do + @io.should_receive(:tty?).and_return(true) + @formatter.colour = true + @formatter.example_failed("spec", 98, Reporter::Failure.new("c s", Spec::DSL::PendingFixedError.new)) + @io.string.should eql("\e[34mF\e[0m") + end + + it "should push nothing on start" do + @formatter.start(4) + @io.string.should eql("") + end + + it "should ensure two ':' in the first backtrace" do + backtrace = ["/tmp/x.rb:1", "/tmp/x.rb:2", "/tmp/x.rb:3"] + @formatter.format_backtrace(backtrace).should eql(<<-EOE.rstrip) +/tmp/x.rb:1: +/tmp/x.rb:2: +/tmp/x.rb:3: +EOE + + backtrace = ["/tmp/x.rb:1: message", "/tmp/x.rb:2", "/tmp/x.rb:3"] + @formatter.format_backtrace(backtrace).should eql(<<-EOE.rstrip) +/tmp/x.rb:1: message +/tmp/x.rb:2: +/tmp/x.rb:3: +EOE + end + + it "should dump pending" do + @formatter.example_pending("behaviour", "example", "message") + @formatter.dump_pending + @io.string.should =~ /Pending\:\nbehaviour example \(message\)\n/ + end + end + + describe "ProgressBarFormatter outputting to custom out" do + before(:each) do + @out = mock("out") + @out.stub!(:puts) + @formatter = ProgressBarFormatter.new(@out) + @formatter.class.send :public, :output_to_tty? + end + + after(:each) do + @formatter.class.send :protected, :output_to_tty? + end + + it "should not throw NoMethodError on output_to_tty?" do + @out.should_receive(:tty?).and_raise(NoMethodError) + @formatter.output_to_tty?.should be_false + end + end + end + end +end diff --git a/vendor/plugins/rspec/spec/spec/runner/formatter/rdoc_formatter_dry_run_spec.rb b/vendor/plugins/rspec/spec/spec/runner/formatter/rdoc_formatter_dry_run_spec.rb new file mode 100644 index 000000000..c864162ed --- /dev/null +++ b/vendor/plugins/rspec/spec/spec/runner/formatter/rdoc_formatter_dry_run_spec.rb @@ -0,0 +1,19 @@ +require File.dirname(__FILE__) + '/../../../spec_helper.rb' + +module Spec +module Runner +module Formatter +describe "RdocFormatterDryRun" do + before(:each) do + @io = StringIO.new + @formatter = RdocFormatter.new(@io) + @formatter.dry_run = true + end + it "should not produce summary on dry run" do + @formatter.dump_summary(3, 2, 1, 0) + @io.string.should == "" + end +end +end +end +end diff --git a/vendor/plugins/rspec/spec/spec/runner/formatter/rdoc_formatter_spec.rb b/vendor/plugins/rspec/spec/spec/runner/formatter/rdoc_formatter_spec.rb new file mode 100644 index 000000000..728a515f1 --- /dev/null +++ b/vendor/plugins/rspec/spec/spec/runner/formatter/rdoc_formatter_spec.rb @@ -0,0 +1,46 @@ +require File.dirname(__FILE__) + '/../../../spec_helper.rb' + +module Spec + module Runner + module Formatter + describe "RdocFormatter" do + before(:each) do + @io = StringIO.new + @formatter = RdocFormatter.new(@io) + @formatter.dry_run = true + end + + it "should produce no summary" do + @formatter.dump_summary(nil, nil, nil, nil) + @io.string.should be_empty + end + + it "should produce nothing on start dump" do + @formatter.start_dump + @io.string.should be_empty + end + + it "should push out context" do + @formatter.add_behaviour(Spec::DSL::Description.new("context")) + @io.string.should eql("# context\n") + end + + it "should push out failed spec" do + @formatter.example_failed(DSL::Example.new("spec"), 98, nil) + @io.string.should eql("# * spec [98 - FAILED]\n") + end + + it "should push out spec" do + @formatter.example_passed(DSL::Example.new("spec")) + @io.string.should eql("# * spec\n") + end + + it "should push out not pending example" do + @formatter.example_pending("behaviour", "example", "reason") + @io.string.should eql("# * behaviour example [PENDING: reason]\n") + end + + end + end + end +end diff --git a/vendor/plugins/rspec/spec/spec/runner/formatter/snippet_extractor_spec.rb b/vendor/plugins/rspec/spec/spec/runner/formatter/snippet_extractor_spec.rb new file mode 100644 index 000000000..dce5c2ff2 --- /dev/null +++ b/vendor/plugins/rspec/spec/spec/runner/formatter/snippet_extractor_spec.rb @@ -0,0 +1,11 @@ +require File.dirname(__FILE__) + '/../../../spec_helper.rb' + +describe Spec::Runner::Formatter::SnippetExtractor do + it "should fall back on a default message when it doesn't understand a line" do + Spec::Runner::Formatter::SnippetExtractor.new.snippet_for("blech").should == ["# Couldn't get snippet for blech", 1] + end + + it "should fall back on a default message when it doesn't find the file" do + Spec::Runner::Formatter::SnippetExtractor.new.lines_around("blech", 8).should == "# Couldn't get snippet for blech" + end +end diff --git a/vendor/plugins/rspec/spec/spec/runner/formatter/specdoc_formatter_dry_run_spec.rb b/vendor/plugins/rspec/spec/spec/runner/formatter/specdoc_formatter_dry_run_spec.rb new file mode 100644 index 000000000..c86899cb1 --- /dev/null +++ b/vendor/plugins/rspec/spec/spec/runner/formatter/specdoc_formatter_dry_run_spec.rb @@ -0,0 +1,21 @@ +require File.dirname(__FILE__) + '/../../../spec_helper.rb' + +module Spec +module Runner +module Formatter +describe "SpecdocFormatterDryRun" do + before(:each) do + @io = StringIO.new + @formatter = SpecdocFormatter.new(@io) + @formatter.dry_run = true + end + it "should not produce summary on dry run" do + @formatter.dump_summary(3, 2, 1, 0) + @io.string.should eql("") + + end + +end +end +end +end diff --git a/vendor/plugins/rspec/spec/spec/runner/formatter/specdoc_formatter_spec.rb b/vendor/plugins/rspec/spec/spec/runner/formatter/specdoc_formatter_spec.rb new file mode 100644 index 000000000..14f436036 --- /dev/null +++ b/vendor/plugins/rspec/spec/spec/runner/formatter/specdoc_formatter_spec.rb @@ -0,0 +1,62 @@ +require File.dirname(__FILE__) + '/../../../spec_helper.rb' + +module Spec + module Runner + module Formatter + describe "SpecdocFormatter" do + before(:each) do + @io = StringIO.new + @formatter = SpecdocFormatter.new(@io) + end + + it "should produce standard summary without pending when pending has a 0 count" do + @formatter.dump_summary(3, 2, 1, 0) + @io.string.should eql("\nFinished in 3 seconds\n\n2 examples, 1 failure\n") + end + + it "should produce standard summary" do + @formatter.dump_summary(3, 2, 1, 4) + @io.string.should eql("\nFinished in 3 seconds\n\n2 examples, 1 failure, 4 pending\n") + end + + it "should push context name" do + @formatter.add_behaviour(Spec::DSL::Description.new("context")) + @io.string.should eql("\ncontext\n") + end + + it "should push failing spec name and failure number" do + @formatter.example_failed(DSL::Example.new("spec"), 98, Reporter::Failure.new("c s", RuntimeError.new)) + @io.string.should eql("- spec (ERROR - 98)\n") + end + + it "should push nothing on start" do + @formatter.start(5) + @io.string.should eql("") + end + + it "should push nothing on start dump" do + @formatter.start_dump + @io.string.should eql("") + end + + it "should push passing spec name" do + @formatter.example_passed(DSL::Example.new("spec")) + @io.string.should eql("- spec\n") + end + + it "should push pending example name and message" do + @formatter.example_pending('behaviour', 'example','reason') + @io.string.should eql("- example (PENDING: reason)\n") + end + + it "should dump pending" do + @formatter.example_pending('behaviour', 'example','reason') + @io.rewind + @formatter.dump_pending + @io.string.should =~ /Pending\:\nbehaviour example \(reason\)\n/ + end + + end + end + end +end diff --git a/vendor/plugins/rspec/spec/spec/runner/heckle_runner_spec.rb b/vendor/plugins/rspec/spec/spec/runner/heckle_runner_spec.rb new file mode 100644 index 000000000..1f5d11759 --- /dev/null +++ b/vendor/plugins/rspec/spec/spec/runner/heckle_runner_spec.rb @@ -0,0 +1,63 @@ +require File.dirname(__FILE__) + '/../../spec_helper.rb' +unless [/mswin/, /java/].detect{|p| p =~ RUBY_PLATFORM} + require 'spec/runner/heckle_runner' + + module Foo + class Bar + def one; end + def two; end + end + + class Zap + def three; end + def four; end + end + end + + describe "HeckleRunner" do + before(:each) do + @heckle = mock("heckle", :null_object => true) + @behaviour_runner = mock("behaviour_runner") + @heckle_class = mock("heckle_class") + end + + it "should heckle all methods in all classes in a module" do + @heckle_class.should_receive(:new).with("Foo::Bar", "one", behaviour_runner).and_return(@heckle) + @heckle_class.should_receive(:new).with("Foo::Bar", "two", behaviour_runner).and_return(@heckle) + @heckle_class.should_receive(:new).with("Foo::Zap", "three", behaviour_runner).and_return(@heckle) + @heckle_class.should_receive(:new).with("Foo::Zap", "four", behaviour_runner).and_return(@heckle) + + heckle_runner = Spec::Runner::HeckleRunner.new("Foo", @heckle_class) + heckle_runner.heckle_with(behaviour_runner) + end + + it "should heckle all methods in a class" do + @heckle_class.should_receive(:new).with("Foo::Bar", "one", behaviour_runner).and_return(@heckle) + @heckle_class.should_receive(:new).with("Foo::Bar", "two", behaviour_runner).and_return(@heckle) + + heckle_runner = Spec::Runner::HeckleRunner.new("Foo::Bar", @heckle_class) + heckle_runner.heckle_with(behaviour_runner) + end + + it "should fail heckling when the class is not found" do + lambda do + heckle_runner = Spec::Runner::HeckleRunner.new("Foo::Bob", @heckle_class) + heckle_runner.heckle_with(behaviour_runner) + end.should raise_error(StandardError, "Heckling failed - \"Foo::Bob\" is not a known class or module") + end + + it "should heckle specific method in a class (with #)" do + @heckle_class.should_receive(:new).with("Foo::Bar", "two", behaviour_runner).and_return(@heckle) + + heckle_runner = Spec::Runner::HeckleRunner.new("Foo::Bar#two", @heckle_class) + heckle_runner.heckle_with(behaviour_runner) + end + + it "should heckle specific method in a class (with .)" do + @heckle_class.should_receive(:new).with("Foo::Bar", "two", behaviour_runner).and_return(@heckle) + + heckle_runner = Spec::Runner::HeckleRunner.new("Foo::Bar.two", @heckle_class) + heckle_runner.heckle_with(behaviour_runner) + end + end +end diff --git a/vendor/plugins/rspec/spec/spec/runner/heckler_spec.rb b/vendor/plugins/rspec/spec/spec/runner/heckler_spec.rb new file mode 100644 index 000000000..31d33ab5e --- /dev/null +++ b/vendor/plugins/rspec/spec/spec/runner/heckler_spec.rb @@ -0,0 +1,14 @@ +require File.dirname(__FILE__) + '/../../spec_helper.rb' +unless [/mswin/, /java/].detect{|p| p =~ RUBY_PLATFORM} + require 'spec/runner/heckle_runner' + + describe "Heckler" do + it "should run behaviour_runner on tests_pass?" do + behaviour_runner = mock("behaviour_runner") + behaviour_runner.should_receive(:run).with([], false) + heckler = Spec::Runner::Heckler.new('Array', 'push', behaviour_runner) + + heckler.tests_pass? + end + end +end diff --git a/vendor/plugins/rspec/spec/spec/runner/noisy_backtrace_tweaker_spec.rb b/vendor/plugins/rspec/spec/spec/runner/noisy_backtrace_tweaker_spec.rb new file mode 100644 index 000000000..522d346d9 --- /dev/null +++ b/vendor/plugins/rspec/spec/spec/runner/noisy_backtrace_tweaker_spec.rb @@ -0,0 +1,45 @@ +require File.dirname(__FILE__) + '/../../spec_helper.rb' + +module Spec + module Runner + describe "NoisyBacktraceTweaker" do + before(:each) do + @error = RuntimeError.new + @tweaker = NoisyBacktraceTweaker.new + end + + it "should leave anything in lib spec dir" do + ["expectations", "mocks", "runner", "stubs"].each do |child| + @error.set_backtrace(["/lib/spec/#{child}/anything.rb"]) + @tweaker.tweak_backtrace(@error, "spec name") + @error.backtrace.should_not be_empty + end + end + + it "should leave anything in spec dir" do + @error.set_backtrace(["/lib/spec/expectations/anything.rb"]) + @tweaker.tweak_backtrace(@error, "spec name") + @error.backtrace.should_not be_empty + end + + it "should leave bin spec" do + @error.set_backtrace(["bin/spec:"]) + @tweaker.tweak_backtrace(@error, "spec name") + @error.backtrace.should_not be_empty + end + + it "should not barf on nil backtrace" do + lambda do + @tweaker.tweak_backtrace(@error, "spec name") + end.should_not raise_error + end + + it "should clean up double slashes" do + @error.set_backtrace(["/a//b/c//d.rb"]) + @tweaker.tweak_backtrace(@error, "spec name") + @error.backtrace.should include("/a/b/c/d.rb") + end + + end + end +end diff --git a/vendor/plugins/rspec/spec/spec/runner/object_ext_spec.rb b/vendor/plugins/rspec/spec/spec/runner/object_ext_spec.rb new file mode 100644 index 000000000..0d8348bb2 --- /dev/null +++ b/vendor/plugins/rspec/spec/spec/runner/object_ext_spec.rb @@ -0,0 +1,11 @@ +require File.dirname(__FILE__) + '/../../spec_helper.rb' + +module Spec + module Runner + describe "ObjectExt" do + it "should add copy_instance_variables_from to object" do + Object.new.should respond_to(:copy_instance_variables_from) + end + end + end +end diff --git a/vendor/plugins/rspec/spec/spec/runner/option_parser_spec.rb b/vendor/plugins/rspec/spec/spec/runner/option_parser_spec.rb new file mode 100644 index 000000000..95e1f75a3 --- /dev/null +++ b/vendor/plugins/rspec/spec/spec/runner/option_parser_spec.rb @@ -0,0 +1,349 @@ +require File.dirname(__FILE__) + '/../../spec_helper.rb' + +describe "OptionParser" do + before(:each) do + @out = StringIO.new + @err = StringIO.new + @parser = Spec::Runner::OptionParser.new + end + + def parse(args) + @parser.parse(args, @err, @out, true) + end + + def behaviour_runner(args) + @parser.create_behaviour_runner(args, @err, @out, true) + end + + it "should accept dry run option" do + options = parse(["--dry-run"]) + options.dry_run.should be_true + end + + it "should eval and use custom formatter when none of the builtins" do + options = parse(["--format", "Custom::Formatter"]) + options.formatters[0].class.should be(Custom::Formatter) + end + + it "should support formatters with relative and absolute paths, even on windows" do + options = parse([ + "--format", "Custom::Formatter:C:\\foo\\bar", + "--format", "Custom::Formatter:foo/bar", + "--format", "Custom::Formatter:foo\\bar", + "--format", "Custom::Formatter:/foo/bar" + ]) + options.formatters[0].where.should eql("C:\\foo\\bar") + options.formatters[1].where.should eql("foo/bar") + options.formatters[2].where.should eql("foo\\bar") + options.formatters[3].where.should eql("/foo/bar") + end + + it "should not be verbose by default" do + options = parse([]) + options.verbose.should be_nil + end + + it "should not use colour by default" do + options = parse([]) + options.colour.should == false + end + + it "should print help to stdout" do + options = parse(["--help"]) + @out.rewind + @out.read.should match(/Usage: spec \(FILE\|DIRECTORY\|GLOB\)\+ \[options\]/m) + end + + it "should print instructions about how to require missing formatter" do + lambda { options = parse(["--format", "Custom::MissingFormatter"]) }.should raise_error(NameError) + @err.string.should match(/Couldn't find formatter class Custom::MissingFormatter/n) + end + + it "should print usage to err if no dir specified" do + options = parse([]) + @err.string.should match(/Usage: spec/) + end + + it "should print version to stdout" do + options = parse(["--version"]) + @out.rewind + @out.read.should match(/RSpec-\d+\.\d+\.\d+.*\(r\d+\) - BDD for Ruby\nhttp:\/\/rspec.rubyforge.org\/\n/n) + end + + it "should require file when require specified" do + lambda do + parse(["--require", "whatever"]) + end.should raise_error(LoadError) + end + + it "should support c option" do + options = parse(["-c"]) + options.colour.should be_true + end + + it "should support queens colour option" do + options = parse(["--colour"]) + options.colour.should be_true + end + + it "should support us color option" do + options = parse(["--color"]) + options.colour.should be_true + end + + it "should support single example with -e option" do + options = parse(["-e", "something or other"]) + options.examples.should eql(["something or other"]) + end + + it "should support single example with -s option (will be removed when autotest supports -e)" do + options = parse(["-s", "something or other"]) + options.examples.should eql(["something or other"]) + end + + it "should support single example with --example option" do + options = parse(["--example", "something or other"]) + options.examples.should eql(["something or other"]) + end + + it "should read several example names from file if --example is given an existing file name" do + options = parse(["--example", File.dirname(__FILE__) + '/examples.txt']) + options.examples.should eql([ + "Sir, if you were my husband, I would poison your drink.", + "Madam, if you were my wife, I would drink it."]) + end + + it "should read no examples if given an empty file" do + options = parse(["--example", File.dirname(__FILE__) + '/empty_file.txt']) + options.examples.should eql([]) + end + + it "should use html formatter when format is h" do + options = parse(["--format", "h"]) + options.formatters[0].class.should equal(Spec::Runner::Formatter::HtmlFormatter) + end + + it "should use html formatter when format is html" do + options = parse(["--format", "html"]) + options.formatters[0].class.should equal(Spec::Runner::Formatter::HtmlFormatter) + end + + it "should use html formatter with explicit output when format is html:test.html" do + FileUtils.rm 'test.html' if File.exist?('test.html') + options = parse(["--format", "html:test.html"]) + File.should be_exist('test.html') + options.formatters[0].class.should equal(Spec::Runner::Formatter::HtmlFormatter) + options.formatters[0].close + FileUtils.rm 'test.html' + end + + it "should use noisy backtrace tweaker with b option" do + options = parse(["-b"]) + options.backtrace_tweaker.should be_instance_of(Spec::Runner::NoisyBacktraceTweaker) + end + + it "should use noisy backtrace tweaker with backtrace option" do + options = parse(["--backtrace"]) + options.backtrace_tweaker.should be_instance_of(Spec::Runner::NoisyBacktraceTweaker) + end + + it "should use quiet backtrace tweaker by default" do + options = parse([]) + options.backtrace_tweaker.should be_instance_of(Spec::Runner::QuietBacktraceTweaker) + end + + it "should use progress bar formatter by default" do + options = parse([]) + options.formatters[0].class.should equal(Spec::Runner::Formatter::ProgressBarFormatter) + end + + it "should use rdoc formatter when format is r" do + options = parse(["--format", "r"]) + options.formatters[0].class.should equal(Spec::Runner::Formatter::RdocFormatter) + end + + it "should use rdoc formatter when format is rdoc" do + options = parse(["--format", "rdoc"]) + options.formatters[0].class.should equal(Spec::Runner::Formatter::RdocFormatter) + end + + it "should use specdoc formatter when format is s" do + options = parse(["--format", "s"]) + options.formatters[0].class.should equal(Spec::Runner::Formatter::SpecdocFormatter) + end + + it "should use specdoc formatter when format is specdoc" do + options = parse(["--format", "specdoc"]) + options.formatters[0].class.should equal(Spec::Runner::Formatter::SpecdocFormatter) + end + + it "should support diff option when format is not specified" do + options = parse(["--diff"]) + options.diff_format.should == :unified + end + + it "should use unified diff format option when format is unified" do + options = parse(["--diff", "unified"]) + options.diff_format.should == :unified + options.differ_class.should equal(Spec::Expectations::Differs::Default) + end + + it "should use context diff format option when format is context" do + options = parse(["--diff", "context"]) + options.diff_format.should == :context + options.differ_class.should == Spec::Expectations::Differs::Default + end + + it "should use custom diff format option when format is a custom format" do + options = parse(["--diff", "Custom::Formatter"]) + options.diff_format.should == :custom + options.differ_class.should == Custom::Formatter + end + + it "should print instructions about how to fix missing differ" do + lambda { parse(["--diff", "Custom::MissingFormatter"]) }.should raise_error(NameError) + @err.string.should match(/Couldn't find differ class Custom::MissingFormatter/n) + end + + it "should support --line to identify spec" do + spec_parser = mock("spec_parser") + @parser.instance_variable_set('@spec_parser', spec_parser) + + file_factory = mock("File") + file_factory.should_receive(:file?).and_return(true) + file_factory.should_receive(:open).and_return("fake_io") + @parser.instance_variable_set('@file_factory', file_factory) + + spec_parser.should_receive(:spec_name_for).with("fake_io", 169).and_return("some spec") + + options = parse(["some file", "--line", "169"]) + options.examples.should eql(["some spec"]) + File.rspec_verify + end + + it "should fail with error message if file is dir along with --line" do + spec_parser = mock("spec_parser") + @parser.instance_variable_set('@spec_parser', spec_parser) + + file_factory = mock("File") + file_factory.should_receive(:file?).and_return(false) + file_factory.should_receive(:directory?).and_return(true) + @parser.instance_variable_set('@file_factory', file_factory) + + options = parse(["some file", "--line", "169"]) + @err.string.should match(/You must specify one file, not a directory when using the --line option/n) + end + + it "should fail with error message if file is dir along with --line" do + spec_parser = mock("spec_parser") + @parser.instance_variable_set('@spec_parser', spec_parser) + + file_factory = mock("File") + file_factory.should_receive(:file?).and_return(false) + file_factory.should_receive(:directory?).and_return(false) + @parser.instance_variable_set('@file_factory', file_factory) + + options = parse(["some file", "--line", "169"]) + @err.string.should match(/some file does not exist/n) + end + + it "should fail with error message if more than one files are specified along with --line" do + spec_parser = mock("spec_parser") + @parser.instance_variable_set('@spec_parser', spec_parser) + + options = parse(["some file", "some other file", "--line", "169"]) + @err.string.should match(/Only one file can be specified when using the --line option/n) + end + + it "should fail with error message if --example and --line are used simultaneously" do + spec_parser = mock("spec_parser") + @parser.instance_variable_set('@spec_parser', spec_parser) + + options = parse(["some file", "--example", "some example", "--line", "169"]) + @err.string.should match(/You cannot use both --line and --example/n) + end + + if [/mswin/, /java/].detect{|p| p =~ RUBY_PLATFORM} + it "should barf when --heckle is specified (and platform is windows)" do + lambda do + options = parse(["--heckle", "Spec"]) + end.should raise_error(StandardError, "Heckle not supported on Windows") + end + else + it "should heckle when --heckle is specified (and platform is not windows)" do + options = parse(["--heckle", "Spec"]) + options.heckle_runner.should be_instance_of(Spec::Runner::HeckleRunner) + end + end + + it "should read options from file when --options is specified" do + Spec::Runner::CommandLine.should_receive(:run).with(["--diff", "--colour"], @err, @out, true, true) + options = parse(["--options", File.dirname(__FILE__) + "/spec.opts"]) + end + + it "should append options from file when --options is specified" do + Spec::Runner::CommandLine.should_receive(:run).with(["some/spec.rb", "--diff", "--colour"], @err, @out, true, true) + options = parse(["some/spec.rb", "--options", File.dirname(__FILE__) + "/spec.opts"]) + end + + it "should read spaced and multi-line options from file when --options is specified" do + Spec::Runner::CommandLine.should_receive(:run).with(["--diff", "--colour", "--format", "s"], @err, @out, true, true) + options = parse(["--options", File.dirname(__FILE__) + "/spec_spaced.opts"]) + end + + it "should save config to file when --generate-options is specified" do + FileUtils.rm 'test.spec.opts' if File.exist?('test.spec.opts') + options = parse(["--colour", "--generate-options", "test.spec.opts", "--diff"]) + IO.read('test.spec.opts').should == "--colour\n--diff\n" + FileUtils.rm 'test.spec.opts' + end + + it "should call DrbCommandLine when --drb is specified" do + Spec::Runner::DrbCommandLine.should_receive(:run).with(["some/spec.rb", "--diff", "--colour"], @err, @out, true, true) + options = parse(["some/spec.rb", "--diff", "--drb", "--colour"]) + end + + it "should not return an Options object when --drb is specified" do + Spec::Runner::DrbCommandLine.stub!(:run) + parse(["some/spec.rb", "--drb"]).should be_nil + end + + it "should reverse spec order when --reverse is specified" do + options = parse(["some/spec.rb", "--reverse"]) + end + + it "should set an mtime comparator when --loadby mtime" do + behaviour_runner = behaviour_runner(["--loadby", 'mtime']) + Dir.chdir(File.dirname(__FILE__)) do + FileUtils.touch "most_recent_spec.rb" + all_files = ['command_line_spec.rb', 'most_recent_spec.rb'] + sorted_files = behaviour_runner.sort_paths(all_files) + sorted_files.should == ["most_recent_spec.rb", "command_line_spec.rb"] + FileUtils.rm "most_recent_spec.rb" + end + end + + it "should use the standard runner by default" do + options = parse([]) + options.create_behaviour_runner.class.should equal(Spec::Runner::BehaviourRunner) + end + + it "should use a custom runner when given" do + options = parse(["--runner", "Custom::BehaviourRunner"]) + options.create_behaviour_runner.class.should equal(Custom::BehaviourRunner) + end + + it "should use a custom runner with extra options" do + options = parse(["--runner", "Custom::BehaviourRunner:something"]) + options.create_behaviour_runner.class.should equal(Custom::BehaviourRunner) + end + + it "should return the correct default behaviour runner" do + @parser.create_behaviour_runner([], @err, @out, true).should be_instance_of(Spec::Runner::BehaviourRunner) + end + + it "should return the correct default behaviour runner" do + @parser.create_behaviour_runner(["--runner", "Custom::BehaviourRunner"], @err, @out, true).should be_instance_of(Custom::BehaviourRunner) + end + +end diff --git a/vendor/plugins/rspec/spec/spec/runner/options_spec.rb b/vendor/plugins/rspec/spec/spec/runner/options_spec.rb new file mode 100644 index 000000000..609d8d95c --- /dev/null +++ b/vendor/plugins/rspec/spec/spec/runner/options_spec.rb @@ -0,0 +1,175 @@ +require File.dirname(__FILE__) + '/../../spec_helper.rb' + +module Spec + module Runner + describe Options do + before do + @err = StringIO.new('') + @out = StringIO.new('') + @options = Options.new(@err, @out) + end + + it "instantiates empty arrays" do + @options.examples.should == [] + @options.formatters.should == [] + end + + it "defaults to QuietBacktraceTweaker" do + @options.backtrace_tweaker.class.should == QuietBacktraceTweaker + end + + it "defaults to no dry_run" do + @options.dry_run.should == false + end + + it "parse_diff sets context_lines" do + @options.parse_diff nil + @options.context_lines.should == 3 + end + + it "defaults diff to unified" do + @options.parse_diff nil + @options.diff_format.should == :unified + end + + it "should use unified diff format option when format is unified" do + @options.parse_diff 'unified' + @options.diff_format.should == :unified + @options.differ_class.should equal(Spec::Expectations::Differs::Default) + end + + it "should use context diff format option when format is context" do + @options.parse_diff 'context' + @options.diff_format.should == :context + @options.differ_class.should == Spec::Expectations::Differs::Default + end + + it "should use custom diff format option when format is a custom format" do + @options.parse_diff "Custom::Formatter" + @options.diff_format.should == :custom + @options.differ_class.should == Custom::Formatter + end + + it "should print instructions about how to fix missing differ" do + lambda { @options.parse_diff "Custom::MissingDiffer" }.should raise_error(NameError) + @err.string.should match(/Couldn't find differ class Custom::MissingDiffer/n) + end + + it "should print instructions about how to fix bad formatter" do + lambda do + @options.parse_format "Custom::BadFormatter" + end.should raise_error(NameError, /undefined local variable or method `bad_method'/) + end + + it "parse_example sets single example when argument not a file" do + example = "something or other" + File.file?(example).should == false + @options.parse_example example + @options.examples.should eql(["something or other"]) + end + + it "parse_example sets examples to contents of file" do + example = "#{File.dirname(__FILE__)}/examples.txt" + File.should_receive(:file?).with(example).and_return(true) + file = StringIO.new("Sir, if you were my husband, I would poison your drink.\nMadam, if you were my wife, I would drink it.") + File.should_receive(:open).with(example).and_return(file) + + @options.parse_example example + @options.examples.should eql([ + "Sir, if you were my husband, I would poison your drink.", + "Madam, if you were my wife, I would drink it." + ]) + end + end + + describe Options, "splitting class names and args" do + before do + @err = StringIO.new('') + @out = StringIO.new('') + @options = Options.new(@err, @out) + end + + it "should split class names with args" do + @options.split_at_colon('Foo').should == ['Foo', nil] + @options.split_at_colon('Foo:arg').should == ['Foo', 'arg'] + @options.split_at_colon('Foo::Bar::Zap:arg').should == ['Foo::Bar::Zap', 'arg'] + @options.split_at_colon('Foo:arg1,arg2').should == ['Foo', 'arg1,arg2'] + @options.split_at_colon('Foo::Bar::Zap:arg1,arg2').should == ['Foo::Bar::Zap', 'arg1,arg2'] + @options.split_at_colon('Foo::Bar::Zap:drb://foo,drb://bar').should == ['Foo::Bar::Zap', 'drb://foo,drb://bar'] + end + + it "should raise error when splitting something starting with a number" do + lambda { @options.split_at_colon('') }.should raise_error("Couldn't parse \"\"") + end + + it "should raise error when not class name" do + lambda do + @options.load_class('foo', 'fruit', '--food') + end.should raise_error('"foo" is not a valid class name') + end + end + + describe Options, "receiving create_behaviour_runner" do + before do + @err = StringIO.new + @out = StringIO.new + @options = Options.new(@err, @out) + end + + it "should fail when custom runner not found" do + @options.runner_arg = "Whatever" + lambda { @options.create_behaviour_runner }.should raise_error(NameError) + @err.string.should match(/Couldn't find behaviour runner class/) + end + + it "should fail when custom runner not valid class name" do + @options.runner_arg = "whatever" + lambda { @options.create_behaviour_runner }.should raise_error('"whatever" is not a valid class name') + @err.string.should match(/"whatever" is not a valid class name/) + end + + it "returns nil when generate is true" do + @options.generate = true + @options.create_behaviour_runner.should == nil + end + + it "returns a BehaviourRunner by default" do + runner = @options.create_behaviour_runner + runner.class.should == BehaviourRunner + end + + it "does not set Expectations differ when differ_class is not set" do + @options.differ_class = nil + Spec::Expectations.should_not_receive(:differ=) + @options.create_behaviour_runner + end + + it "sets Expectations differ when differ_class is set" do + @options.differ_class = Spec::Expectations::Differs::Default + Spec::Expectations.should_receive(:differ=).with(anything()).and_return do |arg| + arg.class.should == Spec::Expectations::Differs::Default + end + @options.configure + end + + it "creates a Reporter" do + formatter = ::Spec::Runner::Formatter::BaseFormatter.new(:somewhere) + @options.formatters << formatter + reporter = Reporter.new(@formatters, @backtrace_tweaker) + Reporter.should_receive(:new).with(@options.formatters, @options.backtrace_tweaker).and_return(reporter) + @options.configure + @options.reporter.should === reporter + end + + it "sets colour and dry_run on the formatters" do + @options.colour = true + @options.dry_run = true + formatter = ::Spec::Runner::Formatter::BaseTextFormatter.new(:somewhere) + formatter.should_receive(:colour=).with(true) + formatter.should_receive(:dry_run=).with(true) + @options.formatters << formatter + @options.configure + end + end + end +end diff --git a/vendor/plugins/rspec/spec/spec/runner/quiet_backtrace_tweaker_spec.rb b/vendor/plugins/rspec/spec/spec/runner/quiet_backtrace_tweaker_spec.rb new file mode 100644 index 000000000..2578dbe6d --- /dev/null +++ b/vendor/plugins/rspec/spec/spec/runner/quiet_backtrace_tweaker_spec.rb @@ -0,0 +1,56 @@ +require File.dirname(__FILE__) + '/../../spec_helper.rb' + +module Spec + module Runner + describe "QuietBacktraceTweaker" do + before(:each) do + @error = RuntimeError.new + @tweaker = QuietBacktraceTweaker.new + end + + it "should not barf on nil backtrace" do + lambda do + @tweaker.tweak_backtrace(@error, "spec name") + end.should_not raise_error + end + + it "should remove anything from textmate ruby bundle" do + @error.set_backtrace(["/Applications/TextMate.app/Contents/SharedSupport/Bundles/Ruby.tmbundle/Support/tmruby.rb:147"]) + @tweaker.tweak_backtrace(@error, "spec name") + @error.backtrace.should be_empty + end + + it "should remove anything in lib spec dir" do + ["expectations", "mocks", "runner"].each do |child| + element="/lib/spec/#{child}/anything.rb" + @error.set_backtrace([element]) + @tweaker.tweak_backtrace(@error, "spec name") + unless (@error.backtrace.empty?) + raise("Should have tweaked away '#{element}'") + end + end + end + + it "should remove mock_frameworks/rspec" do + element = "mock_frameworks/rspec" + @error.set_backtrace([element]) + @tweaker.tweak_backtrace(@error, "spec name") + unless (@error.backtrace.empty?) + raise("Should have tweaked away '#{element}'") + end + end + + it "should remove bin spec" do + @error.set_backtrace(["bin/spec:"]) + @tweaker.tweak_backtrace(@error, "spec name") + @error.backtrace.should be_empty + end + + it "should clean up double slashes" do + @error.set_backtrace(["/a//b/c//d.rb"]) + @tweaker.tweak_backtrace(@error, "spec name") + @error.backtrace.should include("/a/b/c/d.rb") + end + end + end +end diff --git a/vendor/plugins/rspec/spec/spec/runner/reporter_spec.rb b/vendor/plugins/rspec/spec/spec/runner/reporter_spec.rb new file mode 100644 index 000000000..574625ce8 --- /dev/null +++ b/vendor/plugins/rspec/spec/spec/runner/reporter_spec.rb @@ -0,0 +1,205 @@ +require File.dirname(__FILE__) + '/../../spec_helper.rb' + +module Spec + module Runner + + module ReporterSpecHelper + def setup + @io = StringIO.new + @backtrace_tweaker = stub("backtrace tweaker", :tweak_backtrace => nil) + @formatter = mock("formatter") + @reporter = Reporter.new([@formatter], @backtrace_tweaker) + end + + def failure + Mocks::DuckTypeArgConstraint.new(:header, :exception) + end + + def description(s) + Spec::DSL::Description.new(s) + end + end + + describe Reporter do + include ReporterSpecHelper + before(:each) {setup} + + it "should tell formatter when behaviour is added" do + @formatter.should_receive(:add_behaviour).with(description("behaviour")) + @reporter.add_behaviour(description("behaviour")) + end + + it "should handle multiple behaviours with same name" do + @formatter.should_receive(:add_behaviour).exactly(3).times + @formatter.should_receive(:example_started).exactly(3).times + @formatter.should_receive(:example_passed).exactly(3).times + @formatter.should_receive(:start_dump) + @formatter.should_receive(:close).with(no_args) + @formatter.should_receive(:dump_summary).with(anything(), 3, 0, 0) + @reporter.add_behaviour(description("behaviour")) + @reporter.example_started("spec 1") + @reporter.example_finished("spec 1") + @reporter.add_behaviour(description("behaviour")) + @reporter.example_started("spec 2") + @reporter.example_finished("spec 2") + @reporter.add_behaviour(description("behaviour")) + @reporter.example_started("spec 3") + @reporter.example_finished("spec 3") + @reporter.dump + end + + it "should handle multiple examples with the same name" do + error=RuntimeError.new + @formatter.should_receive(:add_behaviour).exactly(2).times + @formatter.should_receive(:example_passed).with("example").exactly(2).times + @formatter.should_receive(:example_failed).with("example", 1, failure) + @formatter.should_receive(:example_failed).with("example", 2, failure) + @formatter.should_receive(:dump_failure).exactly(2).times + @formatter.should_receive(:start_dump) + @formatter.should_receive(:close).with(no_args) + @formatter.should_receive(:dump_summary).with(anything(), 4, 2, 0) + @backtrace_tweaker.should_receive(:tweak_backtrace).twice + @reporter.add_behaviour(description("behaviour")) + @reporter.example_finished("example") + @reporter.example_finished("example", error) + @reporter.add_behaviour(description("behaviour")) + @reporter.example_finished("example") + @reporter.example_finished("example", error) + @reporter.dump + end + + it "should push stats to formatter even with no data" do + @formatter.should_receive(:start_dump) + @formatter.should_receive(:dump_summary).with(anything(), 0, 0, 0) + @formatter.should_receive(:close).with(no_args) + @reporter.dump + end + + it "should push time to formatter" do + @formatter.should_receive(:start).with(5) + @formatter.should_receive(:start_dump) + @formatter.should_receive(:close).with(no_args) + @formatter.should_receive(:dump_summary) do |time, a, b| + time.to_s.should match(/[0-9].[0-9|e|-]+/) + end + @reporter.start(5) + @reporter.end + @reporter.dump + end + end + + describe Reporter, "reporting one passing example" do + include ReporterSpecHelper + before(:each) {setup} + + it "should tell formatter example passed" do + @formatter.should_receive(:example_passed) + @reporter.example_finished("example") + end + + it "should not delegate to backtrace tweaker" do + @formatter.should_receive(:example_passed) + @backtrace_tweaker.should_not_receive(:tweak_backtrace) + @reporter.example_finished("example") + end + + it "should account for passing example in stats" do + @formatter.should_receive(:example_passed) + @formatter.should_receive(:start_dump) + @formatter.should_receive(:dump_summary).with(anything(), 1, 0, 0) + @formatter.should_receive(:close).with(no_args) + @reporter.example_finished("example") + @reporter.dump + end + end + + describe Reporter, "reporting one failing example" do + include ReporterSpecHelper + before(:each) {setup} + + it "should tell formatter that example failed" do + @formatter.should_receive(:example_failed) + @reporter.example_finished("example", RuntimeError.new) + end + + it "should delegate to backtrace tweaker" do + @formatter.should_receive(:example_failed) + @backtrace_tweaker.should_receive(:tweak_backtrace) + @reporter.example_finished("spec", RuntimeError.new) + end + + it "should account for failing example in stats" do + @formatter.should_receive(:add_behaviour) + @formatter.should_receive(:example_failed).with("example", 1, failure) + @formatter.should_receive(:start_dump) + @formatter.should_receive(:dump_failure).with(1, anything()) + @formatter.should_receive(:dump_summary).with(anything(), 1, 1, 0) + @formatter.should_receive(:close).with(no_args) + @reporter.add_behaviour(description("behaviour")) + @reporter.example_finished("example", RuntimeError.new) + @reporter.dump + end + + end + + describe Reporter, "reporting one pending example (Not Yet Implemented)" do + include ReporterSpecHelper + before(:each) {setup} + + it "should tell formatter example is pending" do + @formatter.should_receive(:example_pending).with(description("behaviour"), "example", "Not Yet Implemented") + @formatter.should_receive(:add_behaviour).with(description("behaviour")) + @reporter.add_behaviour(description('behaviour')) + @reporter.example_finished("example", nil, nil, true) + end + + it "should account for pending example in stats" do + @formatter.should_receive(:example_pending).with(description("behaviour"), "example", "Not Yet Implemented") + @formatter.should_receive(:start_dump) + @formatter.should_receive(:dump_summary).with(anything(), 1, 0, 1) + @formatter.should_receive(:add_behaviour).with(description("behaviour")) + @formatter.should_receive(:close).with(no_args) + @reporter.add_behaviour(description('behaviour')) + @reporter.example_finished("example", nil, nil, true) + @reporter.dump + end + end + + describe Reporter, "reporting one pending example (ExamplePendingError)" do + include ReporterSpecHelper + before(:each) {setup} + + it "should tell formatter example is pending" do + @formatter.should_receive(:example_pending).with(description("behaviour"), "example", "reason") + @formatter.should_receive(:add_behaviour).with(description("behaviour")) + @reporter.add_behaviour(description('behaviour')) + @reporter.example_finished("example", Spec::DSL::ExamplePendingError.new("reason"), nil, false) + end + + it "should account for pending example in stats" do + @formatter.should_receive(:example_pending).with(description("behaviour"), "example", "reason") + @formatter.should_receive(:start_dump) + @formatter.should_receive(:dump_summary).with(anything(), 1, 0, 1) + @formatter.should_receive(:close).with(no_args) + @formatter.should_receive(:add_behaviour).with(description("behaviour")) + @reporter.add_behaviour(description('behaviour')) + @reporter.example_finished("example", Spec::DSL::ExamplePendingError.new("reason"), nil, false) + @reporter.dump + end + end + + describe Reporter, "reporting one pending example (PendingFixedError)" do + include ReporterSpecHelper + before(:each) {setup} + + it "should tell formatter pending example is fixed" do + @formatter.should_receive(:example_failed) do |name, counter, failure| + failure.header.should == "'behaviour example' FIXED" + end + @formatter.should_receive(:add_behaviour).with(description("behaviour")) + @reporter.add_behaviour(description('behaviour')) + @reporter.example_finished("example", Spec::DSL::PendingFixedError.new("reason"), nil, false) + end + end + end +end diff --git a/vendor/plugins/rspec/spec/spec/runner/spec.opts b/vendor/plugins/rspec/spec/spec/runner/spec.opts new file mode 100644 index 000000000..fd816a424 --- /dev/null +++ b/vendor/plugins/rspec/spec/spec/runner/spec.opts @@ -0,0 +1,2 @@ +--diff +--colour
\ No newline at end of file diff --git a/vendor/plugins/rspec/spec/spec/runner/spec_parser_spec.rb b/vendor/plugins/rspec/spec/spec/runner/spec_parser_spec.rb new file mode 100644 index 000000000..6fb83dc35 --- /dev/null +++ b/vendor/plugins/rspec/spec/spec/runner/spec_parser_spec.rb @@ -0,0 +1,93 @@ +require File.dirname(__FILE__) + '/../../spec_helper.rb' + +describe "c" do + + it "1" do + end + + it "2" do + end + +end + +describe "d" do + + it "3" do + end + + it "4" do + end + +end + +class SpecParserSubject +end + +describe SpecParserSubject do + + it "5" do + end + +end + +describe SpecParserSubject, "described" do + + it "6" do + end + +end + +describe "SpecParser" do + before(:each) do + @p = Spec::Runner::SpecParser.new + end + + it "should find spec name for 'specify' at same line" do + @p.spec_name_for(File.open(__FILE__), 5).should == "c 1" + end + + it "should find spec name for 'specify' at end of spec line" do + @p.spec_name_for(File.open(__FILE__), 6).should == "c 1" + end + + it "should find context for 'context' above all specs" do + @p.spec_name_for(File.open(__FILE__), 4).should == "c" + end + + it "should find spec name for 'it' at same line" do + @p.spec_name_for(File.open(__FILE__), 15).should == "d 3" + end + + it "should find spec name for 'it' at end of spec line" do + @p.spec_name_for(File.open(__FILE__), 16).should == "d 3" + end + + it "should find context for 'describe' above all specs" do + @p.spec_name_for(File.open(__FILE__), 14).should == "d" + end + + it "should find nearest example name between examples" do + @p.spec_name_for(File.open(__FILE__), 7).should == "c 1" + end + + it "should find nothing outside a context" do + @p.spec_name_for(File.open(__FILE__), 2).should be_nil + end + + it "should find context name for type" do + @p.spec_name_for(File.open(__FILE__), 26).should == "SpecParserSubject" + end + + it "should find context and spec name for type" do + @p.spec_name_for(File.open(__FILE__), 28).should == "SpecParserSubject 5" + end + + it "should find context and description for type" do + @p.spec_name_for(File.open(__FILE__), 33).should == "SpecParserSubject described" + end + + it "should find context and description and example for type" do + @p.spec_name_for(File.open(__FILE__), 36).should == "SpecParserSubject described 6" + end + +end diff --git a/vendor/plugins/rspec/spec/spec/runner/spec_spaced.opts b/vendor/plugins/rspec/spec/spec/runner/spec_spaced.opts new file mode 100644 index 000000000..6b3efd20f --- /dev/null +++ b/vendor/plugins/rspec/spec/spec/runner/spec_spaced.opts @@ -0,0 +1,2 @@ +--diff --colour +--format s
\ No newline at end of file diff --git a/vendor/plugins/rspec/spec/spec/spec_classes.rb b/vendor/plugins/rspec/spec/spec/spec_classes.rb new file mode 100644 index 000000000..89eee72c4 --- /dev/null +++ b/vendor/plugins/rspec/spec/spec/spec_classes.rb @@ -0,0 +1,119 @@ +# This file contains various classes used by the specs. +module Spec + module Expectations + class Person + attr_reader :name + def initialize name + @name = name + end + def == other + return @name == other.name + end + end + + class ClassWithMultiWordPredicate + def multi_word_predicate? + true + end + end + + module Helper + class CollectionWithSizeMethod + def initialize; @list = []; end + def size; @list.size; end + def push(item); @list.push(item); end + end + + class CollectionWithLengthMethod + def initialize; @list = []; end + def length; @list.size; end + def push(item); @list.push(item); end + end + + class CollectionOwner + attr_reader :items_in_collection_with_size_method, :items_in_collection_with_length_method + + def initialize + @items_in_collection_with_size_method = CollectionWithSizeMethod.new + @items_in_collection_with_length_method = CollectionWithLengthMethod.new + end + + def add_to_collection_with_size_method(item) + @items_in_collection_with_size_method.push(item) + end + + def add_to_collection_with_length_method(item) + @items_in_collection_with_length_method.push(item) + end + + def items_for(arg) + return [1, 2, 3] if arg == 'a' + [1] + end + + end + + class HandCodedMock + include Spec::Matchers + def initialize(return_val) + @return_val = return_val + @funny_called = false + end + + def funny? + @funny_called = true + @return_val + end + + def hungry?(a, b, c) + a.should equal(1) + b.should equal(2) + c.should equal(3) + @funny_called = true + @return_val + end + + def exists? + @return_val + end + + def multi_word_predicate? + @return_val + end + + def rspec_verify + @funny_called.should be_true + end + end + class ClassWithUnqueriedPredicate + attr_accessor :foo + def initialize(foo) + @foo = foo + end + end + end + end +end + +module Custom + class Formatter < Spec::Runner::Formatter::BaseTextFormatter + attr_reader :where + + def initialize(where) + @where = where + end + end + + class BadFormatter < Spec::Runner::Formatter::BaseTextFormatter + attr_reader :where + + def initialize(where) + bad_method + end + end + + class BehaviourRunner + def initialize(options, arg=nil); end + end +end + diff --git a/vendor/plugins/rspec/spec/spec/translator_spec.rb b/vendor/plugins/rspec/spec/spec/translator_spec.rb new file mode 100644 index 000000000..e11983a42 --- /dev/null +++ b/vendor/plugins/rspec/spec/spec/translator_spec.rb @@ -0,0 +1,264 @@ +require File.dirname(__FILE__) + '/../spec_helper.rb' + +describe "Translator" do + before do + @t = Spec::Translator.new + end + + it "should translate files" do + from = File.dirname(__FILE__) + '/..' + to = File.dirname(__FILE__) + '/../../translated_specs' + @t.translate_dir(from, to) + end + + it "should translate context_setup do" do + @t.translate_line( + "context_setup do\n" + ).should eql( + "before(:all) do\n" + ) + end + + it "should translate context_setup {foo}" do + @t.translate_line( + "context_setup {foo}\n" + ).should eql( + "before(:all) {foo}\n" + ) + end + + it "should translate context ' to describe '" do + @t.translate_line( + "context 'Translator' do\n" + ).should eql( + "describe 'Translator' do\n" + ) + end + + it 'should translate context " to describe "' do + @t.translate_line( + 'context "Translator"' + ).should eql( + 'describe "Translator"' + ) + end + + it 'should translate spaces then context " to describe "' do + @t.translate_line( + ' context "Translator"' + ).should eql( + ' describe "Translator"' + ) + end + + it "should not translate context=foo" do + @t.translate_line(' context=foo').should eql(' context=foo') + end + + it "should not translate context = foo" do + @t.translate_line(' context = foo').should eql(' context = foo') + end + + it "should not translate context = foo" do + @t.translate_line(' context = foo').should eql(' context = foo') + end + + it "should translate should_be_close" do + @t.translate_line('5.0.should_be_close(5.0, 0.5)').should eql('5.0.should be_close(5.0, 0.5)') + end + + it "should translate should_not_raise" do + @t.translate_line('lambda { self.call }.should_not_raise').should eql('lambda { self.call }.should_not raise_error') + end + + it "should translate should_throw" do + @t.translate_line('lambda { self.call }.should_throw').should eql('lambda { self.call }.should throw_symbol') + end + + it "should not translate 0.9 should_not" do + @t.translate_line('@target.should_not @matcher').should eql('@target.should_not @matcher') + end + + it "should leave should_not_receive" do + @t.translate_line('@mock.should_not_receive(:not_expected).with("unexpected text")').should eql('@mock.should_not_receive(:not_expected).with("unexpected text")') + end + + it "should leave should_receive" do + @t.translate_line('@mock.should_receive(:not_expected).with("unexpected text")').should eql('@mock.should_receive(:not_expected).with("unexpected text")') + end + + it "should translate multi word predicates" do + @t.translate_line('foo.should_multi_word_predicate').should eql('foo.should be_multi_word_predicate') + end + + it "should translate multi word predicates prefixed with be" do + @t.translate_line('foo.should_be_multi_word_predicate').should eql('foo.should be_multi_word_predicate') + end + + it "should translate be(expected) to equal(expected)" do + @t.translate_line('foo.should_be :cool').should eql('foo.should equal :cool') + end + + it "should translate instance_of" do + @t.translate_line('5.should_be_an_instance_of(Integer)').should eql('5.should be_an_instance_of(Integer)') + end + + it "should translate should_be <" do + @t.translate_line('3.should_be < 4').should eql('3.should be < 4') + end + + it "should translate should_be <=" do + @t.translate_line('3.should_be <= 4').should eql('3.should be <= 4') + end + + it "should translate should_be >=" do + @t.translate_line('4.should_be >= 3').should eql('4.should be >= 3') + end + + it "should translate should_be >" do + @t.translate_line('4.should_be > 3').should eql('4.should be > 3') + end + + it "should translate should_be_happy" do + @t.translate_line("4.should_be_happy").should eql("4.should be_happy") + end + + it "should translate custom method taking regexp with parenthesis" do + @t.translate_line("@browser.should_contain_text(/Sn.rrunger og annet rusk/)").should eql("@browser.should be_contain_text(/Sn.rrunger og annet rusk/)") + end + + it "should translate custom method taking regexp without parenthesis" do + @t.translate_line("@browser.should_contain_text /Sn.rrunger og annet rusk/\n").should eql("@browser.should be_contain_text(/Sn.rrunger og annet rusk/)\n") + end + + it "should translate should_not_be_nil" do + @t.translate_line("foo.should_not_be_nil\n").should eql("foo.should_not be_nil\n") + end + + it "should translate kind of" do + @t.translate_line('@object.should_be_kind_of(MessageExpectation)').should( + eql('@object.should be_kind_of(MessageExpectation)')) + end + + it "should translate should_be_true" do + @t.translate_line("foo.should_be_true\n").should eql("foo.should be_true\n") + end + + # [#9674] spec_translate incorrectly handling shoud_match, when regexp in a var, in a block + # http://rubyforge.org/tracker/?func=detail&atid=3149&aid=9674&group_id=797 + it "should translate should_match on a regexp, in a var, in a block" do + @t.translate_line("collection.each { |c| c.should_match a_regexp_in_a_var }\n").should eql("collection.each { |c| c.should match(a_regexp_in_a_var) }\n") + @t.translate_line("collection.each{|c| c.should_match a_regexp_in_a_var}\n").should eql("collection.each{|c| c.should match(a_regexp_in_a_var) }\n") + end + + # From Rubinius specs + it "should translate close_to without parens" do + @t.translate_line("end.should_be_close 3.14159_26535_89793_23846, TOLERANCE\n").should eql("end.should be_close(3.14159_26535_89793_23846, TOLERANCE)\n") + end + + # [#9882] 0.9 Beta 1 - translator bugs + # http://rubyforge.org/tracker/index.php?func=detail&aid=9882&group_id=797&atid=3149 + it "should support symbol arguments" do + @t.translate_line( + "lambda { sequence.parse('bar') }.should_throw :ZeroWidthParseSuccess\n" + ).should eql( + "lambda { sequence.parse('bar') }.should throw_symbol(:ZeroWidthParseSuccess)\n" + ) + end + + # [#9882] 0.9 Beta 1 - translator bugs + # http://rubyforge.org/tracker/index.php?func=detail&aid=9882&group_id=797&atid=3149 + it "should support instance var arguments" do + @t.translate_line( + "a.should_eql @local" + ).should eql( + "a.should eql(@local)" + ) + end + + # [#9882] 0.9 Beta 1 - translator bugs + # http://rubyforge.org/tracker/index.php?func=detail&aid=9882&group_id=797&atid=3149 + it "should support lambdas as expecteds" do + @t.translate_line( + "@parslet.should_not_eql lambda { nil }.to_parseable" + ).should eql( + "@parslet.should_not eql(lambda { nil }.to_parseable)" + ) + end + + # [#9882] 0.9 Beta 1 - translator bugs + # http://rubyforge.org/tracker/index.php?func=detail&aid=9882&group_id=797&atid=3149 + it "should support fully qualified names" do + @t.translate_line( + "results.should_be_kind_of SimpleASTLanguage::Identifier" + ).should eql( + "results.should be_kind_of(SimpleASTLanguage::Identifier)" + ) + end + + # [#9882] 0.9 Beta 1 - translator bugs + # http://rubyforge.org/tracker/index.php?func=detail&aid=9882&group_id=797&atid=3149 + # it "should leave whitespace between expression and comments" do + # @t.translate_line( + # "lambda { @instance.foo = foo }.should_raise NoMethodError # no writer defined" + # ).should eql( + # "lambda { @instance.foo = foo }.should raise_error(NoMethodError) # no writer defined" + # ) + # end + + it "should translate redirects" do + @t.translate_line( + "controller.should_redirect_to 'http://not_existing_domain_for_novalis.test.host/404.html'" + ).should eql( + "controller.should redirect_to('http://not_existing_domain_for_novalis.test.host/404.html')" + ) + end + + it "should translate :any_args" do + @t.translate_line( + "mock.should_receive(:foo).with(:any_args)" + ).should eql( + "mock.should_receive(:foo).with(any_args)" + ) + end + + it "should translate :anything" do + @t.translate_line( + "mock.should_receive(:foo).with(:anything)" + ).should eql( + "mock.should_receive(:foo).with(anything)" + ) + end + + it "should translate :boolean" do + @t.translate_line( + "mock.should_receive(:foo).with(:boolean)" + ).should eql( + "mock.should_receive(:foo).with(boolean)" + ) + end + + it "should translate :no_args" do + @t.translate_line( + "mock.should_receive(:foo).with(:no_args)" + ).should eql( + "mock.should_receive(:foo).with(no_args)" + ) + end + + it "should translate :numeric" do + @t.translate_line( + "mock.should_receive(:foo).with(:numeric)" + ).should eql( + "mock.should_receive(:foo).with(an_instance_of(Numeric))" + ) + end + + it "should translate :string" do + @t.translate_line( + "mock.should_receive(:foo).with(:string)" + ).should eql( + "mock.should_receive(:foo).with(an_instance_of(String))" + ) + end +end diff --git a/vendor/plugins/rspec/spec/spec_helper.rb b/vendor/plugins/rspec/spec/spec_helper.rb new file mode 100644 index 000000000..a7a4a82db --- /dev/null +++ b/vendor/plugins/rspec/spec/spec_helper.rb @@ -0,0 +1,46 @@ +require 'stringio' +require 'rbconfig' + +dir = File.dirname(__FILE__) +lib_path = File.expand_path("#{dir}/../lib") +$LOAD_PATH.unshift lib_path unless $LOAD_PATH.include?(lib_path) +$_spec_spec = true # Prevents Kernel.exit in various places + +require 'spec' +require 'spec/mocks' +require 'hpricot' # Needed to compare generated with wanted HTML +spec_classes_path = File.expand_path("#{dir}/../spec/spec/spec_classes") +require spec_classes_path unless $LOAD_PATH.include?(spec_classes_path) + +module Spec + module Matchers + def fail + raise_error(Spec::Expectations::ExpectationNotMetError) + end + + def fail_with(message) + raise_error(Spec::Expectations::ExpectationNotMetError, message) + end + + class Pass + def matches?(proc, &block) + begin + proc.call + true + rescue Exception => @error + false + end + end + + def failure_message + @error.message + "\n" + @error.backtrace.join("\n") + end + end + + def pass + Pass.new + end + end +end + +class NonStandardError < Exception; end |