// 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/values.h"
#include "extensions/browser/extension_function.h"
template <typename T>
struct DefaultSingletonTraits;
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:
virtual ~TestExtensionFunction();
// SyncExtensionFunction:
virtual bool RunSync() OVERRIDE;
virtual bool RunSafe() = 0;
};
class TestNotifyPassFunction : public TestExtensionFunction {
public:
DECLARE_EXTENSION_FUNCTION("test.notifyPass", UNKNOWN)
protected:
virtual ~TestNotifyPassFunction();
// TestExtensionFunction:
virtual bool RunSafe() OVERRIDE;
};
class TestNotifyFailFunction : public TestExtensionFunction {
public:
DECLARE_EXTENSION_FUNCTION("test.notifyFail", UNKNOWN)
protected:
virtual ~TestNotifyFailFunction();
// TestExtensionFunction:
virtual bool RunSafe() OVERRIDE;
};
class TestLogFunction : public TestExtensionFunction {
public:
DECLARE_EXTENSION_FUNCTION("test.log", UNKNOWN)
protected:
virtual ~TestLogFunction();
// TestExtensionFunction:
virtual 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:
virtual ~TestSendMessageFunction();
// ExtensionFunction:
virtual 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 DefaultSingletonTraits<TestConfigState>;
TestConfigState();
base::DictionaryValue* config_state_;
DISALLOW_COPY_AND_ASSIGN(TestConfigState);
};
virtual ~TestGetConfigFunction();
// TestExtensionFunction:
virtual bool RunSafe() OVERRIDE;
};
class TestWaitForRoundTripFunction : public TestExtensionFunction {
public:
DECLARE_EXTENSION_FUNCTION("test.waitForRoundTrip", UNKNOWN)
protected:
virtual ~TestWaitForRoundTripFunction();
// TestExtensionFunction:
virtual bool RunSafe() OVERRIDE;
};
} // namespace extensions
#endif // EXTENSIONS_BROWSER_API_TEST_TEST_API_H_