* @license http://opensource.org/licenses/gpl-2.0.php GNU General Public License v2 * @copyright Copyright (c) 2014, jgen */ require_once('lib/simpletest/unit_tester.php'); require_once('lib/simpletest/web_tester.php'); require_once('lib/simpletest/reporter.php'); // Enable all errors. error_reporting(E_ALL); // Get the command line option telling us what database to use. $options = getopt("d:h:"); $db = $options["d"]; $host = rtrim(trim(trim($options["h"], '"')), "/"); if (empty($db)){ die("Error: need to specifiy a database for the test environment."); } if (empty($host)){ $host = "http://127.0.0.1"; } define("_TRAVIS_DATABASE", $db); define("_TRAVIS_WEBHOST", $host); class ShimmieInstallerTest extends WebTestCase { function testInstallShimmie() { $db = constant("_TRAVIS_DATABASE"); $host = constant("_TRAVIS_WEBHOST"); // Make sure that we know where the host is. $this->assertFalse(empty($host)); // Make sure that we know what database to use. $this->assertFalse(empty($db)); $this->get($host); $this->assertResponse(200); $this->assertTitle("Shimmie Installation"); $this->assertText("Database Install"); $this->setField("database_type", $db); $this->assertField("database_host", "localhost"); if ($db === "mysql") { $this->setField("database_user", "root"); $this->setField("database_password", ""); } elseif ($db === "pgsql") { $this->setField("database_user", "postgres"); $this->setField("database_password", ""); } else { die("Unsupported Database Option"); } $this->assertField("database_name", "shimmie"); $this->clickSubmit("Go!"); if (!$this->assertText("Installation Succeeded!")) { $this->showSource(); } } } $test = new TestSuite('Install Shimmie'); $test->add(new ShimmieInstallerTest()); exit ($test->run(new TextReporter()) ? 0 : 1);