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
66 lines
2.3 KiB
PHP
66 lines
2.3 KiB
PHP
<?php
|
|
|
|
/**
|
|
* Test class to test rcmail_action_contacts_search_delete
|
|
*/
|
|
class Actions_Contacts_Search_Delete extends ActionTestCase
|
|
{
|
|
/**
|
|
* Test error handling
|
|
*/
|
|
public function test_search_delete_errors()
|
|
{
|
|
$action = new rcmail_action_contacts_search_delete();
|
|
$output = $this->initOutput(rcmail_action::MODE_AJAX, 'contacts', 'search-delete');
|
|
|
|
$this->assertInstanceOf('rcmail_action', $action);
|
|
$this->assertTrue($action->checks());
|
|
|
|
$_POST = ['_sid' => 'unknown'];
|
|
|
|
$this->runAndAssert($action, OutputJsonMock::E_EXIT);
|
|
|
|
$result = $output->getOutput();
|
|
|
|
$this->assertSame(['Content-Type: application/json; charset=UTF-8'], $output->headers);
|
|
$this->assertSame('search-delete', $result['action']);
|
|
$this->assertSame('this.display_message("Could not delete saved search.","error",0);', trim($result['exec']));
|
|
}
|
|
|
|
/**
|
|
* Test deleting a saved-search
|
|
*/
|
|
public function test_search_create_success()
|
|
{
|
|
$action = new rcmail_action_contacts_search_delete();
|
|
$output = $this->initOutput(rcmail_action::MODE_AJAX, 'contacts', 'search-delete');
|
|
|
|
$this->assertTrue($action->checks());
|
|
|
|
self::initDB('searches');
|
|
|
|
$db = rcmail::get_instance()->get_dbh();
|
|
$query = $db->query('SELECT * FROM `searches` WHERE `name` = \'test\'');
|
|
$result = $db->fetch_assoc($query);
|
|
$sid = $result['search_id'];
|
|
|
|
$_POST = ['_sid' => $sid];
|
|
|
|
$this->runAndAssert($action, OutputJsonMock::E_EXIT);
|
|
|
|
$result = $output->getOutput();
|
|
|
|
$this->assertSame(['Content-Type: application/json; charset=UTF-8'], $output->headers);
|
|
$this->assertSame('search-delete', $result['action']);
|
|
$this->assertSame(0, $result['env']['pagecount']);
|
|
$this->assertTrue(strpos($result['exec'], 'this.display_message("Saved search deleted successfully.","confirmation",0);') !== false);
|
|
$this->assertTrue(strpos($result['exec'], 'this.remove_search_item("' . $sid . '")') !== false);
|
|
$this->assertTrue(strpos($result['exec'], 'this.set_rowcount("No contacts found.");') !== false);
|
|
|
|
$query = $db->query('SELECT * FROM `searches` WHERE `name` = \'test\'');
|
|
$result = $db->fetch_assoc($query);
|
|
|
|
$this->assertTrue(empty($result));
|
|
}
|
|
}
|