From 0e9b036a96cd9aee48f593d7f1ea5d32cfb5cebb Mon Sep 17 00:00:00 2001 From: Richard Gowers Date: Fri, 11 Nov 2016 15:39:33 +0000 Subject: [PATCH] Added tests for deprecated Group init methods --- .../MDAnalysisTests/core/test_atomgroup.py | 71 +++++++++++++++++-- 1 file changed, 65 insertions(+), 6 deletions(-) diff --git a/testsuite/MDAnalysisTests/core/test_atomgroup.py b/testsuite/MDAnalysisTests/core/test_atomgroup.py index 41f7f53aa92..661583c01fc 100644 --- a/testsuite/MDAnalysisTests/core/test_atomgroup.py +++ b/testsuite/MDAnalysisTests/core/test_atomgroup.py @@ -38,18 +38,77 @@ ) from MDAnalysisTests.datafiles import (PSF, DCD) +from MDAnalysisTests.core.groupbase import make_Universe from MDAnalysisTests import tempdir # I want to catch all warnings in the tests. If this is not set at the start it # could cause test that check for warnings to fail. warnings.simplefilter('always') - -def test_usage_warning(): - with warnings.catch_warnings(record=True) as warn: - warnings.simplefilter('always') - mda.core.AtomGroup.Universe(PSF, DCD) - assert_equal(len(warn), 1) +class TestDeprecationWarnings(object): + @staticmethod + def test_AtomGroupUniverse_usage_warning(): + with warnings.catch_warnings(record=True) as warn: + warnings.simplefilter('always') + mda.core.AtomGroup.Universe(PSF, DCD) + assert_equal(len(warn), 1) + + @staticmethod + def test_old_AtomGroup_init_warns(): + u = make_Universe(('names',)) + at_list = list(u.atoms[:10]) + with warnings.catch_warnings(record=True) as warn: + warnings.simplefilter('always') + ag = mda.core.groups.AtomGroup(at_list) + assert_equal(len(warn), 1) + + @staticmethod + def test_old_AtomGroup_init_works(): + u = make_Universe(('names',)) + at_list = list(u.atoms[:10]) + ag = mda.core.groups.AtomGroup(at_list) + + assert_(isinstance(ag, mda.core.groups.AtomGroup)) + assert_(len(ag) == 10) + assert_equal(ag.names, u.atoms[:10].names) + + @staticmethod + def test_old_ResidueGroup_init_warns(): + u = make_Universe(('resnames',)) + res_list = list(u.residues[:10]) + with warnings.catch_warnings(record=True) as warn: + warnings.simplefilter('always') + rg = mda.core.groups.ResidueGroup(res_list) + assert_equal(len(warn), 1) + + @staticmethod + def test_old_ResidueGroup_init_works(): + u = make_Universe(('resnames',)) + res_list = list(u.residues[:10]) + rg = mda.core.groups.ResidueGroup(res_list) + + assert_(isinstance(rg, mda.core.groups.ResidueGroup)) + assert_(len(rg) == 10) + assert_equal(rg.resnames, u.residues[:10].resnames) + + @staticmethod + def test_old_SegmentGroup_init_warns(): + u = make_Universe(('segids',)) + seg_list = list(u.segments[:3]) + with warnings.catch_warnings(record=True) as warn: + warnings.simplefilter('always') + sg = mda.core.groups.SegmentGroup(seg_list) + assert_equal(len(warn), 1) + + @staticmethod + def test_old_SegmentGroup_init_works(): + u = make_Universe(('segids',)) + seg_list = list(u.segments[:3]) + sg = mda.core.groups.SegmentGroup(seg_list) + + assert_(isinstance(sg, mda.core.groups.SegmentGroup)) + assert_(len(sg) == 3) + assert_equal(sg.segids, u.segments[:3].segids) class TestAtomGroupToTopology(object):