206 lines
7.7 KiB
PHP
206 lines
7.7 KiB
PHP
<?php
|
|
/**
|
|
* COPS (Calibre OPDS PHP Server) test file
|
|
*
|
|
* @license GPL 2 (http://www.gnu.org/licenses/gpl.html)
|
|
* @author Sébastien Lucas <sebastien@slucas.fr>
|
|
*/
|
|
|
|
require_once (dirname(__FILE__) . "/config_test.php");
|
|
require_once (dirname(__FILE__) . "/../resources/doT-php/doT.php");
|
|
require_once (dirname(__FILE__) . "/../base.php");
|
|
|
|
class BaseTest extends PHPUnit_Framework_TestCase
|
|
{
|
|
public function testAddURLParameter ()
|
|
{
|
|
$this->assertEquals ("?db=0", addURLParameter ("?", "db", "0"));
|
|
$this->assertEquals ("?key=value&db=0", addURLParameter ("?key=value", "db", "0"));
|
|
$this->assertEquals ("?key=value&otherKey=&db=0", addURLParameter ("?key=value&otherKey", "db", "0"));
|
|
}
|
|
|
|
/**
|
|
* FALSE is returned if the create_function failed (meaning there was a syntax error)
|
|
* @dataProvider providerTemplate
|
|
*/
|
|
public function testServerSideRender ($template)
|
|
{
|
|
$_COOKIE["template"] = $template;
|
|
$this->assertNull (serverSideRender (NULL));
|
|
}
|
|
|
|
/**
|
|
* The function for the head of the HTML catalog
|
|
* @dataProvider providerTemplate
|
|
*/
|
|
public function testGenerateHeader ($templateName)
|
|
{
|
|
$_SERVER["HTTP_USER_AGENT"] = "Firefox";
|
|
global $config;
|
|
$headcontent = file_get_contents(dirname(__FILE__) . '/../templates/' . $templateName . '/file.html');
|
|
$template = new doT ();
|
|
$tpl = $template->template ($headcontent, NULL);
|
|
$data = array("title" => $config['cops_title_default'],
|
|
"version" => VERSION,
|
|
"opds_url" => $config['cops_full_url'] . "feed.php",
|
|
"customHeader" => "",
|
|
"template" => $templateName,
|
|
"server_side_rendering" => useServerSideRendering (),
|
|
"current_css" => getCurrentCss (),
|
|
"favico" => $config['cops_icon'],
|
|
"getjson_url" => "getJSON.php?" . addURLParameter (getQueryString (), "complete", 1));
|
|
|
|
$head = $tpl ($data);
|
|
$this->assertContains ("<head>", $head);
|
|
$this->assertContains ("</head>", $head);
|
|
}
|
|
|
|
public function providerTemplate ()
|
|
{
|
|
return array (
|
|
array ("bootstrap"),
|
|
array ("default")
|
|
);
|
|
}
|
|
|
|
public function testLocalize ()
|
|
{
|
|
$this->assertEquals ("Authors", localize ("authors.title"));
|
|
|
|
$this->assertEquals ("unknow.key", localize ("unknow.key"));
|
|
}
|
|
|
|
public function testLocalizeFr ()
|
|
{
|
|
$_SERVER['HTTP_ACCEPT_LANGUAGE'] = "fr,fr-fr;q=0.8,en-us;q=0.5,en;q=0.3";
|
|
$this->assertEquals ("Auteurs", localize ("authors.title", -1, true));
|
|
|
|
$_SERVER['HTTP_ACCEPT_LANGUAGE'] = "en";
|
|
localize ("authors.title", -1, true);
|
|
}
|
|
|
|
public function testLocalizeUnknown ()
|
|
{
|
|
$_SERVER['HTTP_ACCEPT_LANGUAGE'] = "aa";
|
|
$this->assertEquals ("Authors", localize ("authors.title", -1, true));
|
|
|
|
$_SERVER['HTTP_ACCEPT_LANGUAGE'] = "en";
|
|
localize ("authors.title", -1, true);
|
|
}
|
|
|
|
/**
|
|
* @dataProvider providerGetLangAndTranslationFile
|
|
*/
|
|
public function testGetLangAndTranslationFile ($acceptLanguage, $result)
|
|
{
|
|
$_SERVER['HTTP_ACCEPT_LANGUAGE'] = $acceptLanguage;
|
|
list ($lang, $lang_file) = GetLangAndTranslationFile ();
|
|
$this->assertEquals ($result, $lang);
|
|
|
|
$_SERVER['HTTP_ACCEPT_LANGUAGE'] = "en";
|
|
localize ("authors.title", -1, true);
|
|
}
|
|
|
|
public function providerGetLangAndTranslationFile ()
|
|
{
|
|
return array (
|
|
array ("en", "en"),
|
|
array ("fr,fr-fr;q=0.8,en-us;q=0.5,en;q=0.3", "fr"),
|
|
array ("fr-FR", "fr"),
|
|
array ("pt,en-us;q=0.7,en;q=0.3", "en"),
|
|
array ("pt-br,pt;q=0.8,en-us;q=0.5,en;q=0.3", "pt_BR"),
|
|
array ("pt-pt,pt;q=0.8,en;q=0.5,en-us;q=0.3", "pt_PT"),
|
|
array ("zl", "en"),
|
|
);
|
|
}
|
|
|
|
/**
|
|
* @dataProvider providerGetAcceptLanguages
|
|
*/
|
|
public function testGetAcceptLanguages ($acceptLanguage, $result)
|
|
{
|
|
$_SERVER['HTTP_ACCEPT_LANGUAGE'] = $acceptLanguage;
|
|
$langs = array_keys(GetAcceptLanguages ());
|
|
$this->assertEquals ($result, $langs[0]);
|
|
|
|
$_SERVER['HTTP_ACCEPT_LANGUAGE'] = "en";
|
|
localize ("authors.title", -1, true);
|
|
}
|
|
|
|
public function providerGetAcceptLanguages ()
|
|
{
|
|
return array (
|
|
array ("en", "en"),
|
|
array ("en-US", "en_US"),
|
|
array ("fr,fr-fr;q=0.8,en-us;q=0.5,en;q=0.3", "fr"), // French locale with Firefox
|
|
array ("fr-FR,fr;q=0.8,en-US;q=0.6,en;q=0.4", "fr_FR"), // French locale with Chrome
|
|
array ("fr-FR", "fr_FR"), // French locale with IE11
|
|
array ("pt-br,pt;q=0.8,en-us;q=0.5,en;q=0.3", "pt_BR"),
|
|
array ("zl", "zl"),
|
|
);
|
|
}
|
|
|
|
public function testBaseFunction () {
|
|
global $config;
|
|
|
|
$this->assertFalse (Base::isMultipleDatabaseEnabled ());
|
|
$this->assertEquals (array ("" => dirname(__FILE__) . "/BaseWithSomeBooks/"), Base::getDbList ());
|
|
|
|
$config['calibre_directory'] = array ("Some books" => dirname(__FILE__) . "/BaseWithSomeBooks/",
|
|
"One book" => dirname(__FILE__) . "/BaseWithOneBook/");
|
|
|
|
$this->assertTrue (Base::isMultipleDatabaseEnabled ());
|
|
$this->assertEquals ("Some books", Base::getDbName (0));
|
|
$this->assertEquals ("One book", Base::getDbName (1));
|
|
$this->assertEquals ($config['calibre_directory'], Base::getDbList ());
|
|
}
|
|
|
|
public function testCheckDatabaseAvailability_1 () {
|
|
$this->assertTrue (Base::checkDatabaseAvailability ());
|
|
}
|
|
|
|
public function testCheckDatabaseAvailability_2 () {
|
|
global $config;
|
|
|
|
$config['calibre_directory'] = array ("Some books" => dirname(__FILE__) . "/BaseWithSomeBooks/",
|
|
"One book" => dirname(__FILE__) . "/BaseWithOneBook/");
|
|
|
|
$this->assertTrue (Base::checkDatabaseAvailability ());
|
|
}
|
|
|
|
/**
|
|
* @expectedException Exception
|
|
* @expectedExceptionMessage not found
|
|
*/
|
|
public function testCheckDatabaseAvailability_Exception1 () {
|
|
global $config;
|
|
|
|
$config['calibre_directory'] = array ("Some books" => dirname(__FILE__) . "/BaseWithSomeBooks/",
|
|
"One book" => dirname(__FILE__) . "/OneBook/");
|
|
|
|
$this->assertTrue (Base::checkDatabaseAvailability ());
|
|
}
|
|
|
|
/**
|
|
* @expectedException Exception
|
|
* @expectedExceptionMessage not found
|
|
*/
|
|
public function testCheckDatabaseAvailability_Exception2 () {
|
|
global $config;
|
|
|
|
$config['calibre_directory'] = array ("Some books" => dirname(__FILE__) . "/SomeBooks/",
|
|
"One book" => dirname(__FILE__) . "/BaseWithOneBook/");
|
|
|
|
$this->assertTrue (Base::checkDatabaseAvailability ());
|
|
}
|
|
|
|
/*
|
|
Test normalized utf8 string according to unicode.org output
|
|
more here :
|
|
http://unicode.org/cldr/utility/transform.jsp?a=Latin-ASCII&b=%C3%80%C3%81%C3%82%C3%83%C3%84%C3%85%C3%87%C3%88%C3%89%C3%8A%C3%8B%C3%8C%C3%8D%C3%8E%C3%8F%C5%92%C3%92%C3%93%C3%94%C3%95%C3%96%C3%99%C3%9A%C3%9B%C3%9C%C3%9D%C3%A0%C3%A1%C3%A2%C3%A3%C3%A4%C3%A5%C3%A7%C3%A8%C3%A9%C3%AA%C3%AB%C3%AC%C3%AD%C3%AE%C3%AF%C5%93%C3%B0%C3%B2%C3%B3%C3%B4%C3%B5%C3%B6%C3%B9%C3%BA%C3%BB%C3%BC%C3%BD%C3%BF%C3%B1
|
|
*/
|
|
public function testNormalizeUtf8String () {
|
|
$this->assertEquals ("AAAAAACEEEEIIIIOEOOOOOUUUUYaaaaaaceeeeiiiioedooooouuuuyyn",
|
|
normalizeUtf8String ("ÀÁÂÃÄÅÇÈÉÊËÌÍÎÏŒÒÓÔÕÖÙÚÛÜÝàáâãäåçèéêëìíîïœðòóôõöùúûüýÿñ"));
|
|
}
|
|
} |