diff --git a/core/config/schema/core.data_types.schema.yml b/core/config/schema/core.data_types.schema.yml index e7883bbab329a7799047cd185bda8eaaf42904d8..2b86cd7e771f7f580916c41874e3ef7b51327d4b 100644 --- a/core/config/schema/core.data_types.schema.yml +++ b/core/config/schema/core.data_types.schema.yml @@ -253,3 +253,42 @@ config_entity: dependencies: type: config_dependencies label: 'Dependencies' + +block_settings: + type: mapping + label: 'Block settings' + mapping: + id: + type: string + label: 'ID' + label: + type: label + label: 'Description' + label_display: + type: string + label: 'Display title' + cache: + type: mapping + label: 'Cache settings' + mapping: + max_age: + type: integer + label: 'Maximum age' + contexts: + type: sequence + label: 'Vary by context' + sequence: + - type: string + label: 'Context' + status: + type: boolean + label: 'Status' + info: + type: label + label: 'Admin info' + view_mode: + type: string + label: 'View mode' + provider: + type: string + label: 'Provider' diff --git a/core/modules/aggregator/config/schema/aggregator.schema.yml b/core/modules/aggregator/config/schema/aggregator.schema.yml index d4a93c59bf529cbb70ff3f18a480dfcb36cd9bf9..db7c93a65f5124afe5a55186983430d51c2d3df6 100644 --- a/core/modules/aggregator/config/schema/aggregator.schema.yml +++ b/core/modules/aggregator/config/schema/aggregator.schema.yml @@ -36,3 +36,14 @@ aggregator.settings: list_max: type: integer label: 'Number of items shown in listing pages' + +block.settings.aggregator_feed_block: + type: block_settings + label: 'Aggregator feed block' + mapping: + block_count: + type: integer + label: 'Block count' + feed: + type: string + label: 'Feed' diff --git a/core/modules/block/config/schema/block.schema.yml b/core/modules/block/config/schema/block.schema.yml index 7f4ad9e30e0f9e9c58d1cf42c3fb3f5ecd547828..9e4508b4c559c9b712567fa4f9279d9bb762223d 100644 --- a/core/modules/block/config/schema/block.schema.yml +++ b/core/modules/block/config/schema/block.schema.yml @@ -54,37 +54,7 @@ block.block.*: type: string label: 'Plugin' settings: - type: mapping - label: 'Block settings' - mapping: - label: - type: label - label: 'Description' - label_display: - type: string - label: 'Display title' - cache: - type: mapping - label: 'Cache settings' - mapping: - max_age: - type: integer - label: 'Maximum age' - contexts: - type: sequence - label: 'Vary by context' - sequence: - - type: string - label: 'Context' - status: - type: boolean - label: 'Status' - info: - type: label - label: 'Admin info' - view_mode: - type: string - label: 'View mode' - provider: - type: string - label: 'Provider' + type: block.settings.[%parent.plugin] + +block.settings.*: + type: block_settings diff --git a/core/modules/block/src/Tests/BlockConfigSchemaTest.php b/core/modules/block/src/Tests/BlockConfigSchemaTest.php new file mode 100644 index 0000000000000000000000000000000000000000..54d20de4fc0d572c28bfae0858c8713a97f89fd7 --- /dev/null +++ b/core/modules/block/src/Tests/BlockConfigSchemaTest.php @@ -0,0 +1,86 @@ +<?php + +/** + * @file + * Contains \Drupal\block\Tests\BlockConfigSchemaTest. + */ + +namespace Drupal\block\Tests; + +use Drupal\block\Entity\Block; +use Drupal\config\Tests\ConfigSchemaTestBase; + +/** + * Tests the block config schema. + */ +class BlockConfigSchemaTest extends ConfigSchemaTestBase { + + /** + * {@inheritdoc} + */ + public static $modules = array('block', 'aggregator', 'book', 'custom_block', 'forum', 'statistics'); + + /** + * The typed config manager. + * + * @var \Drupal\Core\Config\TypedConfigManagerInterface + */ + protected $typedConfig; + + /** + * The block manager. + * + * @var \Drupal\block\BlockManagerInterface + */ + protected $blockManager; + + /** + * {@inheritdoc} + */ + public static function getInfo() { + return array( + 'name' => 'Block config schema', + 'description' => '', + 'group' => 'Block', + ); + } + + /** + * {@inheritdoc} + */ + protected function setUp() { + parent::setUp(); + + $this->typedConfig = \Drupal::service('config.typed'); + $this->blockManager = \Drupal::service('plugin.manager.block'); + } + + /** + * Tests the block config schema for block plugins. + */ + public function testBlockConfigSchema() { + foreach ($this->blockManager->getDefinitions() as $block_id => $definition) { + $id = strtolower($this->randomName()); + $block = Block::create(array( + 'id' => $id, + 'theme' => 'stark', + 'weight' => 00, + 'status' => TRUE, + 'region' => 'content', + 'plugin' => $block_id, + 'settings' => array( + 'label' => $this->randomName(), + 'provider' => 'system', + 'label_display' => FALSE, + ), + 'visibility' => array(), + )); + $block->save(); + + $config = \Drupal::config("block.block.$id"); + $this->assertEqual($config->get('id'), $id); + $this->assertConfigSchema($this->typedConfig, $config->getName(), $config->get()); + } + } + +} diff --git a/core/modules/book/config/schema/book.schema.yml b/core/modules/book/config/schema/book.schema.yml index ea8bd3345924e7877ee2cfd2afe1b44a9de0a036..20d18bcbfaadc912e2c3cbbe4173bc3442b51d69 100644 --- a/core/modules/book/config/schema/book.schema.yml +++ b/core/modules/book/config/schema/book.schema.yml @@ -24,3 +24,11 @@ book.settings: child_type: type: string label: 'Content type for child pages' + +block.settings.book_navigation: + type: block_settings + label: 'Book navigation block' + mapping: + block_mode: + type: string + label: 'Block display mode' diff --git a/core/modules/forum/config/schema/forum.schema.yml b/core/modules/forum/config/schema/forum.schema.yml index 9ca1ed80c787f3e3caa50a6f8d1b3fe4ba305c68..f74587cb1ca02ae42e4cd07d39223b9cba14b803 100644 --- a/core/modules/forum/config/schema/forum.schema.yml +++ b/core/modules/forum/config/schema/forum.schema.yml @@ -38,3 +38,29 @@ forum.settings: vocabulary: type: string label: 'Forum vocabulary ID' + +block.settings.forum_active_block: + type: block_settings + label: 'Active forum topics block' + mapping: + properties: + type: sequence + label: 'Properties' + sequence: + - type: string + block_count: + type: integer + label: 'Block count' + +block.settings.forum_new_block: + type: block_settings + label: 'New forum topics block' + mapping: + properties: + type: sequence + label: 'Properties' + sequence: + - type: string + block_count: + type: integer + label: 'Block count' diff --git a/core/modules/node/config/schema/node.schema.yml b/core/modules/node/config/schema/node.schema.yml index 446e373e0da8836d7bf3d0befcc42f6648feced7..4e8a55cbf138f2e40c4372c469d1000aef96ecad 100644 --- a/core/modules/node/config/schema/node.schema.yml +++ b/core/modules/node/config/schema/node.schema.yml @@ -129,3 +129,11 @@ action.configuration.node_unpublish_by_keyword_action: sequence: - type: sequence label: 'Keyword' + +block.settings.node_syndicate_block: + type: block_settings + label: 'Syndicate block' + mapping: + block_count: + type: integer + label: 'Block count' diff --git a/core/modules/system/config/schema/system.schema.yml b/core/modules/system/config/schema/system.schema.yml index 6ce1be7e7e8d439a951e5c4d84cc7d7310ff6f6e..9ed58a297ab705f4c144bf1f669669de64313e17 100644 --- a/core/modules/system/config/schema/system.schema.yml +++ b/core/modules/system/config/schema/system.schema.yml @@ -338,3 +338,17 @@ system.mail: system.theme.global: type: theme_settings label: 'Theme global settings' + +block.settings.system_branding_block: + type: block_settings + label: 'Branding block' + mapping: + use_site_logo: + type: boolean + label: 'Use site logo' + use_site_name: + type: boolean + label: 'Use site name' + use_site_slogan: + type: boolean + label: 'Use site slogan'