tim@345: /**
tim@345:  *
tim@345:  */
tim@345: package de.intevation.gnv.artifacts;
tim@345: 
tim@345: import java.io.FileOutputStream;
tim@345: 
tim@345: import org.apache.log4j.Logger;
tim@345: import org.w3c.dom.Document;
tim@345: 
tim@345: import de.intevation.artifacts.Artifact;
tim@345: import de.intevation.artifacts.ArtifactFactory;
tim@345: import de.intevation.artifacts.CallContext;
tim@345: 
tim@345: /**
tim@345:  * @author Tim Englich <tim.englich@intevation.de>
tim@345:  *
tim@345:  */
tim@345: public class TimeSeriesPointTimeSeriesTestCase extends GNVArtifactsTestCaseBase {
tim@345: 
tim@345:     
tim@345:     /**
tim@345:      * the logger, used to log exceptions and additonaly information
tim@345:      */
tim@345:     private static Logger log = Logger.getLogger(TimeSeriesPointTimeSeriesTestCase.class);
tim@345:     
tim@345:     /**
tim@345:      * Constructor
tim@345:      */
tim@345:     public TimeSeriesPointTimeSeriesTestCase() {
tim@345:     }
tim@345: 
tim@345:     /**
tim@345:      * Constructor
tim@345:      * @param name
tim@345:      */
tim@345:     public TimeSeriesPointTimeSeriesTestCase(String name) {
tim@345:         super(name);
tim@345:     }
tim@345: 
tim@345:     /**
tim@345:      * @see de.intevation.gnv.artifacts.GNVArtifactsTestCaseBase#testArtifact()
tim@345:      */
tim@345:     @Override
tim@345:     public void testArtifact() {
tim@345:         log.debug("GNVArtifactsTestCase.testTimeSeriesArtifact");
tim@345:         try {
tim@345:             String artefactName = "fis_marnet";
tim@345:             ArtifactFactory artifactFactory = this
tim@345:                     .getArtifactFactory(artefactName);
tim@345:             assertNotNull(artifactFactory);
tim@345:             log.debug("TimeSeries-ArtifactFactory is available");
tim@595:             
tim@595:             Artifact artifact = createArtifact(artifactFactory);
tim@345:     
tim@485:             CallContext cc = createCallContext(artifactFactory);
tim@345:     
tim@345:             // Erster Schritt
tim@345:     
tim@345:             Document describeDocument = this.readDocument("src/test/ressources/timeseries/timeseries_describe.xml");
tim@345:             
tim@345:             int steps = 6;
tim@345:             
tim@345:             for (int i = 1; i <= steps; i++){
tim@345:             
tim@345:                 this.doNextStep(
tim@345:                             artifact,
tim@345:                             cc,
tim@345:                             "src/test/ressources/timeseries/" +
tim@345:                             "timeseries_step_0"+i+"_feed.xml",
tim@345:                             "src/test/ressources/timeseries/" +
tim@345:                             "timeseries_step_0"+i+"_advance.xml", 
tim@345:                             describeDocument);
tim@345:             }
tim@345:             
tim@345:             Document outputData = artifact.describe(describeDocument,cc);
tim@345:             FileOutputStream fos = null;
tim@345:             FileOutputStream fos2 = null;
tim@345:             FileOutputStream fos3 = null;
tim@345:             FileOutputStream fos4 = null;
tim@345:             try {
tim@345:                 fos = new FileOutputStream("src/test/results/timeseries"
tim@345:                                            + System.currentTimeMillis()
tim@345:                                            + ".png");
tim@345:                 fos2 = new FileOutputStream("src/test/results/timeseries"
tim@345:                                             + System.currentTimeMillis()
tim@345:                                             + ".xml");
tim@345:                 fos3 = new FileOutputStream("src/test/results/timeseries"
tim@345:                                             + System.currentTimeMillis()
tim@345:                                             + ".csv");
tim@345:                 fos4 = new FileOutputStream("src/test/results/timeseries"
tim@345:                         + System.currentTimeMillis()
tim@345:                         + ".odv");
tim@345:             
tim@345:                 artifact.out(this
tim@345:                              .readDocument("src/test/ressources/timeseries/timeseries_step_06_out_chart.xml"),
tim@345:                                            fos, cc);
tim@345:                 artifact.out(this
tim@345:                         .readDocument("src/test/ressources/timeseries/timeseries_step_06_out_statistics.xml"),
tim@345:                                       fos2, cc);
tim@345:                 artifact.out(this
tim@345:                         .readDocument("src/test/ressources/timeseries/timeseries_step_06_out_csv.xml"),
tim@345:                                       fos3, cc);
tim@345:                 artifact.out(this
tim@345:                         .readDocument("src/test/ressources/timeseries/timeseries_step_06_out_odv.xml"),
tim@345:                                       fos4, cc);
tim@345:             } catch (Exception e) {
tim@345:                 log.error(e, e);
tim@345:                 fail();
tim@345:             } finally {
tim@345:                 try {
tim@345:                     fos.flush();
tim@345:                     fos.close();
tim@345:                 } catch (Exception e) {
tim@345:                     log.error(e, e);
tim@345:                 }
tim@345:             }
tim@345:         } catch (Exception e) {
tim@345:             log.error(e, e);
tim@345:             fail();
tim@345:         }
tim@345:     }
tim@345: 
tim@345: }