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
|
require File.dirname(__FILE__) + '/../../spec_helper'
require 'complex'
describe "Complex#* with Complex" do
it "multiplies according to the usual rule for complex numbers: (a + bi) * (c + di) = ac - bd + (ad + bc)i" do
(Complex(1, 2) * Complex(10, 20)).should == Complex((1 * 10) - (2 * 20), (1 * 20) + (2 * 10))
(Complex(1.5, 2.1) * Complex(100.2, -30.3)).should == Complex((1.5 * 100.2) - (2.1 * -30.3), (1.5 * -30.3) + (2.1 * 100.2))
end
end
describe "Complex#* with Integer" do
it "multiplies both parts of self by the given Integer" do
(Complex(3, 2) * 50).should == Complex(150, 100)
(Complex(-3, 2) * 50.5).should == Complex(-151.5, 101)
end
end
describe "Complex#* with Object" do
it "tries to coerce self into other" do
value = Complex(3, 9)
obj = mock("Object")
obj.should_receive(:coerce).with(value).and_return([2, 5])
(value * obj).should == 2 * 5
end
end
|