//%2006//////////////////////////////////////////////////////////////////////// // // 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. // Copyright (c) 2006 Hewlett-Packard Development Company, L.P.; IBM Corp.; // EMC Corporation; Symantec 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: () // // Modified By: // //%///////////////////////////////////////////////////////////////////////////// #include #include #include "ExceptionsTest.h" #include PEGASUS_NAMESPACE_BEGIN PEGASUS_USING_STD; // The following macro is enabled/ disabled by defining in the Makefile. #ifdef TEST_EXCEPTIONS #define PEGASUS_EXCEPTION PEGASUS_CIM_EXCEPTION(CIM_ERR_FAILED, \ "ExceptionsTest Exception") #define CIM_EXCEPTION CIMException(CIM_ERR_FAILED, "Test Provider") #else #define PEGASUS_EXCEPTION #define CIM_EXCEPTION #endif // Update the value of the following macro for enabling/ disabling exceptions. // #define EXCEPTION_TYPE 1 #define CheckExceptionType(X) { \ cout <<" Exception Type " << X << endl;\ if (X == 1) throw PEGASUS_EXCEPTION; \ if (X == 2) throw CIM_EXCEPTION; \ } ExceptionsTest::ExceptionsTest(void) { } ExceptionsTest::~ExceptionsTest(void) { } void ExceptionsTest::initialize(CIMOMHandle & cimom) { cout <<" ExceptionsTest::initialize" << endl; CheckExceptionType(EXCEPTION_TYPE); // create default instances for FirstClass CIMInstance instance1("FirstClass"); CIMObjectPath reference1("FirstClass.Id=1"); instance1.addProperty(CIMProperty("Id", Uint8(1))); // key instance1.addProperty(CIMProperty("Message", String("Subodh....."))); _instances.append(instance1); _instanceNames.append(reference1); CheckExceptionType(EXCEPTION_TYPE); CIMInstance instance2("FirstClass"); CIMObjectPath reference2("FirstClass.Id=2"); instance2.addProperty(CIMProperty("Id", Uint8(2))); // key instance2.addProperty(CIMProperty("Message", String("Soni...."))); _instances.append(instance2); _instanceNames.append(reference2); CheckExceptionType(EXCEPTION_TYPE); // create default instances for SecondClass CIMInstance instance_1("SecondClass"); CIMObjectPath reference_1("SecondClass.Srno=11"); instance_1.addProperty(CIMProperty("Srno", Uint8(1))); // key instance_1.addProperty(CIMProperty("Name", String("Class Two Instance 1....."))); _instances_second.append(instance_1); _instanceNames_second.append(reference_1); CheckExceptionType(EXCEPTION_TYPE); CIMInstance instance_2("SecondClass"); CIMObjectPath reference_2("SecondClass.Srno=2"); instance_2.addProperty(CIMProperty("Srno", Uint8(2))); // key instance_2.addProperty(CIMProperty("Name", String("Class Two Instance 2...."))); _instances_second.append(instance_2); _instanceNames_second.append(reference_2); CheckExceptionType(EXCEPTION_TYPE); } void ExceptionsTest::terminate(void) { } void ExceptionsTest::getInstance( const OperationContext & context, const CIMObjectPath & instanceReference, const Boolean includeQualifiers, const Boolean includeClassOrigin, const CIMPropertyList & propertyList, InstanceResponseHandler & handler) { // convert a potential fully qualified reference into a local reference // (class name and keys only). CIMObjectPath localReference = CIMObjectPath( String(), String(), instanceReference.getClassName(), instanceReference.getKeyBindings()); CIMName className = instanceReference.getClassName(); // begin processing the request handler.processing(); cout <<"Calling Exception ExceptionsTest::getInstance 1" << endl; CheckExceptionType(EXCEPTION_TYPE); if (className == CIMName("FirstClass")) { // instance index corresponds to reference index for(Uint32 i = 0, n = _instances.size(); i < n; i++) { if(localReference == _instanceNames[i]) { // deliver requested instance handler.deliver(_instances[i]); break; } } } // complete processing the request handler.complete(); cout <<"Calling Exception ExceptionsTest::getInstance 2" << endl; CheckExceptionType(EXCEPTION_TYPE); } void ExceptionsTest::enumerateInstances( const OperationContext & context, const CIMObjectPath & classReference, const Boolean includeQualifiers, const Boolean includeClassOrigin, const CIMPropertyList & propertyList, InstanceResponseHandler & handler) { cout <<"Calling Exception ExceptionsTest::enumerateInstances 1" << endl; CheckExceptionType(EXCEPTION_TYPE); CIMName clName = classReference.getClassName(); String className = clName.getString(); if (String::equalNoCase(className, "FirstClass")) { // announce operation processing. handler.processing(); for(Uint32 i = 0, n = _instances.size(); i < n; i++) // deliver instance handler.deliver(_instances[i]); } if (String::equalNoCase(className, "SecondClass")) { handler.processing(); for(Uint32 i = 0, n = _instances_second.size(); i < n; i++) // deliver instance handler.deliver(_instances_second[i]); } if (String::equalNoCase(className, "ThirdClass")) { handler.processing(); for(Uint32 i = 0, n = _instances_third.size(); i < n; i++) // deliver instance handler.deliver(_instances_third[i]); } cout <<"Calling Exception ExceptionsTest::enumerateInstances 2" << endl; CheckExceptionType(EXCEPTION_TYPE); // complete processing the request handler.complete(); } void ExceptionsTest::enumerateInstanceNames( const OperationContext & context, const CIMObjectPath & classReference, ObjectPathResponseHandler & handler) { // begin processing the request handler.processing(); cout <<"Calling Exception ExceptionsTest::enumerateInstanceNames 1" << endl; CheckExceptionType(EXCEPTION_TYPE); CIMName clName = classReference.getClassName(); String className = clName.getString(); if (className == "FirstClass") { for(Uint32 i = 0, n = _instances.size(); i < n; i++) // deliver reference handler.deliver(_instanceNames[i]); } else if (className == "SecondClass") { for(Uint32 i = 0, n = _instances_second.size(); i < n; i++) // deliver reference handler.deliver(_instanceNames_second[i]); } else if (className == "ThirdClass") { for(Uint32 i = 0, n = _instances_third.size(); i < n; i++) // deliver reference handler.deliver(_instanceNames_third[i]); } // complete processing the request cout <<"Calling Exception ExceptionsTest::enumerateInstanceNames 2" << endl; CheckExceptionType(EXCEPTION_TYPE); handler.complete(); } void ExceptionsTest::modifyInstance( const OperationContext & context, const CIMObjectPath & instanceReference, const CIMInstance & instanceObject, const Boolean includeQualifiers, const CIMPropertyList & propertyList, ResponseHandler & handler) { // convert a potential fully qualified reference into a local reference // (class name and keys only). CIMObjectPath localReference = CIMObjectPath( String(), String(), instanceReference.getClassName(), instanceReference.getKeyBindings()); cout <<"Calling Exception ExceptionsTest::modifyInstance 1" << endl; CheckExceptionType(EXCEPTION_TYPE); // begin processing the request handler.processing(); // instance index corresponds to reference index for(Uint32 i = 0, n = _instances.size(); i < n; i++) { if(localReference == _instanceNames[i]) { // overwrite existing instance _instances[i] = instanceObject; break; } } // complete processing the request handler.complete(); cout <<"Calling Exception ExceptionsTest::modifyInstance 2" << endl; CheckExceptionType(EXCEPTION_TYPE); } void ExceptionsTest::createInstance( const OperationContext & context, const CIMObjectPath & instanceReference, const CIMInstance & instanceObject, ObjectPathResponseHandler & handler) { // convert a potential fully qualified reference into a local reference // (class name and keys only). CIMObjectPath localReference = CIMObjectPath( String(), String(), instanceReference.getClassName(), instanceReference.getKeyBindings()); cout <<"Calling Exception ExceptionsTest::createInstance 1" << endl; CheckExceptionType(EXCEPTION_TYPE); // instance index corresponds to reference index for(Uint32 i = 0, n = _instanceNames.size(); i < n; i++) { if(localReference == _instanceNames[i]) { throw CIMObjectAlreadyExistsException( localReference.toString()); } } // begin processing the request handler.processing(); // add the new instance to the array _instances.append(instanceObject); _instanceNames.append(instanceReference); cout <<"Calling Exception ExceptionsTest::createInstance 2" << endl; CheckExceptionType(EXCEPTION_TYPE); // deliver the new instance handler.deliver(_instanceNames[_instanceNames.size() - 1]); // complete processing the request handler.complete(); } void ExceptionsTest::deleteInstance( const OperationContext & context, const CIMObjectPath & instanceReference, ResponseHandler & handler) { // convert a potential fully qualified reference into a local reference // (class name and keys only). CIMObjectPath localReference = CIMObjectPath( String(), String(), instanceReference.getClassName(), instanceReference.getKeyBindings()); // begin processing the request handler.processing(); cout <<"Calling Exception ExceptionsTest::deleteInstance 1" << endl; CheckExceptionType(EXCEPTION_TYPE); // instance index corresponds to reference index for(Uint32 i = 0, n = _instances.size(); i < n; i++) { if(localReference == _instanceNames[i]) { // save the instance locally CIMInstance cimInstance(_instances[i]); // remove instance from the array _instances.remove(i); _instanceNames.remove(i); // exit loop break; } } cout <<"Calling Exception ExceptionsTest::deleteInstance 2" << endl; CheckExceptionType(EXCEPTION_TYPE); // complete processing the request handler.complete(); } PEGASUS_NAMESPACE_END