⭐ 欢迎来到虫虫下载站! | 📦 资源下载 📁 资源专辑 ℹ️ 关于我们
⭐ 虫虫下载站

📄 exceptionstest.cpp

📁 Pegasus is an open-source implementationof the DMTF CIM and WBEM standards. It is designed to be por
💻 CPP
字号:
//%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: <Subodh Soni> (<ssubodh@in.ibm.com>)//// Modified By:////%/////////////////////////////////////////////////////////////////////////////#include <stdio.h>#include <iostream>#include "ExceptionsTest.h"#include <Pegasus/Common/InternalException.h>PEGASUS_NAMESPACE_BEGINPEGASUS_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

⌨️ 快捷键说明

复制代码 Ctrl + C
搜索代码 Ctrl + F
全屏模式 F11
切换主题 Ctrl + Shift + D
显示快捷键 ?
增大字号 Ctrl + =
减小字号 Ctrl + -