tim@345: package de.intevation.gnv.artifacts;
tim@345: 
sascha@779: import de.intevation.artifacts.Artifact;
sascha@779: import de.intevation.artifacts.ArtifactFactory;
sascha@779: import de.intevation.artifacts.CallContext;
sascha@779: 
tim@345: import java.io.FileOutputStream;
tim@345: 
tim@345: import org.apache.log4j.Logger;
tim@345: 
sascha@779: import org.w3c.dom.Document;
tim@345: 
tim@345: /**
sascha@780:  * @author <a href="mailto:tim.englich@intevation.de">Tim Englich</a>
tim@345:  *
tim@345:  */
tim@345: public class MeshTimeSeriesTestCase extends GNVArtifactsTestCaseBase {
tim@345: 
tim@345:     private static Logger log = Logger.getLogger(MeshTimeSeriesTestCase.class);
sascha@778: 
tim@345:     /**
tim@345:      * Constructor
tim@345:      */
tim@345:     public MeshTimeSeriesTestCase() {
tim@345:     }
tim@345: 
tim@345:     /**
tim@345:      * Constructor
tim@345:      * @param name
tim@345:      */
tim@345:     public MeshTimeSeriesTestCase(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:         try {
tim@345:             log.debug("GNVArtifactsTestCase.testTimeSeriesMeshArtifact");
tim@345:             String artefactName = "fis_modeldata";
tim@345:             ArtifactFactory artifactFactory = this
tim@345:                     .getArtifactFactory(artefactName);
tim@345:             assertNotNull(artifactFactory);
tim@345:             log.debug("TimeSeriesMesh-ArtifactFactory is available");
sascha@778: 
tim@595:             Artifact artifact = createArtifact(artifactFactory);
tim@345: 
tim@485:             CallContext cc = createCallContext(artifactFactory);
tim@345: 
tim@345:             Document describeDocument = this.readDocument("src/test/ressources/timeseries_mesh/timeseries_describe.xml");
sascha@778: 
tim@345:             int steps = 8;
sascha@778: 
tim@345:             for (int i = 1; i <= steps; i++){
tim@345:                 this.doNextStep(
tim@345:                             artifact,
tim@345:                             cc,
tim@345:                             "src/test/ressources/timeseries_mesh/" +
tim@345:                             "timeseries_step_0"+i+"_feed.xml",
tim@345:                             "src/test/ressources/timeseries_mesh/" +
sascha@778:                             "timeseries_step_0"+i+"_advance.xml",
tim@345:                             describeDocument);
tim@345:             }
tim@345:             // Achter Schritt
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_mesh"
tim@345:                                            + System.currentTimeMillis()
tim@345:                                            + ".png");
tim@345:                 fos2 = new FileOutputStream("src/test/results/timeseries_mesh"
tim@345:                                             + System.currentTimeMillis()
tim@345:                                             + ".xml");
tim@345:                 fos3 = new FileOutputStream("src/test/results/timeseries_mesh"
tim@345:                                             + System.currentTimeMillis()
tim@345:                                             + ".csv");
tim@345:                 fos4 = new FileOutputStream("src/test/results/timeseries_mesh"
tim@345:                         + System.currentTimeMillis()
tim@345:                         + ".odv");
tim@345:                 artifact
tim@345:                         .out(
tim@345:                                 this
tim@345:                                         .readDocument("src/test/ressources/timeseries_mesh/timeseries_step_08_out_statistics.xml"),
tim@345:                                 fos2, cc);
tim@345:                 artifact
tim@345:                         .out(
tim@345:                                 this
tim@345:                                         .readDocument("src/test/ressources/timeseries_mesh/timeseries_step_08_out_chart.xml"),
tim@345:                                 fos, cc);
tim@345:                 artifact
tim@345:                         .out(
tim@345:                                 this
tim@345:                                         .readDocument("src/test/ressources/timeseries_mesh/timeseries_step_08_out_csv.xml"),
tim@345:                                 fos3, cc);
tim@345:                 artifact
tim@345:                 .out(
tim@345:                         this
tim@345:                                 .readDocument("src/test/ressources/timeseries_mesh/timeseries_step_08_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:                     fos2.flush();
tim@345:                     fos2.close();
tim@345:                     fos3.flush();
tim@345:                     fos3.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: }