Browse Source

Merge pull request #30417 from nextcloud/sualko-patch-1

tags/v29.0.0beta1
John Molakvoæ 3 months ago
parent
commit
b0b4c7e042
No account linked to committer's email address

+ 4
- 0
lib/private/AppFramework/OCS/BaseResponse.php View File

@@ -159,6 +159,10 @@ abstract class BaseResponse extends Response {
$writer->startElement($k);
$this->toXML($v, $writer);
$writer->endElement();
} elseif ($v instanceof \JsonSerializable) {
$writer->startElement($k);
$this->toXML($v->jsonSerialize(), $writer);
$writer->endElement();
} else {
$writer->writeElement($k, $v);
}

+ 39
- 0
tests/lib/AppFramework/OCS/BaseResponseTest.php View File

@@ -28,6 +28,17 @@ namespace Test\AppFramework\Middleware;

use OC\AppFramework\OCS\BaseResponse;

class ArrayValue implements \JsonSerializable {
private $array;
public function __construct(array $array) {
$this->array = $array;
}

public function jsonSerialize(): mixed {
return $this->array;
}
}

class BaseResponseTest extends \Test\TestCase {
public function testToXml(): void {
/** @var BaseResponse $response */
@@ -56,4 +67,32 @@ class BaseResponseTest extends \Test\TestCase {
$writer->outputMemory(true)
);
}
public function testToXmlJsonSerializable(): void {
/** @var BaseResponse $response */
$response = $this->createMock(BaseResponse::class);

$writer = new \XMLWriter();
$writer->openMemory();
$writer->setIndent(false);
$writer->startDocument();

$data = [
'hello' => 'hello',
'information' => new ArrayValue([
'@test' => 'some data',
'someElement' => 'withAttribute',
]),
'value without key',
'object' => new \stdClass(),
];

$this->invokePrivate($response, 'toXml', [$data, $writer]);
$writer->endDocument();

$this->assertEquals(
"<?xml version=\"1.0\"?>\n<hello>hello</hello><information test=\"some data\"><someElement>withAttribute</someElement></information><element>value without key</element><object/>\n",
$writer->outputMemory(true)
);
}
}

Loading…
Cancel
Save