/** * '$RCSfile: EMLParserTest.java,v $' * Copyright: 2000 Regents of the University of California and the * National Center for Ecological Analysis and Synthesis * * '$Author: walbridge $' * '$Date: 2008-11-05 23:00:46 $' * '$Revision: 1.6 $' * * This program 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 2 of the License, or * (at your option) any later version. * * This program 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 this program; if not, write to the Free Software * Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA 02111-1307 USA */ package org.ecoinformatics.emltest; import java.io.File; import java.util.Vector; import junit.framework.Test; import junit.framework.TestCase; import junit.framework.TestSuite; import org.ecoinformatics.eml.EMLParser; /** * A JUnit test for testing the EMLParser * * @author Chad Berkley */ public class EMLParserTest extends TestCase { private final static String TEST_DIR = "./src/test/resources"; private final static String INVALID_DIR = TEST_DIR + "/invalidEML"; private final static String ERROR1 = INVALID_DIR + "/eml-error1.xml"; private final static String ERROR3 = INVALID_DIR + "/eml-error3.xml"; private final static String ERROR4 = INVALID_DIR + "/eml-error4.xml"; private EMLParser emlp; /** * Constructor to build the test * * @param name the name of the test method */ public EMLParserTest(String name) { super(name); } /** Establish a testing framework by initializing appropriate objects */ public void setUp() { } /** Release any objects after tests are complete */ public void tearDown() { } /** * Create a suite of tests to be run together * * @return The test suite */ public static Test suite() { TestSuite suite = new TestSuite(); suite.addTest(new EMLParserTest("initialize")); suite.addTest(new EMLParserTest("testParse")); return suite; } /** * Check that the testing framework is functioning properly with a trivial * assertion. */ public void initialize() { assertTrue(true); } public void testParse() { // all valid documents should validate File testDir = new File(TEST_DIR); Vector fileList = getXmlFiles(testDir); for (int i=0; i < fileList.size(); i++) { File testFile = (File)fileList.elementAt(i); try { System.err.println("Validating file: " + testFile.getName()); emlp = new EMLParser(testFile); } catch (Exception e) { e.printStackTrace(System.err); fail("Document NOT valid!\n\n" + e.getClass().getName() + "(" + e.getMessage() + ")" ); } } // at least one invalid should not validate // NOTE: EMLParser does not validate against the schema (see SAXParserTest) int failures = 0; File invalidDir = new File(INVALID_DIR); Vector invalidList = getXmlFiles(invalidDir); for (int i=0; i < invalidList.size(); i++) { File invalidFile = (File)invalidList.elementAt(i); try { System.err.println("Invalidating file: " + invalidFile.getName()); emlp = new EMLParser(invalidFile); } catch (Exception e) { failures++; assertTrue(e.getMessage() != null); break; } } if (failures == 0) { fail("Error: An EMLParserException should have been thrown at least once."); } try { File f = new File(ERROR1); emlp = new EMLParser(f); fail("Error 1. An EMLParserException should have been thrown."); } catch(Exception e) { assertTrue(e.getMessage().indexOf("Error in xml document. " + "This EML document is not valid because the id 23445 occurs more " + "than once. IDs must be unique.") != -1); } try { File f = new File(ERROR3); emlp = new EMLParser(f); fail("Error 3. An EMLParserException should have been thrown."); } catch(Exception e) { assertTrue(e.getMessage().equals("Error processing keyrefs: " + "//references : Error in xml document. This EML instance is " + "invalid because referenced id 23447 does not exist in the " + "given keys.")); } try { File f = new File(ERROR4); emlp = new EMLParser(f); fail("Error 3. An EMLParserException should have been thrown."); } catch(Exception e) { //System.out.println(e.getMessage()); assertTrue(e.getMessage().equals("Error processing keyrefs: " + "//references : Error in xml document. This EML instance is invalid " + "because this element has an id and it is being used in " + "a keyref expression.")); } } /** * Get the list of files in a directory. * * @param directory the directory to list * @return a vector of File objects in the directory */ private Vector getXmlFiles(File directory) { String[] files = directory.list(); Vector fileList = new Vector(); for (int i=0; i < files.length; i++) { String filename = files[i]; File currentFile = new File(directory, filename); if (currentFile.isFile() && filename.endsWith(".xml")) { fileList.addElement(currentFile); } } return fileList; } }