testPlugin found bug: added unionArrayTest
This commit is contained in:
@ -151,8 +151,10 @@ bool PVArrayFilter::filter(const PVFieldPtr & pvField,const BitSetPtr & bitSet,b
|
|||||||
{
|
{
|
||||||
PVFieldPtr pvCopy = pvField;
|
PVFieldPtr pvCopy = pvField;
|
||||||
PVScalarArrayPtr copyArray;
|
PVScalarArrayPtr copyArray;
|
||||||
|
bool isUnion = false;
|
||||||
Type type = masterField->getField()->getType();
|
Type type = masterField->getField()->getType();
|
||||||
if(type==epics::pvData::union_) {
|
if(type==epics::pvData::union_) {
|
||||||
|
isUnion = true;
|
||||||
PVUnionPtr pvMasterUnion = std::tr1::static_pointer_cast<PVUnion>(masterField);
|
PVUnionPtr pvMasterUnion = std::tr1::static_pointer_cast<PVUnion>(masterField);
|
||||||
PVUnionPtr pvCopyUnion = std::tr1::static_pointer_cast<PVUnion>(pvCopy);
|
PVUnionPtr pvCopyUnion = std::tr1::static_pointer_cast<PVUnion>(pvCopy);
|
||||||
if(toCopy) pvCopyUnion->copy(*pvMasterUnion);
|
if(toCopy) pvCopyUnion->copy(*pvMasterUnion);
|
||||||
@ -194,6 +196,7 @@ bool PVArrayFilter::filter(const PVFieldPtr & pvField,const BitSetPtr & bitSet,b
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
copyArray->setLength(len);
|
copyArray->setLength(len);
|
||||||
|
bitSet->set(pvField->getFieldOffset());
|
||||||
return true;
|
return true;
|
||||||
}
|
}
|
||||||
if (end - start >= 0) len = 1 + (end - start) / increment;
|
if (end - start >= 0) len = 1 + (end - start) / increment;
|
||||||
@ -210,7 +213,7 @@ bool PVArrayFilter::filter(const PVFieldPtr & pvField,const BitSetPtr & bitSet,b
|
|||||||
indto += increment;
|
indto += increment;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
masterField->postPut();
|
if(isUnion) masterField->postPut();
|
||||||
return true;
|
return true;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -145,6 +145,73 @@ static void arrayTest()
|
|||||||
testOk1(nset==1);
|
testOk1(nset==1);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
static void unionArrayTest()
|
||||||
|
{
|
||||||
|
if(debug) {cout << endl << endl << "****unionArrayTest****" << endl;}
|
||||||
|
bool result = false;
|
||||||
|
uint32 nset = 0;
|
||||||
|
size_t n = 10;
|
||||||
|
shared_vector<double> values(n);
|
||||||
|
for(size_t i=0; i<n; i++) values[i] = i + .06;
|
||||||
|
PVDoubleArrayPtr pvDoubleArray =
|
||||||
|
static_pointer_cast<PVDoubleArray>(PVDataCreate::getPVDataCreate()->createPVScalarArray(pvDouble));
|
||||||
|
const shared_vector<const double> yyy(freeze(values));
|
||||||
|
pvDoubleArray->putFrom(yyy);
|
||||||
|
|
||||||
|
StandardFieldPtr standardField = getStandardField();
|
||||||
|
FieldCreatePtr fieldCreate = getFieldCreate();
|
||||||
|
StructureConstPtr top = fieldCreate->createFieldBuilder()->
|
||||||
|
add("value",fieldCreate->createVariantUnion()) ->
|
||||||
|
add("timeStamp", standardField->timeStamp()) ->
|
||||||
|
addNestedStructure("subfield") ->
|
||||||
|
add("value",fieldCreate->createVariantUnion()) ->
|
||||||
|
endNested()->
|
||||||
|
createStructure();
|
||||||
|
PVStructurePtr pvRecordStructure(PVDataCreate::getPVDataCreate()->createPVStructure(top));
|
||||||
|
PVRecordPtr pvRecord(PVRecord::create("unionArrayRecord",pvRecordStructure));
|
||||||
|
PVUnionPtr pvUnion = pvRecord->getPVStructure()->getSubField<PVUnion>("value");
|
||||||
|
pvUnion->set(pvDoubleArray);
|
||||||
|
pvUnion = pvRecord->getPVStructure()->getSubField<PVUnion>("subfield.value");
|
||||||
|
pvUnion->set(pvDoubleArray);
|
||||||
|
if(debug) { cout << "initial\n" << pvRecordStructure << "\n";}
|
||||||
|
|
||||||
|
PVStructurePtr pvRequest(CreateRequest::create()->createRequest("value[array=1:3]"));
|
||||||
|
PVCopyPtr pvCopy(PVCopy::create(pvRecordStructure,pvRequest,""));
|
||||||
|
PVStructurePtr pvStructureCopy(pvCopy->createPVStructure());
|
||||||
|
BitSetPtr bitSet(new BitSet(pvStructureCopy->getNumberFields()));
|
||||||
|
PVDoubleArrayPtr pvValue(pvRecordStructure->getSubField<PVDoubleArray>("value"));
|
||||||
|
result = pvCopy->updateCopySetBitSet(pvStructureCopy,bitSet);
|
||||||
|
nset = bitSet->cardinality();
|
||||||
|
if(debug) {
|
||||||
|
cout << "after get value"
|
||||||
|
<< " result " << (result ? "true" : "false")
|
||||||
|
<< " nset " << nset
|
||||||
|
<< " bitSet " << *bitSet
|
||||||
|
<< " pvStructureCopy\n" << pvStructureCopy
|
||||||
|
<< "\n";
|
||||||
|
}
|
||||||
|
testOk1(result==true);
|
||||||
|
testOk1(nset==1);
|
||||||
|
|
||||||
|
pvRequest = CreateRequest::create()->createRequest("subfield.value[array=1:3]");
|
||||||
|
pvCopy = PVCopy::create(pvRecordStructure,pvRequest,"");
|
||||||
|
pvStructureCopy = pvCopy->createPVStructure();
|
||||||
|
bitSet = BitSetPtr(new BitSet(pvStructureCopy->getNumberFields()));
|
||||||
|
pvValue = pvRecordStructure->getSubField<PVDoubleArray>("subfield.value");
|
||||||
|
result = pvCopy->updateCopySetBitSet(pvStructureCopy,bitSet);
|
||||||
|
nset = bitSet->cardinality();
|
||||||
|
if(debug) {
|
||||||
|
cout << "after get subfield.value"
|
||||||
|
<< " result " << (result ? "true" : "false")
|
||||||
|
<< " nset " << nset
|
||||||
|
<< " bitSet " << *bitSet
|
||||||
|
<< " pvStructureCopy\n" << pvStructureCopy
|
||||||
|
<< "\n";
|
||||||
|
}
|
||||||
|
testOk1(result==true);
|
||||||
|
testOk1(nset==1);
|
||||||
|
}
|
||||||
|
|
||||||
static void timeStampTest()
|
static void timeStampTest()
|
||||||
{
|
{
|
||||||
if(debug) {cout << endl << endl << "****timeStampTest****" << endl;}
|
if(debug) {cout << endl << endl << "****timeStampTest****" << endl;}
|
||||||
@ -267,10 +334,11 @@ static void ignoreTest()
|
|||||||
|
|
||||||
MAIN(testPlugin)
|
MAIN(testPlugin)
|
||||||
{
|
{
|
||||||
testPlan(22);
|
testPlan(26);
|
||||||
PVDatabasePtr pvDatabase(PVDatabase::getMaster());
|
PVDatabasePtr pvDatabase(PVDatabase::getMaster());
|
||||||
deadbandTest();
|
deadbandTest();
|
||||||
arrayTest();
|
arrayTest();
|
||||||
|
unionArrayTest();
|
||||||
timeStampTest();
|
timeStampTest();
|
||||||
ignoreTest();
|
ignoreTest();
|
||||||
return 0;
|
return 0;
|
||||||
|
Reference in New Issue
Block a user