|
| 1 | +""" |
| 2 | +scaffoldgraph tests.core.test_scaffold |
| 3 | +""" |
| 4 | + |
| 5 | +import pytest |
| 6 | +from rdkit import Chem |
| 7 | + |
| 8 | +from scaffoldgraph.core.scaffold import * |
| 9 | + |
| 10 | + |
| 11 | +@pytest.fixture(name='scaffold') |
| 12 | +def basic_scaffold(): |
| 13 | + # murcko scaffold smiles |
| 14 | + mol = Chem.MolFromSmiles('O=C(Nc1ccccc1)Nc1cc2c(s1)CNCC2') |
| 15 | + scaffold = Scaffold(mol) |
| 16 | + return scaffold |
| 17 | + |
| 18 | + |
| 19 | +def test_new(): |
| 20 | + scaffold = Scaffold(None) |
| 21 | + assert scaffold is None |
| 22 | + |
| 23 | + |
| 24 | +def test_smiles(scaffold): |
| 25 | + assert scaffold.smiles == 'O=C(Nc1ccccc1)Nc1cc2c(s1)CNCC2' |
| 26 | + assert scaffold.get_canonical_identifier() == scaffold.smiles |
| 27 | + assert scaffold == Scaffold(Chem.MolFromSmiles(scaffold.smiles)) |
| 28 | + assert scaffold == scaffold.smiles |
| 29 | + assert str(scaffold) == scaffold.smiles |
| 30 | + assert hash(scaffold) == hash(scaffold.smiles) |
| 31 | + |
| 32 | + |
| 33 | +def test_name(scaffold): |
| 34 | + assert scaffold.name is None |
| 35 | + scaffold.name = 'TEST' |
| 36 | + assert scaffold.name == 'TEST' |
| 37 | + assert repr(scaffold) == '<Scaffold at {}>'.format(hex(id(scaffold))) |
| 38 | + assert bool(scaffold) is True |
| 39 | + |
| 40 | + |
| 41 | +def test_atoms(scaffold): |
| 42 | + atoms = scaffold.atoms |
| 43 | + assert len(atoms) == scaffold.mol.GetNumAtoms() |
| 44 | + assert all([isinstance(x, Chem.Atom) for x in atoms]) |
| 45 | + |
| 46 | + |
| 47 | +def test_bonds(scaffold): |
| 48 | + bonds = scaffold.bonds |
| 49 | + assert len(bonds) == scaffold.mol.GetNumBonds() |
| 50 | + assert all([isinstance(x, Chem.Bond) for x in bonds]) |
| 51 | + |
| 52 | + |
| 53 | +def test_rings(scaffold): |
| 54 | + rings = scaffold.rings |
| 55 | + assert isinstance(rings, RingStack) |
| 56 | + assert hasattr(rings, 'owner') |
| 57 | + assert hasattr(rings, 'info') |
| 58 | + assert hasattr(rings, 'atom_rings') |
| 59 | + assert hasattr(rings, 'bond_rings') |
| 60 | + assert rings.count == 3 and len(rings) == 3 |
| 61 | + assert repr(rings) == '<RingStack at {}>'.format(hex(id(rings))) |
| 62 | + assert isinstance(rings[0], Ring) |
| 63 | + assert len([x for x in rings]) == 3 |
| 64 | + assert isinstance(rings.info, Chem.RingInfo) |
| 65 | + assert len(rings.atom_rings) == 3 and len(rings.bond_rings) == 3 |
| 66 | + ring = rings[1] |
| 67 | + assert hasattr(ring, 'owner') |
| 68 | + assert hasattr(ring, 'aix') |
| 69 | + assert hasattr(ring, 'bix') |
| 70 | + assert all([isinstance(x, Chem.Bond) for x in ring.bonds]) |
| 71 | + assert all([isinstance(x, Chem.Atom) for x in ring.atoms]) |
| 72 | + assert isinstance(ring.size, int) |
| 73 | + assert len(ring) == len(ring.atoms) |
| 74 | + assert repr(ring) == '<Ring at {}>'.format(hex(id(ring))) |
| 75 | + |
| 76 | + |
| 77 | +def test_ring_systems(scaffold): |
| 78 | + rings = scaffold.ring_systems |
| 79 | + assert isinstance(rings, RingSystemStack) |
| 80 | + assert hasattr(rings, 'owner') |
| 81 | + assert hasattr(rings, 'ring_indexes') |
| 82 | + assert hasattr(rings, 'atom_rings') |
| 83 | + assert hasattr(rings, 'bond_rings') |
| 84 | + assert rings.count == 2 and len(rings) == 2 |
| 85 | + assert repr(rings) == '<RingSystemStack at {}>'.format(hex(id(rings))) |
| 86 | + assert isinstance(rings[0], RingSystem) |
| 87 | + assert len([x for x in rings]) == 2 |
| 88 | + assert len(rings.atom_rings) == 2 and len(rings.bond_rings) == 2 |
| 89 | + ring = rings[1] |
| 90 | + assert hasattr(ring, 'owner') |
| 91 | + assert hasattr(ring, 'aix') |
| 92 | + assert hasattr(ring, 'bix') |
| 93 | + assert hasattr(ring, 'rix') |
| 94 | + assert all([isinstance(x, Chem.Bond) for x in ring.bonds]) |
| 95 | + assert all([isinstance(x, Chem.Atom) for x in ring.atoms]) |
| 96 | + assert isinstance(ring.size, int) |
| 97 | + assert len(ring) == len(ring.atoms) |
| 98 | + assert repr(ring) == '<RingSystem at {}>'.format(hex(id(ring))) |
| 99 | + assert isinstance(ring[0], Ring) |
| 100 | + assert len(list(ring.get_rings())) == 2 |
0 commit comments