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 75 76 77 78
|
require File.expand_path('../../../spec_helper', __FILE__)
describe :complex_to_s, :shared => true do
describe "when self's real component is 0" do
ruby_version_is ""..."1.9" do
it "returns only the imaginary component as String" do
Complex(0, 5).to_s.should == "5i"
Complex(0, -3.2).to_s.should == "-3.2i"
end
end
ruby_version_is "1.9" do
it "returns both the real and imaginary component even when the real is 0" do
Complex(0, 5).to_s.should == "0+5i"
Complex(0, -3.2).to_s.should == "0-3.2i"
end
end
end
it "returns self as String" do
Complex(1, 5).to_s.should == "1+5i"
Complex(-2.5, 1.5).to_s.should == "-2.5+1.5i"
Complex(1, -5).to_s.should == "1-5i"
Complex(-2.5, -1.5).to_s.should == "-2.5-1.5i"
# Guard against the Mathn library
conflicts_with :Prime do
Complex(1, 0).to_s.should == "1+0i"
Complex(1, -0).to_s.should == "1+0i"
end
end
ruby_version_is ""..."1.9" do
it "returns 1+0.0i for Complex(1, 0.0)" do
Complex(1, 0.0).to_s.should == "1+0.0i"
end
it "returns 1+0.0i for Complex(1, -0.0)" do
# This is a bit weird, but it's what MRI does
Complex(1, -0.0).to_s.should == "1+0.0i"
end
it "returns 1+Infinityi for Complex(1, Infinity)" do
Complex(1, infinity_value).to_s.should == "1+Infinityi"
end
it "returns 1-Infinityi for Complex(1, -Infinity)" do
Complex(1, -infinity_value).to_s.should == "1-Infinityi"
end
it "returns 1-NaNi for Complex(1, NaN)" do
Complex(1, nan_value).to_s.should == "1-NaNi"
end
end
ruby_version_is "1.9" do
it "returns 1+0.0i for Complex(1, 0.0)" do
Complex(1, 0.0).to_s.should == "1+0.0i"
end
it "returns 1-0.0i for Complex(1, -0.0)" do
Complex(1, -0.0).to_s.should == "1-0.0i"
end
it "returns 1+Infinity*i for Complex(1, Infinity)" do
Complex(1, infinity_value).to_s.should == "1+Infinity*i"
end
it "returns 1-Infinity*i for Complex(1, -Infinity)" do
Complex(1, -infinity_value).to_s.should == "1-Infinity*i"
end
it "returns 1+NaN*i for Complex(1, NaN)" do
Complex(1, nan_value).to_s.should == "1+NaN*i"
end
end
end
|