X-Git-Url: http://source.jalview.org/gitweb/?a=blobdiff_plain;f=test%2Fjalview%2Fgui%2FSequenceRendererTest.java;h=359377aced9097432fb309eff1a0d947525fbedb;hb=09d3b755d9b00f5c3acb44049aedd49361dc0690;hp=0f3d4f6e2edbf2743a8ebfcf8c7a4c028682ddf7;hpb=fddf3084802b37e5cee17829e32692a4aac3e60d;p=jalview.git diff --git a/test/jalview/gui/SequenceRendererTest.java b/test/jalview/gui/SequenceRendererTest.java index 0f3d4f6..359377a 100644 --- a/test/jalview/gui/SequenceRendererTest.java +++ b/test/jalview/gui/SequenceRendererTest.java @@ -1,37 +1,89 @@ +/* + * Jalview - A Sequence Alignment Editor and Viewer ($$Version-Rel$$) + * Copyright (C) $$Year-Rel$$ The Jalview Authors + * + * This file is part of Jalview. + * + * Jalview is free software: you can redistribute it and/or + * modify it under the terms of the GNU General Public License + * as published by the Free Software Foundation, either version 3 + * of the License, or (at your option) any later version. + * + * Jalview is distributed in the hope that it will be useful, but + * WITHOUT ANY WARRANTY; without even the implied warranty + * of MERCHANTABILITY or FITNESS FOR A PARTICULAR + * PURPOSE. See the GNU General Public License for more details. + * + * You should have received a copy of the GNU General Public License + * along with Jalview. If not, see . + * The Jalview Authors are detailed in the 'AUTHORS' file. + */ package jalview.gui; -import static org.testng.AssertJUnit.assertEquals; +import static org.testng.Assert.assertEquals; +import jalview.bin.Jalview; import jalview.datamodel.Alignment; import jalview.datamodel.AlignmentI; import jalview.datamodel.Sequence; +import jalview.datamodel.SequenceGroup; import jalview.datamodel.SequenceI; +import jalview.renderer.ResidueShader; +import jalview.renderer.ResidueShaderI; import jalview.schemes.ZappoColourScheme; import java.awt.Color; +import org.testng.annotations.BeforeClass; +import org.testng.annotations.BeforeMethod; import org.testng.annotations.Test; public class SequenceRendererTest { + AlignmentI al; + AlignViewport av; - @Test(groups ={ "Functional" }) - public void testGetResidueBoxColour_zappo() + SequenceI seq1; + + @BeforeClass(alwaysRun = true) + public static void setUpBeforeClass() throws Exception { - SequenceI seq = new Sequence("name", "MATVLGSPRAPAFF"); // FER1_MAIZE... - AlignmentI al = new Alignment(new SequenceI[] - { seq }); - final AlignViewport av = new AlignViewport(al); - SequenceRenderer sr = new SequenceRenderer(av); - av.setGlobalColourScheme(new ZappoColourScheme()); + Jalview.main( + new String[] + { "-nonews", "-props", "test/jalview/testProps.jvprops" }); + } - // @see ResidueProperties.zappo - assertEquals(Color.pink, sr.getResidueColour(seq, 0, null)); // M - assertEquals(Color.green, sr.getResidueColour(seq, 2, null)); // T - assertEquals(Color.magenta, sr.getResidueColour(seq, 5, null)); // G - assertEquals(Color.orange, sr.getResidueColour(seq, 12, null)); // F + @BeforeMethod(alwaysRun = true) + public void setUp() + { + seq1 = new Sequence("Seq1", "ABCEEEABCABC"); + SequenceI seq2 = new Sequence("Seq2", "ABCABCABCABC"); + SequenceI seq3 = new Sequence("Seq3", "ABCABCABCABC"); + SequenceI[] seqs = new SequenceI[] { seq1, seq2, seq3 }; + al = new Alignment(seqs); + al.setDataset(null); + av = new AlignViewport(al); } - // TODO more tests for getResidueBoxColour covering groups, feature rendering, - // gaps, overview... + @Test(groups = "Functional") + public void testGetResidueColour_WithGroup() + { + SequenceRenderer sr = new SequenceRenderer(av); + SequenceGroup sg = new SequenceGroup(); + sg.addSequence(seq1, false); + sg.setStartRes(3); + sg.setEndRes(5); + + ResidueShaderI rs = new ResidueShader(); + rs.setColourScheme(new ZappoColourScheme()); + sg.setGroupColourScheme(rs); + + av.getAlignment().addGroup(sg); + + // outside group residues are white + assertEquals(Color.white, sr.getResidueColour(seq1, 1, null)); + + // within group use Zappo scheme - E = red + assertEquals(Color.red, sr.getResidueColour(seq1, 3, null)); + } }