tim@52: /** tim@52: * tim@52: */ tim@52: package de.intevation.gnv.artifacts; tim@52: tim@52: import javax.xml.parsers.DocumentBuilderFactory; tim@52: import javax.xml.parsers.ParserConfigurationException; tim@52: tim@52: import org.apache.log4j.BasicConfigurator; tim@52: import org.apache.log4j.Logger; tim@52: import org.w3c.dom.Document; tim@52: tim@52: import de.intevation.artifactdatabase.Config; tim@52: import de.intevation.artifactdatabase.FactoryBootstrap; tim@52: import de.intevation.artifacts.Artifact; tim@52: import de.intevation.artifacts.ArtifactFactory; tim@52: import de.intevation.gnv.artifacts.context.GNVArtifactContext; tim@52: import de.intevation.gnv.artifacts.context.GNVArtifactContextFactory; tim@52: import junit.framework.TestCase; tim@52: tim@52: /** tim@52: * @author Tim Englich tim@52: * tim@52: */ tim@52: public class GNVArtifactsTestCase extends TestCase { tim@52: tim@52: /** tim@52: * the logger, used to log exceptions and additonaly information tim@52: */ tim@52: private static Logger log = null; tim@52: tim@52: static { tim@52: BasicConfigurator.configure(); tim@52: log = Logger.getLogger(GNVArtifactContext.class); tim@52: } tim@52: tim@52: private String configurationFile = "src/test/ressources/GNVArtifactsTestCase_Configuration.xml"; tim@52: tim@52: private FactoryBootstrap bootstrap = null; tim@52: /** tim@52: * Constructor tim@52: * @param name tim@52: */ tim@52: public GNVArtifactsTestCase(String name) { tim@52: super(name); tim@52: } tim@52: tim@52: /** tim@52: * @see junit.framework.TestCase#setUp() tim@52: */ tim@52: protected void setUp() throws Exception { tim@52: log.debug("GNVArtifactsTestCase.setUp"); tim@52: super.setUp(); tim@52: log.info(Config.CONFIG_PROPERTY + " ==> "+configurationFile); tim@52: System.setProperty(Config.CONFIG_PROPERTY, configurationFile); tim@52: log.info("Bootstrap wird initialisiert."); tim@52: bootstrap = new FactoryBootstrap(); tim@52: bootstrap.boot(); tim@52: } tim@52: tim@52: public void testTimeSeriesArtifact(){ tim@52: log.debug("GNVArtifactsTestCase.testTimeSeriesArtifact"); tim@52: String artefactName = "timeSeries"; tim@52: ArtifactFactory artifactFactory = this.getArtifactFactory(artefactName); tim@52: assertNotNull(artifactFactory); tim@52: log.debug("TimeSeries-ArtifactFactory is available"); tim@52: Artifact artifact = artifactFactory.createArtifact(""+System.currentTimeMillis(),bootstrap.getContext()); tim@52: assertNotNull(artifact); tim@52: log.debug("TimeSeries-Artifact is available"); tim@52: tim@52: Document indata = this.getDocument(); tim@52: Document outData = this.createOutputDocument(); tim@52: artifact.feed(indata, bootstrap.getContext()); tim@52: artifact.advance(outData, bootstrap.getContext()); tim@52: Document outputData = artifact.describe(bootstrap.getContext()); tim@52: tim@52: tim@52: tim@52: } tim@52: private Document getDocument(){ tim@52: return this.createOutputDocument(); tim@52: } tim@52: tim@52: private Document createOutputDocument(){ tim@52: try { tim@52: return DocumentBuilderFactory tim@52: .newInstance() tim@52: .newDocumentBuilder() tim@52: .newDocument(); tim@52: } tim@52: catch (ParserConfigurationException e) { tim@52: log.error(e,e); tim@52: } tim@52: return null; tim@52: } tim@52: tim@52: /** tim@52: * @param artefactName tim@52: */ tim@52: private ArtifactFactory getArtifactFactory(String artefactName){ tim@52: log.debug("GNVArtifactsTestCase.getArtifactFactory"); tim@52: ArtifactFactory[] artifactFactories = bootstrap.getArtifactFactories(); tim@52: for (int i = 0; i < artifactFactories.length; i++){ tim@52: if (artifactFactories[i].getName().equals(artefactName)){ tim@52: log.debug("ArtifactFactory wurde gefunden."); tim@52: return artifactFactories[i]; tim@52: } tim@52: } tim@52: return null; tim@52: } tim@52: tim@52: }