mirror of
https://github.com/ruby/ruby.git
synced 2022-11-09 12:17:21 -05:00
failed to add some test directories in the previous commit.
git-svn-id: svn+ssh://ci.ruby-lang.org/ruby/branches/ruby_1_8@8503 b2dd03c8-39d4-4d8f-98ff-823fe69b080e
This commit is contained in:
parent
991d0c409c
commit
b5fed06c2a
2 changed files with 78 additions and 0 deletions
55
test/wsdl/rpc/echoDriver.rb
Normal file
55
test/wsdl/rpc/echoDriver.rb
Normal file
|
@ -0,0 +1,55 @@
|
||||||
|
require 'echo.rb'
|
||||||
|
|
||||||
|
require 'soap/rpc/driver'
|
||||||
|
|
||||||
|
class Echo_port_type < ::SOAP::RPC::Driver
|
||||||
|
DefaultEndpointUrl = "http://localhost:10080"
|
||||||
|
MappingRegistry = ::SOAP::Mapping::Registry.new
|
||||||
|
|
||||||
|
MappingRegistry.set(
|
||||||
|
Person,
|
||||||
|
::SOAP::SOAPStruct,
|
||||||
|
::SOAP::Mapping::Registry::TypedStructFactory,
|
||||||
|
{ :type => XSD::QName.new("urn:rpc-type", "person") }
|
||||||
|
)
|
||||||
|
|
||||||
|
Methods = [
|
||||||
|
["echo", "echo",
|
||||||
|
[
|
||||||
|
["in", "arg1", [::SOAP::SOAPStruct, "urn:rpc-type", "person"]],
|
||||||
|
["in", "arg2", [::SOAP::SOAPStruct, "urn:rpc-type", "person"]],
|
||||||
|
["retval", "return", [::SOAP::SOAPStruct, "urn:rpc-type", "person"]]
|
||||||
|
],
|
||||||
|
"", "urn:rpc", :rpc
|
||||||
|
]
|
||||||
|
]
|
||||||
|
|
||||||
|
def initialize(endpoint_url = nil)
|
||||||
|
endpoint_url ||= DefaultEndpointUrl
|
||||||
|
super(endpoint_url, nil)
|
||||||
|
self.mapping_registry = MappingRegistry
|
||||||
|
init_methods
|
||||||
|
end
|
||||||
|
|
||||||
|
private
|
||||||
|
|
||||||
|
def init_methods
|
||||||
|
Methods.each do |name_as, name, params, soapaction, namespace, style|
|
||||||
|
qname = XSD::QName.new(namespace, name_as)
|
||||||
|
if style == :document
|
||||||
|
@proxy.add_document_method(soapaction, name, params)
|
||||||
|
add_document_method_interface(name, params)
|
||||||
|
else
|
||||||
|
@proxy.add_rpc_method(qname, soapaction, name, params)
|
||||||
|
add_rpc_method_interface(name, params)
|
||||||
|
end
|
||||||
|
if name_as != name and name_as.capitalize == name.capitalize
|
||||||
|
sclass = class << self; self; end
|
||||||
|
sclass.__send__(:define_method, name_as, proc { |*arg|
|
||||||
|
__send__(name, *arg)
|
||||||
|
})
|
||||||
|
end
|
||||||
|
end
|
||||||
|
end
|
||||||
|
end
|
||||||
|
|
23
test/wsdl/rpc/echo_serviceClient.rb
Normal file
23
test/wsdl/rpc/echo_serviceClient.rb
Normal file
|
@ -0,0 +1,23 @@
|
||||||
|
#!/usr/bin/env ruby
|
||||||
|
require 'echoDriver.rb'
|
||||||
|
|
||||||
|
endpoint_url = ARGV.shift
|
||||||
|
obj = Echo_port_type.new(endpoint_url)
|
||||||
|
|
||||||
|
# Uncomment the below line to see SOAP wiredumps.
|
||||||
|
# obj.wiredump_dev = STDERR
|
||||||
|
|
||||||
|
# SYNOPSIS
|
||||||
|
# echo(arg1, arg2)
|
||||||
|
#
|
||||||
|
# ARGS
|
||||||
|
# arg1 Person - {urn:rpc-type}person
|
||||||
|
# arg2 Person - {urn:rpc-type}person
|
||||||
|
#
|
||||||
|
# RETURNS
|
||||||
|
# v_return Person - {urn:rpc-type}person
|
||||||
|
#
|
||||||
|
arg1 = arg2 = nil
|
||||||
|
puts obj.echo(arg1, arg2)
|
||||||
|
|
||||||
|
|
Loading…
Add table
Add a link
Reference in a new issue