diff options
author | Leon Breedt <bitserf@gmail.com> | 2005-04-04 22:58:02 +0000 |
---|---|---|
committer | Leon Breedt <bitserf@gmail.com> | 2005-04-04 22:58:02 +0000 |
commit | d7a7d85dbdd2e13612affe48cca39aa48643944d (patch) | |
tree | d4a7cd556125b93b4d93e53a074ee730fc25effa /actionwebservice/lib/action_web_service/casting.rb | |
parent | a87c1d4dd856d138e97e821083c905b481982399 (diff) | |
download | rails-d7a7d85dbdd2e13612affe48cca39aa48643944d.tar.gz rails-d7a7d85dbdd2e13612affe48cca39aa48643944d.tar.bz2 rails-d7a7d85dbdd2e13612affe48cca39aa48643944d.zip |
* Fix casting of nested members in structured types if we have a signature
type available for it even if they are already of the desired type as
SOAP/XML-RPC unmarshaling may have gotten it wrong: SOAP likes to always
use DateTime no matter what, for example, whereas we allow a distinction
between Date, DateTime and Time in the signature for convenience casting
* Fix raising of exceptions by test_invoke so functional tests fail properly on exception
instead of returning the exception object
* Fix Struct#each_pair to yield the value and not the member type
git-svn-id: http://svn-commit.rubyonrails.org/rails/trunk@1089 5ecf4fe2-1ee6-0310-87b1-e25e094e27de
Diffstat (limited to 'actionwebservice/lib/action_web_service/casting.rb')
-rw-r--r-- | actionwebservice/lib/action_web_service/casting.rb | 13 |
1 files changed, 10 insertions, 3 deletions
diff --git a/actionwebservice/lib/action_web_service/casting.rb b/actionwebservice/lib/action_web_service/casting.rb index 113b24a93c..42ef97fd3b 100644 --- a/actionwebservice/lib/action_web_service/casting.rb +++ b/actionwebservice/lib/action_web_service/casting.rb @@ -40,7 +40,7 @@ module ActionWebService # :nodoc: def cast(value, signature_type) # :nodoc: return value if signature_type.nil? # signature.length != params.length - unless signature_type.array? + unless signature_type.array? || signature_type.structured? return value if canonical_type(value.class) == signature_type.type end if signature_type.array? @@ -86,13 +86,20 @@ module ActionWebService # :nodoc: end def cast_to_structured_type(value, signature_type) # :nodoc: - obj = signature_type.type_class.new + obj = nil + obj = value if canonical_type(value.class) == canonical_type(signature_type.type) + obj ||= signature_type.type_class.new if value.respond_to?(:each_pair) klass = signature_type.type_class value.each_pair do |name, val| type = klass.respond_to?(:member_type) ? klass.member_type(name) : nil val = cast(val, type) if type - obj.send("#{name}=", val) + obj.__send__("#{name}=", val) + end + elsif value.respond_to?(:attributes) + signature_type.each_member do |name, type| + val = value.__send__(name) + obj.__send__("#{name}=", cast(val, type)) end else raise CastingError, "Don't know how to cast #{value.class} to #{signature_type.type_class}" |