X-Git-Url: http://source.jalview.org/gitweb/?a=blobdiff_plain;f=test%2Fjalview%2Fgui%2FStructureChooserTest.java;h=1e41a16146a5987267c6492d755e49ff2048f3d7;hb=4d9ad51dc8a445c2f1fb02b997e13bd945fa8ad2;hp=078174f6c66aad5714be144f11cb7f2d0c055b01;hpb=d9cedb863c0d5b665b8cdde3f8791d8a96030c6b;p=jalview.git diff --git a/test/jalview/gui/StructureChooserTest.java b/test/jalview/gui/StructureChooserTest.java index 078174f..1e41a16 100644 --- a/test/jalview/gui/StructureChooserTest.java +++ b/test/jalview/gui/StructureChooserTest.java @@ -1,30 +1,50 @@ +/* + * 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.junit.Assert.assertEquals; -import static org.junit.Assert.assertTrue; +import static org.testng.AssertJUnit.assertEquals; +import static org.testng.AssertJUnit.assertTrue; + import jalview.datamodel.DBRefEntry; +import jalview.datamodel.DBRefSource; import jalview.datamodel.PDBEntry; import jalview.datamodel.Sequence; import jalview.datamodel.SequenceI; -import jalview.ws.dbsources.PDBRestClient.PDBDocField; -import java.util.ArrayList; -import java.util.List; import java.util.Vector; -import org.junit.After; -import org.junit.Before; -import org.junit.Test; +import org.testng.annotations.AfterMethod; +import org.testng.annotations.BeforeMethod; +import org.testng.annotations.Test; public class StructureChooserTest { Sequence seq; - @Before + @BeforeMethod(alwaysRun = true) public void setUp() throws Exception { - seq = new Sequence("Test_Seq", "ABCDEFGHIJKLMNOPQRSTUVWXYZ", 1, 26); - seq.setDatasetSequence(seq); + seq = new Sequence("PDB|4kqy|4KQY|A", "ABCDEFGHIJKLMNOPQRSTUVWXYZ", 1, + 26); + seq.createDatasetSequence(); for (int x = 1; x < 5; x++) { DBRefEntry dbRef = new DBRefEntry(); @@ -41,60 +61,91 @@ public class StructureChooserTest seq.setPDBId(pdbIds); } - @After + @AfterMethod(alwaysRun = true) public void tearDown() throws Exception { seq = null; } - @Test - public void getPDBIdColumIndexTest() - { - List wantedFields = new ArrayList(); - wantedFields.add(PDBDocField.MOLECULE_TYPE); - wantedFields.add(PDBDocField.GENUS); - wantedFields.add(PDBDocField.GENE_NAME); - wantedFields.add(PDBDocField.TITLE); - wantedFields.add(PDBDocField.PDB_ID); - assertEquals(5, StructureChooser.getPDBIdColumIndex(wantedFields)); - } - - @Test + @Test(groups = { "Functional" }) public void buildQueryTest() { + String query = StructureChooser.buildQuery(seq); + assertEquals("pdb_id:1tim", query); + System.out.println("seq >>>> " + seq); + seq.getAllPDBEntries().clear(); + query = StructureChooser.buildQuery(seq); assertEquals( - "1tim OR text:XYZ_1 OR text:XYZ_2 OR text:XYZ_3 OR text:XYZ_4", - StructureChooser.buildQuery(seq)); + "text:XYZ_1 OR text:XYZ_2 OR text:XYZ_3 OR text:XYZ_4 OR text:4kqy", + query); + seq.setDBRefs(null); + query = StructureChooser.buildQuery(seq); + assertEquals("text:4kqy", query); + + DBRefEntry uniprotDBRef = new DBRefEntry(); + uniprotDBRef.setAccessionId("P12345"); + uniprotDBRef.setSource(DBRefSource.UNIPROT); + seq.addDBRef(uniprotDBRef); + + DBRefEntry pdbDBRef = new DBRefEntry(); + pdbDBRef.setAccessionId("1XYZ"); + pdbDBRef.setSource(DBRefSource.PDB); + seq.addDBRef(pdbDBRef); + + for (int x = 1; x < 5; x++) + { + DBRefEntry dbRef = new DBRefEntry(); + dbRef.setAccessionId("XYZ_" + x); + seq.addDBRef(dbRef); + } + query = StructureChooser.buildQuery(seq); + assertEquals( + "uniprot_accession:P12345 OR uniprot_id:P12345 OR pdb_id:1xyz", + query); } - @Test - public void populateFilterComboBoxTest() + @Test(groups = { "Functional" }) + public void populateFilterComboBoxTest() throws InterruptedException { - SequenceI[] selectedSeqs = new SequenceI[] - { seq }; - StructureChooser sc = new StructureChooser(selectedSeqs, seq, - null); - sc.populateFilterComboBox(); + SequenceI[] selectedSeqs = new SequenceI[] { seq }; + StructureChooser sc = new StructureChooser(selectedSeqs, seq, null); + sc.populateFilterComboBox(false); int optionsSize = sc.getCmbFilterOption().getItemCount(); - assertEquals(2, optionsSize); // if structures are not discovered then don't + assertEquals(3, optionsSize); // if structures are not discovered then don't // populate filter options - sc.setStructuresDiscovered(true); - sc.populateFilterComboBox(); + sc.populateFilterComboBox(true); optionsSize = sc.getCmbFilterOption().getItemCount(); - assertTrue(optionsSize > 2); // if structures are found, filter options + assertTrue(optionsSize > 3); // if structures are found, filter options // should be populated } - @Test + @Test(groups = { "Functional" }) public void fetchStructuresInfoTest() { - SequenceI[] selectedSeqs = new SequenceI[] - { seq }; + SequenceI[] selectedSeqs = new SequenceI[] { seq }; StructureChooser sc = new StructureChooser(selectedSeqs, seq, null); sc.fetchStructuresMetaData(); assertTrue(sc.getDiscoveredStructuresSet() != null); assertTrue(sc.getDiscoveredStructuresSet().size() > 0); } + + @Test(groups = { "Functional" }) + public void sanitizeSeqNameTest() + { + String name = "ab_cdEF|fwxyz012349"; + assertEquals(name, StructureChooser.sanitizeSeqName(name)); + + // remove a [nn] substring + name = "abcde12[345]fg"; + assertEquals("abcde12fg", StructureChooser.sanitizeSeqName(name)); + + // remove characters other than a-zA-Z0-9 | or _ + name = "ab[cd],.\t£$*!- \\\"@:e"; + assertEquals("abcde", StructureChooser.sanitizeSeqName(name)); + + name = "abcde12[345a]fg"; + assertEquals("abcde12345afg", StructureChooser.sanitizeSeqName(name)); + } }