X-Git-Url: http://source.jalview.org/gitweb/?a=blobdiff_plain;f=test%2Fjalview%2Fdatamodel%2FAlignedCodonIteratorTest.java;h=dd3ec7c7854cf49ce78456ff605bbf2b1faf8fbf;hb=0bf5983f8a17fdfecb2cac649e3650763a8973ce;hp=60042c48f6bfa3dee62725a09f0cd6531a1f8e01;hpb=17e77c3f2949a0729322b4a8d907f3f34b6a9914;p=jalview.git diff --git a/test/jalview/datamodel/AlignedCodonIteratorTest.java b/test/jalview/datamodel/AlignedCodonIteratorTest.java index 60042c4..dd3ec7c 100644 --- a/test/jalview/datamodel/AlignedCodonIteratorTest.java +++ b/test/jalview/datamodel/AlignedCodonIteratorTest.java @@ -1,6 +1,6 @@ /* - * Jalview - A Sequence Alignment Editor and Viewer (Version 2.9) - * Copyright (C) 2015 The Jalview Authors + * Jalview - A Sequence Alignment Editor and Viewer ($$Version-Rel$$) + * Copyright (C) $$Year-Rel$$ The Jalview Authors * * This file is part of Jalview. * @@ -23,11 +23,13 @@ package jalview.datamodel; import static org.testng.AssertJUnit.assertEquals; import static org.testng.AssertJUnit.assertFalse; +import jalview.gui.JvOptionPane; import jalview.util.MapList; import java.util.Iterator; import org.testng.Assert; +import org.testng.annotations.BeforeClass; import org.testng.annotations.Test; /** @@ -38,6 +40,14 @@ import org.testng.annotations.Test; */ public class AlignedCodonIteratorTest { + + @BeforeClass(alwaysRun = true) + public void setUpJvOptionPane() + { + JvOptionPane.setInteractiveMode(false); + JvOptionPane.setMockResponse(JvOptionPane.CANCEL_OPTION); + } + /** * Test normal case for iterating over aligned codons. */ @@ -150,4 +160,31 @@ public class AlignedCodonIteratorTest assertEquals("Q", codon.product); assertFalse(codons.hasNext()); } + + /** + * Test for a case with sequence (and mappings) not starting at 1 + */ + @Test(groups = { "Functional" }) + public void testNext_withOffset() + { + SequenceI from = new Sequence("Seq1", "-CgC-C-cCtAG-AtG-Gc", 7, 20); + from.createDatasetSequence(); + SequenceI to = new Sequence("Seq1/10-12", "-PQ-R-"); + to.createDatasetSequence(); + MapList map = new MapList(new int[] { 7, 7, 9, 10, 12, 12, 14, 16, 18, + 19 }, new int[] { 10, 12 }, 3, 1); + Mapping m = new Mapping(to.getDatasetSequence(), map); + + Iterator codons = m.getCodonIterator(from, '-'); + AlignedCodon codon = codons.next(); + assertEquals("[1, 3, 5]", codon.toString()); + assertEquals("P", codon.product); + codon = codons.next(); + assertEquals("[8, 10, 11]", codon.toString()); + assertEquals("Q", codon.product); + codon = codons.next(); + assertEquals("[13, 15, 17]", codon.toString()); + assertEquals("R", codon.product); + assertFalse(codons.hasNext()); + } }