diff options
| author | Christian Weiske <cweiske@cweiske.de> | 2011-04-06 08:43:42 +0200 | 
|---|---|---|
| committer | Christian Weiske <cweiske@cweiske.de> | 2011-04-06 08:43:42 +0200 | 
| commit | cba0776325ac82bc255feb9a44b3bf312b02f6dc (patch) | |
| tree | d902b2f9fa462d76421c0938357a8bf4cd6f0f5c /tests | |
| parent | c81566f5d8c6149e87432b158331fd724e7e35e5 (diff) | |
| download | semanticscuttle-cba0776325ac82bc255feb9a44b3bf312b02f6dc.tar.gz semanticscuttle-cba0776325ac82bc255feb9a44b3bf312b02f6dc.tar.bz2 | |
cherry-pick:
 move setUnittestConfig to TestBaseApi since it makes only sense to use it there
Conflicts:
	tests/TestBaseApi.php
Diffstat (limited to 'tests')
| -rw-r--r-- | tests/TestBase.php | 44 | ||||
| -rw-r--r-- | tests/TestBaseApi.php | 90 | ||||
| -rw-r--r-- | tests/ajax/GetAdminTagsTest.php | 63 | 
3 files changed, 153 insertions, 44 deletions
| diff --git a/tests/TestBase.php b/tests/TestBase.php index edafd3d..5a61b7b 100644 --- a/tests/TestBase.php +++ b/tests/TestBase.php @@ -23,18 +23,6 @@  class TestBase extends PHPUnit_Framework_TestCase  {      /** -     * Clean up after test -     */ -    public function tearDown() -    { -        if (file_exists($GLOBALS['datadir'] . '/config.unittest.php')) { -            unlink($GLOBALS['datadir'] . '/config.unittest.php'); -        } -    } - - - -    /**       * Create a new bookmark.       *       * @param integer $user    User ID the bookmark shall belong @@ -157,38 +145,6 @@ class TestBase extends PHPUnit_Framework_TestCase          return $uid;      } - - -    /** -     * Writes a special unittest configuration file. -     * The unittest config file is read when a GET request with unittestMode=1 -     * is sent, and the user allowed unittestmode in config.php. -     * -     * @param array $arConfig Array with config names as key and their value as -     *                        value -     * -     * @return void -     */ -    protected function setUnittestConfig($arConfig) -    { -        $str = '<' . "?php\r\n"; -        foreach ($arConfig as $name => $value) { -            $str .= '$' . $name . ' = ' -                . var_export($value, true) . ";\n"; -        } - -        if (!is_dir($GLOBALS['datadir'])) { -            $this->fail( -                'datadir not set or not a directory: ' . $GLOBALS['datadir'] -            ); -        } - -        $this->assertInternalType( -            'integer', -            file_put_contents($GLOBALS['datadir'] . '/config.unittest.php', $str), -            'Writing config.unittest.php failed' -        ); -    }  }  ?>
\ No newline at end of file diff --git a/tests/TestBaseApi.php b/tests/TestBaseApi.php index dacdecd..73135fb 100644 --- a/tests/TestBaseApi.php +++ b/tests/TestBaseApi.php @@ -58,6 +58,18 @@ class TestBaseApi extends TestBase      /** +     * Clean up after test +     */ +    public function tearDown() +    { +        if (file_exists($GLOBALS['datadir'] . '/config.unittest.php')) { +            unlink($GLOBALS['datadir'] . '/config.unittest.php'); +        } +    } + + + +    /**       * Gets a HTTP request object.       * Uses $this->url plus $urlSuffix as request URL.       * @@ -109,5 +121,83 @@ class TestBaseApi extends TestBase          return array($req, $uid);      } + + +    /** +     * Creates a user and a HTTP_Request2 object, does a normal login +     * and prepares the cookies for the HTTP request object so that +     * the user is seen as logged in when requesting any HTML page. +     * +     * Useful for testing HTML pages or ajax URLs. +     * +     * @param string $urlSuffix Suffix for the URL +     * @param mixed  $auth      If user authentication is needed (true/false) +     *                          or array with username and password +     * +     * @return array(HTTP_Request2, integer) HTTP request object and user id +     * +     * @uses getRequest() +     */ +    protected function getLoggedInRequest($urlSuffix = null, $auth = true) +    { +        if (is_array($auth)) { +            list($username, $password) = $auth; +        } else { +            $username = 'testuser'; +            $password = 'testpassword'; +        } +        $uid = $this->addUser($username, $password); + +        $req = new HTTP_Request2( +            $GLOBALS['unittestUrl'] . '/login.php', +            HTTP_Request2::METHOD_POST +        ); +        $cookies = $req->setCookieJar()->getCookieJar(); +        $req->addPostParameter('username', $username); +        $req->addPostParameter('password', $password); +        $req->addPostParameter('submitted', 'Log In'); +        $res = $req->send(); + +        //after login, we normally get redirected +        $this->assertEquals(302, $res->getStatus(), 'Login failure'); + +        $req = $this->getRequest($urlSuffix); +        $req->setCookieJar($cookies); + +        return array($req, $uid); +    } + + + +    /** +     * Writes a special unittest configuration file. +     * The unittest config file is read when a GET request with unittestMode=1 +     * is sent, and the user allowed unittestmode in config.php. +     * +     * @param array $arConfig Array with config names as key and their value as +     *                        value +     * +     * @return void +     */ +    protected function setUnittestConfig($arConfig) +    { +        $str = '<' . "?php\r\n"; +        foreach ($arConfig as $name => $value) { +            $str .= '$' . $name . ' = ' +                . var_export($value, true) . ";\n"; +        } + +        if (!is_dir($GLOBALS['datadir'])) { +            $this->fail( +                'datadir not set or not a directory: ' . $GLOBALS['datadir'] +            ); +        } + +        $this->assertInternalType( +            'integer', +            file_put_contents($GLOBALS['datadir'] . '/config.unittest.php', $str), +            'Writing config.unittest.php failed' +        ); +    }  }  ?>
\ No newline at end of file diff --git a/tests/ajax/GetAdminTagsTest.php b/tests/ajax/GetAdminTagsTest.php new file mode 100644 index 0000000..5c941e8 --- /dev/null +++ b/tests/ajax/GetAdminTagsTest.php @@ -0,0 +1,63 @@ +<?php +/** + * SemanticScuttle - your social bookmark manager. + * + * PHP version 5. + * + * @category Bookmarking + * @package  SemanticScuttle + * @author   Benjamin Huynh-Kim-Bang <mensonge@users.sourceforge.net> + * @author   Christian Weiske <cweiske@cweiske.de> + * @author   Eric Dane <ericdane@users.sourceforge.net> + * @license  GPL http://www.gnu.org/licenses/gpl.html + * @link     http://sourceforge.net/projects/semanticscuttle + */ + +require_once dirname(__FILE__) . '/../prepare.php'; +require_once 'HTTP/Request2.php'; + +/** + * Unit tests for the ajax getadmintags.php script + * + * @category Bookmarking + * @package  SemanticScuttle + * @author   Christian Weiske <cweiske@cweiske.de> + * @license  GPL http://www.gnu.org/licenses/gpl.html + * @link     http://sourceforge.net/projects/semanticscuttle + */ +class ajax_GetAdminTagsTest extends TestBaseApi +{ +    protected $urlPart = 'ajax/getadmintags.php'; + + +    public function testTags() +    { +        list($user1, $uname1) = $this->addUserData(); +        $user2 = $this->addUser(); +        $this->addBookmark($user1, null, 0, array('admintag', 'admintag2')); +        $this->addBookmark($user2, null, 0, array('lusertag', 'lusertag2')); + +        $this->setUnittestConfig( +            array( +                'admin_users' => array($uname1) +            ) +        ); + +        $req = $this->getRequest('?unittestMode=1'); +        $res = $req->send(); +        $this->assertEquals(200, $res->getStatus()); +        $this->assertEquals( +            'application/json; charset=utf-8', +            $res->getHeader('content-type') +        ); +        $data = json_decode($res->getBody()); +        $this->assertInternalType('array', $data); +        $this->assertEquals(2, count($data)); +        $this->assertContains('admintag', $data); +        $this->assertContains('admintag2', $data); +    } + +} + + +?>
\ No newline at end of file | 
