From a3064d2020d442266b3bcdf70029775a72f67dae Mon Sep 17 00:00:00 2001
From: webchick <webchick@24967.no-reply.drupal.org>
Date: Tue, 5 Mar 2013 10:06:58 -0500
Subject: [PATCH] =?UTF-8?q?Issue=20#1929136=20by=20G=C3=A1bor=20Hojtsy,=20?=
 =?UTF-8?q?alexpott,=20YesCT:=20Fixed=20override-free=20context,=20move=20?=
 =?UTF-8?q?global=20config=20overrides=20back=20to=20an=20event=20listener?=
 =?UTF-8?q?.?=
MIME-Version: 1.0
Content-Type: text/plain; charset=UTF-8
Content-Transfer-Encoding: 8bit

---
 core/lib/Drupal/Core/Config/Config.php        | 16 +---
 core/lib/Drupal/Core/Config/ConfigFactory.php |  3 +-
 .../Core/Config/Context/ConfigContext.php     | 57 ++++++-----
 .../Core/Config/Context/ContextInterface.php  | 33 +++++--
 .../Core/Config/Context/FreeConfigContext.php | 30 ++++++
 .../Config/Context/GlobalConfigContext.php    | 29 ------
 core/lib/Drupal/Core/CoreBundle.php           |  9 +-
 .../ConfigGlobalOverrideSubscriber.php        | 42 ++++++++
 .../ConfigOverrideSubscriber.php              | 41 --------
 .../config/Tests/ConfigLocaleOverride.php     | 96 ++++++++++++++++---
 .../config/Tests/ConfigOverrideTest.php       | 47 +++------
 .../lib/Drupal/user/UserConfigContext.php     | 12 +--
 12 files changed, 236 insertions(+), 179 deletions(-)
 create mode 100644 core/lib/Drupal/Core/Config/Context/FreeConfigContext.php
 delete mode 100644 core/lib/Drupal/Core/Config/Context/GlobalConfigContext.php
 create mode 100644 core/lib/Drupal/Core/EventSubscriber/ConfigGlobalOverrideSubscriber.php
 delete mode 100644 core/lib/Drupal/Core/EventSubscriber/ConfigOverrideSubscriber.php

diff --git a/core/lib/Drupal/Core/Config/Config.php b/core/lib/Drupal/Core/Config/Config.php
index 0337d2873619..c0d2617dc561 100644
--- a/core/lib/Drupal/Core/Config/Config.php
+++ b/core/lib/Drupal/Core/Config/Config.php
@@ -50,14 +50,7 @@ class Config {
   protected $data;
 
   /**
-   * The overridden data of the configuration object.
-   *
-   * @var array
-   */
-  protected $overrides = array();
-
-  /**
-   * The current runtime data ($data + $overrides).
+   * The current runtime data ($data + $overrides from Config Context).
    *
    * @var array
    */
@@ -275,7 +268,7 @@ protected function replaceData(array $data) {
    *   The configuration object.
    */
   public function setOverride(array $data) {
-    $this->overrides = NestedArray::mergeDeepArray(array($this->overrides, $data), TRUE);
+    $this->context->setOverrides($this->getName(), $data);
     $this->resetOverriddenData();
     return $this;
   }
@@ -290,8 +283,9 @@ public function setOverride(array $data) {
    */
   protected function setOverriddenData() {
     $this->overriddenData = $this->data;
-    if (!empty($this->overrides)) {
-      $this->overriddenData = NestedArray::mergeDeepArray(array($this->overriddenData, $this->overrides), TRUE);
+    $overrides = $this->context->getOverrides($this->getName());
+    if (is_array($overrides)) {
+      $this->overriddenData = NestedArray::mergeDeepArray(array($this->overriddenData, $overrides), TRUE);
     }
     return $this;
   }
diff --git a/core/lib/Drupal/Core/Config/ConfigFactory.php b/core/lib/Drupal/Core/Config/ConfigFactory.php
index 4edbeada924c..0cd038267665 100644
--- a/core/lib/Drupal/Core/Config/ConfigFactory.php
+++ b/core/lib/Drupal/Core/Config/ConfigFactory.php
@@ -140,7 +140,8 @@ public function rename($old_name, $new_name) {
    *   The config factory object.
    */
   public function enterContext(ContextInterface $context) {
-    $this->contextStack[] = $context;
+    // Initialize the context as it is being entered.
+    $this->contextStack[] = $context->init();
     return $this;
   }
 
diff --git a/core/lib/Drupal/Core/Config/Context/ConfigContext.php b/core/lib/Drupal/Core/Config/Context/ConfigContext.php
index 9be0f7188a5a..a0ee5957ea8f 100644
--- a/core/lib/Drupal/Core/Config/Context/ConfigContext.php
+++ b/core/lib/Drupal/Core/Config/Context/ConfigContext.php
@@ -9,29 +9,31 @@
 
 use Drupal\Core\Config\Config;
 use Drupal\Core\Config\ConfigEvent;
+use Drupal\Component\Utility\NestedArray;
 use Drupal\Component\Uuid\Uuid;
 use Symfony\Component\EventDispatcher\EventDispatcher;
 
 /**
  * Defines the base configuration context object.
  *
- * A configuration context object provides a data array that can be used:
- *   - as a parameter to get customized configuration objects.
- *   - as a store of config data used to override values.
+ * A configuration context object provides a data array that can be used as
+ * parameters to get customized configuration objects.
  */
 class ConfigContext implements ContextInterface {
 
   /**
-   * Predefined key, values to override specific configuration objects.
+   * The actual storage of key-value pairs.
+   *
+   * @var array
    */
-  const OVERRIDE = 'config.override';
+  protected $data = array();
 
   /**
-   * The actual storage of key-value pairs.
+   * Any config overrides of key-value pairs.
    *
    * @var array
    */
-  protected $data = array();
+  protected $overrides = array();
 
   /**
    * An event dispatcher instance to use for configuration events.
@@ -60,10 +62,7 @@ public function __construct(EventDispatcher $event_dispatcher) {
   /**
    * Implements Drupal\Core\Config\Context\ContextInterface::init().
    */
-  public function init($context_key, $data) {
-    if ($data) {
-      $this->set($context_key, $data);
-    }
+  public function init() {
     $this->setUuid();
     // Notify event listeners that a configuration context has been created.
     $this->notify('context', NULL);
@@ -84,20 +83,6 @@ public function set($key, $value) {
     $this->data[$key] = $value;
   }
 
-  /**
-   * Sets override data.
-   *
-   * @param mixed $data
-   *   Override data to store.
-   *
-   * @return \Drupal\Core\Config\Context\ConfigContext
-   *   The config context object.
-   */
-  public function setOverride($data) {
-    $this->init(self::OVERRIDE, $data);
-    return $this;
-  }
-
   /**
    * Implements Drupal\Core\Config\Context\ContextInterface::setUuid().
    */
@@ -120,4 +105,26 @@ public function notify($config_event_name, Config $config = NULL) {
     $this->eventDispatcher->dispatch('config.' . $config_event_name, new ConfigEvent($this, $config));
   }
 
+  /**
+   * Implements \Drupal\Core\Config\Context\ContextInterface::setOverride().
+   */
+  public function setOverrides($config_name, $data) {
+    if (!isset($this->overrides[$config_name])) {
+      $this->overrides[$config_name] = $data;
+    }
+    else {
+      $this->overrides[$config_name] = NestedArray::mergeDeepArray(array($this->overrides[$config_name], $data), TRUE);
+    }
+  }
+
+  /**
+   * Implements \Drupal\Core\Config\Context\ContextInterface::getOverrides().
+   */
+  public function getOverrides($config_name) {
+    if (isset($this->overrides[$config_name])) {
+      return $this->overrides[$config_name];
+    }
+    return FALSE;
+  }
+
 }
diff --git a/core/lib/Drupal/Core/Config/Context/ContextInterface.php b/core/lib/Drupal/Core/Config/Context/ContextInterface.php
index b3107a7750b1..fae5d2d45fd7 100644
--- a/core/lib/Drupal/Core/Config/Context/ContextInterface.php
+++ b/core/lib/Drupal/Core/Config/Context/ContextInterface.php
@@ -22,21 +22,13 @@
  */
 interface ContextInterface {
 
-  /*
+  /**
    * Initialises a config context for use.
    *
-   * Creates a unique context identifier, adds data and notifies system about
-   * the new context.
-   *
-   * @param string $context_key
-   *   The key that is used to set context data.
-   * @param mixed $data
-   *   The context config data.
-   *
    * @return \Drupal\Core\Config\Context\ConfigContext
    *   The config context object.
    */
-  public function init($context_key, $data);
+  public function init();
 
   /**
    * Returns the stored value for a given key.
@@ -85,4 +77,25 @@ public function getUuid();
    */
   public function notify($config_event_name, Config $config = NULL);
 
+  /**
+   * Sets the override data for a configuration object.
+   *
+   * @param string $config_name
+   *   Configuration name.
+   * @param array data
+   *   The override data.
+   */
+  public function setOverrides($config_name, $data);
+
+  /**
+   * Gets the override data for a configuration object.
+   *
+   * @param string $config_name
+   *   Configuration name.
+   *
+   * @return mixed
+   *   The override data or FALSE if there is none.
+   */
+  public function getOverrides($config_name);
+
 }
diff --git a/core/lib/Drupal/Core/Config/Context/FreeConfigContext.php b/core/lib/Drupal/Core/Config/Context/FreeConfigContext.php
new file mode 100644
index 000000000000..4307f972ea2f
--- /dev/null
+++ b/core/lib/Drupal/Core/Config/Context/FreeConfigContext.php
@@ -0,0 +1,30 @@
+<?php
+
+/**
+ * @file
+ * Contains \Drupal\Core\Config\Context\FreeConfigContext.
+ */
+
+namespace Drupal\Core\Config\Context;
+
+/**
+ * Defines the override-free configuration context object.
+ */
+class FreeConfigContext extends ConfigContext {
+
+  /**
+   * Implements \Drupal\Core\Config\Context\ContextInterface::getOverrides().
+   */
+  public function getOverrides($config_name) {
+    // Do nothing as this is override free.
+    return FALSE;
+  }
+
+  /**
+   * Implements \Drupal\Core\Config\Context\ContextInterface::setOverride().
+   */
+  public function setOverrides($config_name, $data) {
+    // Do nothing as this is override free.
+  }
+
+}
diff --git a/core/lib/Drupal/Core/Config/Context/GlobalConfigContext.php b/core/lib/Drupal/Core/Config/Context/GlobalConfigContext.php
deleted file mode 100644
index 9e8fa1e1fae7..000000000000
--- a/core/lib/Drupal/Core/Config/Context/GlobalConfigContext.php
+++ /dev/null
@@ -1,29 +0,0 @@
-<?php
-
-/**
- * @file
- * Contains \Drupal\Core\Config\Context\GlobalConfigContext.
- */
-
-namespace Drupal\Core\Config\Context;
-
-/**
- * Defines the global configuration context object.
- *
- * The global configuration context allows config object data to be overridden
- * with values from the $conf global.
- */
-class GlobalConfigContext extends ConfigContext {
-
-  /**
-   * Sets global override data.
-   *
-   * @return \Drupal\Core\Config\Context\ConfigContext
-   *   The config context object.
-   */
-  public function setGlobalOverride() {
-    global $conf;
-    $this->init(self::OVERRIDE, $conf);
-    return $this;
-  }
-}
diff --git a/core/lib/Drupal/Core/CoreBundle.php b/core/lib/Drupal/Core/CoreBundle.php
index 2968e7a0ae1f..871b859a47ed 100644
--- a/core/lib/Drupal/Core/CoreBundle.php
+++ b/core/lib/Drupal/Core/CoreBundle.php
@@ -58,15 +58,14 @@ public function build(ContainerBuilder $container) {
     $container->register('config.context', 'Drupal\Core\Config\Context\ContextInterface')
       ->setFactoryService(new Reference('config.context.factory'))
       ->setFactoryMethod('get')
-      ->addArgument('Drupal\Core\Config\Context\GlobalConfigContext')
-      ->addTag('persist')
-      ->addMethodCall('setGlobalOverride');
+      ->addTag('persist');
 
     // Register a config context with no overrides for use in administration
     // forms, enabling modules and importing configuration.
     $container->register('config.context.free', 'Drupal\Core\Config\Context\ContextInterface')
       ->setFactoryService(new Reference('config.context.factory'))
-      ->setFactoryMethod('get');
+      ->setFactoryMethod('get')
+      ->addArgument('Drupal\Core\Config\Context\FreeConfigContext');
 
     $container->register('config.factory', 'Drupal\Core\Config\ConfigFactory')
       ->addArgument(new Reference('config.storage'))
@@ -280,7 +279,7 @@ public function build(ContainerBuilder $container) {
     $container->register('request_close_subscriber', 'Drupal\Core\EventSubscriber\RequestCloseSubscriber')
       ->addArgument(new Reference('module_handler'))
       ->addTag('event_subscriber');
-    $container->register('config_global_override_subscriber', 'Drupal\Core\EventSubscriber\ConfigOverrideSubscriber')
+    $container->register('config_global_override_subscriber', 'Drupal\Core\EventSubscriber\ConfigGlobalOverrideSubscriber')
       ->addTag('event_subscriber');
     $container->register('language_request_subscriber', 'Drupal\Core\EventSubscriber\LanguageRequestSubscriber')
       ->addArgument(new Reference('language_manager'))
diff --git a/core/lib/Drupal/Core/EventSubscriber/ConfigGlobalOverrideSubscriber.php b/core/lib/Drupal/Core/EventSubscriber/ConfigGlobalOverrideSubscriber.php
new file mode 100644
index 000000000000..02bf2cbfad78
--- /dev/null
+++ b/core/lib/Drupal/Core/EventSubscriber/ConfigGlobalOverrideSubscriber.php
@@ -0,0 +1,42 @@
+<?php
+
+/**
+ * @file
+ * Contains \Drupal\Core\EventSubscriber\ConfigGlobalOverrideSubscriber.
+ */
+
+namespace Drupal\Core\EventSubscriber;
+
+use Drupal\Core\Config\Config;
+use Drupal\Core\Config\ConfigEvent;
+use Symfony\Component\EventDispatcher\EventSubscriberInterface;
+
+/**
+ * Defines a configuration global override for contexts.
+ */
+class ConfigGlobalOverrideSubscriber implements EventSubscriberInterface {
+
+  /**
+   * Overrides configuration values with values in global $conf variable.
+   *
+   * @param \Drupal\Core\Config\ConfigEvent $event
+   *   The Event to process.
+   */
+  public function configInit(ConfigEvent $event) {
+    global $conf;
+
+    $config = $event->getConfig();
+    if (isset($conf[$config->getName()])) {
+      $config->setOverride($conf[$config->getName()]);
+    }
+  }
+
+  /**
+   * Implements EventSubscriberInterface::getSubscribedEvents().
+   */
+  static function getSubscribedEvents() {
+    $events['config.init'][] = array('configInit', 30);
+    return $events;
+  }
+
+}
diff --git a/core/lib/Drupal/Core/EventSubscriber/ConfigOverrideSubscriber.php b/core/lib/Drupal/Core/EventSubscriber/ConfigOverrideSubscriber.php
deleted file mode 100644
index 376da1085124..000000000000
--- a/core/lib/Drupal/Core/EventSubscriber/ConfigOverrideSubscriber.php
+++ /dev/null
@@ -1,41 +0,0 @@
-<?php
-/**
- * @file
- * Contains \Drupal\Core\EventSubscriber\ConfigOverrideSubscriber.
- */
-
-namespace Drupal\Core\EventSubscriber;
-
-use Drupal\Core\Config\Config;
-use Drupal\Core\Config\ConfigEvent;
-use Drupal\Core\Config\Context\ConfigContext;
-use Symfony\Component\EventDispatcher\EventSubscriberInterface;
-
-/**
- * Override configuration values with predefined values in context.
- */
-class ConfigOverrideSubscriber implements EventSubscriberInterface {
-
-  /**
-   * Overrides configuration values.
-   *
-   * @param \Drupal\Core\Config\ConfigEvent $event
-   *   The Event to process.
-   */
-  public function configInit(ConfigEvent $event) {
-    if ($override = $event->getContext()->get(ConfigContext::OVERRIDE)) {
-      $config = $event->getConfig();
-      if (isset($override[$config->getName()])) {
-        $config->setOverride($override[$config->getName()]);
-      }
-    }
-  }
-
-  /**
-   * Implements EventSubscriberInterface::getSubscribedEvents().
-   */
-  public static function getSubscribedEvents() {
-    $events['config.init'][] = array('configInit', 30);
-    return $events;
-  }
-}
diff --git a/core/modules/config/lib/Drupal/config/Tests/ConfigLocaleOverride.php b/core/modules/config/lib/Drupal/config/Tests/ConfigLocaleOverride.php
index 78253d3c67ad..5788b36ded17 100644
--- a/core/modules/config/lib/Drupal/config/Tests/ConfigLocaleOverride.php
+++ b/core/modules/config/lib/Drupal/config/Tests/ConfigLocaleOverride.php
@@ -36,7 +36,7 @@ public function setUp() {
     config_install_default_config('module', 'config_test');
   }
 
-  /*
+  /**
    * Tests basic locale override.
    */
   function testConfigLocaleOverride() {
@@ -44,19 +44,22 @@ function testConfigLocaleOverride() {
     // The default language is en so the config key should be localised.
     $config = config($name);
     $this->assertIdentical($config->get('foo'), 'en bar');
+    $this->assertIdentical($config->get('404'), 'herp');
 
-    // Ensure that we get the expected value when we use system_config.
+    // Ensure that we get the expected value when we avoid overrides.
     config_context_enter('config.context.free');
-    $config_admin = config('config_test.system');
+    $config_admin = config($name);
     $this->assertIdentical($config_admin->get('foo'), 'bar');
+    $this->assertIdentical($config_admin->get('404'), 'herp');
 
     // Leave the non override context.
     config_context_leave();
     $config = config($name);
     $this->assertIdentical($config->get('foo'), 'en bar');
+    $this->assertIdentical($config->get('404'), 'herp');
   }
 
-  /*
+  /**
    * Tests locale override based on user's preferred language.
    */
   function testConfigLocaleUserOverride() {
@@ -83,15 +86,19 @@ function testConfigLocaleUserOverride() {
       'status' => 1,
       'preferred_langcode' => 'fr',
     ));
-    $config_factory = drupal_container()->get('config.factory');
 
-    $user_config_context = config_context_enter("Drupal\\user\\UserConfigContext");
+    $user_config_context = config_context_enter('Drupal\user\UserConfigContext');
     $user_config_context->setAccount($account);
     $config = config('config_test.system');
     $this->assertIdentical($config->get('foo'), 'fr bar');
+    // Ensure the non-overriden value is still the same.
+    $this->assertIdentical($config->get('404'), 'herp');
 
-    // Ensure that we get the expected value when we leave the user context.
-    $config_factory->leaveContext();
+    // Ensure that we get the expected value when we leave the user context. The
+    // locale overrides contain an English override too, so although we are not
+    // in a user based language override context, the English language override
+    // applies due to the negotiated language for the page.
+    config_context_leave();
     $config = config('config_test.system');
     $this->assertIdentical($config->get('foo'), 'en bar');
 
@@ -103,6 +110,7 @@ function testConfigLocaleUserOverride() {
       'preferred_langcode' => 'de',
     ));
 
+    $config_factory = drupal_container()->get('config.factory');
     $config_factory->enterContext($user_config_context->setAccount($account));
     // Should not have to re-initialise config object to get new overrides as
     // the new context will have a different uuid.
@@ -118,30 +126,92 @@ function testConfigLocaleUserOverride() {
       'preferred_langcode' => 'en',
     ));
     // Create a new user config context to stack on top of the existign one.
-    $en_user_config_context = config_context_enter("Drupal\\user\\UserConfigContext");
+    $en_user_config_context = config_context_enter('Drupal\user\UserConfigContext');
     $en_user_config_context->setAccount($account);
     $config = config('config_test.system');
     $this->assertIdentical($config->get('foo'), 'en bar');
 
     // Ensure that we get the expected value when we leave the english user
     // context.
-    $config_factory->leaveContext();
+    config_context_leave();
     $config = config('config_test.system');
     $this->assertIdentical($config->get('foo'), 'de bar');
 
     // Ensure that we get the expected value when we leave the german user
     // context.
-    $config_factory->leaveContext();
+    config_context_leave();
     $config = config('config_test.system');
     $this->assertIdentical($config->get('foo'), 'en bar');
 
     // Ensure that we cannot leave the default context.
-    $config_factory->leaveContext();
+    config_context_leave();
     $config = config('config_test.system');
     $this->assertIdentical($config->get('foo'), 'en bar');
   }
 
-  /*
+  /**
+   * Tests locale override in combination with global overrides.
+   */
+  function testConfigLocaleUserAndGlobalOverride() {
+    global $conf;
+
+    // Globally override value for the keys in config_test.system. Although we
+    // override the foo key, there are also language overrides, which trump
+    // global overrides so the 'foo' key override will never surface.
+    $conf['config_test.system']['foo'] = 'global bar';
+    $conf['config_test.system']['404'] = 'global herp';
+
+    $this->installSchema('system', 'variable');
+    $this->installSchema('language', 'language');
+    language_save(new Language(array(
+      'name' => 'French',
+      'langcode' => 'fr',
+    )));
+
+    $this->installSchema('user', 'users');
+    $account = entity_create('user', array(
+      'name' => 'French user',
+      'mail' => 'test@example.com',
+      'created' => REQUEST_TIME,
+      'status' => 1,
+      'preferred_langcode' => 'fr',
+    ));
+
+    $user_config_context = config_context_enter('Drupal\user\UserConfigContext');
+    $user_config_context->setAccount($account);
+    $config = config('config_test.system');
+    $this->assertIdentical($config->get('foo'), 'fr bar');
+    // Ensure the value overriden from global $conf works.
+    $this->assertIdentical($config->get('404'), 'global herp');
+
+    // Ensure that we get the expected value when we leave the user context. The
+    // locale overrides contain an English override too, so although we are not
+    // in a user based language override context, the English language override
+    // applies due to the negotiated language for the page.
+    config_context_leave();
+    $config = config('config_test.system');
+    $this->assertIdentical($config->get('foo'), 'en bar');
+    // Global override should still apply.
+    $this->assertIdentical($config->get('404'), 'global herp');
+
+    // Ensure that we cannot leave the default context.
+    config_context_leave();
+    $config = config('config_test.system');
+    $this->assertIdentical($config->get('foo'), 'en bar');
+    // Global override should still apply.
+    $this->assertIdentical($config->get('404'), 'global herp');
+
+    // Ensure that we get the expected value when we avoid overrides.
+    config_context_enter('config.context.free');
+    $config_admin = config('config_test.system');
+    // Language override should not apply anymore.
+    $this->assertIdentical($config_admin->get('foo'), 'bar');
+    // Global override should not apply.
+    $this->assertIdentical($config_admin->get('404'), 'herp');
+    config_context_leave();
+  }
+
+  /**
    * Tests config_context_enter() invalid context name handling.
    */
   function testInvalidContextName() {
diff --git a/core/modules/config/lib/Drupal/config/Tests/ConfigOverrideTest.php b/core/modules/config/lib/Drupal/config/Tests/ConfigOverrideTest.php
index 2fdf1222ef5e..6dfcf4edef92 100644
--- a/core/modules/config/lib/Drupal/config/Tests/ConfigOverrideTest.php
+++ b/core/modules/config/lib/Drupal/config/Tests/ConfigOverrideTest.php
@@ -51,7 +51,6 @@ function testConfOverride() {
     $conf['config_test.system']['foo'] = 'overridden';
     $conf['config_test.system']['baz'] = 'injected';
     $conf['config_test.system']['404'] = 'derp';
-    drupal_container()->get('config.context')->setGlobalOverride();
 
     config_install_default_config('module', 'config_test');
 
@@ -63,31 +62,17 @@ function testConfOverride() {
     $this->assertFalse(isset($data['baz']));
     $this->assertIdentical($data['404'], $expected_original_data['404']);
 
-    // Remove the $conf overrides and reset value in config.context service.
-    unset($conf['config_test.system']);
-    drupal_container()->get('config.context')->setGlobalOverride();
-
-    // Verify that the original configuration data exists.
+    // Enter an override-free context to ensure the original data remains.
+    config_context_enter('config.context.free');
     $config = config('config_test.system');
     $this->assertIdentical($config->get('foo'), $expected_original_data['foo']);
     $this->assertIdentical($config->get('baz'), $expected_original_data['baz']);
     $this->assertIdentical($config->get('404'), $expected_original_data['404']);
+    config_context_leave();
 
-    // Apply the overridden data, that needs to be set into the config.context
-    // service.
-    $conf['config_test.system']['foo'] = 'overridden';
-    $conf['config_test.system']['baz'] = 'injected';
-    $conf['config_test.system']['404'] = 'derp';
-    drupal_container()->get('config.context')->setGlobalOverride();
-
-    // Verify that the in-memory configuration object still contains the
-    // original data.
-    $this->assertIdentical($config->get('foo'), $expected_original_data['foo']);
-    $this->assertIdentical($config->get('baz'), $expected_original_data['baz']);
-    $this->assertIdentical($config->get('404'), $expected_original_data['404']);
-
-    // Reload the configuration object.
-    $config->init();
+    // Get the configuration object in an overriden context (the one set by
+    // default).
+    $config = config('config_test.system');
 
     // Verify that it contains the overridden data from $conf.
     $this->assertIdentical($config->get('foo'), $conf['config_test.system']['foo']);
@@ -116,24 +101,15 @@ function testConfOverride() {
     $this->assertIdentical($config->get('baz'), $conf['config_test.system']['baz']);
     $this->assertIdentical($config->get('404'), $conf['config_test.system']['404']);
 
-    // Remove the $conf overrides and reset value in config.context service.
-    unset($conf['config_test.system']);
-    drupal_container()->get('config.context')->setGlobalOverride();
-
-    // Reload it and verify that it still contains the original data.
-    $config->init();
+    // Enter an override-free context to ensure the original data remains saved.
+    config_context_enter('config.context.free');
+    $config = config('config_test.system');
     $this->assertIdentical($config->get('foo'), $expected_original_data['foo']);
     $this->assertIdentical($config->get('baz'), $expected_original_data['baz']);
     $this->assertIdentical($config->get('404'), $expected_original_data['404']);
+    config_context_leave();
 
-    // Set globals before importing to prove that the imported file does not
-    // contain these values.
-    $conf['config_test.system']['foo'] = 'overridden';
-    $conf['config_test.system']['baz'] = 'injected';
-    $conf['config_test.system']['404'] = 'derp';
-
-    // Write file to staging
-    drupal_container()->get('config.context')->setGlobalOverride();
+    // Write file to staging.
     $staging = $this->container->get('config.storage.staging');
     $expected_new_data = array(
       'foo' => 'barbar',
@@ -152,6 +128,7 @@ function testConfOverride() {
     $this->assertIdentical($data['404'], $expected_new_data['404']);
 
     // Verifiy the overrides are still working.
+    $config = config('config_test.system');
     $this->assertIdentical($config->get('foo'), $conf['config_test.system']['foo']);
     $this->assertIdentical($config->get('baz'), $conf['config_test.system']['baz']);
     $this->assertIdentical($config->get('404'), $conf['config_test.system']['404']);
diff --git a/core/modules/user/lib/Drupal/user/UserConfigContext.php b/core/modules/user/lib/Drupal/user/UserConfigContext.php
index d6e411449762..917787dde286 100644
--- a/core/modules/user/lib/Drupal/user/UserConfigContext.php
+++ b/core/modules/user/lib/Drupal/user/UserConfigContext.php
@@ -26,14 +26,6 @@ class UserConfigContext extends ConfigContext {
    */
   const USER_KEY = 'user.account';
 
-  /**
-   * Implements \Drupal\Core\Config\Context\ContextInterface::setUuid().
-   */
-  public function setUuid() {
-    // Use the user's uuid to identify the config context.
-    $this->uuid = $this->get(self::USER_KEY)->uuid();
-  }
-
   /*
    * Helper function to create config context for user accounts.
    *
@@ -44,7 +36,9 @@ public function setUuid() {
    *   The user config context object.
    */
   public function setAccount(User $account) {
-    $this->init(self::USER_KEY, $account);
+    $this->set(self::USER_KEY, $account);
+    // Re-initialize since the user change changes the context fundamentally.
+    $this->init();
     return $this;
   }
 
-- 
GitLab