/* * #! * Ontopia Engine * #- * Copyright (C) 2001 - 2013 The Ontopia Project * #- * Licensed 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 net.ontopia.topicmaps.xml; import java.io.File; import java.io.FileOutputStream; import java.io.IOException; import java.util.HashSet; import java.util.Iterator; import java.util.Set; import net.ontopia.topicmaps.core.TopicMapIF; import net.ontopia.topicmaps.core.TopicMapWriterIF; import net.ontopia.topicmaps.utils.deciders.TMDecider; import net.ontopia.topicmaps.utils.ImportExportUtils; import net.ontopia.utils.FileUtils; import net.ontopia.utils.TestFileUtils; import java.util.List; import org.junit.Assert; import org.junit.Test; import org.junit.runner.RunWith; import org.junit.runners.Parameterized; import org.junit.runners.Parameterized.Parameters; @RunWith(Parameterized.class) public class TMXMLWriterGeneralTestCase { protected boolean recanonicalizeSource = false; private final static String testdataDirectory = "tmxmlWriter"; @Parameters public static List generateTests() { return TestFileUtils.getTestInputFiles(testdataDirectory, "in", ".ltm|.rdf|.xtm"); } // --- Test case class private String base; private String filename; public TMXMLWriterGeneralTestCase(String root, String filename) { this.filename = filename; this.base = TestFileUtils.getTestdataOutputDirectory() + testdataDirectory; } /** * Exports a file from the directory 'in' to a TM/XML file in * 'tmxml'. Canonicalizes the TMXML file into the directory 'out'. * Compares the file in 'out' with a baseline file in 'baseline'. * If recanonicalizeSource is set to true, then the source file is * also canonicalized directly into 'baseline' and used as * baseline. */ @Test public void testFile() throws IOException { TestFileUtils.verifyDirectory(base, "out"); TestFileUtils.verifyDirectory(base, "tmxml"); // Path to the input topic map document. String in = TestFileUtils.getTestInputFile(testdataDirectory, "in", filename); // Path to the baseline (canonicalized output of the source topic map). String baseline = TestFileUtils.getTestInputFile(testdataDirectory, "baseline", filename + ".cxtm"); // Path to the exported tmxml topic map document. String tmxml = base + File.separator + "tmxml" + File.separator + filename + ".xml"; // Path to the output (canonicalized output of exported tmxml topic map). String out = base + File.separator + "out" + File.separator + filename + ".xml.cxtm"; // Import topic map from arbitrary source. TopicMapIF sourceMap = ImportExportUtils.getReader(in).read(); if (recanonicalizeSource) { // Canonicalize the source topic map. FileOutputStream fos = new FileOutputStream(baseline); (new CanonicalXTMWriter(fos)).write(sourceMap); fos.close(); } // Export the topic map to tmxml. TopicMapWriterIF writer = new TMXMLWriter(tmxml); writer.write(sourceMap); // Reimport the exported tmxml. TopicMapIF tmxmlMap = ImportExportUtils.getReader(tmxml).read(); // Canonicalize the reimported tmxml. FileOutputStream fos = new FileOutputStream(out); (new CanonicalXTMWriter(fos)).write(tmxmlMap); fos.close(); // compare results Assert.assertTrue("canonicalizing the test file " + filename + " gives a different result than canonicalizing the tmxml export: " + out + " " + baseline, FileUtils.compareFileToResource(out, baseline)); } }