1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 41 42 43 44 45 46 47 48 49 50 51 52 53 54 55 56 57 58 59 60 61 62 63 64 65 66 67 68 69 70 71 72
|
/*
*
* Copyright (c) 2019 Greg Landrum and T5 Informatics GmbH
* All rights reserved.
*
* This file is part of the RDKit.
* The contents are covered by the terms of the BSD license
* which is included in the file license.txt, found at the root
* of the RDKit source tree.
*/
package org.RDKit;
import static org.junit.Assert.*;
import org.junit.*;
public class AbbreviationsTests extends GraphMolTest {
@Before public void setUp() {
}
@Test
public void test1Basics() {
AbbreviationDefinition_Vect abbrevs = RDKFuncs.getDefaultAbbreviations();
RWMol mol = RWMol.MolFromSmiles("C1CCC1C(F)(F)F");
assertEquals(mol.getNumAtoms(),8);
RDKFuncs.condenseMolAbbreviations(mol,abbrevs);
// no changes here due to the threshold
assertEquals(mol.getNumAtoms(),8);
RDKFuncs.condenseMolAbbreviations(mol,abbrevs, 1.0);
assertEquals(mol.getNumAtoms(),5);
assertEquals(RDKFuncs.MolToCXSmiles(mol),"*C1CCC1 |$CF3;;;;$|");
}
@Test
public void test2LinkerBasics() {
AbbreviationDefinition_Vect abbrevs = RDKFuncs.getDefaultLinkers();
RWMol mol = RWMol.MolFromSmiles("COCCOCCOCCOCCCl");
assertEquals(mol.getNumAtoms(),14);
RDKFuncs.condenseMolAbbreviations(mol,abbrevs);
// no changes here due to the threshold
assertEquals(mol.getNumAtoms(),14);
RDKFuncs.condenseMolAbbreviations(mol,abbrevs, 1.0);
assertEquals(mol.getNumAtoms(),3);
assertEquals(RDKFuncs.MolToCXSmiles(mol),"C*Cl |$;PEG4;$|");
}
@Test
public void test3Matching() {
AbbreviationDefinition_Vect abbrevs = RDKFuncs.getDefaultAbbreviations();
RWMol mol = RWMol.MolFromSmiles("C1CCC1C(F)(F)F");
assertEquals(mol.getNumAtoms(),8);
AbbreviationMatch_Vect matches = RDKFuncs.findApplicableAbbreviationMatches(mol,abbrevs,1.0);
assertEquals(matches.size(),1);
assertEquals(matches.get(0).getAbbrev().getLabel(),"CF3");
RDKFuncs.applyMatches(mol,matches);
assertEquals(mol.getNumAtoms(),5);
assertEquals(RDKFuncs.MolToCXSmiles(mol),"*C1CCC1 |$CF3;;;;$|");
}
public static void main(String args[]) {
org.junit.runner.JUnitCore.main("org.RDKit.AbbreviationsTests");
}
}
|