class MenuUiContentTranslationTest
Same name and namespace in other branches
- 11.x core/modules/menu_ui/tests/src/Functional/MenuUiContentTranslationTest.php \Drupal\Tests\menu_ui\Functional\MenuUiContentTranslationTest
Tests Menu UI and Content Translation integration for content entities.
@group menu_ui
Hierarchy
- class \Drupal\Tests\BrowserTestBase uses \Drupal\Core\Test\FunctionalTestSetupTrait, \Drupal\Core\Test\TestSetupTrait, \Drupal\Tests\PhpUnitCompatibilityTrait, \Symfony\Bridge\PhpUnit\ExpectDeprecationTrait, \Drupal\Tests\ExtensionListTestTrait implements \PHPUnit\Framework\TestCase
- class \Drupal\Tests\menu_ui\Functional\MenuUiContentTranslationTest uses \Drupal\Tests\language\Traits\LanguageTestTrait implements \Drupal\Tests\BrowserTestBase
Expanded class hierarchy of MenuUiContentTranslationTest
File
-
core/
modules/ menu_ui/ tests/ src/ Functional/ MenuUiContentTranslationTest.php, line 16
Namespace
Drupal\Tests\menu_ui\FunctionalView source
class MenuUiContentTranslationTest extends BrowserTestBase {
use LanguageTestTrait;
/**
* {@inheritdoc}
*/
protected $defaultTheme = 'stark';
/**
* {@inheritdoc}
*/
protected static $modules = [
'block',
'language',
'content_translation',
'menu_ui',
'node',
];
/**
* {@inheritdoc}
*/
protected function setUp() : void {
parent::setUp();
// Place menu block and local tasks block.
$this->drupalPlaceBlock('system_menu_block:main');
$this->drupalPlaceBlock('local_tasks_block');
// Create a 'page' content type.
$this->drupalCreateContentType([
'type' => 'page',
'name' => 'Basic page',
'display_submitted' => FALSE,
]);
// Add a second language.
static::createLanguageFromLangcode('de');
// Create an account and login.
$user = $this->drupalCreateUser([
'administer site configuration',
'administer nodes',
'create page content',
'edit any page content',
'delete any page content',
'administer content translation',
'translate any entity',
'create content translations',
'administer languages',
'administer content types',
'administer menu',
]);
$this->drupalLogin($user);
// Enable translation for page nodes and menu link content.
static::enableBundleTranslation('node', 'page');
static::enableBundleTranslation('menu_link_content', 'menu_link_content');
}
/**
* Gets a content entity object by title.
*
* @param string $entity_type_id
* Id of content entity type of content entity to load.
* @param string $title
* Title of content entity to load.
*
* @return \Drupal\Core\Entity\ContentEntityInterface
* First found content entity with given title.
*/
protected function getContentEntityByTitle($entity_type_id, $title) {
$entity_type_manager = $this->container
->get('entity_type.manager');
$storage = $entity_type_manager->getStorage($entity_type_id);
$storage->resetCache();
$entities = $storage->loadByProperties([
'title' => $title,
]);
return reset($entities);
}
/**
* Provides test data sets for testChangeContentToPseudoLanguage().
*
* @return array
* Data sets to test keyed by data set label.
*/
public static function provideChangeContentToPseudoLanguageData() {
return [
'und' => [
'langcode' => LanguageInterface::LANGCODE_NOT_SPECIFIED,
],
'zxx' => [
'langcode' => LanguageInterface::LANGCODE_NOT_APPLICABLE,
],
];
}
/**
* Tests changing content with menu link from language to pseudo language.
*
* @param string $langcode
* Language code of pseudo-language to change content language to.
* Either \Drupal\Core\LanguageInterface::LANGCODE_NOT_SPECIFIED or
* \Drupal\Core\LanguageInterface::LANGCODE_NOT_APPLICABLE.
*
* @dataProvider provideChangeContentToPseudoLanguageData
*/
public function testChangeContentToPseudoLanguage($langcode) : void {
$node_title = 'Test node';
$menu_link_title_en = 'Test menu link EN';
$menu_link_title_pseudo = 'Test menu link PSEUDO';
// Create a page node in English.
$this->drupalGet('node/add/page');
$this->assertSession()
->statusCodeEquals(200);
$edit = [
'title[0][value]' => $node_title,
'menu[enabled]' => 1,
'menu[title]' => $menu_link_title_en,
];
$this->submitForm($edit, 'Save');
$this->assertSession()
->statusCodeEquals(200);
// Assert that node exists and node language is English.
$node = $this->getContentEntityByTitle('node', $node_title);
$this->assertTrue(is_object($node));
$this->assertTrue($node->language()
->getId() == 'en');
// Assert that menu link exists and menu link language is English.
$menu_link = $this->getContentEntityByTitle('menu_link_content', $menu_link_title_en);
$this->assertTrue(is_object($menu_link));
$this->assertTrue($menu_link->language()
->getId() == 'en');
$this->assertTrue($menu_link->hasTranslation('en'));
// Assert that menu link is visible with initial title.
$this->assertSession()
->linkExists($menu_link_title_en);
// Change language of page node and title of its menu link.
$this->clickLink('Edit');
$edit = [
'langcode[0][value]' => $langcode,
'menu[title]' => $menu_link_title_pseudo,
];
$this->submitForm($edit, 'Save');
$this->assertSession()
->statusCodeEquals(200);
// Assert that node exists and node language is target language.
$node = $this->getContentEntityByTitle('node', $node_title);
$this->assertTrue(is_object($node));
$this->assertTrue($node->language()
->getId() == $langcode);
// Assert that menu link exists and menu link language is target language.
$menu_link = $this->getContentEntityByTitle('menu_link_content', $menu_link_title_pseudo);
$this->assertTrue(is_object($menu_link));
$this->assertTrue($menu_link->language()
->getId() == $langcode);
$this->assertFalse($menu_link->hasTranslation('en'));
// Assert that menu link is visible with updated title.
$this->assertSession()
->linkExists($menu_link_title_pseudo);
}
}
Members
Title Sort descending | Deprecated | Modifiers | Object type | Summary | Overriden Title | Overrides |
---|---|---|---|---|---|---|
BrowserTestBase::$baseUrl | protected | property | The base URL. | |||
BrowserTestBase::$configImporter | protected | property | The config importer that can be used in a test. | |||
BrowserTestBase::$customTranslations | protected | property | An array of custom translations suitable for SettingsEditor::rewrite(). | |||
BrowserTestBase::$mink | protected | property | Mink session manager. | |||
BrowserTestBase::$minkDefaultDriverArgs | protected | property | Mink default driver params. | |||
BrowserTestBase::$minkDefaultDriverClass | protected | property | Mink class for the default driver to use. | 1 | ||
BrowserTestBase::$originalContainer | protected | property | The original container. | |||
BrowserTestBase::$originalShutdownCallbacks | protected | property | The original array of shutdown function callbacks. | |||
BrowserTestBase::$preserveGlobalState | protected | property | ||||
BrowserTestBase::$profile | protected | property | The profile to install as a basis for testing. | 40 | ||
BrowserTestBase::$runTestInSeparateProcess | protected | property | Browser tests are run in separate processes to prevent collisions between code that may be loaded by tests. |
|||
BrowserTestBase::$timeLimit | protected | property | Time limit in seconds for the test. | |||
BrowserTestBase::$translationFilesDirectory | protected | property | The translation file directory for the test environment. | |||
BrowserTestBase::cleanupEnvironment | protected | function | Clean up the test environment. | |||
BrowserTestBase::config | protected | function | Configuration accessor for tests. Returns non-overridden configuration. | |||
BrowserTestBase::filePreDeleteCallback | public static | function | Ensures test files are deletable. | |||
BrowserTestBase::getDefaultDriverInstance | protected | function | Gets an instance of the default Mink driver. | |||
BrowserTestBase::getDrupalSettings | protected | function | Gets the JavaScript drupalSettings variable for the currently-loaded page. | 1 | ||
BrowserTestBase::getHttpClient | protected | function | Obtain the HTTP client for the system under test. | |||
BrowserTestBase::getMinkDriverArgs | protected | function | Gets the Mink driver args from an environment variable. | 1 | ||
BrowserTestBase::getOptions | protected | function | Helper function to get the options of select field. | |||
BrowserTestBase::getSession | public | function | Returns Mink session. | |||
BrowserTestBase::getSessionCookies | protected | function | Get session cookies from current session. | |||
BrowserTestBase::getTestMethodCaller | protected | function | Retrieves the current calling line in the class under test. | |||
BrowserTestBase::initFrontPage | protected | function | Visits the front page when initializing Mink. | 3 | ||
BrowserTestBase::initMink | protected | function | Initializes Mink sessions. | 1 | ||
BrowserTestBase::installDrupal | public | function | Installs Drupal into the test site. | 2 | ||
BrowserTestBase::registerSessions | protected | function | Registers additional Mink sessions. | |||
BrowserTestBase::setUpAppRoot | protected | function | Sets up the root application path. | |||
BrowserTestBase::setUpBeforeClass | public static | function | 1 | |||
BrowserTestBase::tearDown | protected | function | 3 | |||
BrowserTestBase::translatePostValues | protected | function | Transforms a nested array into a flat array suitable for submitForm(). | |||
BrowserTestBase::xpath | protected | function | Performs an xpath search on the contents of the internal browser. | |||
BrowserTestBase::__get | public | function | ||||
BrowserTestBase::__sleep | public | function | Prevents serializing any properties. | |||
ExtensionListTestTrait::getModulePath | protected | function | Gets the path for the specified module. | |||
ExtensionListTestTrait::getThemePath | protected | function | Gets the path for the specified theme. | |||
FunctionalTestSetupTrait::$apcuEnsureUniquePrefix | protected | property | The flag to set 'apcu_ensure_unique_prefix' setting. | 1 | ||
FunctionalTestSetupTrait::$classLoader | protected | property | The class loader to use for installation and initialization of setup. | |||
FunctionalTestSetupTrait::$rootUser | protected | property | The "#1" admin user. | |||
FunctionalTestSetupTrait::$usesSuperUserAccessPolicy | protected | property | Set to TRUE to make user 1 a super user. | 10 | ||
FunctionalTestSetupTrait::doInstall | protected | function | Execute the non-interactive installer. | 2 | ||
FunctionalTestSetupTrait::getDatabaseTypes | protected | function | Returns all supported database driver installer objects. | |||
FunctionalTestSetupTrait::initConfig | protected | function | Initialize various configurations post-installation. | 1 | ||
FunctionalTestSetupTrait::initKernel | protected | function | Initializes the kernel after installation. | |||
FunctionalTestSetupTrait::initSettings | protected | function | Initialize settings created during install. | |||
FunctionalTestSetupTrait::initUserSession | protected | function | Initializes user 1 for the site to be installed. | |||
FunctionalTestSetupTrait::installDefaultThemeFromClassProperty | protected | function | Installs the default theme defined by `static::$defaultTheme` when needed. | 1 | ||
FunctionalTestSetupTrait::installModulesFromClassProperty | protected | function | Install modules defined by `static::$modules`. | 1 | ||
FunctionalTestSetupTrait::installParameters | protected | function | Returns the parameters that will be used when the test installs Drupal. | 8 | ||
FunctionalTestSetupTrait::prepareEnvironment | protected | function | Prepares the current environment for running the test. | 28 | ||
FunctionalTestSetupTrait::prepareRequestForGenerator | protected | function | Creates a mock request and sets it on the generator. | |||
FunctionalTestSetupTrait::prepareSettings | protected | function | Prepares site settings and services before installation. | 4 | ||
FunctionalTestSetupTrait::rebuildAll | protected | function | Resets and rebuilds the environment after setup. | |||
FunctionalTestSetupTrait::rebuildContainer | protected | function | Rebuilds \Drupal::getContainer(). | |||
FunctionalTestSetupTrait::resetAll | protected | function | Resets all data structures after having enabled new modules. | |||
FunctionalTestSetupTrait::setContainerParameter | protected | function | Changes parameters in the services.yml file. | |||
FunctionalTestSetupTrait::setupBaseUrl | protected | function | Sets up the base URL based upon the environment variable. | |||
FunctionalTestSetupTrait::writeSettings | protected | function | Rewrites the settings.php file of the test site. | 1 | ||
LanguageTestTrait::createLanguageFromLangcode | public static | function | Creates a configurable language object from a langcode. | |||
LanguageTestTrait::disableBundleTranslation | public static | function | Disables translations for the given entity type bundle. | |||
LanguageTestTrait::enableBundleTranslation | public static | function | Enables translations for the given entity type bundle. | |||
LanguageTestTrait::setFieldTranslatable | public static | function | Sets and saves a given field instance translation status. | |||
MenuUiContentTranslationTest::$defaultTheme | protected | property | The theme to install as the default for testing. | Overrides BrowserTestBase::$defaultTheme | ||
MenuUiContentTranslationTest::$modules | protected static | property | Modules to install. | Overrides BrowserTestBase::$modules | ||
MenuUiContentTranslationTest::getContentEntityByTitle | protected | function | Gets a content entity object by title. | |||
MenuUiContentTranslationTest::provideChangeContentToPseudoLanguageData | public static | function | Provides test data sets for testChangeContentToPseudoLanguage(). | |||
MenuUiContentTranslationTest::setUp | protected | function | Overrides BrowserTestBase::setUp | |||
MenuUiContentTranslationTest::testChangeContentToPseudoLanguage | public | function | Tests changing content with menu link from language to pseudo language. | |||
RefreshVariablesTrait::refreshVariables | protected | function | Refreshes in-memory configuration and state information. | 2 | ||
StorageCopyTrait::replaceStorageContents | protected static | function | Copy the configuration from one storage to another and remove stale items. | |||
TestSetupTrait::$configSchemaCheckerExclusions | protected static | property | An array of config object names that are excluded from schema checking. | 2 | ||
TestSetupTrait::$container | protected | property | The dependency injection container used in the test. | |||
TestSetupTrait::$databasePrefix | protected | property | The database prefix of this test run. | |||
TestSetupTrait::$kernel | protected | property | The DrupalKernel instance used in the test. | |||
TestSetupTrait::$originalSite | protected | property | The site directory of the original parent site. | |||
TestSetupTrait::$privateFilesDirectory | protected | property | The private file directory for the test environment. | |||
TestSetupTrait::$publicFilesDirectory | protected | property | The public file directory for the test environment. | |||
TestSetupTrait::$root | protected | property | The app root. | |||
TestSetupTrait::$siteDirectory | protected | property | The site directory of this test run. | |||
TestSetupTrait::$strictConfigSchema | protected | property | Set to TRUE to strict check all configuration saved. | 5 | ||
TestSetupTrait::$tempFilesDirectory | protected | property | The temporary file directory for the test environment. | |||
TestSetupTrait::$testId | protected | property | The test run ID. | |||
TestSetupTrait::changeDatabasePrefix | protected | function | Changes the database connection to the prefixed one. | |||
TestSetupTrait::getConfigSchemaExclusions | protected | function | Gets the config schema exclusions for this test. | |||
TestSetupTrait::getDatabaseConnection | Deprecated | public static | function | Returns the database connection to the site under test. | ||
TestSetupTrait::prepareDatabasePrefix | protected | function | Generates a database prefix for running tests. | 1 |
Buggy or inaccurate documentation? Please file an issue. Need support? Need help programming? Connect with the Drupal community.