blob: 44d6e3dc1b497ad59f90a02acd32e690c0197680 [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 SyncExtensionFunction {
protected:
~TestExtensionFunction() override;
// SyncExtensionFunction:
bool RunSync() override;
virtual bool RunSafe() = 0;
};
class TestNotifyPassFunction : public TestExtensionFunction {
public:
DECLARE_EXTENSION_FUNCTION("test.notifyPass", UNKNOWN)
protected:
~TestNotifyPassFunction() override;
// TestExtensionFunction:
bool RunSafe() override;
};
class TestNotifyFailFunction : public TestExtensionFunction {
public:
DECLARE_EXTENSION_FUNCTION("test.notifyFail", UNKNOWN)
protected:
~TestNotifyFailFunction() override;
// TestExtensionFunction:
bool RunSafe() override;
};
class TestLogFunction : public TestExtensionFunction {
public:
DECLARE_EXTENSION_FUNCTION("test.log", UNKNOWN)
protected:
~TestLogFunction() override;
// TestExtensionFunction:
bool RunSafe() override;
};
class TestSendMessageFunction : public AsyncExtensionFunction {
public:
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;
// ExtensionFunction:
bool RunAsync() override;
};
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;
// TestExtensionFunction:
bool RunSafe() override;
};
class TestWaitForRoundTripFunction : public TestExtensionFunction {
public:
DECLARE_EXTENSION_FUNCTION("test.waitForRoundTrip", UNKNOWN)
protected:
~TestWaitForRoundTripFunction() override;
// TestExtensionFunction:
bool RunSafe() override;
};
} // namespace extensions
#endif // EXTENSIONS_BROWSER_API_TEST_TEST_API_H_