protected function IntegrationTest::addFacet in Facets 8
Tests adding a facet trough the interface.
Parameters
string $facet_name: The name of the facet.
string $facet_type: The field of the facet.
string $source_id: The facet source id.
4 calls to IntegrationTest::addFacet()
- IntegrationTest::testBlockView in tests/
src/ Functional/ IntegrationTest.php - Tests that a block view also works.
- IntegrationTest::testFacetCountCalculations in tests/
src/ Functional/ IntegrationTest.php - Tests calculations of facet count.
- IntegrationTest::testFacetDependencies in tests/
src/ Functional/ IntegrationTest.php - Tests facet dependencies.
- IntegrationTest::testFramework in tests/
src/ Functional/ IntegrationTest.php - Tests various operations via the Facets' admin UI.
File
- tests/
src/ Functional/ IntegrationTest.php, line 947
Class
- IntegrationTest
- Tests the overall functionality of the Facets admin UI.
Namespace
Drupal\Tests\facets\FunctionalCode
protected function addFacet($facet_name, $facet_type = 'type', $source_id = 'search_api:views_page__search_api_test_view__page_1') {
$facet_id = $this
->convertNameToMachineName($facet_name);
// Go to the Add facet page and make sure that returns a 200.
$facet_add_page = '/admin/config/search/facets/add-facet';
$this
->drupalGet($facet_add_page);
$this
->assertSession()
->statusCodeEquals(200);
$form_values = [
'name' => '',
'id' => $facet_id,
];
// Try filling out the form, but without having filled in a name for the
// facet to test for form errors.
$this
->drupalPostForm($facet_add_page, $form_values, 'Save');
$this
->assertSession()
->pageTextContains('Name field is required.');
$this
->assertSession()
->pageTextContains('Facet source field is required.');
// Make sure that when filling out the name, the form error disappears.
$form_values['name'] = $facet_name;
$this
->drupalPostForm(NULL, $form_values, 'Save');
$this
->assertSession()
->pageTextNotContains('Name field is required.');
// Configure the facet source by selecting one of the Search API views.
$this
->drupalGet($facet_add_page);
$this
->drupalPostForm(NULL, [
'facet_source_id' => '' . $source_id . '',
], 'Configure facet source');
// The field is still required.
$this
->drupalPostForm(NULL, $form_values, 'Save');
$this
->assertSession()
->pageTextContains('Field field is required.');
// Fill in all fields and make sure the 'field is required' message is no
// longer shown.
$facet_source_form = [
'facet_source_id' => $source_id,
'facet_source_configs[' . $source_id . '][field_identifier]' => $facet_type,
];
$this
->drupalPostForm(NULL, $form_values + $facet_source_form, 'Save');
$this
->assertSession()
->pageTextNotContains('field is required.');
// Make sure that the redirection to the display page is correct.
$this
->assertSession()
->pageTextContains('Facet ' . $facet_name . ' has been created.');
$this
->assertSession()
->addressEquals('admin/config/search/facets/' . $facet_id . '/edit');
$this
->drupalGet('admin/config/search/facets');
}