class DrupalSolrQueryBreadcrumbTests in Apache Solr Search 5
Hierarchy
- class \DrupalTestCase extends \WebTestCase
Expanded class hierarchy of DrupalSolrQueryBreadcrumbTests
File
- tests/
solr_base_query_breadcrumb.test, line 3
View source
class DrupalSolrQueryBreadcrumbTests extends DrupalTestCase {
function get_info() {
return array(
'name' => 'Solr/query breadcrumb',
'desc' => 'Make sure breadcrumbs get formed correctly.',
'group' => 'Apache Solr tests',
);
}
private $breadcrumb;
private $menu_active_breadcrumb;
function setUp() {
parent::setUp();
$types = node_get_types('types');
shuffle($types);
$type = array_pop($types);
$this->query_string = "sudo tid:44 uid:46 type:" . $type->type . ' tid:58';
$query =& apachesolr_drupal_query($this->query_string, TRUE);
$this->breadcrumb = $query
->get_breadcrumb();
$this->menu_active_breadcrumb = menu_get_active_breadcrumb();
}
function testBreadcrumbIsArray() {
return $this
->assertTrue(is_array($this->breadcrumb));
}
function testBreadcrumbCount() {
$query_count = count(explode(' ', $this->query_string));
$menu_active_count = count($this->menu_active_breadcrumb);
$expected_breadcrumb_count = $menu_active_count + $query_count;
$query_breadcrumb_count = count($this->breadcrumb);
$message = 'The number of items in the breadcrumb (@breadcrumb_count) ' . 'should be equal to the number of items in $menu_active_breadcrumb ' . '(@menu_active_count) plus the number of words in $query ' . '(@query_count).';
$vars = array(
'@breadcrumb_count' => $query_breadcrumb_count,
'@menu_active_count' => $menu_active_count,
'@query_count' => $query_count,
);
return $this
->assertEqual($query_breadcrumb_count, $expected_breadcrumb_count, "'%s' " . t($message, $vars));
}
function testBreadcrumbLinks() {
$link_part = '<a ';
$result = TRUE;
for ($i = 0; $i + 1 < count($this->breadcrumb); ++$i) {
$result &= $this
->assertTrue(strpos($this->breadcrumb[$i], $link_part) !== FALSE, 'Breadcrumb items other than the ' . 'last should be links. But ' . ($i + 1) . 'th item is: ' . str_replace('%', '%%', $this->breadcrumb[$i]) . (is_array($this->breadcrumb[$i]) ? ' true' : ' false'));
}
$result &= $this
->assertTrue(strpos($this->breadcrumb[count($this->breadcrumb) - 1], $link_part) === FALSE, 'Last breadcrumb item should not be a link.');
return $result;
}
function testBreadcrumbsClean() {
$result = TRUE;
$prefix_re = '/\\w+:/';
foreach ($this->breadcrumb as $item) {
$this
->assertTrue(preg_match($prefix_re, strip_tags($item)) == 0, 'Field prefixes like "uid:" should be stripped from the breadcrumbs.');
}
return $result;
}
}
Members
Name | Modifiers | Type | Description | Overrides |
---|---|---|---|---|
DrupalSolrQueryBreadcrumbTests:: |
private | property | ||
DrupalSolrQueryBreadcrumbTests:: |
private | property | ||
DrupalSolrQueryBreadcrumbTests:: |
function | |||
DrupalSolrQueryBreadcrumbTests:: |
function | |||
DrupalSolrQueryBreadcrumbTests:: |
function | |||
DrupalSolrQueryBreadcrumbTests:: |
function | |||
DrupalSolrQueryBreadcrumbTests:: |
function | |||
DrupalSolrQueryBreadcrumbTests:: |
function | |||
DrupalTestCase:: |
property | |||
DrupalTestCase:: |
property | |||
DrupalTestCase:: |
property | |||
DrupalTestCase:: |
property | |||
DrupalTestCase:: |
property | |||
DrupalTestCase:: |
function | Will trigger a pass if both parameters refer to different objects. Fail otherwise. | ||
DrupalTestCase:: |
function | Will trigger a pass if the two parameters have the same value only. Otherwise a fail. | ||
DrupalTestCase:: |
function | Confirms that an error has occurred and optionally that the error text matches exactly. | ||
DrupalTestCase:: |
function | Confirms that an error has occurred and that the error text matches a Perl regular expression. | ||
DrupalTestCase:: |
function | Will trigger a pass if the two parameters have the same value and same type. Otherwise a fail. | ||
DrupalTestCase:: |
function | Type and class test. Will pass if class matches the type name or is a subclass or if not an object, but the type is correct. | ||
DrupalTestCase:: |
function | Confirms that no errors have occurred so far in the test method. | ||
DrupalTestCase:: |
function | Type and class mismatch test. Will pass if class name or underling type does not match the one specified. | ||
DrupalTestCase:: |
function | Will trigger a pass if the two parameters have a different value. Otherwise a fail. | ||
DrupalTestCase:: |
function | Will trigger a pass if the two parameters have the different value or different type. | ||
DrupalTestCase:: |
function | Will be true if the value is set. | ||
DrupalTestCase:: |
function | Will trigger a pass if the Perl regex pattern is not present in subject. Fail if found. | ||
DrupalTestCase:: |
function | Will trigger a pass if the raw text is NOT found on the loaded page Fail otherwise. | ||
DrupalTestCase:: |
function | Will be true if the value is null. | ||
DrupalTestCase:: |
function | Will trigger a pass if both parameters refer to the same object. Fail otherwise. | ||
DrupalTestCase:: |
function | Will trigger a pass if the Perl regex pattern is found in the subject. Fail otherwise. | ||
DrupalTestCase:: |
function | Will trigger a pass if the raw text is found on the loaded page Fail otherwise. | ||
DrupalTestCase:: |
function | Follows a link by name. Will click the first link found with this link text by default, or a later one if an index is given. Match is case insensitive with normalised space. Does make assertations if the click was sucessful or not and it does… | ||
DrupalTestCase:: |
function | @abstract Checks to see if we need to send a http-auth header to authenticate when browsing a site. | ||
DrupalTestCase:: |
function | Create a role / perm combination specified by permissions | ||
DrupalTestCase:: |
function | Creates a user / role / permissions combination specified by permissions | ||
DrupalTestCase:: |
function | @abstract Brokder for the get function adds the authentication headers if necessary @author Earnest Berry III <earnest.berry@gmail.com> | ||
DrupalTestCase:: |
function | @TODO: needs documentation | ||
DrupalTestCase:: |
function | Logs in a user with the internal browser | ||
DrupalTestCase:: |
function | Disables a drupal module | ||
DrupalTestCase:: |
function | Enables a drupal module | ||
DrupalTestCase:: |
function | Do a post request on a drupal page. It will be done as usual post request with SimpleBrowser | ||
DrupalTestCase:: |
function | @abstract Broker for the post function adds the authentication headers if necessary @author Earnest Berry III <earnest.berry@gmail.com> | ||
DrupalTestCase:: |
function | |||
DrupalTestCase:: |
function | Set a druapl variable and keep track of the changes for tearDown() | ||
DrupalTestCase:: |
function | Generates a random string, to be used as name or whatever | ||
DrupalTestCase:: |
function | Just some info for the reporter | ||
DrupalTestCase:: |
function | tearDown implementation, setting back switched modules etc | 1 |