1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 41 42 43 44 45 46 47 48 49 50 51 52 53 54 55 56 57 58 59 60 61 62 63 64 65 66 67 68 69 70 71 72 73 74
|
require_relative '../../spec_helper'
require_relative 'fixtures/common'
describe "Exception#dup" do
before :each do
@obj = ExceptionSpecs::InitializeException.new("my exception")
end
it "calls #initialize_copy on the new instance" do
dup = @obj.dup
ScratchPad.recorded.should_not == @obj.object_id
ScratchPad.recorded.should == dup.object_id
end
it "copies instance variables" do
dup = @obj.dup
dup.ivar.should == 1
end
it "does not copy singleton methods" do
def @obj.special() :the_one end
dup = @obj.dup
-> { dup.special }.should raise_error(NameError)
end
it "does not copy modules included in the singleton class" do
class << @obj
include ExceptionSpecs::ExceptionModule
end
dup = @obj.dup
-> { dup.repr }.should raise_error(NameError)
end
it "does not copy constants defined in the singleton class" do
class << @obj
CLONE = :clone
end
dup = @obj.dup
-> { class << dup; CLONE; end }.should raise_error(NameError)
end
it "does copy the message" do
@obj.dup.message.should == @obj.message
end
it "does copy the backtrace" do
begin
# Explicitly raise so a backtrace is associated with the exception.
# It's tempting to call `set_backtrace` instead, but that complicates
# the test because it might affect other state (e.g., instance variables)
# on some implementations.
raise ExceptionSpecs::InitializeException.new("my exception")
rescue => e
@obj = e
end
@obj.dup.backtrace.should == @obj.backtrace
end
it "does copy the cause" do
begin
raise StandardError, "the cause"
rescue StandardError => cause
begin
raise RuntimeError, "the consequence"
rescue RuntimeError => e
e.cause.should equal(cause)
e.dup.cause.should equal(cause)
end
end
end
end
|