blob: c8ba5b82db22e5160a182f691943ad0e5a723a6c [file] [log] [blame]
// Copyright 2014 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.
#ifndef EXTENSIONS_BROWSER_API_TEST_TEST_API_H_
#define EXTENSIONS_BROWSER_API_TEST_TEST_API_H_
#include "base/macros.h"
#include "base/values.h"
#include "extensions/browser/extension_function.h"
namespace base {
template <typename T>
struct DefaultSingletonTraits;
} // namespace base
namespace extensions {
// A function that is only available in tests.
// Prior to running, checks that we are in a testing process.
class TestExtensionFunction : public ExtensionFunction {
protected:
~TestExtensionFunction() override;
// ExtensionFunction:
bool PreRunValidation(std::string* error) override;
};
class TestNotifyPassFunction : public TestExtensionFunction {
public:
DECLARE_EXTENSION_FUNCTION("test.notifyPass", UNKNOWN)
protected:
~TestNotifyPassFunction() override;
// ExtensionFunction:
ResponseAction Run() override;
};
class TestNotifyFailFunction : public TestExtensionFunction {
public:
DECLARE_EXTENSION_FUNCTION("test.notifyFail", UNKNOWN)
protected:
~TestNotifyFailFunction() override;
// ExtensionFunction:
ResponseAction Run() override;
};
class TestLogFunction : public TestExtensionFunction {
public:
DECLARE_EXTENSION_FUNCTION("test.log", UNKNOWN)
protected:
~TestLogFunction() override;
// ExtensionFunction:
ResponseAction Run() override;
};
class TestSendMessageFunction : public ExtensionFunction {
public:
TestSendMessageFunction();
DECLARE_EXTENSION_FUNCTION("test.sendMessage", UNKNOWN)
// Sends a reply back to the calling extension. Many extensions don't need
// a reply and will just ignore it.
void Reply(const std::string& message);
// Sends an error back to the calling extension.
void ReplyWithError(const std::string& error);
protected:
~TestSendMessageFunction() override;
// UIExtensionFunction:
ResponseAction Run() override;
// Whether or not the function is currently waiting for a reply.
bool waiting_;
ResponseValue response_;
};
class TestGetConfigFunction : public TestExtensionFunction {
public:
DECLARE_EXTENSION_FUNCTION("test.getConfig", UNKNOWN)
// Set the dictionary returned by chrome.test.getConfig().
// Does not take ownership of |value|.
static void set_test_config_state(base::DictionaryValue* value);
protected:
// Tests that set configuration state do so by calling
// set_test_config_state() as part of test set up, and unsetting it
// during tear down. This singleton class holds a pointer to that
// state, owned by the test code.
class TestConfigState {
public:
static TestConfigState* GetInstance();
void set_config_state(base::DictionaryValue* config_state) {
config_state_ = config_state;
}
const base::DictionaryValue* config_state() { return config_state_; }
private:
friend struct base::DefaultSingletonTraits<TestConfigState>;
TestConfigState();
base::DictionaryValue* config_state_;
DISALLOW_COPY_AND_ASSIGN(TestConfigState);
};
~TestGetConfigFunction() override;
// ExtensionFunction:
ResponseAction Run() override;
};
class TestWaitForRoundTripFunction : public TestExtensionFunction {
public:
DECLARE_EXTENSION_FUNCTION("test.waitForRoundTrip", UNKNOWN)
protected:
~TestWaitForRoundTripFunction() override;
// ExtensionFunction:
ResponseAction Run() override;
};
} // namespace extensions
#endif // EXTENSIONS_BROWSER_API_TEST_TEST_API_H_