普通文本  |  136行  |  4.49 KB

// Copyright (c) 2011 The Chromium Authors. All rights reserved.
// Use of this source code is governed by a BSD-style license that can be
// found in the LICENSE file.

#include "chrome/browser/policy/asynchronous_policy_loader.h"
#include "chrome/browser/policy/asynchronous_policy_provider.h"
#include "chrome/browser/policy/asynchronous_policy_test_base.h"
#include "chrome/browser/policy/mock_configuration_policy_provider.h"
#include "chrome/browser/policy/mock_configuration_policy_store.h"
#include "testing/gmock/include/gmock/gmock.h"

using ::testing::_;
using ::testing::InSequence;
using ::testing::Return;

namespace policy {

class MockConfigurationPolicyObserver
    : public ConfigurationPolicyProvider::Observer {
 public:
  MOCK_METHOD0(OnUpdatePolicy, void());
  void OnProviderGoingAway() {}
};

class AsynchronousPolicyLoaderTest : public AsynchronousPolicyTestBase {
 public:
  AsynchronousPolicyLoaderTest() {}
  virtual ~AsynchronousPolicyLoaderTest() {}

  virtual void SetUp() {
    AsynchronousPolicyTestBase::SetUp();
    mock_provider_.reset(new MockConfigurationPolicyProvider());
  }

 protected:
  scoped_ptr<MockConfigurationPolicyProvider> mock_provider_;

 private:
  DISALLOW_COPY_AND_ASSIGN(AsynchronousPolicyLoaderTest);
};

ACTION(CreateTestDictionary) {
  return new DictionaryValue();
}

ACTION_P(CreateSequencedTestDictionary, number) {
  DictionaryValue* test_dictionary = new DictionaryValue();
  test_dictionary->SetInteger("id", ++(*number));
  return test_dictionary;
}

ACTION(RescheduleImmediatePolicyReload) {
  *arg1 = base::TimeDelta();
  return false;
}

TEST_F(AsynchronousPolicyLoaderTest, InitialLoad) {
  DictionaryValue* template_dict(new DictionaryValue());
  EXPECT_CALL(*delegate_, Load()).WillOnce(Return(template_dict));
  scoped_refptr<AsynchronousPolicyLoader> loader =
      new AsynchronousPolicyLoader(delegate_.release(), 10);
  loader->Init();
  const DictionaryValue* loaded_dict(loader->policy());
  EXPECT_TRUE(loaded_dict->Equals(template_dict));
}

// Verify that the fallback policy requests are made.
TEST_F(AsynchronousPolicyLoaderTest, InitialLoadWithFallback) {
  int dictionary_number = 0;
  InSequence s;
  EXPECT_CALL(*delegate_, Load()).WillOnce(
      CreateSequencedTestDictionary(&dictionary_number));
  EXPECT_CALL(*delegate_, Load()).WillOnce(
      CreateSequencedTestDictionary(&dictionary_number));
  scoped_refptr<AsynchronousPolicyLoader> loader =
      new AsynchronousPolicyLoader(delegate_.release(), 10);
  loader->Init();
  loop_.RunAllPending();
  loader->Reload();
  loop_.RunAllPending();

  const DictionaryValue* loaded_dict(loader->policy());
  int loaded_number;
  EXPECT_TRUE(loaded_dict->GetInteger("id", &loaded_number));
  EXPECT_EQ(dictionary_number, loaded_number);
}

// Ensure that calling stop on the loader stops subsequent reloads from
// happening.
TEST_F(AsynchronousPolicyLoaderTest, Stop) {
  ON_CALL(*delegate_, Load()).WillByDefault(CreateTestDictionary());
  EXPECT_CALL(*delegate_, Load()).Times(1);
  scoped_refptr<AsynchronousPolicyLoader> loader =
      new AsynchronousPolicyLoader(delegate_.release(), 10);
  loader->Init();
  loop_.RunAllPending();
  loader->Stop();
  loop_.RunAllPending();
  loader->Reload();
  loop_.RunAllPending();
}

// Verifies that the provider is notified upon policy reload, but only
// if the policy changed.
TEST_F(AsynchronousPolicyLoaderTest, ProviderNotificationOnPolicyChange) {
  InSequence s;
  MockConfigurationPolicyObserver observer;
  int dictionary_number_1 = 0;
  int dictionary_number_2 = 0;
  EXPECT_CALL(*delegate_, Load()).WillOnce(
      CreateSequencedTestDictionary(&dictionary_number_1));
  EXPECT_CALL(*delegate_, Load()).WillOnce(
      CreateSequencedTestDictionary(&dictionary_number_2));
  EXPECT_CALL(observer, OnUpdatePolicy()).Times(0);
  EXPECT_CALL(*delegate_, Load()).WillOnce(
      CreateSequencedTestDictionary(&dictionary_number_2));
  EXPECT_CALL(observer, OnUpdatePolicy()).Times(1);
  EXPECT_CALL(*delegate_, Load()).WillOnce(
      CreateSequencedTestDictionary(&dictionary_number_1));
  scoped_refptr<AsynchronousPolicyLoader> loader =
      new AsynchronousPolicyLoader(delegate_.release(), 10);
  AsynchronousPolicyProvider provider(NULL, loader);
  // |registrar| must be declared last so that it is destroyed first.
  ConfigurationPolicyObserverRegistrar registrar;
  registrar.Init(&provider, &observer);
  loop_.RunAllPending();
  loader->Reload();
  loop_.RunAllPending();
  loader->Reload();
  loop_.RunAllPending();
  loader->Reload();
  loop_.RunAllPending();
}

}  // namespace policy