Files
rdkit/Code/GraphMol/testPicklerGlobalSettings.cpp
Ricardo Rodriguez 7b7a8a4e17 Refactor iostreams includes (#8846)
* refactor iostreams includes

* restore ostream to MonomerInfo.cpp
2025-10-08 16:08:01 +02:00

258 lines
8.6 KiB
C++

//
// Copyright (c) 2017, Novartis Institutes for BioMedical Research Inc.
// All rights reserved.
//
// Redistribution and use in source and binary forms, with or without
// modification, are permitted provided that the following conditions are
// met:
//
// * Redistributions of source code must retain the above copyright
// notice, this list of conditions and the following disclaimer.
// * Redistributions in binary form must reproduce the above
// copyright notice, this list of conditions and the following
// disclaimer in the documentation and/or other materials provided
// with the distribution.
// * Neither the name of Novartis Institutes for BioMedical Research Inc.
// nor the names of its contributors may be used to endorse or promote
// products derived from this software without specific prior written
// permission.
//
// THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS
// "AS IS" AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT
// LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR
// A PARTICULAR PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT
// OWNER OR CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL,
// SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT
// LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE,
// DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY
// THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT
// (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE
// OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
//
#include <RDGeneral/test.h>
#include <RDGeneral/utils.h>
#include <GraphMol/RDKitBase.h>
#include <GraphMol/RDKitQueries.h>
#include <GraphMol/MolPickler.h>
#include <GraphMol/MonomerInfo.h>
#include <GraphMol/SmilesParse/SmilesParse.h>
#include <GraphMol/FileParsers/MolSupplier.h>
#include <GraphMol/FileParsers/FileParsers.h>
#include <GraphMol/SmilesParse/SmilesWrite.h>
#include <GraphMol/SmilesParse/SmartsWrite.h>
#include <GraphMol/Substruct/SubstructMatch.h>
#include <RDGeneral/RDLog.h>
#include <cstdlib>
#include <ctime>
#include <fstream>
#include <boost/algorithm/string.hpp>
using namespace RDKit;
void testGlobalPickleProps() {
BOOST_LOG(rdInfoLog) << "-----------------------\n";
BOOST_LOG(rdInfoLog) << "Testing pickling of properties" << std::endl;
std::vector<double> v;
v.push_back(1234.);
v.push_back(444.);
v.push_back(1123.);
ROMol *m = SmilesToMol("CC");
m->setProp("double", 1.0);
m->setProp("int", 100);
m->setProp("bool", true);
m->setProp("boolfalse", false);
m->setProp("dvec", v);
Atom *a = m->getAtomWithIdx(0);
a->setProp("double", 1.0);
a->setProp("int", 100);
a->setProp("bool", true);
a->setProp("boolfalse", false);
a->setProp("dvec", v);
a->setProp("_private", true);
Bond *b = m->getBondWithIdx(0);
b->setProp("double", 1.0);
b->setProp("int", 100);
b->setProp("bool", true);
b->setProp("boolfalse", false);
b->setProp("dvec", v);
b->setProp("_private", true);
std::string pkl;
{
MolPickler::setDefaultPickleProperties(PicklerOps::AllProps);
MolPickler::pickleMol(*m, pkl);
RWMol *m2 = new RWMol(pkl);
TEST_ASSERT(m2);
TEST_ASSERT(m2->getProp<double>("double") == 1.0);
TEST_ASSERT(m2->getProp<int>("int") == 100);
TEST_ASSERT(m2->getProp<bool>("bool") == true);
TEST_ASSERT(m2->getProp<bool>("boolfalse") == false);
a = m2->getAtomWithIdx(0);
TEST_ASSERT(a->getProp<double>("double") == 1.0);
TEST_ASSERT(a->getProp<int>("int") == 100);
TEST_ASSERT(a->getProp<bool>("bool") == true);
TEST_ASSERT(a->getProp<bool>("boolfalse") == false);
TEST_ASSERT(a->getProp<bool>("_private") == true);
b = m2->getBondWithIdx(0);
TEST_ASSERT(b->getProp<double>("double") == 1.0);
TEST_ASSERT(b->getProp<int>("int") == 100);
TEST_ASSERT(b->getProp<bool>("bool") == true);
TEST_ASSERT(b->getProp<bool>("boolfalse") == false);
TEST_ASSERT(b->getProp<bool>("_private") == true);
// TEST_ASSERT(b->getProp<std::vector<double> >("dvec") == v);
delete m2;
}
{
MolPickler::setDefaultPickleProperties(PicklerOps::MolProps);
MolPickler::pickleMol(*m, pkl);
RWMol *m2 = new RWMol(pkl);
TEST_ASSERT(m2);
TEST_ASSERT(m2->getProp<double>("double") == 1.0);
TEST_ASSERT(m2->getProp<int>("int") == 100);
TEST_ASSERT(m2->getProp<bool>("bool") == true);
TEST_ASSERT(m2->getProp<bool>("boolfalse") == false);
a = m2->getAtomWithIdx(0);
TEST_ASSERT(!a->hasProp("double"));
TEST_ASSERT(!a->hasProp("int"));
TEST_ASSERT(!a->hasProp("bool"));
TEST_ASSERT(!a->hasProp("boolfalse"));
TEST_ASSERT(!a->hasProp("_private"));
b = m2->getBondWithIdx(0);
TEST_ASSERT(!b->hasProp("double"));
TEST_ASSERT(!b->hasProp("int"));
TEST_ASSERT(!b->hasProp("bool"));
TEST_ASSERT(!b->hasProp("boolfalse"));
TEST_ASSERT(!b->hasProp("_private"));
delete m2;
}
{
MolPickler::setDefaultPickleProperties(PicklerOps::AtomProps);
MolPickler::pickleMol(*m, pkl);
RWMol *m2 = new RWMol(pkl);
TEST_ASSERT(m2);
TEST_ASSERT(!m2->hasProp("double"));
TEST_ASSERT(!m2->hasProp("int"));
TEST_ASSERT(!m2->hasProp("bool"));
TEST_ASSERT(!m2->hasProp("boolfalse"));
a = m2->getAtomWithIdx(0);
TEST_ASSERT(a->getProp<double>("double") == 1.0);
TEST_ASSERT(a->getProp<int>("int") == 100);
TEST_ASSERT(a->getProp<bool>("bool") == true);
TEST_ASSERT(a->getProp<bool>("boolfalse") == false);
TEST_ASSERT(!a->hasProp("_private"));
b = m2->getBondWithIdx(0);
TEST_ASSERT(!b->hasProp("double"));
TEST_ASSERT(!b->hasProp("int"));
TEST_ASSERT(!b->hasProp("bool"));
TEST_ASSERT(!b->hasProp("boolfalse"));
TEST_ASSERT(!b->hasProp("_private"));
delete m2;
}
{
MolPickler::setDefaultPickleProperties(PicklerOps::AtomProps |
PicklerOps::PrivateProps);
MolPickler::pickleMol(*m, pkl);
RWMol *m2 = new RWMol(pkl);
TEST_ASSERT(m2);
TEST_ASSERT(!m2->hasProp("double"));
TEST_ASSERT(!m2->hasProp("int"));
TEST_ASSERT(!m2->hasProp("bool"));
TEST_ASSERT(!m2->hasProp("boolfalse"));
a = m2->getAtomWithIdx(0);
TEST_ASSERT(a->getProp<double>("double") == 1.0);
TEST_ASSERT(a->getProp<int>("int") == 100);
TEST_ASSERT(a->getProp<bool>("bool") == true);
TEST_ASSERT(a->getProp<bool>("boolfalse") == false);
TEST_ASSERT(a->getProp<bool>("_private") == true);
b = m2->getBondWithIdx(0);
TEST_ASSERT(!b->hasProp("double"));
TEST_ASSERT(!b->hasProp("int"));
TEST_ASSERT(!b->hasProp("bool"));
TEST_ASSERT(!b->hasProp("boolfalse"));
TEST_ASSERT(!b->hasProp("_private"));
delete m2;
}
{
MolPickler::setDefaultPickleProperties(PicklerOps::BondProps);
MolPickler::pickleMol(*m, pkl);
RWMol *m2 = new RWMol(pkl);
TEST_ASSERT(m2);
TEST_ASSERT(!m2->hasProp("double"));
TEST_ASSERT(!m2->hasProp("int"));
TEST_ASSERT(!m2->hasProp("bool"));
TEST_ASSERT(!m2->hasProp("boolfalse"));
a = m2->getAtomWithIdx(0);
TEST_ASSERT(!a->hasProp("double"));
TEST_ASSERT(!a->hasProp("int"));
TEST_ASSERT(!a->hasProp("bool"));
TEST_ASSERT(!a->hasProp("boolfalse"));
TEST_ASSERT(!a->hasProp("_private"));
b = m2->getBondWithIdx(0);
TEST_ASSERT(b->getProp<double>("double") == 1.0);
TEST_ASSERT(b->getProp<int>("int") == 100);
TEST_ASSERT(b->getProp<bool>("bool") == true);
TEST_ASSERT(b->getProp<bool>("boolfalse") == false);
TEST_ASSERT(!b->hasProp("_private"));
delete m2;
}
{
MolPickler::setDefaultPickleProperties(PicklerOps::BondProps |
PicklerOps::PrivateProps);
MolPickler::pickleMol(*m, pkl);
RWMol *m2 = new RWMol(pkl);
TEST_ASSERT(m2);
TEST_ASSERT(!m2->hasProp("double"));
TEST_ASSERT(!m2->hasProp("int"));
TEST_ASSERT(!m2->hasProp("bool"));
TEST_ASSERT(!m2->hasProp("boolfalse"));
a = m2->getAtomWithIdx(0);
TEST_ASSERT(!a->hasProp("double"));
TEST_ASSERT(!a->hasProp("int"));
TEST_ASSERT(!a->hasProp("bool"));
TEST_ASSERT(!a->hasProp("boolfalse"));
TEST_ASSERT(!a->hasProp("_private"));
b = m2->getBondWithIdx(0);
TEST_ASSERT(b->getProp<double>("double") == 1.0);
TEST_ASSERT(b->getProp<int>("int") == 100);
TEST_ASSERT(b->getProp<bool>("bool") == true);
TEST_ASSERT(b->getProp<bool>("boolfalse") == false);
TEST_ASSERT(b->getProp<bool>("_private") == true);
delete m2;
}
delete m;
BOOST_LOG(rdErrorLog) << "\tdone" << std::endl;
}
int main(int, char **) {
RDLog::InitLogs();
testGlobalPickleProps();
}