package jalview.structure;
import static org.testng.AssertJUnit.assertEquals;
-import static org.testng.AssertJUnit.assertNotNull;
import static org.testng.AssertJUnit.assertTrue;
import jalview.datamodel.AlignedCodonFrame;
-import jalview.gui.AlignFrame;
-import jalview.gui.Desktop;
-import jalview.io.FileLoader;
+import jalview.datamodel.Sequence;
+import jalview.datamodel.SequenceFeature;
+import jalview.datamodel.SequenceI;
import jalview.io.FormatAdapter;
import java.util.HashSet;
-import java.util.LinkedHashSet;
import java.util.Set;
-import org.testng.annotations.BeforeClass;
import org.testng.annotations.BeforeMethod;
import org.testng.annotations.Test;
+import MCview.PDBfile;
+
public class StructureSelectionManagerTest
{
private StructureSelectionManager ssm;
- @BeforeClass(alwaysRun = true)
- public static void setUpBeforeClass() throws Exception
- {
- jalview.bin.Jalview.main(new String[] { "-props",
- "test/jalview/testProps.jvprops" });
- }
-
- @BeforeMethod(alwaysRun = true)
+ @BeforeMethod(alwaysRun = true)
public void setUp()
{
ssm = new StructureSelectionManager();
}
- @Test(groups ={ "Functional" })
+ @Test(groups = { "Functional" })
public void testRegisterMapping()
{
AlignedCodonFrame acf1 = new AlignedCodonFrame();
assertTrue(ssm.seqmappings.contains(acf2));
}
- @Test(groups ={ "Functional" })
+ @Test(groups = { "Functional" })
public void testRegisterMappings()
{
AlignedCodonFrame acf1 = new AlignedCodonFrame();
}
/**
- * Test that a mapping is not deregistered if an alignment holds a reference
- * to it
- */
- @Test(groups ={ "Functional" })
- public void testDeregisterMapping_withAlignmentReference()
- {
- Desktop d = Desktop.instance;
- assertNotNull(d);
-
- /*
- * alignment with reference to mappings
- */
- AlignFrame af1 = new FileLoader().LoadFileWaitTillLoaded(
- ">Seq1\nCAGT\n", FormatAdapter.PASTE);
-
- AlignedCodonFrame acf1 = new AlignedCodonFrame();
- AlignedCodonFrame acf2 = new AlignedCodonFrame();
-
- Set<AlignedCodonFrame> mappings = new LinkedHashSet<AlignedCodonFrame>();
- mappings.add(acf1);
- mappings.add(acf2);
- af1.getViewport().getAlignment().setCodonFrames(mappings);
-
- /*
- * Add one and remove it.
- */
- ssm.registerMapping(acf1);
- ssm.deregisterMapping(acf1);
- assertEquals(1, ssm.seqmappings.size());
- assertTrue(ssm.seqmappings.contains(acf1));
- }
-
- /**
- * Test that a mapping is deregistered if no alignment holds a reference to it
- */
- @Test(groups ={ "Functional" })
- public void testDeregisterMapping_withNoReference()
- {
- Desktop d = Desktop.instance;
- assertNotNull(d);
-
- /*
- * alignment with reference to mappings
- */
- AlignFrame af1 = new FileLoader().LoadFileWaitTillLoaded(
- ">Seq1\nCAGT\n", FormatAdapter.PASTE);
-
- AlignedCodonFrame acf1 = new AlignedCodonFrame();
- AlignedCodonFrame acf2 = new AlignedCodonFrame();
-
- Set<AlignedCodonFrame> mappings = new LinkedHashSet<AlignedCodonFrame>();
- mappings.add(acf2);
- af1.getViewport().getAlignment().setCodonFrames(mappings);
-
- /*
- * Add one and remove it.
- */
- ssm.registerMapping(acf1);
- assertEquals(1, ssm.seqmappings.size());
- assertTrue(ssm.seqmappings.contains(acf1));
- ssm.deregisterMapping(acf1);
- assertEquals(0, ssm.seqmappings.size());
- }
-
- /**
- * Test that a mapping is not deregistered when a second view is closed but
- * the first still holds a reference to the mapping
+ * Verify that RESNUM sequence features are present after creating a PDB
+ * mapping
*/
- @Test(groups ={ "Functional" })
- public void testDeregisterMapping_onCloseView()
+ @Test(groups = { "Functional" })
+ public void testSetMapping_seqFeatures()
{
- /*
- * alignment with reference to mappings
- */
- AlignFrame af1 = new FileLoader().LoadFileWaitTillLoaded(
- ">Seq1\nCAGT\n", FormatAdapter.PASTE);
-
- AlignedCodonFrame acf1 = new AlignedCodonFrame();
- AlignedCodonFrame acf2 = new AlignedCodonFrame();
-
- Set<AlignedCodonFrame> mappings = new LinkedHashSet<AlignedCodonFrame>();
- mappings.add(acf1);
- mappings.add(acf2);
- af1.getViewport().getAlignment().setCodonFrames(mappings);
- af1.newView_actionPerformed(null);
+ SequenceI seq = new Sequence(
+ "1GAQ|B",
+ "ATYNVKLITPEGEVELQVPDDVYILDQAEEDGIDLPYSCRAGSCSSCAGKVVSGSVDQSDQSYLDDGQIADGWVLTCHAYPTSDVVIETHKEEELTGA");
+ StructureSelectionManager sm = new StructureSelectionManager();
+ sm.setProcessSecondaryStructure(true);
+ sm.setAddTempFacAnnot(true);
+ PDBfile pmap = sm.setMapping(true, new SequenceI[] { seq },
+ new String[] { null }, "examples/1gaq.txt", FormatAdapter.FILE);
+ assertTrue(pmap != null);
+
+ assertEquals(3, pmap.getSeqs().size());
+ assertEquals("1GAQ|A", pmap.getSeqs().get(0).getName());
+ assertEquals("1GAQ|B", pmap.getSeqs().get(1).getName());
+ assertEquals("1GAQ|C", pmap.getSeqs().get(2).getName());
/*
- * Verify that creating the alignment for the new View has registered the
- * mappings
+ * Verify a RESNUM sequence feature in the PDBfile sequence
*/
- ssm = StructureSelectionManager
- .getStructureSelectionManager(Desktop.instance);
- assertEquals(2, ssm.seqmappings.size());
- assertTrue(ssm.seqmappings.contains(acf1));
- assertTrue(ssm.seqmappings.contains(acf2));
+ SequenceFeature sf = pmap.getSeqs().get(0).getSequenceFeatures()[0];
+ assertEquals("RESNUM", sf.getType());
+ assertEquals("1gaq", sf.getFeatureGroup());
+ assertEquals("GLU: 19 1gaqA", sf.getDescription());
/*
- * Close the second view. Verify that mappings are not removed as the first
- * view still holds a reference to them.
+ * Verify a RESNUM sequence feature in the StructureSelectionManager mapped
+ * sequence
*/
- af1.closeMenuItem_actionPerformed(false);
- assertEquals(2, ssm.seqmappings.size());
- assertTrue(ssm.seqmappings.contains(acf1));
- assertTrue(ssm.seqmappings.contains(acf2));
+ StructureMapping map = sm.getMapping("examples/1gaq.txt")[0];
+ sf = map.sequence.getSequenceFeatures()[0];
+ assertEquals("RESNUM", sf.getType());
+ assertEquals("1gaq", sf.getFeatureGroup());
+ assertEquals("ALA: 1 1gaqB", sf.getDescription());
}
}