Mercurial > dive4elements > gnv-client
view gnv-artifacts/src/test/java/de/intevation/gnv/artifacts/GNVArtifactsTestCase.java @ 69:f24c825144bc
TestCase Refactored to the new Folder-Based Configuration.
Also added further steps to the Testcase.
gnv-artifacts/trunk@56 c6561f87-3c4e-4783-a992-168aeb5c3f6f
author | Tim Englich <tim.englich@intevation.de> |
---|---|
date | Thu, 10 Sep 2009 07:57:30 +0000 |
parents | 9f57053d0384 |
children | 1fece4da4f2f |
line wrap: on
line source
/** * */ package de.intevation.gnv.artifacts; import java.io.ByteArrayInputStream; import java.io.File; import java.io.FileNotFoundException; import java.io.FileOutputStream; import java.io.IOException; import java.io.StringWriter; import javax.xml.parsers.DocumentBuilder; import javax.xml.parsers.DocumentBuilderFactory; import javax.xml.parsers.ParserConfigurationException; import javax.xml.transform.Transformer; import javax.xml.transform.TransformerConfigurationException; import javax.xml.transform.TransformerException; import javax.xml.transform.TransformerFactory; import javax.xml.transform.TransformerFactoryConfigurationError; import javax.xml.transform.dom.DOMSource; import javax.xml.transform.stream.StreamResult; import org.apache.log4j.BasicConfigurator; import org.apache.log4j.Logger; import org.w3c.dom.Document; import org.xml.sax.SAXException; import de.intevation.artifactdatabase.Config; import de.intevation.artifactdatabase.FactoryBootstrap; import de.intevation.artifacts.Artifact; import de.intevation.artifacts.ArtifactFactory; import de.intevation.gnv.artifacts.context.GNVArtifactContext; import junit.framework.TestCase; /** * @author Tim Englich <tim.englich@intevation.de> * */ public class GNVArtifactsTestCase extends TestCase { /** * the logger, used to log exceptions and additonaly information */ private static Logger log = null; static { BasicConfigurator.configure(); log = Logger.getLogger(GNVArtifactContext.class); } private String configurationDir = "src/test/ressources/"; private FactoryBootstrap bootstrap = null; /** * Constructor * @param name */ public GNVArtifactsTestCase(String name) { super(name); } /** * @see junit.framework.TestCase#setUp() */ protected void setUp() throws Exception { log.debug("GNVArtifactsTestCase.setUp"); super.setUp(); log.info(Config.CONFIG_DIR + " ==> "+configurationDir); System.setProperty(Config.CONFIG_DIR, configurationDir); log.info("Bootstrap wird initialisiert."); bootstrap = new FactoryBootstrap(); bootstrap.boot(); } public void testTimeSeriesArtifact(){ log.debug("GNVArtifactsTestCase.testTimeSeriesArtifact"); String artefactName = "timeSeries"; ArtifactFactory artifactFactory = this.getArtifactFactory(artefactName); assertNotNull(artifactFactory); log.debug("TimeSeries-ArtifactFactory is available"); Artifact artifact = artifactFactory.createArtifact(""+System.currentTimeMillis(),bootstrap.getContext()); assertNotNull(artifact); log.debug("TimeSeries-Artifact is available"); // Erster Schritt Document outputData = artifact.describe(bootstrap.getContext()); this.writeDocument2Log(outputData); artifact.feed(this.readDocument("src/test/ressources/timeseries/timeseries_step_01_feed.xml"), bootstrap.getContext()); outputData = artifact.advance(this.readDocument("src/test/ressources/timeseries/timeseries_step_01_advance.xml"), bootstrap.getContext()); this.writeDocument2Log(outputData); // Zweiter Schritt outputData = artifact.describe(bootstrap.getContext()); this.writeDocument2Log(outputData); artifact.feed(this.readDocument("src/test/ressources/timeseries/timeseries_step_02_feed.xml"), bootstrap.getContext()); outputData = artifact.advance(this.readDocument("src/test/ressources/timeseries/timeseries_step_02_advance.xml"), bootstrap.getContext()); this.writeDocument2Log(outputData); // Dritter Schritt outputData = artifact.describe(bootstrap.getContext()); this.writeDocument2Log(outputData); artifact.feed(this.readDocument("src/test/ressources/timeseries/timeseries_step_03_feed.xml"), bootstrap.getContext()); outputData = artifact.advance(this.readDocument("src/test/ressources/timeseries/timeseries_step_03_advance.xml"), bootstrap.getContext()); this.writeDocument2Log(outputData); // Vierter Schritt outputData = artifact.describe(bootstrap.getContext()); this.writeDocument2Log(outputData); artifact.feed(this.readDocument("src/test/ressources/timeseries/timeseries_step_04_feed.xml"), bootstrap.getContext()); outputData = artifact.advance(this.readDocument("src/test/ressources/timeseries/timeseries_step_04_advance.xml"), bootstrap.getContext()); this.writeDocument2Log(outputData); // F�nfter Schritt outputData = artifact.describe(bootstrap.getContext()); artifact.feed(this.readDocument("src/test/ressources/timeseries/timeseries_step_05_feed.xml"), bootstrap.getContext()); byte[] result = artifact.out(this.readDocument("src/test/ressources/timeseries/timeseries_step_05_out.xml"), bootstrap.getContext()); this.createFile(result, "src/test/results/timeseriesdiagramm"+System.currentTimeMillis()+".png"); } protected void createFile(byte[] content, String fileName){ try { FileOutputStream fos = new FileOutputStream(new File(fileName)); ByteArrayInputStream bis = new ByteArrayInputStream(content); byte[] buf = new byte[4096]; while (bis.read(buf) > 0){ fos.write(buf); } fos.flush(); fos.close(); } catch (FileNotFoundException e) { log.error(e,e); } catch (IOException e) { log.error(e,e); } } /** * @param artefactName */ private ArtifactFactory getArtifactFactory(String artefactName){ log.debug("GNVArtifactsTestCase.getArtifactFactory"); ArtifactFactory[] artifactFactories = bootstrap.getArtifactFactories(); for (int i = 0; i < artifactFactories.length; i++){ if (artifactFactories[i].getName().equals(artefactName)){ log.debug("ArtifactFactory wurde gefunden."); return artifactFactories[i]; } } return null; } protected void writeDocument2Log(Document document){ try { TransformerFactory transformerFactory = TransformerFactory.newInstance(); Transformer transformer = transformerFactory.newTransformer(); DOMSource source = new DOMSource(document); StringWriter sw = new StringWriter(); StreamResult result = new StreamResult(sw); transformer.transform(source, result); log.debug(sw.getBuffer().toString()); } catch (TransformerConfigurationException e) { log.error(e,e); } catch (TransformerFactoryConfigurationError e) { log.error(e,e); } catch (TransformerException e) { log.error(e,e); } } protected Document readDocument(String fileName){ Document returnValue = null; try { DocumentBuilderFactory docBuilderFactory = DocumentBuilderFactory.newInstance(); DocumentBuilder docBuilder = docBuilderFactory.newDocumentBuilder(); returnValue = docBuilder.parse (new File(fileName)); } catch (ParserConfigurationException e) { log.error(e,e); } catch (SAXException e) { log.error(e,e); } catch (IOException e) { log.error(e,e); } return returnValue; } }