Many resources are needed to download a project. Please understand that we have to compensate our server costs. Thank you in advance. Project price only 1 $
You can buy this project and download/modify it how often you want.
/*
Licensed to the Apache Software Foundation (ASF) under one or more
contributor license agreements. See the NOTICE file distributed with
this work for additional information regarding copyright ownership.
The ASF licenses this file to You under the Apache License, Version 2.0
(the "License"); you may not use this file except in compliance with
the License. You may obtain a copy of the License at
http://www.apache.org/licenses/LICENSE-2.0
Unless required by applicable law or agreed to in writing, software
distributed under the License is distributed on an "AS IS" BASIS,
WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
See the License for the specific language governing permissions and
limitations under the License.
*/
package org.apache.batik.test.svg;
import java.io.File;
import java.io.FileOutputStream;
import java.io.FileWriter;
import java.io.StringReader;
import java.net.URL;
import org.apache.batik.test.AbstractTest;
import org.apache.batik.test.DefaultTestSuite;
import org.apache.batik.test.Test;
import org.apache.batik.test.TestReport;
import org.apache.batik.test.TestReportValidator;
import org.apache.batik.transcoder.TranscoderInput;
import org.apache.batik.transcoder.TranscoderOutput;
import org.apache.batik.transcoder.image.ImageTranscoder;
import org.apache.batik.transcoder.image.PNGTranscoder;
/**
* Validates the operation of SVGRenderingAccuracyTest
* by forcing specific test case situations and checking that
* they are handled properly by the class.
*
* @author Vincent Hardy
* @version $Id$
*/
public class SVGRenderingAccuracyTestValidator extends DefaultTestSuite {
/**
* Simple valid SVG content used for this test
*/
private static final String validSVG
= "\n";
/**
* Simple valid SVG content used for this test
*/
private static final String validSVGVariation
= "\n";
/**
* Simple valid SVG content used for this test, small size
*/
private static final String validSmallSVG
= "\n";
/**
* Simple valid SVG content used for this test, red rectangle
*/
private static final String validRedSVG
= "\n";
/**
* Simple invalid SVG content used for this test
* (the error is that a double quote is missing at the
* end of the width attribute value.
*/
private static final String invalidSVG
= "\n";
/**
* This test creates a sample SVG file dynamically and
* valides that errors are generated for the
* following cases:
*
* + invalid SVG URL
* + corrupted SVG image (i.e., cannot be transcoded to
* an image).
* + invalid reference image URL
* + valid reference image URL, but inexisting resource.
* + reference image of different size than generated
* image.
* + reference image different than the generated image
*
* This test finally validates that the test
* passes if the reference image corresponds to the
* newly generated image.
*/
public SVGRenderingAccuracyTestValidator(){
addTest(new InvalidSVGURL());
addTest(new InvalidSVGContent());
addTest(new InvalidReferenceImageURL());
addTest(new InexistingReferenceImage());
addTest(new DifferentSizes());
addTest(new SameSizeDifferentContent());
addTest(new AccurateRendering());
addTest(new AccurateRenderingWithVariation());
addTest(new DefaultConfigTest());
}
/**
* Creates a SVG source URL for the given svg content
*/
public static URL createSVGSourceURL(String svgContent) throws Exception{
File tmpFile = File.createTempFile(SVGRenderingAccuracyTest.TEMP_FILE_PREFIX,
null);
FileWriter writer = new FileWriter(tmpFile);
writer.write(svgContent);
writer.close();
return tmpFile.toURI().toURL();
}
/**
* Helper method: creates a valid reference image
*/
public static URL createValidReferenceImage(String svgContent) throws Exception{
TranscoderInput validSrc = new TranscoderInput(new StringReader(svgContent));
File tmpFile = File.createTempFile(SVGRenderingAccuracyTest.TEMP_FILE_PREFIX,
SVGRenderingAccuracyTest.TEMP_FILE_SUFFIX);
TranscoderOutput validDst
= new TranscoderOutput(new FileOutputStream(tmpFile));
ImageTranscoder transcoder
= new PNGTranscoder();
transcoder.transcode(validSrc, validDst);
tmpFile.deleteOnExit();
return tmpFile.toURI().toURL();
}
/**
* Validates that the default parameters computation is
* working as expected.
*/
static class DefaultConfigTest extends AbstractTest {
String svgURL = "samples/anne.svg";
String expectedRefImgURL = "test-references/samples/anne.png";
String expectedVariationURL = "test-references/samples/accepted-variation/anne.png";
String expectedCandidateURL = "test-references/samples/candidate-variation/anne.png";
String ERROR_EXCEPTION_WHILE_BUILDING_TEST
= "error.exception.while.building.test";
String ERROR_UNEXPECTED_REFERENCE_IMAGE_URL
= "error.unexpected.reference.image.url";
String ERROR_UNEXPECTED_VARIATION_URL
= "error.unexpected.variation.url";
String ERROR_UNEXPECTED_CANDIDATE_URL
= "error.unexpected.candidate.url";
String ENTRY_KEY_EXPECTED_VALUE
= "entry.key.expected.value";
String ENTRY_KEY_FOUND_VALUE
= "entry.key.found.value";
public DefaultConfigTest(){
super();
setId("defaultTest");
}
public TestReport runImpl() throws Exception {
SVGRenderingAccuracyTest t
= new SamplesRenderingTest();
t.setId(svgURL);
if(!t.refImgURL.toString().endsWith(expectedRefImgURL)){
TestReport r = reportError(ERROR_UNEXPECTED_REFERENCE_IMAGE_URL);
r.addDescriptionEntry(ENTRY_KEY_EXPECTED_VALUE, expectedRefImgURL);
r.addDescriptionEntry(ENTRY_KEY_FOUND_VALUE, "" + t.refImgURL);
return r;
}
if (t.variationURLs == null
|| t.variationURLs.size() != 3
|| !t.variationURLs.get(0).toString()
.endsWith(expectedVariationURL)) {
TestReport r = reportError(ERROR_UNEXPECTED_VARIATION_URL);
r.addDescriptionEntry(ENTRY_KEY_EXPECTED_VALUE, expectedVariationURL);
String found;
if (t.variationURLs == null) {
found = "null";
} else if (t.variationURLs.size() != 1) {
found = "";
} else {
found = t.variationURLs.get(0).toString();
}
r.addDescriptionEntry(ENTRY_KEY_FOUND_VALUE, found);
return r;
}
if(!t.saveVariation.toURI().toURL().toString().endsWith(expectedCandidateURL)){
TestReport r = reportError(ERROR_UNEXPECTED_CANDIDATE_URL);
r.addDescriptionEntry(ENTRY_KEY_EXPECTED_VALUE, expectedCandidateURL);
r.addDescriptionEntry(ENTRY_KEY_FOUND_VALUE, "" + t.saveVariation.toURI().toURL().toString());
return r;
}
return reportSuccess();
}
}
/**
* Creates an SVGRenderingAccuracyTest with an
* invalid URL for the source SVG. Checks that this
* error is reported as a failure.
*/
static class InvalidSVGURL extends TestReportValidator {
public TestReport runImpl() throws Exception {
// Create an invalid URL for the SVG file
URL invalidSVGURL = new URL("http",
"dummyHost",
"dummyFile.svg");
// Create a valid reference image
URL refImgURL = createValidReferenceImage(validSVG);
Test t = new SVGRenderingAccuracyTest(invalidSVGURL.toString(),
refImgURL.toString());
setConfig(t,
false,
SVGRenderingAccuracyTest.ERROR_CANNOT_TRANSCODE_SVG);
return super.runImpl();
}
}
/**
* Creates an SVGRenderingAccuracyTest with a
* valid URL pointing to an invalid SVG document. Checks that this
* error is reported as a failure.
*/
static class InvalidSVGContent extends TestReportValidator {
public TestReport runImpl() throws Exception {
// Create an SVG URL from invalid SVG content.
URL validSVGURL = createSVGSourceURL(invalidSVG);
// Create a valid reference image
URL refImgURL = createValidReferenceImage(validSVG);
Test t = new SVGRenderingAccuracyTest(validSVGURL.toString(),
refImgURL.toString());
setConfig(t,
false,
SVGRenderingAccuracyTest.ERROR_CANNOT_TRANSCODE_SVG);
return super.runImpl();
}
}
/**
* Creates an SVGRenderingAccuracyTest with an
* valid URL for the source SVG but with an invalid
* URL for the reference image.
*/
static class InvalidReferenceImageURL extends TestReportValidator {
public TestReport runImpl() throws Exception {
// Create a valid SVG URL from valid SVG content.
URL validSVGURL = createSVGSourceURL(validSVG);
// Create an invalid URL for the reference image.
URL invalidReferenceImageURL = null;
invalidReferenceImageURL = new URL("http",
"dummyHost",
"dummyFile.png");
Test t = new SVGRenderingAccuracyTest(validSVGURL.toString(),
invalidReferenceImageURL.toString());
setConfig(t,
false,
SVGRenderingAccuracyTest.ERROR_CANNOT_OPEN_REFERENCE_IMAGE);
return super.runImpl();
}
}
/**
* Creates an SVGRenderingAccuracyTest with an
* valid URL for the source SVG valid
* URL for the reference image, but the reference image,
* but the reference image does not exist
*/
static class InexistingReferenceImage extends TestReportValidator {
public TestReport runImpl() throws Exception {
// Create a valid SVG URL from valid SVG content.
URL validSVGURL = createSVGSourceURL(validSVG);
// Create an valid URL for the reference image.
// We use the createSVGSourceURL method to create
// a File that the ImageLoader is not able to load.
File tmpFile = File.createTempFile(SVGRenderingAccuracyTest.TEMP_FILE_PREFIX,
null);
URL refImgURL = tmpFile.toURI().toURL();
tmpFile.delete();
Test t = new SVGRenderingAccuracyTest(validSVGURL.toString(),
refImgURL.toString());
setConfig(t,
false,
SVGRenderingAccuracyTest.ERROR_CANNOT_OPEN_REFERENCE_IMAGE);
return super.runImpl();
}
}
static class DifferentSizes extends TestReportValidator {
public TestReport runImpl() throws Exception {
//
// Create a valid SVG URL from valid SVG content.
//
URL validSVGURL = createSVGSourceURL(validSVG);
//
// Create an valid URL for the reference image.
//
URL validRefImageURL = createValidReferenceImage(validSmallSVG);
//
// Run test and check report
//
Test t = new SVGRenderingAccuracyTest(validSVGURL.toString(),
validRefImageURL.toString());
setConfig(t,
false,
SVGRenderingAccuracyTest.ERROR_SVG_RENDERING_NOT_ACCURATE);
return super.runImpl();
}
}
static class SameSizeDifferentContent extends TestReportValidator {
public TestReport runImpl() throws Exception {
// Create a valid SVG URL from valid SVG content.
URL validSVGURL = createSVGSourceURL(validSVG);
// Create an valid URL for the reference image.
URL validRefImageURL = createValidReferenceImage(validRedSVG);
Test t = new SVGRenderingAccuracyTest(validSVGURL.toString(),
validRefImageURL.toString());
setConfig(t,
false,
SVGRenderingAccuracyTest.ERROR_SVG_RENDERING_NOT_ACCURATE);
return super.runImpl();
}
}
static class AccurateRendering extends TestReportValidator {
public TestReport runImpl() throws Exception {
// Create a valid SVG URL from valid SVG content.
URL validSVGURL = createSVGSourceURL(validSVG);
// Create an valid URL for the reference image.
URL validRefImageURL = createValidReferenceImage(validSVG);
setConfig(new SVGRenderingAccuracyTest(validSVGURL.toString(),
validRefImageURL.toString()),
true,
null);
return super.runImpl();
}
}
/**
* Validates that test passes if proper variation is given
*/
static class AccurateRenderingWithVariation extends TestReportValidator {
public TestReport runImpl() throws Exception {
// Create a valid SVG URL from valid SVG content.
URL validSVGURL = createSVGSourceURL(validSVG);
// Create an valid URL for the reference image.
URL validRefImageURL = createValidReferenceImage(validSVGVariation);
SVGRenderingAccuracyTest t
= new SVGRenderingAccuracyTest(validSVGURL.toString(),
validRefImageURL.toString());
File tmpVariationFile = File.createTempFile(SVGRenderingAccuracyTest.TEMP_FILE_PREFIX, null);
// Run the test with the tmpVariationFile
t.setSaveVariation(tmpVariationFile);
setConfig(t,
false,
SVGRenderingAccuracyTest.ERROR_SVG_RENDERING_NOT_ACCURATE);
super.runImpl();
t.addVariationURL(tmpVariationFile.toURI().toURL().toString());
t.setSaveVariation(null);
setConfig(t, true, null);
return super.runImpl();
}
}
}