nextcloud/tests/lib/app/infoparser.php

56 lines
1.3 KiB
PHP
Raw Normal View History

<?php
/**
* @author Thomas Müller
* @copyright 2014 Thomas Müller deepdiver@owncloud.com
* later.
* See the COPYING-README file.
*/
namespace Test\App;
use OC;
use OCP\IURLGenerator;
2015-12-17 19:29:17 +03:00
use Test\TestCase;
2015-12-17 19:29:17 +03:00
class InfoParser extends TestCase {
/** @var \OC\App\InfoParser */
private $parser;
public function setUp() {
$urlGenerator = $this->getMockBuilder('\OCP\IURLGenerator')
->disableOriginalConstructor()
->getMock();
/** @var IURLGenerator | \PHPUnit_Framework_MockObject_MockObject $urlGenerator */
2014-11-24 19:26:07 +03:00
$urlGenerator->expects($this->any())
->method('linkToDocs')
->will($this->returnCallback(function ($url) {
2014-11-24 19:26:07 +03:00
return "https://docs.example.com/server/go.php?to=$url";
}));
$this->parser = new \OC\App\InfoParser($urlGenerator);
}
/**
* @dataProvider providesInfoXml
*/
public function testParsingValidXml($expectedJson, $xmlFile) {
$expectedData = null;
if (!is_null($expectedJson)) {
$expectedData = json_decode(file_get_contents(OC::$SERVERROOT . "/tests/data/app/$expectedJson"), true);
}
$data = $this->parser->parse(OC::$SERVERROOT. "/tests/data/app/$xmlFile");
2014-11-24 19:26:07 +03:00
$this->assertEquals($expectedData, $data);
}
2014-11-25 12:22:06 +03:00
function providesInfoXml() {
return array(
array('expected-info.json', 'valid-info.xml'),
array(null, 'invalid-info.xml'),
);
2014-11-25 12:22:06 +03:00
}
}