/* * Geotoolkit - An Open Source Java GIS Toolkit * http://www.geotoolkit.org * * (C) 2012, Geomatys * * This library is free software; you can redistribute it and/or * modify it under the terms of the GNU Lesser General Public * License as published by the Free Software Foundation; either * version 2.1 of the License, or (at your option) any later version. * * This library 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 * Lesser General Public License for more details. */ package org.geotoolkit.wps.converters.inputs.complex; import java.io.IOException; import java.io.InputStream; import java.util.HashMap; import java.util.Map; import org.geotoolkit.coverage.grid.GridCoverage2D; import org.geotoolkit.nio.IOUtilities; import org.apache.sis.util.UnconvertibleObjectException; import org.geotoolkit.wps.converters.WPSConverterRegistry; import org.geotoolkit.wps.converters.WPSObjectConverter; import org.geotoolkit.wps.xml.v100.ComplexDataType; import org.junit.Test; import static org.geotoolkit.test.Assert.*; import org.geotoolkit.wps.converters.AbstractWPSConverterTest; import org.geotoolkit.wps.converters.ConvertersTestUtils; import org.opengis.geometry.Envelope; import org.apache.sis.util.Utilities; /** * * @author Quentin Boileau (Geomatys) */ public class ComplexToCoverageConverterTest extends AbstractWPSConverterTest { @Test @org.junit.Ignore("Fails randomly because of GeoTIFF reader not found.") public void testConversion() throws UnconvertibleObjectException, IOException, InterruptedException { final WPSObjectConverter<ComplexDataType, GridCoverage2D> converter = WPSConverterRegistry.getInstance().getConverter(ComplexDataType.class, GridCoverage2D.class); final InputStream expectedStream = ComplexToRenderedImageConvereterTest.class.getResourceAsStream("/expected/coverage_base64"); assertNotNull(expectedStream); final String encodedCoverage = IOUtilities.toString(expectedStream); final Map<String, Object> param = new HashMap<String, Object>(); param.put(WPSObjectConverter.MIME, "image/x-geotiff"); param.put(WPSObjectConverter.ENCODING, "base64"); final ComplexDataType complex = new ComplexDataType(); complex.setEncoding("base64"); complex.setMimeType("image/x-geotiff"); complex.setSchema(null); complex.getContent().add(encodedCoverage); final GridCoverage2D convertedCoverage = converter.convert(complex, param); assertNotNull(convertedCoverage); final GridCoverage2D expectedCoverage = ConvertersTestUtils.makeCoverage(); final Envelope convertedEnvelope = convertedCoverage.getEnvelope(); final Envelope expectedEnvelope = expectedCoverage.getEnvelope(); assertTrue(Utilities.equalsIgnoreMetadata(expectedEnvelope.getCoordinateReferenceSystem(), convertedEnvelope.getCoordinateReferenceSystem())); assertTrue(expectedEnvelope.getMinimum(0) == convertedEnvelope.getMinimum(0)); assertTrue(expectedEnvelope.getMinimum(1) == convertedEnvelope.getMinimum(1)); assertTrue(expectedEnvelope.getMaximum(0) == convertedEnvelope.getMaximum(0)); assertTrue(expectedEnvelope.getMaximum(1) == convertedEnvelope.getMaximum(1)); assertRasterEquals(expectedCoverage, convertedCoverage); } }