mirror of
https://github.com/roundcube/roundcubemail.git
synced 2026-03-20 23:07:01 +01:00
* Check plugins composer.json using CI * Add "require-dev" and "config.allow-plugins" to plugins * fix composer.json format - rm invalid email * fix composer.json format - fix ext require * fix composer.json format - fix plugin name * tmp * Revert "tmp" * fix ext in ext install * disable plugin in plugin install until Roundcube is fully autoloadable * fix composer.json format - fix non-canonical license name * Revert "Add "require-dev" and "config.allow-plugins" to plugins" * no composer install for plugins needed * Revert "fix ext in ext install" * add standard "Test" suffix to phpunit files * rm unneeded "suffix" in phpunit config * simplify phpunit config * fix default "xhtml" doctype in unit testing * fix test_format_date test to not rely on other tests * even more phpunit config simplify * stricter/unify phpunit params for E2E tests * run E2E tests on maximal php version too with lowest deps * "repositories" in bundled plugins are useless as for root package only * add/unify missing plugin test
65 lines
2.2 KiB
PHP
65 lines
2.2 KiB
PHP
<?php
|
|
|
|
/**
|
|
* Test class to test rcmail_action_contacts_search_create
|
|
*/
|
|
class Actions_Contacts_Search_Create extends ActionTestCase
|
|
{
|
|
/**
|
|
* Test error handling
|
|
*/
|
|
public function test_search_create_errors()
|
|
{
|
|
$action = new rcmail_action_contacts_search_create();
|
|
$output = $this->initOutput(rcmail_action::MODE_AJAX, 'contacts', 'search-create');
|
|
|
|
$this->assertInstanceOf('rcmail_action', $action);
|
|
$this->assertTrue($action->checks());
|
|
|
|
// Unset group name
|
|
$_POST = ['_name' => ''];
|
|
|
|
$this->runAndAssert($action, OutputJsonMock::E_EXIT);
|
|
|
|
$result = $output->getOutput();
|
|
|
|
$this->assertSame(['Content-Type: application/json; charset=UTF-8'], $output->headers);
|
|
$this->assertSame('search-create', $result['action']);
|
|
$this->assertSame('this.display_message("Could not create saved search.","error",0);', trim($result['exec']));
|
|
}
|
|
|
|
/**
|
|
* Test creating a saved-search
|
|
*/
|
|
public function test_search_create_success()
|
|
{
|
|
$action = new rcmail_action_contacts_search_create();
|
|
$output = $this->initOutput(rcmail_action::MODE_AJAX, 'contacts', 'search-create');
|
|
|
|
$this->assertTrue($action->checks());
|
|
|
|
self::initDB('searches');
|
|
|
|
$_POST = ['_search' => 'fakeid', '_name' => 'test2'];
|
|
$_SESSION['contact_search_params'] = [
|
|
'id' => 'fakeid',
|
|
'data' => ['*', 'bush'],
|
|
];
|
|
|
|
$this->runAndAssert($action, OutputJsonMock::E_EXIT);
|
|
|
|
$result = $output->getOutput();
|
|
|
|
$this->assertSame(['Content-Type: application/json; charset=UTF-8'], $output->headers);
|
|
$this->assertSame('search-create', $result['action']);
|
|
$this->assertTrue(strpos($result['exec'], 'this.display_message("Saved search created successfully.","confirmation",0);') !== false);
|
|
$this->assertTrue(strpos($result['exec'], 'this.insert_saved_search("test2",') !== false);
|
|
|
|
$db = rcmail::get_instance()->get_dbh();
|
|
$query = $db->query('SELECT * FROM `searches` WHERE `name` = \'test2\'');
|
|
$result = $db->fetch_assoc($query);
|
|
|
|
$this->assertTrue(!empty($result));
|
|
}
|
|
}
|