You are here

class DrupalSolrQueryTests in Apache Solr Search 5

Same name and namespace in other branches
  1. 6 tests/solr_base_query.test \DrupalSolrQueryTests
  2. 6.2 tests/solr_base_query.test \DrupalSolrQueryTests

Hierarchy

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

Namesort descending Modifiers Type Description Overrides
DrupalSolrQueryTests::$queries private property
DrupalSolrQueryTests::get_info function
DrupalSolrQueryTests::testAddTerm function
DrupalSolrQueryTests::testParseSimple function
DrupalSolrQueryTests::testRemoveTerm function
DrupalTestCase::$_cleanupModules property
DrupalTestCase::$_cleanupRoles property
DrupalTestCase::$_cleanupUsers property
DrupalTestCase::$_cleanupVariables property
DrupalTestCase::$_content property
DrupalTestCase::assertCopy function Will trigger a pass if both parameters refer to different objects. Fail otherwise.
DrupalTestCase::assertEqual function Will trigger a pass if the two parameters have the same value only. Otherwise a fail.
DrupalTestCase::assertError function Confirms that an error has occurred and optionally that the error text matches exactly.
DrupalTestCase::assertErrorPattern function Confirms that an error has occurred and that the error text matches a Perl regular expression.
DrupalTestCase::assertIdentical function Will trigger a pass if the two parameters have the same value and same type. Otherwise a fail.
DrupalTestCase::assertIsA 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::assertNoErrors function Confirms that no errors have occurred so far in the test method.
DrupalTestCase::assertNotA function Type and class mismatch test. Will pass if class name or underling type does not match the one specified.
DrupalTestCase::assertNotEqual function Will trigger a pass if the two parameters have a different value. Otherwise a fail.
DrupalTestCase::assertNotIdentical function Will trigger a pass if the two parameters have the different value or different type.
DrupalTestCase::assertNotNull function Will be true if the value is set.
DrupalTestCase::assertNoUnwantedPattern function Will trigger a pass if the Perl regex pattern is not present in subject. Fail if found.
DrupalTestCase::assertNoUnwantedRaw function Will trigger a pass if the raw text is NOT found on the loaded page Fail otherwise.
DrupalTestCase::assertNull function Will be true if the value is null.
DrupalTestCase::assertReference function Will trigger a pass if both parameters refer to the same object. Fail otherwise.
DrupalTestCase::assertWantedPattern function Will trigger a pass if the Perl regex pattern is found in the subject. Fail otherwise.
DrupalTestCase::assertWantedRaw function Will trigger a pass if the raw text is found on the loaded page Fail otherwise.
DrupalTestCase::clickLink 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::drupalCheckAuth function @abstract Checks to see if we need to send a http-auth header to authenticate when browsing a site.
DrupalTestCase::drupalCreateRolePerm function Create a role / perm combination specified by permissions
DrupalTestCase::drupalCreateUserRolePerm function Creates a user / role / permissions combination specified by permissions
DrupalTestCase::drupalGet function @abstract Brokder for the get function adds the authentication headers if necessary @author Earnest Berry III <earnest.berry@gmail.com>
DrupalTestCase::drupalGetContent function @TODO: needs documentation
DrupalTestCase::drupalLoginUser function Logs in a user with the internal browser
DrupalTestCase::drupalModuleDisable function Disables a drupal module
DrupalTestCase::drupalModuleEnable function Enables a drupal module
DrupalTestCase::drupalPostRequest function Do a post request on a drupal page. It will be done as usual post request with SimpleBrowser
DrupalTestCase::drupalRawPost function @abstract Broker for the post function adds the authentication headers if necessary @author Earnest Berry III <earnest.berry@gmail.com>
DrupalTestCase::DrupalTestCase function
DrupalTestCase::drupalVariableSet function Set a druapl variable and keep track of the changes for tearDown()
DrupalTestCase::randomName function Generates a random string, to be used as name or whatever
DrupalTestCase::run function Just some info for the reporter
DrupalTestCase::tearDown function tearDown implementation, setting back switched modules etc 1