You are here

NodeImportCreateTest.php in Zircon Profile 8.0

Same filename and directory in other branches
  1. 8 core/modules/node/src/Tests/Config/NodeImportCreateTest.php

File

core/modules/node/src/Tests/Config/NodeImportCreateTest.php
View source
<?php

/**
 * @file
 * Contains \Drupal\node\Tests\Config\NodeImportCreateTest.
 */
namespace Drupal\node\Tests\Config;

use Drupal\field\Entity\FieldConfig;
use Drupal\node\Entity\NodeType;
use Drupal\simpletest\KernelTestBase;

/**
 * Create content types during config create method invocation.
 *
 * @group node
 */
class NodeImportCreateTest extends KernelTestBase {

  /**
   * Modules to enable.
   *
   * @var array
   */
  public static $modules = array(
    'node',
    'field',
    'text',
    'system',
    'user',
  );

  /**
   * Set the default field storage backend for fields created during tests.
   */
  protected function setUp() {
    parent::setUp();
    $this
      ->installEntitySchema('user');

    // Set default storage backend.
    $this
      ->installConfig(array(
      'field',
    ));
  }

  /**
   * Tests creating a content type during default config import.
   */
  public function testImportCreateDefault() {
    $node_type_id = 'default';

    // Check that the content type does not exist yet.
    $this
      ->assertFalse(NodeType::load($node_type_id));

    // Enable node_test_config module and check that the content type
    // shipped in the module's default config is created.
    $this->container
      ->get('module_installer')
      ->install(array(
      'node_test_config',
    ));
    $node_type = NodeType::load($node_type_id);
    $this
      ->assertTrue($node_type, 'The default content type was created.');
  }

  /**
   * Tests creating a content type during config import.
   */
  public function testImportCreate() {
    $node_type_id = 'import';
    $node_type_config_name = "node.type.{$node_type_id}";

    // Simulate config data to import.
    $active = $this->container
      ->get('config.storage');
    $sync = $this->container
      ->get('config.storage.sync');
    $this
      ->copyConfig($active, $sync);

    // Manually add new node type.
    $src_dir = drupal_get_path('module', 'node_test_config') . '/sync';
    $target_dir = $this->configDirectories[CONFIG_SYNC_DIRECTORY];
    $this
      ->assertTrue(file_unmanaged_copy("{$src_dir}/{$node_type_config_name}.yml", "{$target_dir}/{$node_type_config_name}.yml"));

    // Import the content of the sync directory.
    $this
      ->configImporter()
      ->import();

    // Check that the content type was created.
    $node_type = NodeType::load($node_type_id);
    $this
      ->assertTrue($node_type, 'Import node type from sync was created.');
    $this
      ->assertFalse(FieldConfig::loadByName('node', $node_type_id, 'body'));
  }

}

Classes

Namesort descending Description
NodeImportCreateTest Create content types during config create method invocation.