This repository has been archived on 2024-09-05. You can view files and clone it, but cannot push or open issues or pull requests.
shimmie2/tests/test_install.php

78 lines
2.3 KiB
PHP
Raw Normal View History

<?php
2014-02-18 16:59:07 -05:00
/**
* SimpleTest integration with Travis CI for Shimmie
2014-02-22 15:36:52 -05:00
*
2014-02-18 16:59:07 -05:00
* @package Shimmie
* @author jgen <jeffgenovy@gmail.com>
* @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 and host to use.
$options = getopt("d:h:");
$db = $options["d"];
$host = rtrim(trim(trim($options["h"], '"')), "/");
// Check if they are empty.
2014-04-24 22:35:01 -04:00
if (empty($db)){ die("Error: need to specify a database for the test environment."); }
if (empty($host)){ $host = "http://127.0.0.1"; }
define("_TRAVIS_DATABASE", $db);
define("_TRAVIS_WEBHOST", $host);
// Currently the tests only support MySQL and PostgreSQL.
2014-02-22 18:32:42 -05:00
if ($db === "mysql") {
define("_TRAVIS_DATABASE_USERNAME", "root");
define("_TRAVIS_DATABASE_PASSWORD", "");
2014-02-22 18:32:42 -05:00
} elseif ($db === "pgsql") {
define("_TRAVIS_DATABASE_USERNAME", "postgres");
define("_TRAVIS_DATABASE_PASSWORD", "");
} else {
die("Unsupported Database Option");
}
class ShimmieInstallerTest extends WebTestCase {
2014-02-17 15:53:22 -05:00
function testInstallShimmie()
{
// Get the settings from the global constants.
2014-02-18 16:28:43 -05:00
$db = constant("_TRAVIS_DATABASE");
$host = constant("_TRAVIS_WEBHOST");
$username = constant("_TRAVIS_DATABASE_USERNAME");
$password = constant("_TRAVIS_DATABASE_PASSWORD");
2014-02-22 15:36:52 -05:00
// Make sure that we know where the host is.
$this->assertFalse(empty($host));
2014-02-18 15:41:42 -05:00
// Make sure that we know what database to use.
2014-02-18 16:28:43 -05:00
$this->assertFalse(empty($db));
2014-02-22 15:36:52 -05:00
$this->get($host);
$this->assertResponse(200);
2014-02-17 15:45:42 -05:00
$this->assertTitle("Shimmie Installation");
$this->assertText("Database Install");
2014-02-22 15:36:52 -05:00
2014-02-18 16:28:43 -05:00
$this->setField("database_type", $db);
$this->assertField("database_type", $db);
$this->assertField("database_host", "localhost");
$this->setField("database_user", $username);
$this->setField("database_password", $password);
$this->assertField("database_name", "shimmie");
2014-02-18 03:32:05 -05:00
$this->clickSubmit("Go!");
2014-02-22 15:36:52 -05:00
if (!$this->assertText("Installation Succeeded!")) {
print "ERROR --- '" + $db + "'";
$this->showSource();
}
}
}
2014-02-19 03:42:18 -05:00
$test = new TestSuite('Install Shimmie');
$test->add(new ShimmieInstallerTest());
exit ($test->run(new TextReporter()) ? 0 : 1);