![]() ![]() |
![]() |
File: [Pegasus] / pegasus / src / Pegasus / Handler / SystemLogListenerDestination / tests / SystemLogHandler.cpp
(download)
Revision: 1.3, Tue Nov 22 02:59:20 2005 UTC (18 years, 7 months ago) by jim.wunderlich Branch: MAIN CVS Tags: STABLE, PEP244_ServerProfile-root, PEP244_ServerProfile-branch, PEP233_EmbeddedInstSupport-root, BUG_4225_PERFORMANCE_VERSION_1_DONE Branch point for: PEP233_EmbeddedInstSupport-branch Changes since 1.2: +1 -1 lines BUG#: 4489 TITLE: Need PEGASUS_TEST_ASSERT() that is always defined DESCRIPTION: This is the first part of a two part change. - This change defines PEGASUS_TEST_ASSERT() and changes references to assert() in all test files to PEGASUS_TEST_ASSERT(). - The second part will change references to PEGASUS_ASSERT() in the test files to PEGASUS_TEST_ASSERT() |
//%2005//////////////////////////////////////////////////////////////////////// // // Copyright (c) 2000, 2001, 2002 BMC Software; Hewlett-Packard Development // Company, L.P.; IBM Corp.; The Open Group; Tivoli Systems. // Copyright (c) 2003 BMC Software; Hewlett-Packard Development Company, L.P.; // IBM Corp.; EMC Corporation, The Open Group. // Copyright (c) 2004 BMC Software; Hewlett-Packard Development Company, L.P.; // IBM Corp.; EMC Corporation; VERITAS Software Corporation; The Open Group. // Copyright (c) 2005 Hewlett-Packard Development Company, L.P.; IBM Corp.; // EMC Corporation; VERITAS Software Corporation; The Open Group. // // Permission is hereby granted, free of charge, to any person obtaining a copy // of this software and associated documentation files (the "Software"), to // deal in the Software without restriction, including without limitation the // rights to use, copy, modify, merge, publish, distribute, sublicense, and/or // sell copies of the Software, and to permit persons to whom the Software is // furnished to do so, subject to the following conditions: // // THE ABOVE COPYRIGHT NOTICE AND THIS PERMISSION NOTICE SHALL BE INCLUDED IN // ALL COPIES OR SUBSTANTIAL PORTIONS OF THE SOFTWARE. THE SOFTWARE IS PROVIDED // "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR IMPLIED, INCLUDING BUT NOT // LIMITED TO THE WARRANTIES OF MERCHANTABILITY, FITNESS FOR A PARTICULAR // PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE AUTHORS OR COPYRIGHT // HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER LIABILITY, WHETHER IN AN // ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM, OUT OF OR IN CONNECTION // WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE SOFTWARE. // //============================================================================== // // Author: Yi Zhou, Hewlett-Packard Company (yi_zhou@hp.com) // //%///////////////////////////////////////////////////////////////////////////// #include <Pegasus/Common/Config.h> #include <Pegasus/Common/FileSystem.h> #include <Pegasus/Common/Constants.h> #include <Pegasus/Common/System.h> #include <Pegasus/Common/PegasusAssert.h> #include <Pegasus/Client/CIMClient.h> PEGASUS_USING_PEGASUS; PEGASUS_USING_STD; const CIMNamespaceName NAMESPACE = CIMNamespaceName ("root/PG_InterOp"); CIMObjectPath CreateHandler1Instance (CIMClient& client) { CIMInstance handlerInstance(PEGASUS_CLASSNAME_LSTNRDST_SYSTEM_LOG); handlerInstance.addProperty (CIMProperty (CIMName ("SystemCreationClassName"), System::getSystemCreationClassName ())); handlerInstance.addProperty (CIMProperty (CIMName ("SystemName"), System::getFullyQualifiedHostName ())); handlerInstance.addProperty (CIMProperty (CIMName ("CreationClassName"), PEGASUS_CLASSNAME_LSTNRDST_SYSTEM_LOG.getString ())); handlerInstance.addProperty(CIMProperty(CIMName ("Name"), String("Handler1"))); CIMObjectPath Ref = client.createInstance(NAMESPACE, handlerInstance); return (Ref); } CIMObjectPath CreateFilterInstance (CIMClient& client, const String & query, const String & name) { CIMInstance filterInstance(PEGASUS_CLASSNAME_INDFILTER); filterInstance.addProperty (CIMProperty (CIMName ("SystemCreationClassName"), System::getSystemCreationClassName ())); filterInstance.addProperty (CIMProperty (CIMName ("SystemName"), System::getFullyQualifiedHostName ())); filterInstance.addProperty(CIMProperty(CIMName ("CreationClassName"), PEGASUS_CLASSNAME_INDFILTER.getString())); filterInstance.addProperty(CIMProperty(CIMName ("Name"), name)); filterInstance.addProperty (CIMProperty(CIMName ("Query"), query)); filterInstance.addProperty (CIMProperty(CIMName ("QueryLanguage"), String("WQL"))); filterInstance.addProperty (CIMProperty(CIMName ("SourceNamespace"), String("root/SampleProvider"))); CIMObjectPath Ref = client.createInstance(NAMESPACE, filterInstance); return (Ref); } CIMObjectPath CreateFormattedSubscriptionIns (CIMClient& client, const CIMObjectPath & handlerRef, const CIMObjectPath & filterRef, const String & textFormat, const Array<String> & textFormatParams) { CIMInstance subscriptionInstance (PEGASUS_CLASSNAME_FORMATTEDINDSUBSCRIPTION); subscriptionInstance.addProperty(CIMProperty(CIMName ("Filter"), filterRef, 0, PEGASUS_CLASSNAME_INDFILTER)); subscriptionInstance.addProperty(CIMProperty(CIMName ("Handler"), handlerRef, 0, PEGASUS_CLASSNAME_LSTNRDST_SYSTEM_LOG)); subscriptionInstance.addProperty (CIMProperty (CIMName ("SubscriptionState"), CIMValue ((Uint16) 2))); subscriptionInstance.addProperty (CIMProperty (CIMName ("TextFormat"), textFormat)); subscriptionInstance.addProperty (CIMProperty (CIMName ("TextFormatParameters"), textFormatParams)); CIMObjectPath Ref = client.createInstance(NAMESPACE, subscriptionInstance); return (Ref); } void generateIndication(CIMClient& client) { CIMInstance indicationInstance (CIMName("RT_TestIndication")); CIMObjectPath path ; path.setNameSpace("root/SampleProvider"); path.setClassName("RT_TestIndication"); indicationInstance.setPath(path); Array<CIMParamValue> inParams; Array<CIMParamValue> outParams; CIMValue ret_value = client.invokeMethod( "root/SampleProvider", path, "SendTestIndication", inParams, outParams); } void DeleteInstance (CIMClient& client, const CIMObjectPath Ref) { client.deleteInstance(NAMESPACE, Ref); } int main(int argc, char** argv) { CIMClient client; try { client.connectLocal(); } catch (Exception & e) { PEGASUS_STD (cerr) << "Exception: " << e.getMessage () << PEGASUS_STD (endl); PEGASUS_STD (cerr) << "Client connects local failed" << PEGASUS_STD (endl); return (-1); } CIMObjectPath Handler1Ref; CIMObjectPath Filter1Ref, Filter2Ref; CIMObjectPath Subscription1Ref, Subscription2Ref; try { Handler1Ref = CreateHandler1Instance (client); } catch (Exception& e) { PEGASUS_STD (cerr) << "Exception: " << e.getMessage () << PEGASUS_STD (endl); PEGASUS_STD (cerr) << "create handler instance failed" << PEGASUS_STD (endl); return (-1); } PEGASUS_STD (cout) << "+++++ handler instances created" << PEGASUS_STD (endl); try { String query="SELECT * FROM rt_testindication"; String name1 = "TestFilter01"; Filter1Ref = CreateFilterInstance (client, query, name1); } catch (Exception& e) { PEGASUS_STD (cerr) << "Exception: " << e.getMessage () << PEGASUS_STD (endl); PEGASUS_STD (cerr) << "create filter instances failed" << PEGASUS_STD (endl); return (-1); } PEGASUS_STD (cout) << "+++++ filter instances created" << PEGASUS_STD (endl); try { Array<String> textFormatParams; textFormatParams.append("IndicationTime"); textFormatParams.append("IndicationIdentifier"); // create a formatted subscription Subscription1Ref = CreateFormattedSubscriptionIns (client, Handler1Ref, Filter1Ref, "The indication occured at {0, datetime} with Indication ID {1}.", textFormatParams); } catch (Exception& e) { PEGASUS_STD (cerr) << "Exception: " << e.getMessage () << PEGASUS_STD (endl); PEGASUS_STD (cerr) << "create subscription instance failed" << PEGASUS_STD (endl); return (-1); } PEGASUS_STD (cout) << "+++++ subscription instances created" << PEGASUS_STD (endl); try { // generate indication generateIndication(client); } catch (Exception& e) { PEGASUS_STD (cerr) << "Exception: " << e.getMessage () << PEGASUS_STD (endl); PEGASUS_STD (cerr) << "generate indication failed" << PEGASUS_STD (endl); return (-1); } PEGASUS_STD (cout) << "+++++ indications generated" << PEGASUS_STD (endl); try { DeleteInstance (client, Subscription1Ref); DeleteInstance (client, Filter1Ref); DeleteInstance (client, Handler1Ref); } catch (Exception& e) { PEGASUS_STD (cerr) << "Exception: " << e.getMessage () << PEGASUS_STD (endl); PEGASUS_STD (cerr) << "delete instance failed" << PEGASUS_STD (endl); exit (-1); } PEGASUS_STD (cout) << "+++++ instances deleted" << PEGASUS_STD (endl); PEGASUS_STD (cout) << "+++++ TestSyslogHandler passed all tests" << PEGASUS_STD (endl); }
No CVS admin address has been configured |
Powered by ViewCVS 0.9.2 |