Commit 83dc45c2 authored by Karl's avatar Karl

Die Testst sind jetzt kommentiert

parent 4947588d
...@@ -6,6 +6,8 @@ use Illuminate\Http\Request; ...@@ -6,6 +6,8 @@ use Illuminate\Http\Request;
class MetaGerPhpTest extends TestCase class MetaGerPhpTest extends TestCase
{ {
// Die Testfunktion die PHP Unit aufruft
// Ruft alle anderen Untertests auf
public function test() public function test()
{ {
$this->fullRunTest(); $this->fullRunTest();
...@@ -24,6 +26,8 @@ class MetaGerPhpTest extends TestCase ...@@ -24,6 +26,8 @@ class MetaGerPhpTest extends TestCase
$this->productsTest(); $this->productsTest();
} }
// Führt alle Schritte einer normalen MetaGer Suche durch
// Es werden keine bestimmten Werte erwartet, nur dass das Programm nicht abstürzt
public function fullRunTest() public function fullRunTest()
{ {
$metager = new MetaGer(); $metager = new MetaGer();
...@@ -36,6 +40,7 @@ class MetaGerPhpTest extends TestCase ...@@ -36,6 +40,7 @@ class MetaGerPhpTest extends TestCase
$metager->createView(); $metager->createView();
} }
// Testet das erkennen von Spezialsuchen in verschiedenen Sucheingaben
public function specialSearchTest() public function specialSearchTest()
{ {
$metager = new MetaGer(); $metager = new MetaGer();
...@@ -72,6 +77,7 @@ class MetaGerPhpTest extends TestCase ...@@ -72,6 +77,7 @@ class MetaGerPhpTest extends TestCase
$this->assertContains("-host:-domain:test", $metager->getPhrases()); $this->assertContains("-host:-domain:test", $metager->getPhrases());
} }
// Testet, ob ein Link wirklich nur einmal hinzugefügt werden kann
public function addLinkTest() public function addLinkTest()
{ {
$metager = new MetaGer(); $metager = new MetaGer();
...@@ -80,6 +86,7 @@ class MetaGerPhpTest extends TestCase ...@@ -80,6 +86,7 @@ class MetaGerPhpTest extends TestCase
$this->assertFalse($metager->addLink($link)); $this->assertFalse($metager->addLink($link));
} }
// Testet die Funktionen die spezielle Sumas filtern
public function specialSumaTest() public function specialSumaTest()
{ {
$metager = new MetaGer(); $metager = new MetaGer();
...@@ -121,6 +128,7 @@ class MetaGerPhpTest extends TestCase ...@@ -121,6 +128,7 @@ class MetaGerPhpTest extends TestCase
$this->assertTrue($metager->sumaIsNotAdsuche($suma)); $this->assertTrue($metager->sumaIsNotAdsuche($suma));
} }
// Testet die Generatoren für spezielle Links
public function linkGeneratorTest() public function linkGeneratorTest()
{ {
$metager = new Metager(); $metager = new Metager();
...@@ -138,6 +146,7 @@ class MetaGerPhpTest extends TestCase ...@@ -138,6 +146,7 @@ class MetaGerPhpTest extends TestCase
'-domain%3Awolf.de'); '-domain%3Awolf.de');
} }
// Prüft ob der Host Count funktioniert
public function getHostCountTest() public function getHostCountTest()
{ {
$metager = new MetaGer(); $metager = new MetaGer();
...@@ -152,6 +161,7 @@ class MetaGerPhpTest extends TestCase ...@@ -152,6 +161,7 @@ class MetaGerPhpTest extends TestCase
$this->assertEquals($before + 1, $after); $this->assertEquals($before + 1, $after);
} }
// Prüft ob bei passender Einstellung der Sumas der Fokus automatisch umgestellt wird
public function adjustFocusTest() public function adjustFocusTest()
{ {
$metager = new MetaGer(); $metager = new MetaGer();
...@@ -173,6 +183,7 @@ class MetaGerPhpTest extends TestCase ...@@ -173,6 +183,7 @@ class MetaGerPhpTest extends TestCase
$this->assertEquals("bilder", $metager->getFokus()); $this->assertEquals("bilder", $metager->getFokus());
} }
// Prüft ob das fehlen einer Suchmaschine mit Seitensuche erkannt wird
public function checkCanNotSitesearchTest() public function checkCanNotSitesearchTest()
{ {
$metager = new MetaGer(); $metager = new MetaGer();
...@@ -188,6 +199,7 @@ class MetaGerPhpTest extends TestCase ...@@ -188,6 +199,7 @@ class MetaGerPhpTest extends TestCase
$this->assertTrue($metager->checkCanNotSitesearch($enabledSearchengines)); $this->assertTrue($metager->checkCanNotSitesearch($enabledSearchengines));
} }
// Prüft ob Bildersuchen erkannt werden
public function isBildersucheTest() public function isBildersucheTest()
{ {
$metager = new MetaGer(); $metager = new MetaGer();
...@@ -201,6 +213,7 @@ class MetaGerPhpTest extends TestCase ...@@ -201,6 +213,7 @@ class MetaGerPhpTest extends TestCase
$this->assertFalse($metager->isBildersuche()); $this->assertFalse($metager->isBildersuche());
} }
// Prüft ob der Link für Minisucher richtig erstellt wird
public function loadMiniSucherTest() public function loadMiniSucherTest()
{ {
$metager = new MetaGer(); $metager = new MetaGer();
...@@ -211,12 +224,14 @@ class MetaGerPhpTest extends TestCase ...@@ -211,12 +224,14 @@ class MetaGerPhpTest extends TestCase
$this->assertContains("fq=subcollection:%28minism1+OR+minism2%29", $minisucher["formData"]->__toString()); $this->assertContains("fq=subcollection:%28minism1+OR+minism2%29", $minisucher["formData"]->__toString());
} }
// Prüft ob der Link für den Image Proxy richtig erstellt wird
public function getImageProxyLinkTest() public function getImageProxyLinkTest()
{ {
$metager = new MetaGer(); $metager = new MetaGer();
$this->containCallbackTester($metager, "getImageProxyLink", ["www.bilder.de/bild1.png"], "url=www.bilder.de%2Fbild1.png"); $this->containCallbackTester($metager, "getImageProxyLink", ["www.bilder.de/bild1.png"], "url=www.bilder.de%2Fbild1.png");
} }
// Prüft ob sich Quicktips korrekt ein und ausschalten lassen
public function showQuicktipsTest() public function showQuicktipsTest()
{ {
$metager = new MetaGer(); $metager = new MetaGer();
...@@ -230,6 +245,7 @@ class MetaGerPhpTest extends TestCase ...@@ -230,6 +245,7 @@ class MetaGerPhpTest extends TestCase
$this->assertTrue($metager->showQuicktips()); $this->assertTrue($metager->showQuicktips());
} }
// Prüft ob Werbung der Werbeliste hinzugefügt wird und ob die pop-funktion für die Werbeergebnisse funktioniert
public function popAdTest() public function popAdTest()
{ {
$metager = new MetaGer(); $metager = new MetaGer();
...@@ -261,6 +277,7 @@ class MetaGerPhpTest extends TestCase ...@@ -261,6 +277,7 @@ class MetaGerPhpTest extends TestCase
$this->assertEquals("Werbetitel", $metager->popAd()['titel']); $this->assertEquals("Werbetitel", $metager->popAd()['titel']);
} }
// Prüft ob Produktergebnisse der Produktliste hinzugefügt werden
public function productsTest() public function productsTest()
{ {
$metager = new MetaGer(); $metager = new MetaGer();
...@@ -294,6 +311,7 @@ class MetaGerPhpTest extends TestCase ...@@ -294,6 +311,7 @@ class MetaGerPhpTest extends TestCase
$this->assertEquals("Produkttitel", $metager->getProducts()[0]['titel']); $this->assertEquals("Produkttitel", $metager->getProducts()[0]['titel']);
} }
// Erstellt eine Suchanfrage zu Testzwecken
public function createDummyRequest() public function createDummyRequest()
{ {
/** /**
...@@ -324,6 +342,14 @@ class MetaGerPhpTest extends TestCase ...@@ -324,6 +342,14 @@ class MetaGerPhpTest extends TestCase
return new Request($query); return new Request($query);
} }
/**
* Funktion zum vereinfachen von Tests, bei denen die Ausgabe einer Funktion ein bestimmtes Objekt enthalten soll
*
* @param Object $object Das Object von dem aus die Funktion aufgerufen werden soll
* @param String $funcName Der Name der Funktion
* @param array $input Die Eingaben für die Funktion
* @param mixed $expectedInOutput Etwas das im Funktionsergebnis erwartet wird (meist ein String)
*/
public function containCallbackTester($object, $funcName, $input, $expectedInOutput) public function containCallbackTester($object, $funcName, $input, $expectedInOutput)
{ {
$output = call_user_func_array(array($object, $funcName), $input); $output = call_user_func_array(array($object, $funcName), $input);
......
...@@ -6,6 +6,8 @@ use Illuminate\Http\Request; ...@@ -6,6 +6,8 @@ use Illuminate\Http\Request;
class ResultPhpTest extends TestCase class ResultPhpTest extends TestCase
{ {
// Die Testfunktion die PHP Unit aufruft
// Ruft alle anderen Untertests auf
public function test() public function test()
{ {
$this->rankingTest(); $this->rankingTest();
...@@ -13,18 +15,21 @@ class ResultPhpTest extends TestCase ...@@ -13,18 +15,21 @@ class ResultPhpTest extends TestCase
$this->linkGeneratorsTest(); $this->linkGeneratorsTest();
} }
// Liefert ein standard Suchergebnis
public function getDummyResult() public function getDummyResult()
{ {
$provider = file_get_contents("tests/testSumas.xml"); $provider = file_get_contents("tests/testSumas.xml");
$titel = "Titel"; $titel = "Titel";
$link = "link.de"; $link = "link.de";
$anzeigeLink = "link.de/anzeige"; $anzeigeLink = "link.de/anzeige";
$descr = "Beschreibung: i want phrase"; $descr = "Beschreibung: i want phrase
$gefVon = ""; Lorem ipsum dolor sit amet, consetetur sadipscing elitr, sed diam nonumy eirmod tempor invidunt ut labore et dolore magna aliquyam erat, sed diam voluptua. At vero eos et accusam et justo duo dolores et ea rebum. Stet clita kasd gubergren, no sea takimata sanctus est Lorem ipsum dolor sit amet. Lorem ipsum dolor sit amet, consetetur sadipscing elitr, sed diam nonumy eirmod tempor invidunt ut labore et dolore magna aliquyam erat, sed diam voluptua. At vero eos et accusam et justo duo dolores et ea rebum. Stet clita kasd gubergren, no sea takimata sanctus est Lorem ipsum dolor sit amet.";
$sourceRank = 1; $gefVon = "";
$sourceRank = 1;
return new Result($provider, $titel, $link, $anzeigeLink, $descr, $gefVon, $sourceRank); return new Result($provider, $titel, $link, $anzeigeLink, $descr, $gefVon, $sourceRank);
} }
// Liefert eine standard MetaGer
public function getDummyMetaGer() public function getDummyMetaGer()
{ {
$metager = new MetaGer(); $metager = new MetaGer();
...@@ -34,6 +39,7 @@ class ResultPhpTest extends TestCase ...@@ -34,6 +39,7 @@ class ResultPhpTest extends TestCase
return $metager; return $metager;
} }
// Liefert eine standard Suchanfrage
public function createDummyRequest() public function createDummyRequest()
{ {
$query = []; $query = [];
...@@ -50,6 +56,7 @@ class ResultPhpTest extends TestCase ...@@ -50,6 +56,7 @@ class ResultPhpTest extends TestCase
return new Request($query); return new Request($query);
} }
// Testet ob das Ranking nicht übermäßig vom gewünschten Wert abweicht
public function rankingTest() public function rankingTest()
{ {
$result = $this->getDummyResult(); $result = $this->getDummyResult();
...@@ -63,6 +70,7 @@ class ResultPhpTest extends TestCase ...@@ -63,6 +70,7 @@ class ResultPhpTest extends TestCase
$this->assertEquals(0.4, $result->getRank(), "Not within Range of Actual Value", 0.1); $this->assertEquals(0.4, $result->getRank(), "Not within Range of Actual Value", 0.1);
} }
// Prüft die Valid funktion, die für Ergebnisse auf der Host- oder Domain-Blacklist false zurückgeben soll
public function isValidTest() public function isValidTest()
{ {
$result = $this->getDummyResult(); $result = $this->getDummyResult();
...@@ -91,6 +99,7 @@ class ResultPhpTest extends TestCase ...@@ -91,6 +99,7 @@ class ResultPhpTest extends TestCase
$this->assertFalse($result->isValid($metager)); $this->assertFalse($result->isValid($metager));
} }
// Prüft die Funktionen die Links umformen oder erzeugen
public function linkGeneratorsTest() public function linkGeneratorsTest()
{ {
$result = $this->getDummyResult(); $result = $this->getDummyResult();
...@@ -113,6 +122,14 @@ class ResultPhpTest extends TestCase ...@@ -113,6 +122,14 @@ class ResultPhpTest extends TestCase
'han.solo.de/unterseite/document.htm'); 'han.solo.de/unterseite/document.htm');
} }
/**
* Funktion zum vereinfachen von Tests, bei denen die Ausgabe einer Funktion einem Object entsprechen soll
*
* @param Object $object Das Object von dem aus die Funktion aufgerufen werden soll
* @param String $funcName Der Name der Funktion
* @param array $input Die Eingaben für die Funktion
* @param mixed $expectedInOutput Etwas das als Funktionsergebnis erwartet wird (meist ein String)
*/
public function equalCallbackTester($object, $funcName, $input, $expectedInOutput) public function equalCallbackTester($object, $funcName, $input, $expectedInOutput)
{ {
$output = call_user_func_array(array($object, $funcName), $input); $output = call_user_func_array(array($object, $funcName), $input);
......
...@@ -6,12 +6,15 @@ use Illuminate\Http\Request; ...@@ -6,12 +6,15 @@ use Illuminate\Http\Request;
class SearchenginePhpTest extends TestCase class SearchenginePhpTest extends TestCase
{ {
// Die Testfunktion die PHP Unit aufruft
// Ruft alle anderen Untertests auf
public function test() public function test()
{ {
$this->constructionTest(); $this->constructionTest();
$this->enablingTest(); $this->enablingTest();
} }
// Prüft ob aus einer XML korrekt das Suchmaschinen-Objekt erstellt wird
public function constructionTest() public function constructionTest()
{ {
$engines = simplexml_load_file("tests/testSumas.xml")->xpath("suma"); $engines = simplexml_load_file("tests/testSumas.xml")->xpath("suma");
...@@ -71,6 +74,7 @@ class SearchenginePhpTest extends TestCase ...@@ -71,6 +74,7 @@ class SearchenginePhpTest extends TestCase
$searchengine->cacheDuration); $searchengine->cacheDuration);
} }
// Prüft ob Suchmaschinen korrekt ein- und ausgeschaltet werden können
public function enablingTest() public function enablingTest()
{ {
$engines = simplexml_load_file("tests/testSumas.xml")->xpath("suma"); $engines = simplexml_load_file("tests/testSumas.xml")->xpath("suma");
...@@ -93,7 +97,7 @@ class SearchenginePhpTest extends TestCase ...@@ -93,7 +97,7 @@ class SearchenginePhpTest extends TestCase
$this->assertTrue($searchengine->isEnabled()); $this->assertTrue($searchengine->isEnabled());
} }
/* /* Noch fehlende Funktionen (teils kaum testbar)
abstract public function loadResults($result); abstract public function loadResults($result);
private function setStatistic($key, $val) private function setStatistic($key, $val)
protected function getHost() protected function getHost()
...@@ -111,6 +115,14 @@ class SearchenginePhpTest extends TestCase ...@@ -111,6 +115,14 @@ class SearchenginePhpTest extends TestCase
removeCurlHandle($mh) removeCurlHandle($mh)
*/ */
/**
* Funktion zum vereinfachen von Tests, bei denen die Ausgabe einer Funktion einem Object entsprechen soll
*
* @param Object $object Das Object von dem aus die Funktion aufgerufen werden soll
* @param String $funcName Der Name der Funktion
* @param array $input Die Eingaben für die Funktion
* @param mixed $expectedInOutput Etwas das als Funktionsergebnis erwartet wird (meist ein String)
*/
public function equalCallbackTester($object, $funcName, $input, $expectedInOutput) public function equalCallbackTester($object, $funcName, $input, $expectedInOutput)
{ {
$output = call_user_func_array(array($object, $funcName), $input); $output = call_user_func_array(array($object, $funcName), $input);
......
<?xml version="1.0" encoding="UTF-8"?> <?xml version="1.0" encoding="UTF-8"?>
<!-- Eine Test XML mit einer bildersuchmaschine mit subcollections -->
<sumas> <sumas>
<suma name="minism" host="www.suchmaschine.de" skript="/suche/" formData="sprache=de&amp;sortieren=true&amp;queue=&lt;&lt;QUERY&gt;&gt;&amp;rows=&lt;&lt;COUNT&gt;&gt;&amp;fq=subcollection:&lt;&lt;SUBCOLLECTIONS&gt;&gt;" package="suchmaschine" displayName="Meine Suchmaschine" homepage="www.suchmaschine.de/welcome" port="443" inputEncoding="Latin1" userSelectable="1" type="bilder" engineBoost="1.2" additionalHeaders="$#!#$" hasSiteSearch="1" cacheDuration="60"/> <suma name="minism" host="www.suchmaschine.de" skript="/suche/" formData="sprache=de&amp;sortieren=true&amp;queue=&lt;&lt;QUERY&gt;&gt;&amp;rows=&lt;&lt;COUNT&gt;&gt;&amp;fq=subcollection:&lt;&lt;SUBCOLLECTIONS&gt;&gt;" package="suchmaschine" displayName="Meine Suchmaschine" homepage="www.suchmaschine.de/welcome" port="443" inputEncoding="Latin1" userSelectable="1" type="bilder" engineBoost="1.2" additionalHeaders="$#!#$" hasSiteSearch="1" cacheDuration="60"/>
</sumas> </sumas>
<?xml version="1.0" encoding="UTF-8"?> <?xml version="1.0" encoding="UTF-8"?>
<!-- Eine Test XML mit 2 bilder und 1 web suchmaschine -->
<sumas> <sumas>
<suma name="name1" host="www.suchmaschine1.de" skript="/suche1/" formData="sprache=de&amp;sortieren=true&amp;queue=&lt;&lt;QUERY&gt;&gt;&amp;rows=&lt;&lt;COUNT&gt;&gt;&amp;fq=subcollection:&lt;&lt;SUBCOLLECTIONS&gt;&gt;" package="suchmaschine1" displayName="Meine Suchmaschine1" homepage="www.suchmaschine1.de/welcome" port="443" inputEncoding="Latin1" userSelectable="1" type="bilder" engineBoost="1.2" additionalHeaders="$#!#$" hasSiteSearch="0" cacheDuration="60"/> <suma name="name1" host="www.suchmaschine1.de" skript="/suche1/" formData="sprache=de&amp;sortieren=true&amp;queue=&lt;&lt;QUERY&gt;&gt;&amp;rows=&lt;&lt;COUNT&gt;&gt;&amp;fq=subcollection:&lt;&lt;SUBCOLLECTIONS&gt;&gt;" package="suchmaschine1" displayName="Meine Suchmaschine1" homepage="www.suchmaschine1.de/welcome" port="443" inputEncoding="Latin1" userSelectable="1" type="bilder" engineBoost="1.2" additionalHeaders="$#!#$" hasSiteSearch="0" cacheDuration="60"/>
<suma name="name2" host="www.suchmaschine2.de" skript="/suche2/" formData="sprache=de&amp;sortieren=true&amp;queue=&lt;&lt;QUERY&gt;&gt;&amp;rows=&lt;&lt;COUNT&gt;&gt;&amp;fq=subcollection:&lt;&lt;SUBCOLLECTIONS&gt;&gt;" package="suchmaschine2" displayName="Meine Suchmaschine2" homepage="www.suchmaschine2.de/welcome" port="443" inputEncoding="Latin1" userSelectable="1" type="web" engineBoost="1.2" additionalHeaders="$#!#$" hasSiteSearch="0" cacheDuration="60"/> <suma name="name2" host="www.suchmaschine2.de" skript="/suche2/" formData="sprache=de&amp;sortieren=true&amp;queue=&lt;&lt;QUERY&gt;&gt;&amp;rows=&lt;&lt;COUNT&gt;&gt;&amp;fq=subcollection:&lt;&lt;SUBCOLLECTIONS&gt;&gt;" package="suchmaschine2" displayName="Meine Suchmaschine2" homepage="www.suchmaschine2.de/welcome" port="443" inputEncoding="Latin1" userSelectable="1" type="web" engineBoost="1.2" additionalHeaders="$#!#$" hasSiteSearch="0" cacheDuration="60"/>
......
Markdown is supported
0% or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment