include_once __DIR__ . '/parse_args.php';
+include_once __DIR__ . '/PolyfillTestCase.php';
+
+use PHPUnit\Framework\TestResult;
+
/**
* Tests which involve interaction between the client and the server.
* They are run against the server found in demo/server.php
*/
-class LocalhostTest extends PHPUnit_Framework_TestCase
+class LocalhostTest extends PhpXmlRpc_PolyfillTestCase
{
/** @var xmlrpc_client $client */
protected $client = null;
protected $collectCodeCoverageInformation;
protected $coverageScriptUrl;
- public static function fail($message = '')
+ public static function _fail($message = '')
{
// save in a static var that this particular test has failed
// (but only if not called from subclass objects / multitests)
}
}
- parent::fail($message);
+ parent::_fail($message);
}
/**
* Reimplemented to allow us to collect code coverage info from the target server.
* Code taken from PHPUnit_Extensions_Selenium2TestCase
*
- * @param PHPUnit_Framework_TestResult $result
- * @return PHPUnit_Framework_TestResult
+ * @param TestResult $result
+ * @return TestResult
* @throws Exception
*/
- public function run(PHPUnit_Framework_TestResult $result = NULL)
+ public function _run($result = NULL)
{
$this->testId = get_class($this) . '__' . $this->getName();
$this->collectCodeCoverageInformation = $result->getCollectCodeCoverageInformation();
- parent::run($result);
+ parent::_run($result);
if ($this->collectCodeCoverageInformation) {
$coverage = new PHPUnit_Extensions_SeleniumCommon_RemoteCoverage(
return $result;
}
- public function setUp()
+ public function set_up()
{
$this->args = argParser::getArgs();
- $server = explode(':', $this->args['LOCALSERVER']);
+ $server = explode(':', $this->args['HTTPSERVER']);
if (count($server) > 1) {
- $this->client = new xmlrpc_client($this->args['URI'], $server[0], $server[1]);
+ $this->client = new xmlrpc_client($this->args['HTTPURI'], $server[0], $server[1]);
} else {
- $this->client = new xmlrpc_client($this->args['URI'], $this->args['LOCALSERVER']);
+ $this->client = new xmlrpc_client($this->args['HTTPURI'], $this->args['HTTPSERVER']);
}
$this->client->setDebug($this->args['DEBUG']);
$this->client->request_compression = $this->request_compression;
$this->client->accepted_compression = $this->accepted_compression;
- $this->coverageScriptUrl = 'http://' . $this->args['LOCALSERVER'] . '/' . str_replace( '/demo/server/server.php', 'tests/phpunit_coverage.php', $this->args['URI'] );
+ $this->coverageScriptUrl = 'http://' . $this->args['HTTPSERVER'] . '/' . str_replace( '/demo/server/server.php', 'tests/phpunit_coverage.php', $this->args['HTTPURI'] );
if ($this->args['DEBUG'] == 1)
ob_start();
}
- protected function tearDown()
+ protected function tear_down()
{
if ($this->args['DEBUG'] != 1)
return;
* @param PhpXmlRpc\Request|array $msg
* @param int|array $errorCode
* @param bool $returnResponse
- * @return mixed|\PhpXmlRpc\Response|\PhpXmlRpc\Response[]|\PhpXmlRpc\Value|string|void
+ * @return mixed|\PhpXmlRpc\Response|\PhpXmlRpc\Response[]|\PhpXmlRpc\Value|string|null
*/
protected function send($msg, $errorCode = 0, $returnResponse = false)
{
return $r->value();
}
} else {
- return;
+ return null;
}
}
+ /**
+ * Adds (and replaces) query params to the url currently used by the client
+ * @param array $data
+ */
+ protected function addQueryParams($data)
+ {
+ $query = parse_url($this->client->path, PHP_URL_QUERY);
+ parse_str($query, $vars);
+ $query = http_build_query(array_merge($vars, $data));
+ $this->client->path = parse_url($this->client->path, PHP_URL_PATH) . '?' . $query;
+ }
+
public function testString()
{
$sendString = "here are 3 \"entities\": < > & " .
</params>
</methodCall>';
+ PhpXmlRpc\PhpXmlRpc::$xmlrpc_internalencoding = 'UTF-8';
+ // we have to set the encoding declaration either in the http header or xml prolog, as mb_detect_encoding
+ // (used on the server side) will fail recognizing these 2 charsets
$v = $this->send(mb_convert_encoding(str_replace('_ENC_', 'UCS-4', $str), 'UCS-4', 'UTF-8'));
$this->assertEquals($sendString, $v->scalarval());
$v = $this->send(mb_convert_encoding(str_replace('_ENC_', 'UTF-16', $str), 'UTF-16', 'UTF-8'));
$this->assertEquals($sendString, $v->scalarval());
+ PhpXmlRpc\PhpXmlRpc::$xmlrpc_internalencoding = 'ISO-8859-1';
+ }
+
+ public function testExoticCharsetsRequests2()
+ {
+ // note that we should disable this call also when mbstring is missing server-side
+ if (!function_exists('mb_convert_encoding')) {
+ $this->markTestSkipped('Miss mbstring extension to test exotic charsets');
+ return;
+ }
+ $sendString = '安室奈美恵'; // No idea what this means :-) NB: NOT a valid ISO8859 string!
+ $str = '<?xml version="1.0"?>
+<methodCall>
+ <methodName>examples.stringecho</methodName>
+ <params>
+ <param>
+ <value><string>'.$sendString.'</string></value>
+ </param>
+ </params>
+</methodCall>';
+
+ PhpXmlRpc\PhpXmlRpc::$xmlrpc_internalencoding = 'UTF-8';
+ // no encoding declaration either in the http header or xml prolog, let mb_detect_encoding
+ // (used on the server side) sort it out
+ $this->addQueryParams(array('DETECT_ENCODINGS' => array('EUC-JP', 'UTF-8')));
+ $v = $this->send(mb_convert_encoding($str, 'EUC-JP', 'UTF-8'));
+ $this->assertEquals($sendString, $v->scalarval());
+ PhpXmlRpc\PhpXmlRpc::$xmlrpc_internalencoding = 'ISO-8859-1';
+ }
+
+ public function testExoticCharsetsRequests3()
+ {
+ // note that we should disable this call also when mbstring is missing server-side
+ if (!function_exists('mb_convert_encoding')) {
+ $this->markTestSkipped('Miss mbstring extension to test exotic charsets');
+ return;
+ }
+ $sendString = utf8_decode('élève');
+ $str = '<?xml version="1.0"?>
+<methodCall>
+ <methodName>examples.stringecho</methodName>
+ <params>
+ <param>
+ <value><string>'.$sendString.'</string></value>
+ </param>
+ </params>
+</methodCall>';
+
+ // no encoding declaration either in the http header or xml prolog, let mb_detect_encoding
+ // (used on the server side) sort it out
+ $this->addQueryParams(array('DETECT_ENCODINGS' => array('ISO-8859-1', 'UTF-8')));
+ $v = $this->send($str);
+ $this->assertEquals($sendString, $v->scalarval());
}
/*public function testLatin1Method()
$got = '';
$expected = '37210';
$expect_array = array('ctLeftAngleBrackets', 'ctRightAngleBrackets', 'ctAmpersands', 'ctApostrophes', 'ctQuotes');
- while (list(, $val) = each($expect_array)) {
+ foreach($expect_array as $val) {
$b = $v->structmem($val);
$got .= $b->me['int'];
}
{
// NB: This test will NOT pass if server does not support system.multicall.
+ $noMultiCall = $this->client->no_multicall;
$this->client->no_multicall = false;
$good1 = new xmlrpcmsg('system.methodHelp',
$this->assertTrue($this->client->no_multicall == false,
"server does not support system.multicall"
);
+
+ $this->client->no_multicall = $noMultiCall;
}
public function testClientMulticall2()
{
// NB: This test will NOT pass if server does not support system.multicall.
+ $noMultiCall = $this->client->no_multicall;
$this->client->no_multicall = true;
$good1 = new xmlrpcmsg('system.methodHelp',
$val = $r[3]->value();
$this->assertTrue($val->kindOf() == 'array', "good2 did not return array");
}
+
+ $this->client->no_multicall = $noMultiCall;
}
public function testClientMulticall3()
{
// NB: This test will NOT pass if server does not support system.multicall.
+ $noMultiCall = $this->client->no_multicall;
+ $returnType = $this->client->return_type;
+
$this->client->return_type = 'phpvals';
$this->client->no_multicall = false;
$val = $r[3]->value();
$this->assertTrue(is_array($val), "good2 did not return array");
}
- $this->client->return_type = 'xmlrpcvals';
+
+ $this->client->return_type = $returnType;
+ $this->client->no_multicall = $noMultiCall;
}
public function testCatchWarnings()
new xmlrpcval('whatever', 'string'),
));
$v = $this->send($m, $GLOBALS['xmlrpcerr']['server_error']);
- $this->client->path = $this->args['URI'] . '?EXCEPTION_HANDLING=1';
+ $this->addQueryParams(array('EXCEPTION_HANDLING' => 1));
$v = $this->send($m, 1); // the error code of the expected exception
- $this->client->path = $this->args['URI'] . '?EXCEPTION_HANDLING=2';
+ $this->addQueryParams(array('EXCEPTION_HANDLING' => 2));
// depending on whether display_errors is ON or OFF on the server, we will get back a different error here,
// as php will generate an http status code of either 200 or 500...
$v = $this->send($m, array($GLOBALS['xmlrpcerr']['invalid_return'], $GLOBALS['xmlrpcerr']['http_error']));
$this->fail('Registration of remote server failed');
} else {
$obj = new $class();
- $v = $obj->examples_getStateName(23);
- // work around bug in current (or old?) version of phpunit when reporting the error
- /*if (is_object($v)) {
- $v = var_export($v, true);
- }*/
- $this->assertEquals('Michigan', $v);
+ if (!is_callable(array($obj, 'examples_getStateName'))) {
+ $this->fail('Registration of remote server failed to import method "examples_getStateName"');
+ } else {
+ $v = $obj->examples_getStateName(23);
+ // work around bug in current (or old?) version of phpunit when reporting the error
+ /*if (is_object($v)) {
+ $v = var_export($v, true);
+ }*/
+ $this->assertEquals('Michigan', $v);
+ }
}
}
public function testTransferOfObjectViaWrapping()
{
// make a 'deep client copy' as the original one might have many properties set
- $func = wrap_xmlrpc_method($this->client, 'tests.returnPhpObject', array('simple_client_copy' => true,
+ $func = wrap_xmlrpc_method($this->client, 'tests.returnPhpObject', array('simple_client_copy' => 0,
'decode_php_objs' => true));
if ($func == false) {
$this->fail('Registration of tests.returnPhpObject failed');
new xmlrpcval('hello world', 'string'),
));
$r = $this->send($m, 0, true);
- $this->assertContains('hello world', $r->raw_data);
+ $this->assertStringContainsString('hello world', $r->raw_data);
}
public function testSendTwiceSameMsg()