blob: 448d94a5ef8afbffa43e7d607ee2fff64078be07 [file] [log] [blame]
/* $Id$
*
* Licensed to the Apache Software Foundation (ASF) under one or more
* contributor license agreements. See the NOTICE file distributed with
* this work for additional information regarding copyright ownership.
* The ASF licenses this file to you under the Apache License, Version
* 2.0 (the "License"); you may not use this file except in compliance
* with the License. You may obtain a copy of the License at
*
* http://www.apache.org/licenses/LICENSE-2.0
*
* Unless required by applicable law or agreed to in writing, software
* distributed under the License is distributed on an "AS IS" BASIS,
* WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
* See the License for the specific language governing permissions and
* limitations under the License.
*/
#include <gtest/gtest.h>
#include "serialization/EtchDefaultValueFactory.h"
#include "support/EtchRuntime.h"
class EtchDefaultValueFactoryTest
: public ::testing::Test {
protected:
virtual void SetUp() {
mRuntime = new EtchRuntime();
mRuntime->start();
}
virtual void TearDown() {
mRuntime->shutdown();
delete mRuntime;
mRuntime = NULL;
}
EtchRuntime* mRuntime;
};
TEST_F(EtchDefaultValueFactoryTest, createTest) {
EtchType *_mt_x;
EtchType *_mt_y;
EtchField *_mf_a = new EtchField("a");
EtchField *_mf_b = new EtchField("b");
EtchTypeMap *types = new EtchTypeMap();
EtchClass2TypeMap *class2type = new EtchClass2TypeMap();
//example types
EtchString str("x");
types->get(str, _mt_x);
str.set("y");
types->get(str, _mt_y);
EtchDefaultValueFactory::Init(mRuntime, types, class2type);
types->lock();
class2type->lock();
EtchDefaultValueFactory *test = NULL;
test = new EtchDefaultValueFactory("tcp:", types, class2type);
EXPECT_TRUE(test != NULL);
//clear the added types
types->clear();
delete test;
delete _mf_a;
delete _mf_b;
delete types;
delete class2type;
}
TEST_F(EtchDefaultValueFactoryTest, typeTest) {
EtchType *_mt_x;
EtchType *_mt_y;
EtchField *_mf_a = new EtchField("a");
EtchField *_mf_b = new EtchField("b");
EtchTypeMap *types = new EtchTypeMap();
EtchClass2TypeMap *class2type = new EtchClass2TypeMap();
//example types
EtchString str("x");
types->get(str, _mt_x);
str.set("y");
types->get(str, _mt_y);
EtchDefaultValueFactory::Init(mRuntime, types, class2type);
types->lock();
class2type->lock();
EtchDefaultValueFactory *test = NULL;
test = new EtchDefaultValueFactory("tcp:", types, class2type);
EXPECT_TRUE(test != NULL);
str.set("_Etch_RuntimeException");
EtchType *runtime_exception;
test->getType(str, runtime_exception);
EXPECT_TRUE(runtime_exception->getComponentType()->equals (EtchRuntimeException::TYPE()));
EXPECT_TRUE(runtime_exception->getName().equals(&str));
str.set("_Etch_List");
EtchType *list;
test->getType(str, list);
EXPECT_TRUE(list->getComponentType()->equals (EtchList<EtchObject*>::TYPE()));
EXPECT_TRUE(list->getName().equals(&str));
str.set("_Etch_Map");
EtchType *hashTable;
test->getType(str, hashTable);
EXPECT_TRUE(hashTable->getComponentType()->equals (EtchHashTable<EtchObject*, EtchObject*>::TYPE()));
EXPECT_TRUE(hashTable->getName().equals(&str));
str.set("_Etch_Set");
EtchType *set;
test->getType(str, set);
EXPECT_TRUE(set->getComponentType()->equals (EtchHashSet<EtchObject*>::TYPE()));
EXPECT_TRUE(set->getName().equals(&str));
str.set("_Etch_Datetime");
EtchType *date;
test->getType(str, date);
EXPECT_TRUE(date->getComponentType()->equals (EtchDate::TYPE()));
EXPECT_TRUE(date->getName().equals(&str));
str.set("_Etch_AuthException");
EtchType *auth_exception;
test->getType(str, auth_exception);
EXPECT_TRUE(auth_exception->getComponentType()->equals (EtchAuthenticationException::TYPE()));
EXPECT_TRUE(auth_exception->getName().equals(&str));
str.set("_exception");
EtchType *exception;
test->getType(str, exception);
EXPECT_TRUE(exception->getName().equals(&str));
str.set("x");
EtchType *x;
test->getType(str, x);
EXPECT_TRUE(x->equals(_mt_x));
str.set("y");
EtchType *y;
test->getType(str, y);
EXPECT_TRUE(y->equals(_mt_y));
//clear the added types
types->clear();
delete test;
delete _mf_a;
delete _mf_b;
delete types;
delete class2type;
}
TEST_F(EtchDefaultValueFactoryTest, exportCustomValueTest) {
EtchType *_mt_x;
EtchType *_mt_y;
EtchField *_mf_a = new EtchField("a");
EtchField *_mf_b = new EtchField("b");
EtchTypeMap *types = new EtchTypeMap();
EtchClass2TypeMap *class2type = new EtchClass2TypeMap();
//example types
EtchString str("x");
types->get(str, _mt_x);
str.set("y");
types->get(str, _mt_y);
EtchDefaultValueFactory::Init(mRuntime, types, class2type);
types->lock();
class2type->lock();
EtchDefaultValueFactory *test = NULL;
test = new EtchDefaultValueFactory("tcp:", types, class2type);
EXPECT_TRUE(test != NULL);
str.set("Error Message");
EtchType *type;
capu::SmartPointer<EtchException> value = new EtchRuntimeException(str, ETCH_ERROR);
capu::SmartPointer<EtchObject> serialized;
EtchStructValue* sv;
//ETCH RUNTIME EXCEPTION EXPORT
EXPECT_TRUE(test->exportCustomValue(value, sv) == ETCH_OK);
EtchString strRuntime = "_Etch_RuntimeException";
test->getType(strRuntime, type);
EXPECT_TRUE(sv->isType(type));
EXPECT_EQ(1u, sv->count());
EXPECT_EQ(ETCH_OK, sv->get(EtchDefaultValueFactory::_mf_msg(), &serialized));
EXPECT_TRUE(serialized->equals(&str));
EtchStructValue* sv_unknown;
//TRY UNKNOWN VALUE
capu::SmartPointer<EtchObject> unknown = new EtchObject();
EXPECT_TRUE(test->exportCustomValue(unknown, sv_unknown) == ETCH_EINVAL);
//clear the added types
types->clear();
delete sv;
delete test;
delete _mf_a;
delete _mf_b;
delete types;
delete class2type;
}
TEST_F(EtchDefaultValueFactoryTest, importCustomValueTest) {
EtchType *_mt_x;
EtchType *_mt_y;
EtchField *_mf_a = new EtchField("a");
EtchField *_mf_b = new EtchField("b");
EtchTypeMap *types = new EtchTypeMap();
EtchClass2TypeMap *class2type = new EtchClass2TypeMap();
//example types
EtchString str("x");
types->get(str, _mt_x);
str.set("y");
types->get(str, _mt_y);
EtchDefaultValueFactory::Init(mRuntime, types, class2type);
types->lock();
class2type->lock();
EtchDefaultValueFactory *test = NULL;
test = new EtchDefaultValueFactory("tcp:", types, class2type);
EXPECT_TRUE(test != NULL);
str.set("Error Message");
EtchType *type;
capu::SmartPointer<EtchObject> deserialized;
//create serialized struct value
EtchString strRuntime = "_Etch_RuntimeException";
test->getType(strRuntime, type);
EtchStructValue *sv = new EtchStructValue(type, test);
sv->put(EtchDefaultValueFactory::_mf_msg(), new EtchString("Error Message"));
//construct the object
test->importCustomValue(sv, deserialized);
//check object values
EXPECT_TRUE(deserialized.get() != NULL);
EXPECT_TRUE(((EtchException*) deserialized.get())->getErrorMessage().equals(&str));
EtchString tmp = "x";
test->getType(tmp, type);
EtchStructValue* sv_unknown = new EtchStructValue(type, test);
//TRY IMPORT UNKNOWN VALUE
capu::SmartPointer<EtchObject> unknown;
EXPECT_TRUE(test->importCustomValue(sv_unknown, unknown) == ETCH_EINVAL);
//clear the added types
types->clear();
delete sv;
delete sv_unknown;
delete test;
delete _mf_a;
delete _mf_b;
delete types;
delete class2type;
}
TEST_F(EtchDefaultValueFactoryTest, lockTest) {
EtchType *_mt_x;
EtchType *_mt_y;
EtchField *_mf_a = new EtchField("a");
EtchField *_mf_b = new EtchField("b");
EtchTypeMap *types = new EtchTypeMap();
EtchClass2TypeMap *class2type = new EtchClass2TypeMap();
//example types
EtchString str("x");
types->get(str, _mt_x);
str.set("y");
types->get(str, _mt_y);
EtchDefaultValueFactory::Init(mRuntime, types, class2type);
types->lock();
class2type->lock();
//create value factory
EtchDefaultValueFactory *test = NULL;
test = new EtchDefaultValueFactory("tcp:", types, class2type);
EXPECT_TRUE(test != NULL);
EtchType *t;
EtchString x = "x";
EtchString y = "y";
EtchString a = "a";
EtchString b = "b";
EXPECT_TRUE(test->getType(x, t) == ETCH_OK);
EXPECT_TRUE(test->getType(y, t) == ETCH_OK);
EXPECT_TRUE(test->getType(a, t) == ETCH_OK);
test->lockDynamicTypes();
EXPECT_TRUE(test->getType(b, t) == ETCH_ERROR);
//clear the added types
types->clear();
delete test;
delete _mf_a;
delete _mf_b;
delete types;
delete class2type;
}
TEST_F(EtchDefaultValueFactoryTest, messageIdTest) {
EtchType *_mt_x;
EtchType *_mt_y;
EtchField *_mf_a = new EtchField("a");
EtchField *_mf_b = new EtchField("b");
EtchTypeMap *types = new EtchTypeMap();
EtchClass2TypeMap *class2type = new EtchClass2TypeMap();
//example types
EtchString str("x");
types->get(str, _mt_x);
str.set("y");
types->get(str, _mt_y);
EtchDefaultValueFactory::Init(mRuntime, types, class2type);
types->lock();
class2type->lock();
EtchDefaultValueFactory *test = NULL;
test = new EtchDefaultValueFactory("tcp:", types, class2type);
EXPECT_TRUE(test != NULL);
str.set("foo");
EtchType *mt_foo = new EtchType(str);
capu::SmartPointer<EtchValidator> val;
EtchValidatorLong::Get(mRuntime, 0, val);
mt_foo->putValidator(EtchDefaultValueFactory::_mf__messageId(), val);
EtchMessage *msg = new EtchMessage(mt_foo, test);
capu::int64_t id;
EXPECT_TRUE(test->getMessageId(msg, id) == ETCH_ERROR);
EtchMessage *msg2 = NULL;
EXPECT_TRUE(test->getMessageId(msg2, id) == ETCH_EINVAL);
test->setMessageId(msg, 234L);
test->getMessageId(msg, id);
EXPECT_TRUE(234L == id);
//clear the added types
types->clear();
delete test;
delete msg;
delete _mf_a;
delete _mf_b;
delete types;
delete class2type;
delete mt_foo;
}
TEST_F(EtchDefaultValueFactoryTest, inReplyToTest) {
EtchType *_mt_x;
EtchType *_mt_y;
EtchField *_mf_a = new EtchField("a");
EtchField *_mf_b = new EtchField("b");
EtchTypeMap *types = new EtchTypeMap();
EtchClass2TypeMap *class2type = new EtchClass2TypeMap();
//example types
EtchString str("x");
types->get(str, _mt_x);
str.set("y");
types->get(str, _mt_y);
EtchDefaultValueFactory::Init(mRuntime, types, class2type);
types->lock();
class2type->lock();
EtchDefaultValueFactory *test = NULL;
test = new EtchDefaultValueFactory("tcp:", types, class2type);
EXPECT_TRUE(test != NULL);
str.set("foo");
EtchType *mt_foo = new EtchType(str);
capu::SmartPointer<EtchValidator> val;
EtchValidatorLong::Get(mRuntime, 0, val);
mt_foo->putValidator(EtchDefaultValueFactory::_mf__inReplyTo(), val);
EtchMessage *msg = new EtchMessage(mt_foo, test);
capu::int64_t id;
EXPECT_TRUE(test->getInReplyToMessageId(msg, id) == ETCH_ERROR);
EtchMessage *msg2 = NULL;
EXPECT_TRUE(test->getInReplyToMessageId(msg2, id) == ETCH_EINVAL);
test->setInReplyToMessageId(msg, 234L);
test->getInReplyToMessageId(msg, id);
EXPECT_TRUE(234L == id);
//clear the added types
types->clear();
delete test;
delete msg;
delete _mf_a;
delete _mf_b;
delete types;
delete class2type;
delete mt_foo;
}