class DrupalSolrQueryTests in Apache Solr Search 5
Same name and namespace in other branches
- 6 tests/solr_base_query.test \DrupalSolrQueryTests
- 6.2 tests/solr_base_query.test \DrupalSolrQueryTests
Hierarchy
- class \DrupalTestCase extends \WebTestCase
- class \DrupalSolrQueryTests
Expanded class hierarchy of DrupalSolrQueryTests
File
- tests/
solr_base_query.test, line 3
View source
class DrupalSolrQueryTests extends DrupalTestCase {
function get_info() {
return array(
'name' => 'Solr/query handling',
'desc' => 'Throw various queries at the query object and make sure they all parse correctly.',
'group' => 'Apache Solr tests',
);
}
private $queries = array(
'foo',
'foo bar',
'foo bar "hubba baz"',
'uid:1',
'uid:1 uid:2',
'foo bar uid:1 uid:2',
'foo bar "I love you"',
'foo bar baz -hubba',
'foo -bar -term:31',
'foo*',
'foo?',
'somefield:"I love you"',
);
function testParseSimple() {
$result = TRUE;
foreach ($this->queries as $string) {
$query =& apachesolr_drupal_query($string, TRUE);
// force the query to be rebuilt without removing any fields.
$query
->remove_field('fake-field-name');
if (!$this
->assertEqual($string, $query
->get_query())) {
$result = FALSE;
}
}
return $result;
}
function testAddTerm() {
$result = TRUE;
foreach ($this->queries as $string) {
$query =& apachesolr_drupal_query($string, TRUE);
$query
->add_field('wham', '1');
if (!$this
->assertEqual($string . ' wham:1', $query
->get_query())) {
$result = FALSE;
}
}
return $result;
}
function testRemoveTerm() {
$result = TRUE;
$string = 'foo';
$query =& apachesolr_drupal_query($string, TRUE);
$query
->remove_field('', 'foo');
if (!$this
->assertEqual('foo', $query
->get_query())) {
$result = FALSE;
}
$string = 'foo bar';
$query =& apachesolr_drupal_query($string, TRUE);
$query
->remove_field('', 'foo');
if (!$this
->assertEqual('foo bar', $query
->get_query())) {
$result = FALSE;
}
$string = 'foo uid:1 bar';
$query =& apachesolr_drupal_query($string, TRUE);
$query
->remove_field('uid', '1');
if (!$this
->assertEqual('foo bar', $query
->get_query())) {
$result = FALSE;
}
$string = 'foo uid:1 bar';
$query =& apachesolr_drupal_query($string, TRUE);
$query
->remove_field('uid');
if (!$this
->assertEqual('foo bar', $query
->get_query())) {
$result = FALSE;
}
$string = 'foo uid:1 bar uid:2 tid:3';
$query =& apachesolr_drupal_query($string, TRUE);
$query
->remove_field('uid', '1');
/*// May not work because query doesn't necessarily get rebuilt in same order
if (!$this->assertEqual('foo bar uid:2 tid:3', $query->get_query())) {
$result = FALSE;
}*/
// Not very beautiful, but probably best way there is:
$pass = TRUE;
$components = array(
'foo',
'bar',
'uid:2',
'tid:3',
);
$q = $query
->get_query();
if (count($components) != count(explode(' ', $q))) {
$pass = FALSE;
}
else {
foreach ($components as $s) {
if (strpos($q, $s) === FALSE) {
$pass = false;
break;
}
}
}
if ($pass) {
$this
->assertEqual($q, $q);
}
else {
$this
->assertEqual('foo bar tid:3 uid:2', $q);
$result = FALSE;
}
$string = 'foo uid:1 bar uid:2 tid:3';
$query =& apachesolr_drupal_query($string, TRUE);
$query
->remove_field('uid');
if (!$this
->assertEqual('foo bar tid:3', $query
->get_query())) {
$result = FALSE;
}
return $result;
}
}
Members
Name | Modifiers | Type | Description | Overrides |
---|---|---|---|---|
DrupalSolrQueryTests:: |
private | property | ||
DrupalSolrQueryTests:: |
function | |||
DrupalSolrQueryTests:: |
function | |||
DrupalSolrQueryTests:: |
function | |||
DrupalSolrQueryTests:: |
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 |