// 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 #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_