public function VocabularyLanguageTest::testVocabularyDefaultLanguageForTerms in Drupal 8
Same name and namespace in other branches
- 9 core/modules/taxonomy/tests/src/Functional/VocabularyLanguageTest.php \Drupal\Tests\taxonomy\Functional\VocabularyLanguageTest::testVocabularyDefaultLanguageForTerms()
- 10 core/modules/taxonomy/tests/src/Functional/VocabularyLanguageTest.php \Drupal\Tests\taxonomy\Functional\VocabularyLanguageTest::testVocabularyDefaultLanguageForTerms()
Tests term language settings for vocabulary terms are saved and updated.
File
- core/
modules/ taxonomy/ tests/ src/ Functional/ VocabularyLanguageTest.php, line 74
Class
- VocabularyLanguageTest
- Tests the language functionality for vocabularies.
Namespace
Drupal\Tests\taxonomy\FunctionalCode
public function testVocabularyDefaultLanguageForTerms() {
// Add a new vocabulary and check that the default language settings are for
// the terms are saved.
$edit = [
'name' => $this
->randomMachineName(),
'vid' => mb_strtolower($this
->randomMachineName()),
'default_language[langcode]' => 'bb',
'default_language[language_alterable]' => TRUE,
];
$vid = $edit['vid'];
$this
->drupalPostForm('admin/structure/taxonomy/add', $edit, t('Save'));
// Check that the vocabulary was actually created.
$this
->drupalGet('admin/structure/taxonomy/manage/' . $edit['vid']);
$this
->assertSession()
->statusCodeEquals(200);
// Check that the language settings were saved.
$language_settings = ContentLanguageSettings::loadByEntityTypeBundle('taxonomy_term', $edit['vid']);
$this
->assertEqual($language_settings
->getDefaultLangcode(), 'bb', 'The langcode was saved.');
$this
->assertTrue($language_settings
->isLanguageAlterable(), 'The visibility setting was saved.');
// Check that the correct options are selected in the interface.
$this
->assertOptionSelected('edit-default-language-langcode', 'bb', 'The correct default language for the terms of this vocabulary is selected.');
$this
->assertFieldChecked('edit-default-language-language-alterable', 'Show language selection option is checked.');
// Edit the vocabulary and check that the new settings are updated.
$edit = [
'default_language[langcode]' => 'aa',
'default_language[language_alterable]' => FALSE,
];
$this
->drupalPostForm('admin/structure/taxonomy/manage/' . $vid, $edit, t('Save'));
// And check again the settings and also the interface.
$language_settings = ContentLanguageSettings::loadByEntityTypeBundle('taxonomy_term', $vid);
$this
->assertEqual($language_settings
->getDefaultLangcode(), 'aa', 'The langcode was saved.');
$this
->assertFalse($language_settings
->isLanguageAlterable(), 'The visibility setting was saved.');
$this
->drupalGet('admin/structure/taxonomy/manage/' . $vid);
$this
->assertOptionSelected('edit-default-language-langcode', 'aa', 'The correct default language for the terms of this vocabulary is selected.');
$this
->assertNoFieldChecked('edit-default-language-language-alterable', 'Show language selection option is not checked.');
// Check that language settings are changed after editing vocabulary.
$edit = [
'name' => $this
->randomMachineName(),
'default_language[langcode]' => 'authors_default',
'default_language[language_alterable]' => FALSE,
];
$this
->drupalPostForm('admin/structure/taxonomy/manage/' . $vid, $edit, t('Save'));
// Check that we have the new settings.
$new_settings = ContentLanguageSettings::loadByEntityTypeBundle('taxonomy_term', $vid);
$this
->assertEqual($new_settings
->getDefaultLangcode(), 'authors_default', 'The langcode was saved.');
$this
->assertFalse($new_settings
->isLanguageAlterable(), 'The new visibility setting was saved.');
}