X-Git-Url: http://source.jalview.org/gitweb/?a=blobdiff_plain;f=test%2Fjalview%2Furls%2FCustomUrlProviderTest.java;h=f9ed893d9ad03cccf01082a27c85f6d567102f5e;hb=e88567692c9f1f3adfb9764a802474e83ff4c69f;hp=35ec5ff8a9bb3c5fa91c86b20634491136ecd077;hpb=a889a61789f15e79ecde7043cddfdea18ad00166;p=jalview.git diff --git a/test/jalview/urls/CustomUrlProviderTest.java b/test/jalview/urls/CustomUrlProviderTest.java index 35ec5ff..f9ed893 100644 --- a/test/jalview/urls/CustomUrlProviderTest.java +++ b/test/jalview/urls/CustomUrlProviderTest.java @@ -24,6 +24,7 @@ import static org.testng.AssertJUnit.assertEquals; import static org.testng.AssertJUnit.assertFalse; import static org.testng.AssertJUnit.assertTrue; +import jalview.urls.api.UrlProviderI; import jalview.util.UrlConstants; import java.util.Arrays; @@ -40,6 +41,9 @@ public class CustomUrlProviderTest + "TEST2|http://address/$SEQUENCE_ID$|SRS|" + "http://theSRSlink/$SEQUENCE_ID$"; + private static final String unselectedList = "NON1|http://x/y/$DB_ACCESSION$|" + + "NON2|http://a/b/c/$DB_ACCESSION"; + private static final HashMap urlMap = new HashMap() { { @@ -50,15 +54,29 @@ public class CustomUrlProviderTest } }; + private static final HashMap unselUrlMap = new HashMap() + { + { + put("NON1", "http://x/y/$DB_ACCESSION$"); + put("NON2", "http://a/b/c/$DB_ACCESSION"); + } + }; + private static final String[] dlinks = { "TEST|http://someurl.blah/$DB_ACCESSION$", "ANOTHER|http://test/t$SEQUENCE_ID$", "TEST2|http://address/$SEQUENCE_ID$", UrlConstants.DEFAULT_STRING }; + private static final String[] unselDlinks = { + "NON1|http://x/y/$DB_ACCESSION$", "NON2|http://a/b/c/$DB_ACCESSION" }; + private static final Vector displayLinks = new Vector( Arrays.asList(dlinks)); + private static final Vector unselDisplayLinks = new Vector( + Arrays.asList(unselDlinks)); + private static final String[] dlinks2 = { "a|http://x.y.z/$SEQUENCE_ID$" }; private static final Vector displayLinks2 = new Vector( @@ -80,27 +98,28 @@ public class CustomUrlProviderTest @Test(groups = { "Functional" }) public void testDefaultUrl() { - UrlProviderI customProv = new CustomUrlProvider(cachedList); + UrlProviderI customProv = new CustomUrlProvider(cachedList, + unselectedList); // default url can be set - assertTrue(customProv.setDefaultUrl("ANOTHER")); + assertTrue(customProv.setPrimaryUrl("ANOTHER")); // supplied replacement id must be more than 4 chars - String result = customProv.getDefaultUrl("123"); + String result = customProv.getPrimaryUrl("123"); assertEquals(null, result); // default url can be retrieved given a sequence id - result = customProv.getDefaultUrl("seqid"); + result = customProv.getPrimaryUrl("seqid"); assertEquals("http://test/tseqid", result); // if there is no default url it sets the default to null - assertFalse(customProv.setDefaultUrl("No default")); - result = customProv.getDefaultUrl("testid"); + assertFalse(customProv.setPrimaryUrl("No default")); + result = customProv.getPrimaryUrl("testid"); assertEquals(null, result); // choosing the default picks the DEFAULT_STRING option - customProv.chooseDefaultUrl(); - result = customProv.getDefaultUrl("seqid"); + customProv.choosePrimaryUrl(); + result = customProv.getPrimaryUrl("seqid"); assertEquals( UrlConstants.DEFAULT_STRING.split("\\|")[1].split("\\$")[0] + "seqid", @@ -114,22 +133,31 @@ public class CustomUrlProviderTest public void testUrlLinks() { // creation from cached url list works + old links upgraded - UrlProviderI customProv = new CustomUrlProvider(cachedList); + UrlProviderI customProv = new CustomUrlProvider(cachedList, + unselectedList); assertTrue(displayLinks.containsAll(customProv.getLinksForMenu())); // creation from map works + old links upgraded - UrlProviderI customProv2 = new CustomUrlProvider(urlMap); + UrlProviderI customProv2 = new CustomUrlProvider(urlMap, unselUrlMap); assertTrue(displayLinks.containsAll(customProv2.getLinksForMenu())); // writing url links as a string works // because UrlProvider does not guarantee order of links, we can't just // compare the output of writeUrlsAsString to a string, hence the hoops here - String result = customProv.writeUrlsAsString(); - UrlProviderI up = new CustomUrlProvider(result); + String result = customProv.writeUrlsAsString(true); + UrlProviderI up = new CustomUrlProvider(result, ""); assertTrue(displayLinks.containsAll(up.getLinksForMenu())); - result = customProv2.writeUrlsAsString(); - UrlProviderI up2 = new CustomUrlProvider(result); + result = customProv.writeUrlsAsString(false); + up = new CustomUrlProvider("", result); + assertTrue(unselDisplayLinks.containsAll(up.getLinksForMenu())); + + result = customProv2.writeUrlsAsString(true); + UrlProviderI up2 = new CustomUrlProvider(result, ""); + assertTrue(displayLinks.containsAll(up2.getLinksForMenu())); + + result = customProv2.writeUrlsAsString(false); + up2 = new CustomUrlProvider("", result); assertTrue(displayLinks.containsAll(up2.getLinksForMenu())); } }