// 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.
#ifndef CONTENT_TEST_PLUGIN_PLUGIN_TEST_H_
#define CONTENT_TEST_PLUGIN_PLUGIN_TEST_H_
#include <string>
#include "third_party/npapi/bindings/npapi.h"
#include "third_party/npapi/bindings/nphostapi.h"
namespace NPAPIClient {
// A PluginTest represents an instance of the plugin, which in
// our case is a test case.
class PluginTest {
public:
// Constructor.
PluginTest(NPP id, NPNetscapeFuncs *host_functions);
// Destructor
virtual ~PluginTest();
// Returns true if the test runs in windowless plugin mode.
virtual bool IsWindowless() const;
//
// NPAPI Functions
//
virtual NPError New(uint16 mode, int16 argc, const char* argn[],
const char* argv[], NPSavedData* saved);
virtual NPError Destroy();
virtual NPError SetWindow(NPWindow* pNPWindow);
virtual NPError NewStream(NPMIMEType type, NPStream* stream,
NPBool seekable, uint16* stype);
virtual int32 WriteReady(NPStream *stream);
virtual int32 Write(NPStream *stream, int32 offset, int32 len,
void *buffer);
virtual NPError DestroyStream(NPStream *stream, NPError reason);
virtual void StreamAsFile(NPStream* stream, const char* fname);
virtual void URLNotify(const char* url, NPReason reason, void* data);
virtual int16 HandleEvent(void* event);
virtual void URLRedirectNotify(const char* url, int32_t status,
void* notify_data);
// Returns true if the test has not had any errors.
bool Succeeded() { return test_status_.length() == 0; }
// Sets an error for the test case. Appends the msg to the
// error that will be returned from the test.
void SetError(const std::string &msg);
// Expect two string values are equal, and if not, logs an
// appropriate error about it.
void ExpectStringLowerCaseEqual(const std::string &val1,
const std::string &val2);
// Expect two values to not be equal, and if they are
// logs an appropriate error about it.
void ExpectAsciiStringNotEqual(const char *val1, const char *val2);
// Expect two integer values are equal, and if not, logs an
// appropriate error about it.
void ExpectIntegerEqual(int val1, int val2);
// Signals to the Test that invoked us that the test is
// completed. This is done by forcing the plugin to
// set a cookie in the browser window, which the test program
// is waiting for. Note - because this is done by
// using javascript, the browser must have the frame
// setup before the plugin calls this function. So plugin
// tests MUST NOT call this function prior to having
// received the SetWindow() callback from the browser.
void SignalTestCompleted();
protected:
// Helper function to lookup names in the input array.
// If the name is found, returns the value, otherwise
// returns NULL.
const char *GetArgValue(const char *name, const int16 argc,
const char *argn[], const char *argv[]);
// Access to the list of functions provided
// by the NPAPI host.
NPNetscapeFuncs *HostFunctions() { return host_functions_; }
// The NPP Identifier for this plugin instance.
NPP id() { return id_; }
std::string test_id() const { return test_id_; }
std::string test_name() const { return test_name_; }
bool test_completed() const { return test_completed_; }
private:
NPP id_;
NPNetscapeFuncs * host_functions_;
std::string test_name_;
std::string test_id_;
std::string test_status_;
bool test_completed_;
};
} // namespace NPAPIClient
#endif // CONTENT_TEST_PLUGIN_PLUGIN_TEST_H_