-
Notifications
You must be signed in to change notification settings - Fork 667
/
Copy pathbase.py
93 lines (73 loc) · 3.51 KB
/
base.py
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
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
# -*- Mode: python; tab-width: 4; indent-tabs-mode:nil; coding:utf-8 -*-
# vim: tabstop=4 expandtab shiftwidth=4 softtabstop=4 fileencoding=utf-8
#
# MDAnalysis --- https://www.mdanalysis.org
# Copyright (c) 2006-2017 The MDAnalysis Development Team and contributors
# (see the file AUTHORS for the full list of names)
#
# Released under the GNU Public Licence, v2 or any higher version
#
# Please cite your use of MDAnalysis in published work:
#
# R. J. Gowers, M. Linke, J. Barnoud, T. J. E. Reddy, M. N. Melo, S. L. Seyler,
# D. L. Dotson, J. Domanski, S. Buchoux, I. M. Kenney, and O. Beckstein.
# MDAnalysis: A Python package for the rapid analysis of molecular dynamics
# simulations. In S. Benthall and S. Rostrup editors, Proceedings of the 15th
# Python in Science Conference, pages 102-109, Austin, TX, 2016. SciPy.
# doi: 10.25080/majora-629e541a-00e
#
# N. Michaud-Agrawal, E. J. Denning, T. B. Woolf, and O. Beckstein.
# MDAnalysis: A Toolkit for the Analysis of Molecular Dynamics Simulations.
# J. Comput. Chem. 32 (2011), 2319--2327, doi:10.1002/jcc.21787
#
import pytest
import MDAnalysis as mda
from MDAnalysis.core.topology import Topology
mandatory_attrs = ['ids', 'resids', 'resnums', 'segids']
class ParserBase(object):
"""Base class for testing Topology parsers.
All Parsers must subclass this class!
"""
expected_attrs = []
@pytest.fixture
def filename(self):
return self.ref_filename
@pytest.fixture()
def top(self, filename):
with self.parser(filename) as p:
yield p.parse()
def test_output(self, filename):
"""Testing the call signature"""
with self.parser(filename) as p:
top = p.parse()
assert isinstance(top, Topology)
def test_mandatory_attributes(self, top):
# attributes required as part of the API
# ALL parsers must provide these
for attr in mandatory_attrs:
assert hasattr(top, attr), 'Missing required attribute: {}'.format(attr)
def test_expected_attributes(self, top):
# Extra attributes as declared in specific implementations
for attr in self.expected_attrs:
assert hasattr(top, attr), 'Missing expected attribute: {}'.format(attr)
def test_no_unexpected_attributes(self, top):
attrs = set(self.expected_attrs
+ mandatory_attrs
+ ['indices', 'resindices', 'segindices'])
for attr in top.attrs:
assert attr.attrname in attrs, 'Unexpected attribute: {}'.format(attr.attrname)
def test_size(self, top):
"""Check that the Topology is correctly sized"""
assert top.n_atoms == self.expected_n_atoms, '{} atoms read, {} expected in {}'.format(
top.n_atoms, self.expected_n_atoms, self.__class__.__name__)
assert top.n_residues == self.expected_n_residues, '{} residues read, {} expected in {}'.format(
top.n_residues, self.expected_n_residues, self.__class__.__name__)
assert top.n_segments == self.expected_n_segments, '{} segment read, {} expected in {}'.format(
top.n_segments, self.expected_n_segments, self.__class__.__name__)
def test_tt_size(self, top):
"""Check that the transtable is appropriately sized"""
assert top.tt.size == (self.expected_n_atoms, self.expected_n_residues, self.expected_n_segments)
def test_creates_universe(self, filename):
"""Check that Universe works with this Parser"""
u = mda.Universe(filename)
assert isinstance(u, mda.Universe)