1
0
Fork 0
mirror of https://github.com/rails/rails.git synced 2022-11-09 12:12:34 -05:00

add backwards compatibility for the public API change made to #api_methods, as it is

being used in some apps.


git-svn-id: http://svn-commit.rubyonrails.org/rails/trunk@1197 5ecf4fe2-1ee6-0310-87b1-e25e094e27de
This commit is contained in:
Leon Breedt 2005-04-17 17:20:44 +00:00
parent 0591c53efd
commit c11cc309fa
4 changed files with 37 additions and 8 deletions

View file

@ -4,8 +4,7 @@
* Add scaffolding via ActionController::Base.web_service_scaffold for quick testing using a web browser
* ActionWebService::API::Base#api_methods now returns a hash containing ActionWebService::API::Method objects
instead of hashes
* ActionWebService::API::Base#api_methods now returns a hash containing ActionWebService::API::Method objects instead of hashes. However, ActionWebService::API::Method defines a #[]() backwards compatibility method so any existing code utilizing this will still work.
* The :layered dispatching mode can now be used with SOAP as well, allowing you to support SOAP and XML-RPC clients for APIs like the metaWeblog API

View file

@ -204,6 +204,16 @@ module ActionWebService # :nodoc:
h
end
# Backwards compatibility with previous API
def [](sig_type)
case sig_type
when :expects
@expects.map{|x| compat_signature_entry(x)}
when :returns
@returns.map{|x| compat_signature_entry(x)}
end
end
# String representation of this method
def to_s
fqn = ""
@ -215,6 +225,18 @@ module ActionWebService # :nodoc:
end
private
def compat_signature_entry(entry)
if entry.array?
[compat_signature_entry(entry.element_type)]
else
if entry.spec.is_a?(Hash)
{entry.spec.keys.first => entry.type_class}
else
entry.type_class
end
end
end
def friendly_param(type, show_name=true)
name = type.name.to_s
type_type = type.array?? type.element_type.type.to_s : type.type.to_s

View file

@ -10,19 +10,20 @@ module ActionWebService # :nodoc:
end
def canonical_signature_entry(spec, i)
orig_spec = spec
name = "param#{i}"
if spec.is_a?(Hash)
name, spec = spec.keys.first, spec.values.first
end
type = spec
if spec.is_a?(Array)
ArrayType.new(canonical_signature_entry(spec[0], 0), name)
ArrayType.new(orig_spec, canonical_signature_entry(spec[0], 0), name)
else
type = canonical_type(type)
if type.is_a?(Symbol)
BaseType.new(type, name)
BaseType.new(orig_spec, type, name)
else
StructuredType.new(type, name)
StructuredType.new(orig_spec, type, name)
end
end
end
@ -126,11 +127,13 @@ module ActionWebService # :nodoc:
class BaseType # :nodoc:
include SignatureTypes
attr :spec
attr :type
attr :type_class
attr :name
def initialize(type, name)
def initialize(spec, type, name)
@spec = spec
@type = canonical_type(type)
@type_class = canonical_type_class(@type)
@name = name
@ -152,8 +155,8 @@ module ActionWebService # :nodoc:
class ArrayType < BaseType # :nodoc:
attr :element_type
def initialize(element_type, name)
super(Array, name)
def initialize(spec, element_type, name)
super(spec, Array, name)
@element_type = element_type
end

View file

@ -91,6 +91,11 @@ class TC_API < Test::Unit::TestCase
assert_equal({:appkey => 5, :publish => false}, hash)
end
def test_api_methods_compat
sig = API.api_methods[:named_signature][:expects]
assert_equal [{:appkey=>Integer}, {:publish=>TrueClass}], sig
end
def test_to_s
assert_equal 'void Expects(int param0, bool param1)', APITest::API.api_methods[:expects].to_s
end