nextcloud/tests/lib/app/infoparser.php

62 lines
1.5 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;
class InfoParser extends \PHPUnit_Framework_TestCase {
/**
* @var \OC\App\InfoParser
*/
private $parser;
public function setUp() {
2014-11-27 20:19:14 +03:00
$config = $this->getMockBuilder('\OCP\IConfig')
2014-11-24 19:26:07 +03:00
->disableOriginalConstructor()->getMock();
$httpHelper = $this->getMockBuilder('\OC\HTTPHelper')
2014-11-24 19:26:07 +03:00
->setConstructorArgs(array($config))
->setMethods(array('getHeaders'))
->getMock();
$urlGenerator = $this->getMockBuilder('\OCP\IURLGenerator')
->disableOriginalConstructor()
->getMock();
//linkToDocs
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($httpHelper, $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
}
}