Allow to produce a jar for the integration-test-code so we can use it directly in the mass-regression tests without having to copy it for every run.

Enable some forbidden-api-checks for integration-test code

git-svn-id: https://svn.apache.org/repos/asf/poi/trunk@1808506 13f79535-47bb-0310-9956-ffa450edef68
This commit is contained in:
Dominik Stadler 2017-09-16 08:20:50 +00:00
parent 6044d4629c
commit 92ae9ce5e0
2 changed files with 74 additions and 64 deletions

View File

@ -445,6 +445,8 @@ under the License.
<path refid="ooxml.classpath"/> <path refid="ooxml.classpath"/>
<path refid="ooxml.xmlsec.classpath"/> <path refid="ooxml.xmlsec.classpath"/>
<path refid="excelant.classpath"/> <path refid="excelant.classpath"/>
<path refid="examples.classpath"/>
<pathelement location="${examples.output.dir}"/>
<path path="${env.CLASSPATH}"/> <path path="${env.CLASSPATH}"/>
</path> </path>
@ -1978,6 +1980,9 @@ under the License.
<maven-jar dir="${excelant.src}"/> <maven-jar dir="${excelant.src}"/>
</target> </target>
<target name="integration-test-jar" depends="compile-integration,-manifest" description="target for packaging the integration-test code for mass regression test runs">
<maven-jar dir="${integration.output.test.dir}"/>
</target>
<target name="-do-jar-check-javadocs-package-list"> <target name="-do-jar-check-javadocs-package-list">
<condition property="javadocs.package-list.present"> <condition property="javadocs.package-list.present">
@ -2228,7 +2233,7 @@ under the License.
<!-- spot any cases where we've accidently used methods we shouldn't --> <!-- spot any cases where we've accidently used methods we shouldn't -->
<!-- See https://github.com/policeman-tools/forbidden-apis for details --> <!-- See https://github.com/policeman-tools/forbidden-apis for details -->
<!-- of the checks that this can do --> <!-- of the checks that this can do -->
<target name="forbidden-apis-check" depends="init, compile"> <target name="forbidden-apis-check" depends="init, compile, compile-integration">
<taskdef name="forbiddenapis" <taskdef name="forbiddenapis"
classname="de.thetaphi.forbiddenapis.ant.AntTask" classname="de.thetaphi.forbiddenapis.ant.AntTask"
classpath="${forbidden.jar}"/> classpath="${forbidden.jar}"/>
@ -2262,6 +2267,7 @@ under the License.
<!-- <!--
<fileset dir="${scratchpad.output.test.dir}"/> <fileset dir="${scratchpad.output.test.dir}"/>
<fileset dir="${excelant.output.test.dir}"/> <fileset dir="${excelant.output.test.dir}"/>
<fileset dir="${integration.output.test.dir}"/>
--> -->
</forbiddenapis> </forbiddenapis>
@ -2277,6 +2283,7 @@ under the License.
<fileset dir="${ooxml.output.dir}"/> <fileset dir="${ooxml.output.dir}"/>
<fileset dir="${scratchpad.output.dir}"/> <fileset dir="${scratchpad.output.dir}"/>
<fileset dir="${excelant.output.dir}"/> <fileset dir="${excelant.output.dir}"/>
<fileset dir="${integration.output.test.dir}"/>
</forbiddenapis> </forbiddenapis>
</target> </target>

View File

@ -24,78 +24,81 @@ import java.io.*;
import org.apache.poi.hslf.record.Record; import org.apache.poi.hslf.record.Record;
import org.apache.poi.hslf.usermodel.HSLFSlideShow; import org.apache.poi.hslf.usermodel.HSLFSlideShow;
import org.apache.poi.hslf.usermodel.HSLFSlideShowImpl; import org.apache.poi.hslf.usermodel.HSLFSlideShowImpl;
import org.apache.poi.util.POILogger;
import org.apache.poi.util.SystemOutLogger;
import org.junit.Test; import org.junit.Test;
public class HSLFFileHandler extends SlideShowHandler { public class HSLFFileHandler extends SlideShowHandler {
@Override @Override
public void handleFile(InputStream stream, String path) throws Exception { public void handleFile(InputStream stream, String path) throws Exception {
HSLFSlideShowImpl slide = new HSLFSlideShowImpl(stream); HSLFSlideShowImpl slide = new HSLFSlideShowImpl(stream);
assertNotNull(slide.getCurrentUserAtom()); assertNotNull(slide.getCurrentUserAtom());
assertNotNull(slide.getEmbeddedObjects()); assertNotNull(slide.getEmbeddedObjects());
assertNotNull(slide.getUnderlyingBytes()); assertNotNull(slide.getUnderlyingBytes());
assertNotNull(slide.getPictureData()); assertNotNull(slide.getPictureData());
Record[] records = slide.getRecords(); Record[] records = slide.getRecords();
assertNotNull(records); assertNotNull(records);
for(Record record : records) { for(Record record : records) {
assertNotNull("Found a record which was null", record); assertNotNull("Found a record which was null", record);
assertTrue(record.getRecordType() >= 0); assertTrue(record.getRecordType() >= 0);
} }
handlePOIDocument(slide); handlePOIDocument(slide);
HSLFSlideShow ss = new HSLFSlideShow(slide); HSLFSlideShow ss = new HSLFSlideShow(slide);
handleSlideShow(ss); handleSlideShow(ss);
} }
@Test
public void testOne() throws Exception {
testOneFile(new File("test-data/slideshow/54880_chinese.ppt"));
}
// a test-case to test this locally without executing the full TestAllFiles
@Override
@Test @Test
public void test() throws Exception { public void testOne() throws Exception {
File[] files = new File("test-data/slideshow/").listFiles(new FilenameFilter() { testOneFile(new File("test-data/slideshow/54880_chinese.ppt"));
@Override }
public boolean accept(File dir, String name) {
return name.endsWith(".ppt");
}
});
assertNotNull(files);
System.out.println("Testing " + files.length + " files"); // a test-case to test all .ppt files without executing the full TestAllFiles
@Override
@Test
public void test() throws Exception {
File[] files = new File("test-data/slideshow/").listFiles(new FilenameFilter() {
@Override
public boolean accept(File dir, String name) {
return name.endsWith(".ppt");
}
});
assertNotNull(files);
for(File file : files) { System.out.println("Testing " + files.length + " files");
try {
testOneFile(file);
} catch (Throwable e) {
e.printStackTrace();
}
}
}
private void testOneFile(File file) throws Exception { POILogger logger = new SystemOutLogger();
System.out.println(file); for(File file : files) {
try {
testOneFile(file);
} catch (Throwable e) {
logger.log(POILogger.WARN, "Failed to handle file " + file, e);
}
}
}
//System.setProperty("org.apache.poi.util.POILogger", "org.apache.poi.util.SystemOutLogger"); private void testOneFile(File file) throws Exception {
InputStream stream = new FileInputStream(file); System.out.println(file);
try {
//System.setProperty("org.apache.poi.util.POILogger", "org.apache.poi.util.SystemOutLogger");
InputStream stream = new FileInputStream(file);
try {
handleFile(stream, file.getPath()); handleFile(stream, file.getPath());
} finally { } finally {
stream.close(); stream.close();
} }
handleExtracting(file); handleExtracting(file);
} }
public static void main(String[] args) throws Exception { public static void main(String[] args) throws Exception {
System.setProperty("org.apache.poi.util.POILogger", "org.apache.poi.util.SystemOutLogger"); System.setProperty("org.apache.poi.util.POILogger", "org.apache.poi.util.SystemOutLogger");
InputStream stream = new FileInputStream(args[0]); InputStream stream = new FileInputStream(args[0]);
try { try {
new HSLFFileHandler().handleFile(stream, args[0]); new HSLFFileHandler().handleFile(stream, args[0]);
} finally { } finally {
stream.close(); stream.close();
} }
} }
} }