class LocaleModuleTest in SimpleTest 6
Hierarchy
- class \DrupalTestCase extends \WebTestCase
- class \LocaleModuleTest
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
Name | Modifiers | Type | Description | Overrides |
---|---|---|---|---|
DrupalTestCase:: |
property | |||
DrupalTestCase:: |
property | |||
DrupalTestCase:: |
property | |||
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 | Retrieves and saves current modules list into $_originalModules and $_modules. | ||
DrupalTestCase:: |
function | Follows a link by name. | ||
DrupalTestCase:: |
function | @abstract Checks to see if we need to send a http-auth header to authenticate when browsing a site. | ||
DrupalTestCase:: |
function | Creates a custom content type based on default settings. | ||
DrupalTestCase:: |
function | Creates a node based on default settings. | ||
DrupalTestCase:: |
function | Create a role / perm combination specified by permissions | ||
DrupalTestCase:: |
function | Creates a user / role / permissions combination specified by permissions | ||
DrupalTestCase:: |
function | @abstract Broker 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 By $reporting you specify if this request does assertions or not Warning: empty ("") returns will cause fails with $reporting | ||
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 drupal 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 | 8 | |
LocaleModuleTest:: |
function | Implementation of get_info() for information | ||
LocaleModuleTest:: |
function | |||
LocaleModuleTest:: |
function |