Files
roundcubemail/tests/Actions/Contacts/SearchTest.php
Michael Voříšek 736795326c Fix plugins composer.json format (#9405)
* 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
2024-04-05 17:55:46 +02:00

77 lines
2.5 KiB
PHP

<?php
/**
* Test class to test rcmail_action_contacts_search
*/
class Actions_Contacts_Search extends ActionTestCase
{
/**
* Test search form request
*/
public function test_run_search_form()
{
$action = new rcmail_action_contacts_search();
$output = $this->initOutput(rcmail_action::MODE_HTTP, 'contacts', 'search');
$this->assertInstanceOf('rcmail_action', $action);
$this->assertTrue($action->checks());
$_GET = ['_form' => 1];
$this->runAndAssert($action, OutputHtmlMock::E_EXIT);
$result = $output->getOutput();
$this->assertSame('contactsearch', $output->template);
$this->assertSame('', $output->getProperty('pagetitle')); // TODO: there should be a title
$this->assertTrue(stripos($result, '<!DOCTYPE html>') === 0);
}
/**
* Test search request
*/
public function test_run_quick_search()
{
$action = new rcmail_action_contacts_search();
$output = $this->initOutput(rcmail_action::MODE_AJAX, 'contacts', 'search');
$this->assertTrue($action->checks());
self::initDB('contacts');
$_GET = ['_q' => 'George'];
$this->runAndAssert($action, OutputJsonMock::E_EXIT);
$result = $output->getOutput();
$this->assertSame(['Content-Type: application/json; charset=UTF-8'], $output->headers);
$this->assertSame('search', $result['action']);
$this->assertSame(1, $result['env']['pagecount']);
$this->assertMatchesRegularExpression('/^[0-9a-z]{32}$/', $result['env']['search_request']);
$this->assertTrue(strpos($result['exec'], 'this.add_contact_row') !== false);
$this->assertTrue(strpos($result['exec'], 'this.set_rowcount("Contacts 1 to 1 of 1");') !== false);
$this->assertTrue(strpos($result['exec'], 'this.display_message("1 contacts found.","confirmation",0);') !== false);
$this->assertTrue(strpos($result['exec'], 'this.unselect_directory();') !== false);
$this->assertTrue(strpos($result['exec'], 'this.enable_command("search-create",true);') !== false);
$this->assertTrue(strpos($result['exec'], 'this.update_group_commands()') !== false);
}
/**
* Test search request
*/
public function test_run_search()
{
// TODO: Search using saved search, or using the form
$this->markTestIncomplete();
}
/**
* Test contact_search_form() method
*/
public function test_contact_search_form()
{
$this->markTestIncomplete();
}
}