2003-12-02 15:11:02 +00:00
|
|
|
#!/usr/local/bin/lua.5.0
|
|
|
|
-- See Copyright Notice in license.html
|
|
|
|
|
|
|
|
require "xmlrpc"
|
|
|
|
require "xrh"
|
|
|
|
|
2003-12-19 12:46:25 +00:00
|
|
|
function table._print (tab, indent, spacing)
|
2003-12-02 15:11:02 +00:00
|
|
|
spacing = spacing or ""
|
|
|
|
indent = indent or "\t"
|
|
|
|
io.write ("{\n")
|
|
|
|
for nome, val in pairs (tab) do
|
|
|
|
io.write (spacing..indent)
|
|
|
|
local t = type(nome)
|
|
|
|
if t == "string" then
|
|
|
|
io.write (string.format ("[%q] = ", tostring (nome)))
|
|
|
|
elseif t == "number" or t == "boolean" then
|
|
|
|
io.write (string.format ("[%s] = ", tostring (nome)))
|
|
|
|
else
|
|
|
|
io.write (t)
|
|
|
|
end
|
|
|
|
t = type(val)
|
|
|
|
if t == "string" or t == "number" then
|
|
|
|
io.write (string.format ("%q", val))
|
|
|
|
elseif t == "table" then
|
|
|
|
table.print (val, indent, spacing..indent)
|
|
|
|
else
|
|
|
|
io.write (t)
|
|
|
|
end
|
|
|
|
io.write (",\n")
|
|
|
|
end
|
|
|
|
io.write (spacing.."}")
|
|
|
|
end
|
|
|
|
|
2003-12-19 12:46:25 +00:00
|
|
|
function table._tostring (tab, indent, spacing)
|
|
|
|
local s = {}
|
|
|
|
spacing = spacing or ""
|
|
|
|
indent = indent or "\t"
|
|
|
|
table.insert (s, "{\n")
|
|
|
|
for nome, val in pairs (tab) do
|
|
|
|
table.insert (s, spacing..indent)
|
|
|
|
local t = type(nome)
|
|
|
|
if t == "string" then
|
|
|
|
table.insert (s, string.format ("[%q] = ", tostring (nome)))
|
|
|
|
elseif t == "number" or t == "boolean" then
|
|
|
|
table.insert (s, string.format ("[%s] = ", tostring (nome)))
|
|
|
|
else
|
|
|
|
table.insert (s, t)
|
|
|
|
end
|
|
|
|
t = type(val)
|
|
|
|
if t == "string" or t == "number" then
|
|
|
|
table.insert (s, string.format ("%q", val))
|
|
|
|
elseif t == "table" then
|
|
|
|
table.insert (s, table._tostring (val, indent, spacing..indent))
|
|
|
|
else
|
|
|
|
table.insert (s, t)
|
|
|
|
end
|
|
|
|
table.insert (s, ",\n")
|
|
|
|
end
|
|
|
|
table.insert (s, spacing.."}")
|
|
|
|
return table.concat (s)
|
|
|
|
end
|
|
|
|
|
|
|
|
function table.print (tab, indent, spacing)
|
|
|
|
io.write (table._tostring (tab, indent, spacing))
|
|
|
|
end
|
|
|
|
|
|
|
|
function table.equal2 (t1, t2)
|
2003-12-02 15:11:02 +00:00
|
|
|
if type(t1) ~= "table" or type(t2) ~= "table" then
|
|
|
|
return false
|
|
|
|
end
|
|
|
|
for key, v1 in t1 do
|
|
|
|
local v2 = rawget (t2, key)
|
|
|
|
if type(v1) == "table" and type(v2) == "table" then
|
|
|
|
if not table.equal (v1, v2) then
|
|
|
|
return false
|
|
|
|
end
|
|
|
|
elseif v1 ~= v2 then
|
|
|
|
return false
|
|
|
|
end
|
|
|
|
end
|
|
|
|
return true
|
|
|
|
end
|
|
|
|
|
2003-12-19 12:46:25 +00:00
|
|
|
function table.equal (t1, t2)
|
|
|
|
if type(t1) ~= "table" or type(t2) ~= "table" then
|
|
|
|
return false
|
|
|
|
end
|
|
|
|
local s1 = table._tostring (t1)
|
|
|
|
local s2 = table._tostring (t2)
|
|
|
|
s1 = string.gsub (s1, "%s*", "")
|
|
|
|
s2 = string.gsub (s2, "%s*", "")
|
|
|
|
--if s1 ~= s2 then
|
|
|
|
--print(s1, "!!!!", s2)
|
|
|
|
--end
|
2004-01-02 17:37:16 +00:00
|
|
|
return s1 == s2, s1.."!!!"..s2
|
|
|
|
end
|
|
|
|
|
|
|
|
function remove_type (tab)
|
|
|
|
if type(tab) ~= "table" then
|
|
|
|
return tab
|
|
|
|
elseif tab["*type"] then
|
|
|
|
return tab["*value"]
|
|
|
|
end
|
|
|
|
for i,v in pairs (tab) do
|
|
|
|
if type(v) == "table" then
|
|
|
|
tab[i] = remove_type (v)
|
|
|
|
end
|
|
|
|
end
|
|
|
|
return tab
|
2003-12-19 12:46:25 +00:00
|
|
|
end
|
|
|
|
|
2003-12-02 15:11:02 +00:00
|
|
|
function call_test (xml_call, method, ...)
|
|
|
|
local xc = string.gsub (xml_call, "(%p)", "%%%1")
|
2003-12-19 12:46:25 +00:00
|
|
|
--xc = string.gsub (xc, "\r?\n%s*", "%%s*")
|
|
|
|
xc = string.gsub (xc, "%s*", "")
|
2003-12-02 15:11:02 +00:00
|
|
|
arg.n = nil
|
|
|
|
|
|
|
|
-- client enconding test
|
|
|
|
local meth_call = xmlrpc.client_encode (method, unpack (arg))
|
2003-12-19 12:46:25 +00:00
|
|
|
meth_call = string.gsub (meth_call, "%s*", "")
|
2003-12-02 15:11:02 +00:00
|
|
|
local s = string.gsub (meth_call, xc, "")
|
|
|
|
s = string.gsub (s, "%s*", "")
|
2003-12-19 12:46:25 +00:00
|
|
|
assert (s == "", s.."\n!!!\n"..xc)
|
2003-12-02 15:11:02 +00:00
|
|
|
|
|
|
|
-- server decoding test
|
|
|
|
local meth_call, param = xmlrpc.server_decode (xml_call)
|
|
|
|
assert (meth_call == method, meth_call)
|
2004-01-02 17:37:16 +00:00
|
|
|
arg = remove_type (arg)
|
2003-12-15 16:20:47 +00:00
|
|
|
assert (table.equal (arg, param))
|
2003-12-02 15:11:02 +00:00
|
|
|
end
|
|
|
|
|
|
|
|
function response_test (xml_resp, lua_obj)
|
|
|
|
-- client decoding test
|
|
|
|
local ok, obj = xmlrpc.client_decode (xml_resp)
|
|
|
|
|
|
|
|
-- server encoding test
|
|
|
|
xml_resp = string.gsub (xml_resp, "(%p)", "%%%1")
|
|
|
|
xml_resp = string.gsub (xml_resp, "\r?\n%s*", "%%s*")
|
|
|
|
local meth_resp = xmlrpc.server_encode (lua_obj)
|
2004-01-02 17:37:16 +00:00
|
|
|
|
|
|
|
if type (obj) == "table" then
|
|
|
|
lua_obj = remove_type (lua_obj)
|
|
|
|
assert (table.equal (obj, lua_obj))
|
|
|
|
else
|
|
|
|
assert (obj == lua_obj)
|
|
|
|
end
|
2003-12-02 15:11:02 +00:00
|
|
|
local s = string.gsub (meth_resp, xml_resp, "")
|
|
|
|
s = string.gsub (s, "%s*", "")
|
|
|
|
assert (s == "", s)
|
|
|
|
end
|
|
|
|
|
2003-12-11 21:44:54 +00:00
|
|
|
function fault_test (xml_resp, message, code)
|
|
|
|
-- client decoding test
|
|
|
|
local ok, str, n = xmlrpc.client_decode (xml_resp)
|
|
|
|
assert (str == message)
|
|
|
|
assert (n == code)
|
|
|
|
|
|
|
|
-- server encoding test
|
|
|
|
xml_resp = string.gsub (xml_resp, "(%p)", "%%%1")
|
|
|
|
xml_resp = string.gsub (xml_resp, "\r?\n%s*", "%%s*")
|
|
|
|
local meth_resp = xmlrpc.server_encode ({ message = message, code = code }, true)
|
|
|
|
local s = string.gsub (meth_resp, xml_resp, "")
|
|
|
|
s = string.gsub (s, "%s*", "")
|
|
|
|
assert (s == "", s)
|
|
|
|
end
|
|
|
|
|
2003-12-02 15:11:02 +00:00
|
|
|
---------------------------------------------------------------------
|
|
|
|
-- call tests.
|
|
|
|
---------------------------------------------------------------------
|
|
|
|
call_test ([[<?xml version="1.0"?>
|
|
|
|
<methodCall>
|
|
|
|
<methodName>examples.getStateName</methodName>
|
|
|
|
<params>
|
|
|
|
<param>
|
|
|
|
<value><int>41</int></value>
|
|
|
|
</param>
|
|
|
|
</params>
|
|
|
|
</methodCall>]], "examples.getStateName", 41)
|
|
|
|
|
2004-01-02 17:37:16 +00:00
|
|
|
local double_139 = xmlrpc.createTypedValue (139, "double")
|
2003-12-02 15:11:02 +00:00
|
|
|
call_test ([[<?xml version="1.0"?>
|
|
|
|
<methodCall>
|
|
|
|
<methodName>examples.getSomething</methodName>
|
|
|
|
<params>
|
|
|
|
<param>
|
|
|
|
<value>
|
|
|
|
<struct>
|
|
|
|
<member>
|
|
|
|
<name>lowerBound</name>
|
2004-01-02 17:37:16 +00:00
|
|
|
<value><double>18.2</double></value>
|
2003-12-02 15:11:02 +00:00
|
|
|
</member>
|
|
|
|
<member>
|
|
|
|
<name>upperBound</name>
|
2004-01-02 17:37:16 +00:00
|
|
|
<value><double>139</double></value>
|
2003-12-02 15:11:02 +00:00
|
|
|
</member>
|
|
|
|
</struct>
|
|
|
|
</value>
|
|
|
|
</param>
|
|
|
|
</params>
|
2004-01-02 17:37:16 +00:00
|
|
|
</methodCall>]], "examples.getSomething", { lowerBound = 18.2, upperBound = double_139 })
|
2003-12-02 15:11:02 +00:00
|
|
|
|
2004-01-02 17:37:16 +00:00
|
|
|
local double_array = xmlrpc.createArray ("double")
|
2003-12-19 12:46:25 +00:00
|
|
|
call_test ([[<?xml version="1.0"?>
|
|
|
|
<methodCall>
|
|
|
|
<methodName>test</methodName>
|
|
|
|
<params>
|
|
|
|
<param><value><array><data>
|
2004-01-02 17:37:16 +00:00
|
|
|
<value><double>1</double></value>
|
|
|
|
<value><double>2</double></value>
|
|
|
|
<value><double>3</double></value>
|
|
|
|
<value><double>4</double></value>
|
2003-12-19 12:46:25 +00:00
|
|
|
</data></array></value></param>
|
|
|
|
</params>
|
|
|
|
</methodCall>]],
|
|
|
|
"test",
|
2004-01-02 17:37:16 +00:00
|
|
|
xmlrpc.createTypedValue ({ 1, 2, 3, 4, }, double_array)
|
2003-12-19 12:46:25 +00:00
|
|
|
)
|
|
|
|
|
2004-01-02 17:37:16 +00:00
|
|
|
local double_array_array = xmlrpc.createArray (double_array)
|
2003-12-19 12:46:25 +00:00
|
|
|
call_test ([[<?xml version="1.0"?>
|
|
|
|
<methodCall>
|
|
|
|
<methodName>test</methodName>
|
|
|
|
<params>
|
|
|
|
<param><value><array><data>
|
|
|
|
<value><array><data>
|
2004-01-02 17:37:16 +00:00
|
|
|
<value><double>1</double></value>
|
|
|
|
<value><double>2</double></value>
|
|
|
|
<value><double>3</double></value>
|
|
|
|
<value><double>4</double></value>
|
2003-12-19 12:46:25 +00:00
|
|
|
</data></array></value>
|
|
|
|
<value><array><data>
|
2004-01-02 17:37:16 +00:00
|
|
|
<value><double>11</double></value>
|
|
|
|
<value><double>12</double></value>
|
|
|
|
<value><double>13</double></value>
|
|
|
|
<value><double>14</double></value>
|
2003-12-19 12:46:25 +00:00
|
|
|
</data></array></value>
|
|
|
|
<value><array><data>
|
2004-01-02 17:37:16 +00:00
|
|
|
<value><double>21</double></value>
|
|
|
|
<value><double>22</double></value>
|
|
|
|
<value><double>23</double></value>
|
|
|
|
<value><double>24</double></value>
|
2003-12-19 12:46:25 +00:00
|
|
|
</data></array></value>
|
|
|
|
</data></array></value></param>
|
|
|
|
</params>
|
|
|
|
</methodCall>]],
|
|
|
|
"test",
|
|
|
|
xmlrpc.createTypedValue (
|
|
|
|
{
|
|
|
|
{ 1, 2, 3, 4, },
|
|
|
|
{ 11, 12, 13, 14, },
|
|
|
|
{ 21, 22, 23, 24, },
|
|
|
|
},
|
2004-01-02 17:37:16 +00:00
|
|
|
double_array_array
|
2003-12-19 12:46:25 +00:00
|
|
|
)
|
|
|
|
)
|
|
|
|
|
|
|
|
|
2003-12-02 15:11:02 +00:00
|
|
|
call_test ([[<?xml version="1.0"?>
|
|
|
|
<methodCall>
|
|
|
|
<methodName>insertTable</methodName>
|
|
|
|
<params>
|
|
|
|
<param><value><string>people</string></value></param>
|
|
|
|
<param><value>
|
|
|
|
<array><data>
|
|
|
|
<value>
|
|
|
|
<struct>
|
|
|
|
<member>
|
|
|
|
<name>name</name>
|
|
|
|
<value><string>Fulano</string></value>
|
|
|
|
</member>
|
|
|
|
<member>
|
|
|
|
<name>email</name>
|
|
|
|
<value><string>fulano@nowhere.world</string></value>
|
|
|
|
</member>
|
|
|
|
</struct>
|
|
|
|
</value>
|
|
|
|
<value>
|
|
|
|
<struct>
|
|
|
|
<member>
|
|
|
|
<name>name</name>
|
|
|
|
<value><string>Beltrano</string></value>
|
|
|
|
</member>
|
|
|
|
<member>
|
|
|
|
<name>email</name>
|
|
|
|
<value><string>beltrano@nowhere.world</string></value>
|
|
|
|
</member>
|
|
|
|
</struct>
|
|
|
|
</value>
|
|
|
|
<value>
|
|
|
|
<struct>
|
|
|
|
<member>
|
|
|
|
<name>name</name>
|
|
|
|
<value><string>Cicrano</string></value>
|
|
|
|
</member>
|
|
|
|
<member>
|
|
|
|
<name>email</name>
|
|
|
|
<value><string>cicrano@nowhere.world</string></value>
|
|
|
|
</member>
|
|
|
|
</struct>
|
|
|
|
</value>
|
|
|
|
</data></array>
|
|
|
|
</value></param>
|
|
|
|
</params>
|
|
|
|
</methodCall>]],
|
|
|
|
"insertTable",
|
2003-12-19 12:46:25 +00:00
|
|
|
"people",
|
|
|
|
xmlrpc.createTypedValue (
|
|
|
|
{
|
|
|
|
{ name = "Fulano", email = "fulano@nowhere.world", },
|
|
|
|
{ name = "Beltrano", email = "beltrano@nowhere.world", },
|
|
|
|
{ name = "Cicrano", email = "cicrano@nowhere.world", },
|
|
|
|
},
|
|
|
|
xmlrpc.createArray ("struct")
|
|
|
|
)
|
|
|
|
)
|
2003-12-02 15:11:02 +00:00
|
|
|
|
|
|
|
---------------------------------------------------------------------
|
|
|
|
-- response tests.
|
|
|
|
---------------------------------------------------------------------
|
|
|
|
response_test ([[<?xml version="1.0"?>
|
|
|
|
<methodResponse>
|
|
|
|
<params>
|
|
|
|
<param>
|
|
|
|
<value><string>South Dakota</string></value>
|
|
|
|
</param>
|
|
|
|
</params>
|
|
|
|
</methodResponse>]], "South Dakota")
|
|
|
|
|
|
|
|
response_test ([[<?xml version="1.0"?>
|
|
|
|
<methodResponse>
|
|
|
|
<params>
|
|
|
|
<param>
|
|
|
|
<value>
|
|
|
|
<struct>
|
|
|
|
<member>
|
|
|
|
<name>lowerBound</name>
|
2004-01-02 17:37:16 +00:00
|
|
|
<value><double>18.2</double></value>
|
2003-12-02 15:11:02 +00:00
|
|
|
</member>
|
|
|
|
<member>
|
|
|
|
<name>upperBound</name>
|
2004-01-02 17:37:16 +00:00
|
|
|
<value><double>139</double></value>
|
2003-12-02 15:11:02 +00:00
|
|
|
</member>
|
|
|
|
</struct>
|
|
|
|
</value>
|
|
|
|
</param>
|
|
|
|
</params>
|
2004-01-02 17:37:16 +00:00
|
|
|
</methodResponse>]], { lowerBound = 18.2, upperBound = double_139 })
|
2003-12-11 21:44:54 +00:00
|
|
|
|
|
|
|
fault_test ([[<?xml version="1.0"?>
|
|
|
|
<methodResponse>
|
|
|
|
<fault>
|
|
|
|
<value>
|
|
|
|
<struct>
|
|
|
|
<member>
|
|
|
|
<name>faultCode</name>
|
|
|
|
<value><int>1</int></value>
|
|
|
|
</member>
|
|
|
|
<member>
|
|
|
|
<name>faultString</name>
|
|
|
|
<value><string>error string</string></value>
|
|
|
|
</member>
|
|
|
|
</struct>
|
|
|
|
</value>
|
|
|
|
</fault>
|
|
|
|
</methodResponse>]], "error string", 1)
|