You are here

class LocaleModuleTest in SimpleTest 6

Hierarchy

Expanded class hierarchy of LocaleModuleTest

File

tests/locale_module.test, line 3

View source
class LocaleModuleTest extends DrupalTestCase {

  /**
   * Implementation of get_info() for information
   */
  function get_info() {
    return array(
      'name' => t('String translate'),
      'desc' => 'Adds a new locale and translates its name',
      'group' => 'Locale',
    );
  }
  function setUp() {
    parent::setUp();
    $this
      ->drupalModuleEnable('locale');
  }
  function testlocaleModuleTest() {
    global $base_url;

    // User to add and remove language.
    $admin_user = $this
      ->drupalCreateUserRolePerm(array(
      'administer languages',
      'access administration pages',
    ));

    // User to translate and delete string.
    $translate_user = $this
      ->drupalCreateUserRolePerm(array(
      'translate interface',
      'access administration pages',
    ));

    // Code for the language.
    $langcode = str_replace('simpletest_', 'si-', $this
      ->randomName(6));

    // The English name for the language. This will be translated.
    $name = $this
      ->randomName(16);

    // The native name for the language.
    $native = $this
      ->randomName(16);

    // The domain prefix. Not tested yet.
    $prefix = strtolower(str_replace('si-', '', $langcode));

    // This is the language indicator on the translation search screen for
    // untranslated strings. Copied straight from locale.inc.
    $language_indicator = "<em class=\"locale-untranslated\">{$langcode}</em> ";

    // This will be the translation of $name.
    $translation = $this
      ->randomName(16);

    // Add language.
    $this
      ->drupalLoginUser($admin_user);
    $edit = array(
      'langcode' => $langcode,
      'name' => $name,
      'native' => $native,
      'prefix' => $prefix,
      'direction' => '0',
    );
    $this
      ->drupalPost('admin/settings/language/add', $edit, 'Add custom language');

    // Add string.
    t($name, array(), $langcode);

    // Reset locale cache.
    locale(NULL, NULL, TRUE);
    $this
      ->assertText($langcode, 'Language code found');
    $this
      ->assertText($name, 'Name found');
    $this
      ->assertText($native, 'Native found');

    // No t() here, we do not want to add this string to the database and it's
    // surely not translated yet.
    $this
      ->assertText($native, 'Test language added');
    $this
      ->drupalGet('logout');

    // Search for the name and translate it.
    $this
      ->drupalLoginUser($translate_user);
    $search = array(
      'string' => $name,
      'language' => 'all',
      'translation' => 'all',
      'group' => 'all',
    );
    $this
      ->drupalPost('admin/build/translate/search', $search, 'Search');

    // assertText seems to remove the input field where $name always could be
    // found, so this is not a false assert. See how assertNoText succeeds
    // later.
    $this
      ->assertText($name, 'Search found the name');
    $this
      ->assertWantedRaw($language_indicator, 'Name is untranslated');

    // It's presumed that this is the only result. Given the random name, it's
    // reasonable.
    $this
      ->clickLink('edit');

    // We save the lid from the path.
    $lid = preg_replace('/\\D/', '', substr($this
      ->getUrl(), strlen($base_url)));

    // No t() here, it's surely not translated yet.
    $this
      ->assertText($name, 'name found on edit screen');
    $edit = array(
      "translations[{$langcode}]" => $translation,
    );
    $this
      ->drupalPost(NULL, $edit, 'Save translations');
    $this
      ->assertText(t('The string has been saved.'), 'The string has been saved.');
    $this
      ->assertTrue($name != $translation && t($name, array(), $langcode) == $translation, 't() works');
    $this
      ->drupalPost('admin/build/translate/search', $search, 'Search');

    // The indicator should not be here.
    $this
      ->assertNoUnwantedRaw($language_indicator, 'String is translated');
    $this
      ->drupalGet('logout');

    // Delete the language
    $this
      ->drupalLoginUser($admin_user);
    $path = 'admin/settings/language/delete/' . $langcode;

    // This a confirm form, we do not need any fields changed.
    $this
      ->drupalPost($path, array(), 'Delete');

    // We need raw here because %locale will add HTML.
    $this
      ->assertWantedRaw(t('The language %locale has been removed.', array(
      '%locale' => $name,
    )), 'The test language has been removed.');

    // Reload to remove $name.
    $this
      ->drupalGet($path);
    $this
      ->assertNoText($langcode, 'Language code not found');
    $this
      ->assertNoText($name, 'Name not found');
    $this
      ->assertNoText($native, 'Native not found');
    $this
      ->drupalGet('logout');

    // Delete the name string.
    $this
      ->drupalLoginUser($translate_user);
    $this
      ->drupalGet('admin/build/translate/delete/' . $lid);
    $this
      ->assertText(t('The string has been removed.'), 'The string has been removed message.');
    $this
      ->drupalPost('admin/build/translate/search', $search, 'Search');
    $this
      ->assertNoText($name, 'Search now can not find the name');
  }

}

Members

Namesort descending Modifiers Type Description Overrides
DrupalTestCase::$_cleanupContentTypes property
DrupalTestCase::$_cleanupNodes property
DrupalTestCase::$_cleanupRoles property
DrupalTestCase::$_cleanupUsers property
DrupalTestCase::$_cleanupVariables property
DrupalTestCase::$_content property
DrupalTestCase::$_modules property
DrupalTestCase::$_originalModules 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::checkOriginalModules function Retrieves and saves current modules list into $_originalModules and $_modules.
DrupalTestCase::clickLink function Follows a link by name.
DrupalTestCase::drupalCheckAuth function @abstract Checks to see if we need to send a http-auth header to authenticate when browsing a site.
DrupalTestCase::drupalCreateContentType function Creates a custom content type based on default settings.
DrupalTestCase::drupalCreateNode function Creates a node based on default settings.
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 Broker 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::drupalPost function Do a post request on a drupal page. It will be done as usual post request with SimpleBrowser By $reporting you specify if this request does assertions or not Warning: empty ("") returns will cause fails with $reporting
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 drupal 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 8
LocaleModuleTest::get_info function Implementation of get_info() for information
LocaleModuleTest::setUp function
LocaleModuleTest::testlocaleModuleTest function