Adapting plugin tests to use the new split Plugin.{h,cc} structure

that init-plugin now generates.

Also adding new test that makes sure the the skeleton created by
init-plugin compiles on its own withoyt any further changes.
This commit is contained in:
Robin Sommer 2014-07-21 22:54:33 +02:00
parent 2a49932911
commit ca1b882761
7 changed files with 98 additions and 82 deletions

@ -1 +1 @@
Subproject commit 32e8ea92f0880b09821bc5e18406920676aa28a8 Subproject commit 315d7a2ab10f3ff1025e813dca156e7eaff35cef

View file

@ -0,0 +1,3 @@
Demo::Foo - <Insert description> (dynamic, version 1.0)
===

View file

@ -1,25 +1,20 @@
#include <plugin/Plugin.h> #include "Plugin.h"
#include "Foo.h" #include "Foo.h"
namespace plugin { namespace plugin { namespace Demo_Foo { Plugin plugin; } }
namespace Demo_Foo {
class Plugin : public plugin::Plugin { using namespace plugin::Demo_Foo;
public:
plugin::Configuration Configure()
{
AddComponent(new ::file_analysis::Component("Foo", ::plugin::Demo_Foo::Foo::Instantiate));
plugin::Configuration config; plugin::Configuration Plugin::Configure()
config.name = "Demo::Foo"; {
config.description = "A Foo test analyzer"; AddComponent(new ::file_analysis::Component("Foo", ::plugin::Demo_Foo::Foo::Instantiate));
config.version.major = 1;
config.version.minor = 0;
return config;
}
} plugin;
} plugin::Configuration config;
} config.name = "Demo::Foo";
config.description = "A Foo test analyzer";
config.version.major = 1;
config.version.minor = 0;
return config;
}

View file

@ -1,50 +1,37 @@
#include <plugin/Plugin.h> #include "Plugin.h"
#include <Func.h> #include <Func.h>
#include <Event.h> #include <Event.h>
namespace plugin { namespace plugin { namespace Demo_Hooks { Plugin plugin; } }
namespace Demo_Hooks {
class Plugin : public plugin::Plugin using namespace plugin::Demo_Hooks;
{
protected:
plugin::Configuration Configure()
{
EnableHook(HOOK_LOAD_FILE);
EnableHook(HOOK_CALL_FUNCTION);
EnableHook(HOOK_QUEUE_EVENT);
EnableHook(HOOK_DRAIN_EVENTS);
EnableHook(HOOK_UPDATE_NETWORK_TIME);
EnableHook(META_HOOK_PRE);
EnableHook(META_HOOK_POST);
EnableHook(HOOK_BRO_OBJ_DTOR);
plugin::Configuration config; plugin::Configuration Plugin::Configure()
config.name = "Demo::Hooks"; {
config.description = "Exercises all plugin hooks"; EnableHook(HOOK_LOAD_FILE);
config.version.major = 1; EnableHook(HOOK_CALL_FUNCTION);
config.version.minor = 0; EnableHook(HOOK_QUEUE_EVENT);
return config; EnableHook(HOOK_DRAIN_EVENTS);
} EnableHook(HOOK_UPDATE_NETWORK_TIME);
EnableHook(META_HOOK_PRE);
EnableHook(META_HOOK_POST);
EnableHook(HOOK_BRO_OBJ_DTOR);
virtual int HookLoadFile(const std::string& file, const std::string& ext); plugin::Configuration config;
virtual Val* HookCallFunction(const Func* func, val_list* args); config.name = "Demo::Hooks";
virtual bool HookQueueEvent(Event* event); config.description = "Exercises all plugin hooks";
virtual void HookDrainEvents(); config.version.major = 1;
virtual void HookUpdateNetworkTime(double network_time); config.version.minor = 0;
virtual void HookBroObjDtor(void* obj); return config;
virtual void MetaHookPre(HookType hook, const HookArgumentList& args); }
virtual void MetaHookPost(HookType hook, const HookArgumentList& args, HookArgument result);
} plugin; static void describe_hook_args(const plugin::HookArgumentList& args, ODesc* d)
static void describe_hook_args(const HookArgumentList& args, ODesc* d)
{ {
bool first = true; bool first = true;
for ( HookArgumentList::const_iterator i = args.begin(); i != args.end(); i++ ) for ( plugin::HookArgumentList::const_iterator i = args.begin(); i != args.end(); i++ )
{ {
if ( ! first ) if ( ! first )
d->Add(", "); d->Add(", ");
@ -81,14 +68,16 @@ bool Plugin::HookQueueEvent(Event* event)
fprintf(stderr, "%.6f %-15s %s\n", network_time, "| HookQueueEvent", fprintf(stderr, "%.6f %-15s %s\n", network_time, "| HookQueueEvent",
d.Description()); d.Description());
static int i = 0; static int i = 0;
if ( network_time && i == 0 ) { if ( network_time && i == 0 )
fprintf(stderr, "%.6f %-15s %s\n", network_time, "| RequestObjDtor", {
d.Description()); fprintf(stderr, "%.6f %-15s %s\n", network_time, "| RequestObjDtor",
RequestBroObjDtor(event); d.Description());
i = 1;
} RequestBroObjDtor(event);
i = 1;
}
return false; return false;
} }
@ -132,6 +121,3 @@ void Plugin::MetaHookPost(HookType hook, const HookArgumentList& args, HookArgum
hook_name(hook), d1.Description(), hook_name(hook), d1.Description(),
d2.Description()); d2.Description());
} }
}
}

View file

@ -0,0 +1,31 @@
#ifndef BRO_PLUGIN_Demo_Hooks
#define BRO_PLUGIN_Demo_Hooks
#include <plugin/Plugin.h>
namespace plugin {
namespace Demo_Hooks {
class Plugin : public ::plugin::Plugin
{
protected:
virtual int HookLoadFile(const std::string& file, const std::string& ext);
virtual Val* HookCallFunction(const Func* func, val_list* args);
virtual bool HookQueueEvent(Event* event);
virtual void HookDrainEvents();
virtual void HookUpdateNetworkTime(double network_time);
virtual void HookBroObjDtor(void* obj);
virtual void MetaHookPre(HookType hook, const HookArgumentList& args);
virtual void MetaHookPost(HookType hook, const HookArgumentList& args, HookArgument result);
// Overridden from plugin::Plugin.
virtual plugin::Configuration Configure();
};
extern Plugin plugin;
}
}
#endif

View file

@ -0,0 +1,6 @@
# @TEST-EXEC: ${DIST}/aux/bro-aux/plugin-support/init-plugin Demo Foo
# @TEST-EXEC: make BRO=${DIST}
# @TEST-EXEC: BRO_PLUGIN_PATH=`pwd` bro -NN Demo::Foo >>output
# @TEST-EXEC: echo === >>output
# @TEST-EXEC: BRO_PLUGIN_PATH=`pwd` bro -r $TRACES/port4242.trace >>output
# @TEST-EXEC: TEST_DIFF_CANONIFIER= btest-diff output

View file

@ -1,25 +1,20 @@
#include <plugin/Plugin.h> #include "Plugin.h"
#include "Foo.h" #include "Foo.h"
namespace plugin { namespace plugin { namespace Demo_Foo { Plugin plugin; } }
namespace Demo_Foo {
class Plugin : public plugin::Plugin { using namespace plugin::Demo_Foo;
public:
plugin::Configuration Configure()
{
AddComponent(new ::analyzer::Component("Foo", plugin::Demo_Foo::Foo::Instantiate));
plugin::Configuration config; plugin::Configuration Plugin::Configure()
config.name = "Demo::Foo"; {
config.description = "A Foo test analyzer"; AddComponent(new ::analyzer::Component("Foo", plugin::Demo_Foo::Foo::Instantiate));
config.version.major = 1;
config.version.minor = 0;
return config;
}
} plugin;
} plugin::Configuration config;
} config.name = "Demo::Foo";
config.description = "A Foo test analyzer";
config.version.major = 1;
config.version.minor = 0;
return config;
}