require "spec_helper" describe Hash do describe "find_regexp" do before do @soap_fault_hash = { "soap:Envelope" => { "soap:Body" => { "soap:Fault" => { "faultcode" => "soap:Server", "faultstring" => "Fault occurred while processing." } } } } end it "returns an empty Hash in case it did not find the specified value" do result = @soap_fault_hash.find_regexp "soap:Fault" result.should be_a Hash result.should be_empty end it "returns the value of the last Regexp filter found in the Hash" do @soap_fault_hash.find_regexp([".+:Envelope", ".+:Body"]). should == @soap_fault_hash["soap:Envelope"]["soap:Body"] @soap_fault_hash.find_regexp([/.+:Envelope/, /.+:Body/, /.+Fault/]). should == @soap_fault_hash["soap:Envelope"]["soap:Body"]["soap:Fault"] end end describe "to_soap_xml" do describe "returns SOAP request compatible XML" do it "for a simple Hash" do { :some => "user" }.to_soap_xml.should == "user" end it "for a nested Hash" do { :some => { :new => "user" } }.to_soap_xml. should == "user" end it "for a Hash with multiple keys" do soap_xml = { :all => "users", :before => "whatever" }.to_soap_xml soap_xml.should include "users" soap_xml.should include "whatever" end it "for a Hash containing an Array" do { :some => ["user", "gorilla"] }.to_soap_xml. should == "usergorilla" end it "for a Hash containing an Array of Hashes" do { :some => [{ :new => "user" }, { :old => "gorilla" }] }.to_soap_xml. should == "usergorilla" end end it "converts Hash key Symbols to lowerCamelCase" do { :find_or_create => "user" }.to_soap_xml. should == "user" end it "does not convert Hash key Strings" do { "find_or_create" => "user" }.to_soap_xml. should == "user" end it "converts DateTime objects to xs:dateTime compliant Strings" do { :before => UserFixture.datetime_object }.to_soap_xml. should == "" << UserFixture.datetime_string << "" end it "converts Objects responding to to_datetime to xs:dateTime compliant Strings" do singleton = Object.new def singleton.to_datetime UserFixture.datetime_object end { :before => singleton }.to_soap_xml. should == "" << UserFixture.datetime_string << "" end it "calls to_s on Strings even if they respond to to_datetime" do singleton = "gorilla" singleton.expects( :to_s ).returns singleton singleton.expects( :to_datetime ).never { :name => singleton }.to_soap_xml.should == "gorilla" end it "call to_s on any other Object" do [666, true, false, nil].each do |object| { :some => object }.to_soap_xml.should == "#{object}" end end end describe "map_soap_response" do it "converts Hash key Strings to snake_case Symbols" do { "userResponse" => { "accountStatus" => "active" } }.map_soap_response. should == { :user_response => { :account_status => "active" } } end it "strips namespaces from Hash keys" do { "ns:userResponse" => { "ns2:id" => "666" } }.map_soap_response. should == { :user_response => { :id => "666" } } end it "converts Hash keys and values in Arrays" do { "response" => [{ "name" => "dude" }, { "name" => "gorilla" }] }.map_soap_response. should == { :response=> [{ :name => "dude" }, { :name => "gorilla" }] } end it "converts xsi:nil values to nil Objects" do { "userResponse" => { "xsi:nil" => "true" } }.map_soap_response. should == { :user_response => nil } end it "converts Hash values matching the xs:dateTime format into DateTime Objects" do { "response" => { "at" => UserFixture.datetime_string } }.map_soap_response. should == { :response => { :at => UserFixture.datetime_object } } end it "converts Hash values matching 'true' to TrueClass" do { "response" => { "active" => "false" } }.map_soap_response. should == { :response => { :active => false } } end it "converts Hash values matching 'false' to FalseClass" do { "response" => { "active" => "true" } }.map_soap_response. should == { :response => { :active => true } } end end end