mirror of https://github.com/apache/poi.git
merge trunk
git-svn-id: https://svn.apache.org/repos/asf/poi/branches/hemf@1847069 13f79535-47bb-0310-9956-ffa450edef68
This commit is contained in:
commit
30d4934edc
161
build.xml
161
build.xml
|
@ -42,7 +42,7 @@ under the License.
|
||||||
|
|
||||||
<description>The Apache POI project Ant build.</description>
|
<description>The Apache POI project Ant build.</description>
|
||||||
|
|
||||||
<property name="version.id" value="4.0.1-SNAPSHOT"/>
|
<property name="version.id" value="4.0.2"/>
|
||||||
<property name="release.rc" value="RC1"/>
|
<property name="release.rc" value="RC1"/>
|
||||||
|
|
||||||
<property environment="env"/>
|
<property environment="env"/>
|
||||||
|
@ -81,7 +81,7 @@ under the License.
|
||||||
user.language and user.country are required as we have locale-sensitive formatters
|
user.language and user.country are required as we have locale-sensitive formatters
|
||||||
-->
|
-->
|
||||||
<property name="testpattern" value="Test*"/> <!--note: this excludes BaseTest* -->
|
<property name="testpattern" value="Test*"/> <!--note: this excludes BaseTest* -->
|
||||||
<property name="POI.testdata.path" value="test-data"/>
|
<property name="POI.testdata.path" location="test-data"/>
|
||||||
<property name="java.awt.headless" value="true"/>
|
<property name="java.awt.headless" value="true"/>
|
||||||
<property name="additionaljar" value=""/>
|
<property name="additionaljar" value=""/>
|
||||||
<propertyreset name="user.language" value="en"/>
|
<propertyreset name="user.language" value="en"/>
|
||||||
|
@ -130,8 +130,12 @@ under the License.
|
||||||
<property name="ooxml.output.dir" location="build/ooxml-classes"/>
|
<property name="ooxml.output.dir" location="build/ooxml-classes"/>
|
||||||
<property name="ooxml.output.test.dir" location="build/ooxml-test-classes"/>
|
<property name="ooxml.output.test.dir" location="build/ooxml-test-classes"/>
|
||||||
<property name="ooxml.testokfile" location="build/ooxml-testokfile.txt"/>
|
<property name="ooxml.testokfile" location="build/ooxml-testokfile.txt"/>
|
||||||
<property name="ooxml.lite.output.dir" location="build/ooxml-lite-classes"/>
|
|
||||||
<property name="ooxml.lite.testokfile" location="build/ooxml-lite-testokfile.txt"/>
|
<property name="ooxml.lite.agent" location="build/ooxml-lite-agent.jar"/>
|
||||||
|
<property name="ooxml.lite.report" location="build/ooxml-lite-report.txt"/>
|
||||||
|
<property name="ooxml.lite.jar" location="build/ooxml-lite-classes.jar"/>
|
||||||
|
<property name="ooxml.lite.includes" value="^(com/microsoft/schemas|org/(etsi|openxmlformats|w3/)|schemaorg_apache_xmlbeans)"/>
|
||||||
|
|
||||||
|
|
||||||
<!-- Integration testing: -->
|
<!-- Integration testing: -->
|
||||||
<property name="integration.src.test" location="src/integrationtest"/>
|
<property name="integration.src.test" location="src/integrationtest"/>
|
||||||
|
@ -331,8 +335,11 @@ under the License.
|
||||||
<propertyref name="user.country"/>
|
<propertyref name="user.country"/>
|
||||||
<propertyref name="javax.xml.stream.XMLInputFactory"/>
|
<propertyref name="javax.xml.stream.XMLInputFactory"/>
|
||||||
<propertyref name="org.apache.commons.logging.Log"/>
|
<propertyref name="org.apache.commons.logging.Log"/>
|
||||||
<propertyref name="java.locale.providers"/> <!-- required for Java 9 compilation -->
|
<!-- required for Java 9 compilation -->
|
||||||
<propertyref name="version.id"/> <!-- to detect if we are running on slow Gump VM -->
|
<propertyref name="java.locale.providers"/>
|
||||||
|
<!-- to detect if we are running on slow Gump VM -->
|
||||||
|
<propertyref name="version.id"/>
|
||||||
|
<propertyref name="scratchpad.ignore"/>
|
||||||
</propertyset>
|
</propertyset>
|
||||||
|
|
||||||
<!-- these need to be set differently when running with Java 9 -->
|
<!-- these need to be set differently when running with Java 9 -->
|
||||||
|
@ -397,7 +404,8 @@ under the License.
|
||||||
|
|
||||||
<path id="ooxml-lite.classpath">
|
<path id="ooxml-lite.classpath">
|
||||||
<path refid="ooxml.base.classpath"/>
|
<path refid="ooxml.base.classpath"/>
|
||||||
<pathelement location="${ooxml.lite.output.dir}"/> <!-- instead of ooxml-xsds.jar use the filtered classes-->
|
<!-- instead of ooxml-xsds.jar use the filtered classes-->
|
||||||
|
<pathelement location="${ooxml.lite.jar}"/>
|
||||||
<pathelement location="${ooxml.output.dir}"/>
|
<pathelement location="${ooxml.output.dir}"/>
|
||||||
<pathelement location="${ooxml.output.test.dir}"/>
|
<pathelement location="${ooxml.output.test.dir}"/>
|
||||||
<pathelement location="${main.output.test.dir}"/>
|
<pathelement location="${main.output.test.dir}"/>
|
||||||
|
@ -1015,8 +1023,6 @@ under the License.
|
||||||
compile-scratchpad, compile-examples, compile-excelant"
|
compile-scratchpad, compile-examples, compile-excelant"
|
||||||
description="Compiles the POI main classes, scratchpad and examples"/>
|
description="Compiles the POI main classes, scratchpad and examples"/>
|
||||||
|
|
||||||
<target name="compile-all" depends="compile,compile-ooxml-lite"/>
|
|
||||||
|
|
||||||
<target name="compile-main" depends="init">
|
<target name="compile-main" depends="init">
|
||||||
<!-- compile the sources -->
|
<!-- compile the sources -->
|
||||||
<javac target="${jdk.version.class}"
|
<javac target="${jdk.version.class}"
|
||||||
|
@ -1127,6 +1133,7 @@ under the License.
|
||||||
<classpath>
|
<classpath>
|
||||||
<path refid="ooxml.classpath"/>
|
<path refid="ooxml.classpath"/>
|
||||||
<pathelement path="${ooxml.output.dir}"/>
|
<pathelement path="${ooxml.output.dir}"/>
|
||||||
|
<pathelement location="${scratchpad.output.dir}"/>
|
||||||
</classpath>
|
</classpath>
|
||||||
</javac>
|
</javac>
|
||||||
<copy todir="${examples.output.dir}">
|
<copy todir="${examples.output.dir}">
|
||||||
|
@ -1297,6 +1304,7 @@ under the License.
|
||||||
<pathelement location="${main.output.test.dir}"/>
|
<pathelement location="${main.output.test.dir}"/>
|
||||||
<pathelement location="${examples.output.dir}"/>
|
<pathelement location="${examples.output.dir}"/>
|
||||||
<pathelement location="${main.ant.jar}"/>
|
<pathelement location="${main.ant.jar}"/>
|
||||||
|
<pathelement location="${scratchpad.output.dir}"/>
|
||||||
</classpath>
|
</classpath>
|
||||||
</javac>
|
</javac>
|
||||||
<!--copy todir="${integration.output.dir}">
|
<!--copy todir="${integration.output.dir}">
|
||||||
|
@ -1338,7 +1346,7 @@ under the License.
|
||||||
<!-- Section: test (execute junit tests on test suites) -->
|
<!-- Section: test (execute junit tests on test suites) -->
|
||||||
<target name="test" depends="compile,jacocotask,test-main,test-scratchpad,test-ooxml,test-excelant"
|
<target name="test" depends="compile,jacocotask,test-main,test-scratchpad,test-ooxml,test-excelant"
|
||||||
description="Tests main, scratchpad and ooxml"/>
|
description="Tests main, scratchpad and ooxml"/>
|
||||||
<target name="test-all" depends="test,test-ooxml-lite,testcoveragereport"
|
<target name="test-all" depends="test,test-integration,test-ooxml-lite,testcoveragereport"
|
||||||
description="Tests main, scratchpad, ooxml, ooxml-lite, and coveragereport"/>
|
description="Tests main, scratchpad, ooxml, ooxml-lite, and coveragereport"/>
|
||||||
|
|
||||||
<target name="testcoveragereport" depends="init,jacocotask" description="create test-report" xmlns:jacoco="antlib:org.jacoco.ant" if="coverage.enabled">
|
<target name="testcoveragereport" depends="init,jacocotask" description="create test-report" xmlns:jacoco="antlib:org.jacoco.ant" if="coverage.enabled">
|
||||||
|
@ -1385,9 +1393,7 @@ under the License.
|
||||||
<group name="OOXML">
|
<group name="OOXML">
|
||||||
<classfiles>
|
<classfiles>
|
||||||
<fileset dir="${ooxml.output.dir}"/>
|
<fileset dir="${ooxml.output.dir}"/>
|
||||||
<!-- there are no actual POI classes in build/ooxml-lite-classes, only generated code...
|
<!-- there are no actual POI classes in build/ooxml-lite-classes, only generated code... -->
|
||||||
<fileset dir="${ooxml.lite.output.dir}"/>
|
|
||||||
-->
|
|
||||||
</classfiles>
|
</classfiles>
|
||||||
<sourcefiles encoding="UTF-8">
|
<sourcefiles encoding="UTF-8">
|
||||||
<fileset dir="${ooxml.src}"/>
|
<fileset dir="${ooxml.src}"/>
|
||||||
|
@ -1564,6 +1570,7 @@ under the License.
|
||||||
<sysproperty key="java.io.tmpdir" value="${tempdir}"/>
|
<sysproperty key="java.io.tmpdir" value="${tempdir}"/>
|
||||||
<jvmarg value="-Xmx768M"/>
|
<jvmarg value="-Xmx768M"/>
|
||||||
<jvmarg value="-ea"/>
|
<jvmarg value="-ea"/>
|
||||||
|
<jvmarg value="-javaagent:${ooxml.lite.agent}=${ooxml.lite.report}|${ooxml.lite.includes}"/>
|
||||||
<jvmarg value="${java9addmods}" />
|
<jvmarg value="${java9addmods}" />
|
||||||
<jvmarg value="${java9addmodsvalue}" />
|
<jvmarg value="${java9addmodsvalue}" />
|
||||||
<jvmarg value="${java9addopens1}" />
|
<jvmarg value="${java9addopens1}" />
|
||||||
|
@ -1598,6 +1605,7 @@ under the License.
|
||||||
</classpath>
|
</classpath>
|
||||||
<syspropertyset refid="junit.properties"/>
|
<syspropertyset refid="junit.properties"/>
|
||||||
<sysproperty key="java.io.tmpdir" value="${tempdir}"/>
|
<sysproperty key="java.io.tmpdir" value="${tempdir}"/>
|
||||||
|
<jvmarg value="-javaagent:${ooxml.lite.agent}=${ooxml.lite.report}|${ooxml.lite.includes}"/>
|
||||||
<jvmarg value="-Xmx768M"/>
|
<jvmarg value="-Xmx768M"/>
|
||||||
<jvmarg value="-ea"/>
|
<jvmarg value="-ea"/>
|
||||||
<jvmarg value="${java9addmods}" />
|
<jvmarg value="${java9addmods}" />
|
||||||
|
@ -1620,7 +1628,7 @@ under the License.
|
||||||
</sequential>
|
</sequential>
|
||||||
</macrodef>
|
</macrodef>
|
||||||
|
|
||||||
<target name="test-ooxml" depends="compile-main,compile-ooxml,-test-ooxml-check,jacocotask" unless="ooxml.test.notRequired"
|
<target name="test-ooxml" depends="compile-main,compile-ooxml,-test-ooxml-check,jacocotask,-ooxml-lite-agent" unless="ooxml.test.notRequired"
|
||||||
description="test OOXML classes">
|
description="test OOXML classes">
|
||||||
<ooxml-test-runner classpath="test.ooxml.classpath" type="ooxml"/>
|
<ooxml-test-runner classpath="test.ooxml.classpath" type="ooxml"/>
|
||||||
<delete file="${ooxml.testokfile}"/>
|
<delete file="${ooxml.testokfile}"/>
|
||||||
|
@ -1638,7 +1646,7 @@ under the License.
|
||||||
</uptodate>
|
</uptodate>
|
||||||
</target>
|
</target>
|
||||||
|
|
||||||
<target name="test-integration" depends="compile-integration,-test-integration-check,jacocotask"
|
<target name="test-integration" depends="compile-integration,-test-integration-check,jacocotask,-ooxml-lite-agent"
|
||||||
unless="integration.test.notRequired" xmlns:jacoco="antlib:org.jacoco.ant">
|
unless="integration.test.notRequired" xmlns:jacoco="antlib:org.jacoco.ant">
|
||||||
<propertyreset name="org.apache.poi.util.POILogger" value="org.apache.poi.util.CommonsLogger"/>
|
<propertyreset name="org.apache.poi.util.POILogger" value="org.apache.poi.util.CommonsLogger"/>
|
||||||
<delete dir="build" includes="test-integration.log*"/>
|
<delete dir="build" includes="test-integration.log*"/>
|
||||||
|
@ -1650,6 +1658,7 @@ under the License.
|
||||||
<sysproperty key="java.io.tmpdir" value="${tempdir}"/>
|
<sysproperty key="java.io.tmpdir" value="${tempdir}"/>
|
||||||
<jvmarg value="-ea"/>
|
<jvmarg value="-ea"/>
|
||||||
<jvmarg value="-Xmx1512M"/>
|
<jvmarg value="-Xmx1512M"/>
|
||||||
|
<jvmarg value="-javaagent:${ooxml.lite.agent}=${ooxml.lite.report}|${ooxml.lite.includes}"/>
|
||||||
<jvmarg value="${java9addmods}" />
|
<jvmarg value="${java9addmods}" />
|
||||||
<jvmarg value="${java9addmodsvalue}" />
|
<jvmarg value="${java9addmodsvalue}" />
|
||||||
<jvmarg value="${java9addopens1}" />
|
<jvmarg value="${java9addopens1}" />
|
||||||
|
@ -1677,57 +1686,28 @@ under the License.
|
||||||
<echo file="${integration.testokfile}" append="false" message="testok"/>
|
<echo file="${integration.testokfile}" append="false" message="testok"/>
|
||||||
</target>
|
</target>
|
||||||
|
|
||||||
<!-- Section: test-ooxml-lite -->
|
<!-- the ooxml lite agent collects referenced schema files while other junit tests are run, -->
|
||||||
<target name="-compile-ooxml-lite-check">
|
<!-- therefore its best to compile the ooxml lite jar after all usual tests are done -->
|
||||||
<uptodate property="ooxml.lite.test.notRequired" targetfile="${ooxml.lite.testokfile}">
|
<target name="compile-ooxml-lite" depends="compile-ooxml,-ooxml-lite-agent,test-ooxml">
|
||||||
<srcfiles dir="${ooxml.src}"/>
|
<echo message="Create ooxml-lite schemas"/>
|
||||||
<srcfiles dir="${ooxml.src.test}"/>
|
|
||||||
<srcfiles file="${ooxml.xsds.jar}"/>
|
|
||||||
<srcfiles file="${ooxml.security.jar}"/>
|
|
||||||
</uptodate>
|
|
||||||
</target>
|
|
||||||
|
|
||||||
<target name="compile-ooxml-lite" depends="-compile-ooxml-lite-check,compile-ooxml"
|
<copy file="${ooxml.lite.report}" tofile="${ooxml.lite.report}-pat" overwrite="true"/>
|
||||||
unless="ooxml.lite.test.notRequired">
|
<replaceregexp file="${ooxml.lite.report}-pat" byline="true" match="(.*)" replace="\1.class${line.separator}\1$*.class"/>
|
||||||
<delete file="${ooxml.lite.testokfile}"/>
|
|
||||||
<echo message="Running ooxml-lite generator"/>
|
|
||||||
|
|
||||||
<property name="ooxml.lite-merged.dir" location="build/ooxml-lite-merged"/>
|
<patternset id="xsbfiles">
|
||||||
<mkdir dir="${ooxml.lite-merged.dir}"/>
|
<includesfile name="${ooxml.lite.report}-pat"/>
|
||||||
|
<include name="schemaorg_apache_xmlbeans/system/**/*.xsb"/>
|
||||||
|
<include name="schemaorg_apache_xmlbeans/element/**/*.xsb"/>
|
||||||
|
</patternset>
|
||||||
|
|
||||||
<jar destfile="${ooxml.lite-merged.dir}/ooxml-lite-merged.jar">
|
<jar destfile="${ooxml.lite.jar}" duplicate="preserve">
|
||||||
<zipfileset includes="**/*" src="${ooxml.xsds.jar}"/>
|
<zipfileset src="${ooxml.xsds.jar}">
|
||||||
<zipfileset includes="**/*" src="${ooxml.security.jar}"/>
|
<patternset refid="xsbfiles"/>
|
||||||
|
</zipfileset>
|
||||||
|
<zipfileset src="${ooxml.security.jar}">
|
||||||
|
<patternset refid="xsbfiles"/>
|
||||||
|
</zipfileset>
|
||||||
</jar>
|
</jar>
|
||||||
|
|
||||||
<java classname="org.apache.poi.ooxml.util.OOXMLLite" fork="yes"
|
|
||||||
failonerror="true">
|
|
||||||
<classpath>
|
|
||||||
<pathelement path="${ooxml.lite-merged.dir}/ooxml-lite-merged.jar"/>
|
|
||||||
</classpath>
|
|
||||||
<classpath refid="test.ooxml.classpath"/>
|
|
||||||
<classpath refid="ooxml.xmlsec.classpath"/>
|
|
||||||
<syspropertyset refid="junit.properties"/>
|
|
||||||
<sysproperty key="java.io.tmpdir" value="${tempdir}"/>
|
|
||||||
<jvmarg value="-Xmx512m"/>
|
|
||||||
<jvmarg value="${java9addmods}" />
|
|
||||||
<jvmarg value="${java9addmodsvalue}" />
|
|
||||||
<jvmarg value="${java9addopens1}" />
|
|
||||||
<jvmarg value="${java9addopens2}" />
|
|
||||||
<jvmarg value="${java9addopens3}" />
|
|
||||||
<jvmarg value="${java9addopens4}" />
|
|
||||||
<jvmarg value="${java9addopens5}" />
|
|
||||||
<jvmarg value="${java9addopens6}" />
|
|
||||||
<jvmarg value="${file.leak.detector}" />
|
|
||||||
<arg value="-ooxml"/>
|
|
||||||
<arg value="${ooxml.lite-merged.dir}/ooxml-lite-merged.jar"/>
|
|
||||||
<arg value="-test"/>
|
|
||||||
<arg value="${ooxml.output.test.dir}"/>
|
|
||||||
<arg value="-dest"/>
|
|
||||||
<arg value="${ooxml.lite.output.dir}"/>
|
|
||||||
</java>
|
|
||||||
|
|
||||||
<echo file="${ooxml.lite.testokfile}" append="false" message="testok"/>
|
|
||||||
</target>
|
</target>
|
||||||
|
|
||||||
<target name="test-ooxml-lite" depends="jacocotask,compile-ooxml-xsds,compile-ooxml-lite">
|
<target name="test-ooxml-lite" depends="jacocotask,compile-ooxml-xsds,compile-ooxml-lite">
|
||||||
|
@ -1736,6 +1716,15 @@ under the License.
|
||||||
<ooxml-test-runner classpath="ooxml-lite.classpath" type="ooxml-lite"/>
|
<ooxml-test-runner classpath="ooxml-lite.classpath" type="ooxml-lite"/>
|
||||||
</target>
|
</target>
|
||||||
|
|
||||||
|
<target name="-ooxml-lite-agent" depends="jacocotask,compile-ooxml-xsds,compile-ooxml">
|
||||||
|
<jar destfile="${ooxml.lite.agent}">
|
||||||
|
<fileset dir="${ooxml.output.test.dir}" includes="org/apache/poi/ooxml/util/OOXMLLiteAgent*.class"/>
|
||||||
|
<manifest>
|
||||||
|
<attribute name="Premain-Class" value="org.apache.poi.ooxml.util.OOXMLLiteAgent"/>
|
||||||
|
</manifest>
|
||||||
|
</jar>
|
||||||
|
</target>
|
||||||
|
|
||||||
<!-- Section: test-excelant -->
|
<!-- Section: test-excelant -->
|
||||||
<target name="-test-excelant-check">
|
<target name="-test-excelant-check">
|
||||||
<uptodate property="excelant.test.notRequired" targetfile="${excelant.testokfile}">
|
<uptodate property="excelant.test.notRequired" targetfile="${excelant.testokfile}">
|
||||||
|
@ -1953,14 +1942,15 @@ under the License.
|
||||||
</target>
|
</target>
|
||||||
|
|
||||||
<macrodef name="maven-jar">
|
<macrodef name="maven-jar">
|
||||||
<attribute name="dir"/>
|
<attribute name="src"/>
|
||||||
<sequential>
|
<sequential>
|
||||||
<local name="destfile"/>
|
<local name="destfile"/>
|
||||||
<pathconvert property="destfile" targetos="unix">
|
<pathconvert property="destfile" targetos="unix">
|
||||||
<path><pathelement path="@{dir}"/></path>
|
<path><pathelement path="@{src}"/></path>
|
||||||
<mapper>
|
<mapper>
|
||||||
<chainedmapper>
|
<chainedmapper>
|
||||||
<filtermapper>
|
<filtermapper>
|
||||||
|
<replaceregex pattern=".jar" replace="" flags="g"/>
|
||||||
<replaceregex pattern="ooxml-lite" replace="ooxml-schemas" flags="g"/>
|
<replaceregex pattern="ooxml-lite" replace="ooxml-schemas" flags="g"/>
|
||||||
<replaceregex pattern="(.java|.src)$$" replace="-sources"/>
|
<replaceregex pattern="(.java|.src)$$" replace="-sources"/>
|
||||||
<replaceregex pattern=".*(?:build|src).?(.*)?" replace="\1"/>
|
<replaceregex pattern=".*(?:build|src).?(.*)?" replace="\1"/>
|
||||||
|
@ -1971,33 +1961,39 @@ under the License.
|
||||||
</chainedmapper>
|
</chainedmapper>
|
||||||
</mapper>
|
</mapper>
|
||||||
</pathconvert>
|
</pathconvert>
|
||||||
|
<local name="isjar"/>
|
||||||
|
<condition property="isjar">
|
||||||
|
<contains string="@{src}" substring=".jar"/>
|
||||||
|
</condition>
|
||||||
|
|
||||||
<jar destfile="build/dist/maven/${destfile}.jar"
|
<jar destfile="build/dist/maven/${destfile}.jar"
|
||||||
manifest="build/poi-manifest.mf">
|
manifest="build/poi-manifest.mf">
|
||||||
<fileset dir="@{dir}"/>
|
<fileset dir="@{src}" unless:true="${isjar}"/>
|
||||||
|
<zipfileset src="@{src}" if:true="${isjar}"/>
|
||||||
<metainf dir="legal/"/>
|
<metainf dir="legal/"/>
|
||||||
</jar>
|
</jar>
|
||||||
</sequential>
|
</sequential>
|
||||||
</macrodef>
|
</macrodef>
|
||||||
|
|
||||||
<target name="jar" depends="compile-all, compile-version, -manifest" description="Creates jar files for distribution">
|
<target name="jar" depends="compile, compile-version, compile-ooxml-lite, -manifest" description="Creates jar files for distribution">
|
||||||
<maven-jar dir="${main.output.dir}"/>
|
<maven-jar src="${main.output.dir}"/>
|
||||||
<maven-jar dir="${scratchpad.output.dir}"/>
|
<maven-jar src="${scratchpad.output.dir}"/>
|
||||||
<maven-jar dir="${ooxml.output.dir}"/>
|
<maven-jar src="${ooxml.output.dir}"/>
|
||||||
<maven-jar dir="${examples.output.dir}"/>
|
<maven-jar src="${examples.output.dir}"/>
|
||||||
<maven-jar dir="${excelant.output.dir}"/>
|
<maven-jar src="${excelant.output.dir}"/>
|
||||||
<maven-jar dir="${ooxml.lite.output.dir}"/>
|
<maven-jar src="${ooxml.lite.jar}"/>
|
||||||
</target>
|
</target>
|
||||||
|
|
||||||
<target name="jar-src" depends="compile-all, compile-version, -manifest" description="Sources for Maven">
|
<target name="jar-src" depends="compile, compile-version, -manifest" description="Sources for Maven">
|
||||||
<maven-jar dir="${main.src}"/>
|
<maven-jar src="${main.src}"/>
|
||||||
<maven-jar dir="${scratchpad.src}"/>
|
<maven-jar src="${scratchpad.src}"/>
|
||||||
<maven-jar dir="${ooxml.src}"/>
|
<maven-jar src="${ooxml.src}"/>
|
||||||
<maven-jar dir="${examples.src}"/>
|
<maven-jar src="${examples.src}"/>
|
||||||
<maven-jar dir="${excelant.src}"/>
|
<maven-jar src="${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">
|
<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}"/>
|
<maven-jar src="${integration.output.test.dir}"/>
|
||||||
</target>
|
</target>
|
||||||
|
|
||||||
<target name="-do-jar-check-javadocs-package-list">
|
<target name="-do-jar-check-javadocs-package-list">
|
||||||
|
@ -2112,6 +2108,7 @@ under the License.
|
||||||
lib/**,
|
lib/**,
|
||||||
bin/**,
|
bin/**,
|
||||||
out/**,
|
out/**,
|
||||||
|
tmp/**,
|
||||||
sonar/**/target/**,
|
sonar/**/target/**,
|
||||||
sonar/*/src/**,
|
sonar/*/src/**,
|
||||||
compile-lib/**,
|
compile-lib/**,
|
||||||
|
@ -2167,14 +2164,12 @@ under the License.
|
||||||
</mvn:mvn>
|
</mvn:mvn>
|
||||||
</target>
|
</target>
|
||||||
|
|
||||||
<target name="dist" depends="clean, compile-all, test-all, rat-check, forbidden-apis-check, docs, jar, release-notes, assemble"
|
<target name="dist" depends="clean, compile, test-all, rat-check, forbidden-apis-check, docs, jar, release-notes, assemble"
|
||||||
description="Creates the entire distribution into build/dist, from scratch">
|
description="Creates the entire distribution into build/dist, from scratch">
|
||||||
</target>
|
</target>
|
||||||
|
|
||||||
<!-- continuous integration targets -->
|
<!-- continuous integration targets -->
|
||||||
<target name="gump" depends="compile-all, test-all, jar"
|
<target name="jenkins" depends="compile, test-all, jar, javadocs, assemble, findbugs, release-notes, rat-check, forbidden-apis-check"
|
||||||
description="Target for running with Apache Gump continuous integration. Builds and tests POI and generates jar artifacts." />
|
|
||||||
<target name="jenkins" depends="compile-all, test-all, test-integration, jar, javadocs, assemble, findbugs, release-notes, rat-check, forbidden-apis-check"
|
|
||||||
description="Target run by Jenkins on a continuous basis. Builds and tests POI, generates artifacts and documentation, and searches for problems."/>
|
description="Target run by Jenkins on a continuous basis. Builds and tests POI, generates artifacts and documentation, and searches for problems."/>
|
||||||
|
|
||||||
<available property="maven.ant.tasks.present" classname="org.apache.maven.artifact.ant.Pom"/>
|
<available property="maven.ant.tasks.present" classname="org.apache.maven.artifact.ant.Pom"/>
|
||||||
|
|
|
@ -114,7 +114,8 @@ def defaultTrigger = 'H/15 * * * *' // check SCM every 60/15 = 4 minutes
|
||||||
def defaultEmail = 'dev@poi.apache.org'
|
def defaultEmail = 'dev@poi.apache.org'
|
||||||
def defaultAnt = 'Ant 1.9.9'
|
def defaultAnt = 'Ant 1.9.9'
|
||||||
// currently a lot of H?? slaves don't have Ant installed ... H21 seems to have a SVN problem
|
// currently a lot of H?? slaves don't have Ant installed ... H21 seems to have a SVN problem
|
||||||
def defaultSlaves = '(ubuntu||beam)&&!cloud-slave&&!H15&&!H17&&!H18&&!H24&&!ubuntu-4&&!H21'
|
// H35 fails with ImageIO create cache file errors, although the java.io.tmpdir is writable
|
||||||
|
def defaultSlaves = '(ubuntu||beam)&&!cloud-slave&&!H15&&!H17&&!H18&&!H24&&!ubuntu-4&&!H21&&!H35'
|
||||||
|
|
||||||
def jdkMapping = [
|
def jdkMapping = [
|
||||||
'1.6': 'JDK 1.6 (latest)',
|
'1.6': 'JDK 1.6 (latest)',
|
||||||
|
@ -376,7 +377,7 @@ poijobs.each { poijob ->
|
||||||
}
|
}
|
||||||
} else if (poijob.noScratchpad) {
|
} else if (poijob.noScratchpad) {
|
||||||
ant {
|
ant {
|
||||||
targets(['clean', 'compile-all'] + (poijob.properties ?: []))
|
targets(['clean', 'compile'] + (poijob.properties ?: []))
|
||||||
prop('coverage.enabled', true)
|
prop('coverage.enabled', true)
|
||||||
antInstallation(antRT)
|
antInstallation(antRT)
|
||||||
}
|
}
|
||||||
|
@ -529,20 +530,18 @@ on that machine correctly.
|
||||||
*/
|
*/
|
||||||
matrixJob('POI-DSL-Test-Environment') {
|
matrixJob('POI-DSL-Test-Environment') {
|
||||||
description(
|
description(
|
||||||
'''
|
'''Check installed version of Java/Ant on all build-nodes
|
||||||
Check installed version of Java/Ant on all build-nodes
|
|
||||||
|
|
||||||
This job is used to verify which machines actually have the required programs installed.
|
This job is used to verify which machines actually have the required programs installed.
|
||||||
|
|
||||||
Unfortunately we often see builds break because of changes/new machines...'''
|
Unfortunately we often see builds break because of changes/new machines...''')
|
||||||
)
|
|
||||||
|
|
||||||
/*throttleConcurrentBuilds {
|
/*throttleConcurrentBuilds {
|
||||||
maxPerNode(1)
|
maxPerNode(1)
|
||||||
maxTotal(1)
|
maxTotal(1)
|
||||||
}*/
|
}*/
|
||||||
logRotator {
|
logRotator {
|
||||||
numToKeep(5)
|
numToKeep(1)
|
||||||
artifactNumToKeep(1)
|
artifactNumToKeep(1)
|
||||||
}
|
}
|
||||||
axes {
|
axes {
|
||||||
|
@ -559,37 +558,54 @@ Unfortunately we often see builds break because of changes/new machines...'''
|
||||||
'JDK 11 b23 (early access build) (Windows Only)',
|
'JDK 11 b23 (early access build) (Windows Only)',
|
||||||
|
|
||||||
'JDK 12 (latest)',
|
'JDK 12 (latest)',
|
||||||
'JDK 12 b8 (early access build) (Windows Only)'
|
'OpenJDK 12 b18 (early access build)'
|
||||||
)
|
|
||||||
label('Nodes',
|
|
||||||
'arm1',
|
|
||||||
'beam1','beam2','beam3','beam4','beam5','beam6','beam7','beam8','beam9',
|
|
||||||
'beam10','beam11','beam12','beam13','beam14','beam15','beam16',
|
|
||||||
'H0','H1','H10','H11','H12','H13','H14','H15','H16','H17','H18','H19',
|
|
||||||
'H2','H20','H21','H22','H23','H24','H25','H26','H27','H28','H29',
|
|
||||||
'H3','H30','H31','H32','H33','H34','H35',
|
|
||||||
'H4','H5','H6','H7','H8','H9',
|
|
||||||
'ubuntu-1','ubuntu-2','ubuntu-4','ubuntu-6','ubuntu-eu2','ubuntu-eu3','ubuntu-ppc64le','ubuntu-us1',
|
|
||||||
'windows-2012-1','windows-2012-2','windows-2012-3','windows-2016-1','windows-2016-2','windows-2016-3'
|
|
||||||
)
|
)
|
||||||
|
elasticAxis {
|
||||||
|
name('Nodes')
|
||||||
|
labelString('!cloud-slave&&!H15&&!H17&&!H18&&!H24&&!ubuntu-4&&!H21&&!H35&&!websites1&&!couchdb&&!plc4x&&!ppc64le')
|
||||||
|
ignoreOffline(true)
|
||||||
|
}
|
||||||
}
|
}
|
||||||
steps {
|
steps {
|
||||||
/*if (poijob.windows) {
|
conditionalSteps {
|
||||||
context.batchFile(cmd)
|
condition {
|
||||||
} else {*/
|
fileExists('/usr', BaseDir.WORKSPACE)
|
||||||
shell('''
|
runner('DontRun')
|
||||||
which javac
|
steps {
|
||||||
|
shell(
|
||||||
|
'''which javac
|
||||||
javac -version
|
javac -version
|
||||||
echo '<?xml version="1.0"?><project name="POI Build" default="test"><target name="test"><echo>Using Ant: ${ant.version} from ${ant.home}</echo></target></project>' > build.xml
|
echo '<?xml version="1.0"?><project name="POI Build" default="test"><target name="test"><echo>Using Ant: ${ant.version} from ${ant.home}</echo></target></project>' > build.xml
|
||||||
''')
|
''')
|
||||||
//}
|
ant {
|
||||||
ant {
|
antInstallation(defaultAnt)
|
||||||
antInstallation(defaultAnt)
|
}
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
publishers {
|
}
|
||||||
mailer('centic@poi.apache.org' /* defaultEmail */, false, false)
|
}
|
||||||
|
}
|
||||||
|
conditionalSteps {
|
||||||
|
condition {
|
||||||
|
fileExists('c:\\windows', BaseDir.WORKSPACE)
|
||||||
|
runner('DontRun')
|
||||||
|
steps {
|
||||||
|
batchFile {
|
||||||
|
command(
|
||||||
|
'''@echo off
|
||||||
|
echo .
|
||||||
|
where javac.exe
|
||||||
|
echo .
|
||||||
|
javac -version
|
||||||
|
echo .
|
||||||
|
echo ^<?xml version=^"1.0^"?^>^<project name=^"POI Build^" default=^"test^"^>^<target name=^"test^"^>^<echo^>Using Ant: ${ant.version} from ${ant.home}^</echo^>^</target^>^</project^> > build.xml
|
||||||
|
''')
|
||||||
|
}
|
||||||
|
ant {
|
||||||
|
antInstallation(defaultAnt + ' (Windows)')
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
|
@ -6,7 +6,7 @@
|
||||||
<parent>
|
<parent>
|
||||||
<groupId>org.apache.poi</groupId>
|
<groupId>org.apache.poi</groupId>
|
||||||
<artifactId>poi-parent</artifactId>
|
<artifactId>poi-parent</artifactId>
|
||||||
<version>4.0.1-SNAPSHOT</version>
|
<version>4.0.2-SNAPSHOT</version>
|
||||||
</parent>
|
</parent>
|
||||||
<artifactId>poi-examples</artifactId>
|
<artifactId>poi-examples</artifactId>
|
||||||
<packaging>jar</packaging>
|
<packaging>jar</packaging>
|
||||||
|
|
|
@ -6,7 +6,7 @@
|
||||||
<parent>
|
<parent>
|
||||||
<groupId>org.apache.poi</groupId>
|
<groupId>org.apache.poi</groupId>
|
||||||
<artifactId>poi-parent</artifactId>
|
<artifactId>poi-parent</artifactId>
|
||||||
<version>4.0.1-SNAPSHOT</version>
|
<version>4.0.2-SNAPSHOT</version>
|
||||||
</parent>
|
</parent>
|
||||||
<artifactId>poi-excelant</artifactId>
|
<artifactId>poi-excelant</artifactId>
|
||||||
<packaging>jar</packaging>
|
<packaging>jar</packaging>
|
||||||
|
|
|
@ -6,7 +6,7 @@
|
||||||
<parent>
|
<parent>
|
||||||
<groupId>org.apache.poi</groupId>
|
<groupId>org.apache.poi</groupId>
|
||||||
<artifactId>poi-parent</artifactId>
|
<artifactId>poi-parent</artifactId>
|
||||||
<version>4.0.1-SNAPSHOT</version>
|
<version>4.0.2-SNAPSHOT</version>
|
||||||
</parent>
|
</parent>
|
||||||
<artifactId>poi-main</artifactId>
|
<artifactId>poi-main</artifactId>
|
||||||
<packaging>jar</packaging>
|
<packaging>jar</packaging>
|
||||||
|
@ -103,7 +103,7 @@
|
||||||
<artifactId>maven-surefire-plugin</artifactId>
|
<artifactId>maven-surefire-plugin</artifactId>
|
||||||
<version>${maven.plugin.surefire.version}</version>
|
<version>${maven.plugin.surefire.version}</version>
|
||||||
<configuration>
|
<configuration>
|
||||||
<argLine>@{argLine} -Duser.language=en -Duser.country=US -Xmx1024m -Djava.io.tmpdir=target/tmp -XX:-OmitStackTraceInFastThrow</argLine>
|
<argLine>@{argLine} -Duser.language=en -Duser.country=US -Xmx1024m -Djava.io.tmpdir=${basedir}/target/tmp -XX:-OmitStackTraceInFastThrow</argLine>
|
||||||
</configuration>
|
</configuration>
|
||||||
</plugin>
|
</plugin>
|
||||||
</plugins>
|
</plugins>
|
||||||
|
|
|
@ -6,7 +6,7 @@
|
||||||
<parent>
|
<parent>
|
||||||
<groupId>org.apache.poi</groupId>
|
<groupId>org.apache.poi</groupId>
|
||||||
<artifactId>poi-parent</artifactId>
|
<artifactId>poi-parent</artifactId>
|
||||||
<version>4.0.1-SNAPSHOT</version>
|
<version>4.0.2-SNAPSHOT</version>
|
||||||
<relativePath>..</relativePath>
|
<relativePath>..</relativePath>
|
||||||
</parent>
|
</parent>
|
||||||
<artifactId>poi-ooxml-schema-encryption</artifactId>
|
<artifactId>poi-ooxml-schema-encryption</artifactId>
|
||||||
|
|
|
@ -6,7 +6,7 @@
|
||||||
<parent>
|
<parent>
|
||||||
<groupId>org.apache.poi</groupId>
|
<groupId>org.apache.poi</groupId>
|
||||||
<artifactId>poi-parent</artifactId>
|
<artifactId>poi-parent</artifactId>
|
||||||
<version>4.0.1-SNAPSHOT</version>
|
<version>4.0.2-SNAPSHOT</version>
|
||||||
<relativePath>..</relativePath>
|
<relativePath>..</relativePath>
|
||||||
</parent>
|
</parent>
|
||||||
<artifactId>poi-ooxml-schema-security</artifactId>
|
<artifactId>poi-ooxml-schema-security</artifactId>
|
||||||
|
|
|
@ -6,7 +6,7 @@
|
||||||
<parent>
|
<parent>
|
||||||
<groupId>org.apache.poi</groupId>
|
<groupId>org.apache.poi</groupId>
|
||||||
<artifactId>poi-parent</artifactId>
|
<artifactId>poi-parent</artifactId>
|
||||||
<version>4.0.1-SNAPSHOT</version>
|
<version>4.0.2-SNAPSHOT</version>
|
||||||
<relativePath>..</relativePath>
|
<relativePath>..</relativePath>
|
||||||
</parent>
|
</parent>
|
||||||
<artifactId>poi-ooxml-schema</artifactId>
|
<artifactId>poi-ooxml-schema</artifactId>
|
||||||
|
|
|
@ -6,7 +6,7 @@
|
||||||
<parent>
|
<parent>
|
||||||
<groupId>org.apache.poi</groupId>
|
<groupId>org.apache.poi</groupId>
|
||||||
<artifactId>poi-parent</artifactId>
|
<artifactId>poi-parent</artifactId>
|
||||||
<version>4.0.1-SNAPSHOT</version>
|
<version>4.0.2-SNAPSHOT</version>
|
||||||
</parent>
|
</parent>
|
||||||
<artifactId>poi-ooxml</artifactId>
|
<artifactId>poi-ooxml</artifactId>
|
||||||
<packaging>jar</packaging>
|
<packaging>jar</packaging>
|
||||||
|
@ -93,7 +93,7 @@
|
||||||
<artifactId>maven-surefire-plugin</artifactId>
|
<artifactId>maven-surefire-plugin</artifactId>
|
||||||
<version>${maven.plugin.surefire.version}</version>
|
<version>${maven.plugin.surefire.version}</version>
|
||||||
<configuration>
|
<configuration>
|
||||||
<argLine>@{argLine} -Duser.language=en -Duser.country=US -Xmx1024m -Djava.io.tmpdir=target/tmp -XX:-OmitStackTraceInFastThrow</argLine>
|
<argLine>@{argLine} -Duser.language=en -Duser.country=US -Xmx1024m -Djava.io.tmpdir=${basedir}/target/tmp -XX:-OmitStackTraceInFastThrow</argLine>
|
||||||
</configuration>
|
</configuration>
|
||||||
</plugin>
|
</plugin>
|
||||||
</plugins>
|
</plugins>
|
||||||
|
|
|
@ -4,7 +4,7 @@
|
||||||
<groupId>org.apache.poi</groupId>
|
<groupId>org.apache.poi</groupId>
|
||||||
<artifactId>poi-parent</artifactId>
|
<artifactId>poi-parent</artifactId>
|
||||||
<packaging>pom</packaging>
|
<packaging>pom</packaging>
|
||||||
<version>4.0.1-SNAPSHOT</version>
|
<version>4.0.2-SNAPSHOT</version>
|
||||||
<name>Apache POI - the Java API for Microsoft Documents</name>
|
<name>Apache POI - the Java API for Microsoft Documents</name>
|
||||||
<description>Maven build of Apache POI for Sonar checks</description>
|
<description>Maven build of Apache POI for Sonar checks</description>
|
||||||
<url>http://poi.apache.org/</url>
|
<url>http://poi.apache.org/</url>
|
||||||
|
@ -117,7 +117,7 @@
|
||||||
<org.apache.poi.util.POILogger>org.apache.poi.util.NullLogger</org.apache.poi.util.POILogger>
|
<org.apache.poi.util.POILogger>org.apache.poi.util.NullLogger</org.apache.poi.util.POILogger>
|
||||||
</systemPropertyVariables>
|
</systemPropertyVariables>
|
||||||
<!-- use to following to analyze OOM issues: -XX:+HeapDumpOnOutOfMemoryError -XX:HeapDumpPath=/tmp -->
|
<!-- use to following to analyze OOM issues: -XX:+HeapDumpOnOutOfMemoryError -XX:HeapDumpPath=/tmp -->
|
||||||
<argLine>@{argLine} -Duser.language=en -Duser.country=US -Xmx1024m -Djava.io.tmpdir=target/tmp
|
<argLine>@{argLine} -Duser.language=en -Duser.country=US -Xmx1024m -Djava.io.tmpdir=${basedir}/target/tmp
|
||||||
</argLine>
|
</argLine>
|
||||||
<excludes>
|
<excludes>
|
||||||
<exclude>**/All*Tests.java</exclude>
|
<exclude>**/All*Tests.java</exclude>
|
||||||
|
|
|
@ -6,7 +6,7 @@
|
||||||
<parent>
|
<parent>
|
||||||
<groupId>org.apache.poi</groupId>
|
<groupId>org.apache.poi</groupId>
|
||||||
<artifactId>poi-parent</artifactId>
|
<artifactId>poi-parent</artifactId>
|
||||||
<version>4.0.1-SNAPSHOT</version>
|
<version>4.0.2-SNAPSHOT</version>
|
||||||
</parent>
|
</parent>
|
||||||
<artifactId>poi-scratchpad</artifactId>
|
<artifactId>poi-scratchpad</artifactId>
|
||||||
<packaging>jar</packaging>
|
<packaging>jar</packaging>
|
||||||
|
|
|
@ -19,7 +19,6 @@ package org.apache.poi.xssf.usermodel.examples;
|
||||||
import java.io.FileOutputStream;
|
import java.io.FileOutputStream;
|
||||||
import java.io.IOException;
|
import java.io.IOException;
|
||||||
|
|
||||||
import org.apache.poi.ss.usermodel.Workbook;
|
|
||||||
import org.apache.poi.ss.util.AreaReference;
|
import org.apache.poi.ss.util.AreaReference;
|
||||||
import org.apache.poi.ss.util.CellReference;
|
import org.apache.poi.ss.util.CellReference;
|
||||||
import org.apache.poi.xssf.usermodel.XSSFCell;
|
import org.apache.poi.xssf.usermodel.XSSFCell;
|
||||||
|
@ -36,8 +35,8 @@ public class CreateTable {
|
||||||
|
|
||||||
public static void main(String[] args) throws IOException {
|
public static void main(String[] args) throws IOException {
|
||||||
|
|
||||||
try (Workbook wb = new XSSFWorkbook()) {
|
try (XSSFWorkbook wb = new XSSFWorkbook()) {
|
||||||
XSSFSheet sheet = (XSSFSheet) wb.createSheet();
|
XSSFSheet sheet = wb.createSheet();
|
||||||
|
|
||||||
// Set which area the table should be placed in
|
// Set which area the table should be placed in
|
||||||
AreaReference reference = wb.getCreationHelper().createAreaReference(
|
AreaReference reference = wb.getCreationHelper().createAreaReference(
|
||||||
|
@ -78,10 +77,6 @@ public class CreateTable {
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
// Create the columns
|
|
||||||
table.createColumn("Column 1");
|
|
||||||
table.createColumn("Column 2");
|
|
||||||
table.createColumn("Column 3");
|
|
||||||
|
|
||||||
// Save
|
// Save
|
||||||
try (FileOutputStream fileOut = new FileOutputStream("ooxml-table.xlsx")) {
|
try (FileOutputStream fileOut = new FileOutputStream("ooxml-table.xlsx")) {
|
||||||
|
|
|
@ -82,7 +82,9 @@ Before running this, you should execute the "assemble" target in the main build.
|
||||||
|
|
||||||
<target name="runCompileTest" depends="init" description="Verify that we can compile most examples without including excelant or scratchpad jars">
|
<target name="runCompileTest" depends="init" description="Verify that we can compile most examples without including excelant or scratchpad jars">
|
||||||
<!-- clean out old stuff in build-dir -->
|
<!-- clean out old stuff in build-dir -->
|
||||||
<delete dir="${build}"/>
|
<delete dir="${build}" quiet="true" failonerror="false"/>
|
||||||
|
<!-- ... try again - on Windows, the JaCoCo ant task seems to keep files open and hence the lib directory can't be removed -->
|
||||||
|
<delete dir="${build}" quiet="true" failonerror="false"/>
|
||||||
<mkdir dir="${build}"/>
|
<mkdir dir="${build}"/>
|
||||||
|
|
||||||
<!-- select latest built jar files without scratchpad.jar -->
|
<!-- select latest built jar files without scratchpad.jar -->
|
||||||
|
|
|
@ -16,17 +16,24 @@
|
||||||
==================================================================== */
|
==================================================================== */
|
||||||
package org.apache.poi;
|
package org.apache.poi;
|
||||||
|
|
||||||
import org.apache.poi.hslf.exceptions.OldPowerPointFormatException;
|
import static org.junit.Assert.assertNotNull;
|
||||||
import org.apache.poi.hssf.OldExcelFormatException;
|
|
||||||
import org.apache.poi.hwpf.OldWordFileFormatException;
|
|
||||||
import org.apache.poi.poifs.filesystem.OfficeXmlFileException;
|
|
||||||
import org.apache.poi.stress.*;
|
|
||||||
import org.junit.Assume;
|
|
||||||
|
|
||||||
import java.io.*;
|
import java.io.BufferedInputStream;
|
||||||
|
import java.io.File;
|
||||||
|
import java.io.FileInputStream;
|
||||||
|
import java.io.IOException;
|
||||||
|
import java.io.InputStream;
|
||||||
import java.util.zip.ZipException;
|
import java.util.zip.ZipException;
|
||||||
|
|
||||||
import static org.junit.Assert.assertNotNull;
|
import org.apache.poi.poifs.filesystem.OfficeXmlFileException;
|
||||||
|
import org.apache.poi.stress.FileHandler;
|
||||||
|
import org.apache.poi.stress.HSLFFileHandler;
|
||||||
|
import org.apache.poi.stress.HSSFFileHandler;
|
||||||
|
import org.apache.poi.stress.HWPFFileHandler;
|
||||||
|
import org.apache.poi.stress.XSLFFileHandler;
|
||||||
|
import org.apache.poi.stress.XSSFFileHandler;
|
||||||
|
import org.apache.poi.stress.XWPFFileHandler;
|
||||||
|
import org.junit.Assume;
|
||||||
|
|
||||||
public class BaseIntegrationTest {
|
public class BaseIntegrationTest {
|
||||||
private final File rootDir;
|
private final File rootDir;
|
||||||
|
@ -53,12 +60,13 @@ public class BaseIntegrationTest {
|
||||||
|
|
||||||
// use XWPF instead of HWPF and XSSF instead of HSSF as the file seems to have the wrong extension
|
// use XWPF instead of HWPF and XSSF instead of HSSF as the file seems to have the wrong extension
|
||||||
handleWrongExtension(inputFile, e);
|
handleWrongExtension(inputFile, e);
|
||||||
} catch (OldWordFileFormatException | OldExcelFormatException | OldPowerPointFormatException e) {
|
|
||||||
// at least perform extracting tests on these old files
|
|
||||||
} catch (OldFileFormatException e) {
|
} catch (OldFileFormatException e) {
|
||||||
// Not even text extraction is supported for these: handler.handleExtracting(inputFile);
|
if (e.getClass().equals(OldFileFormatException.class)) {
|
||||||
//noinspection ConstantConditions
|
// Not even text extraction is supported for these: handler.handleExtracting(inputFile);
|
||||||
Assume.assumeFalse("File " + file + " excluded because it is unsupported old Excel format", true);
|
//noinspection ConstantConditions
|
||||||
|
Assume.assumeFalse("File " + file + " excluded because it is unsupported old Excel format", true);
|
||||||
|
}
|
||||||
|
// otherwise try at least to perform extracting tests on these old files
|
||||||
} catch (EncryptedDocumentException e) {
|
} catch (EncryptedDocumentException e) {
|
||||||
// Do not try to read encrypted files
|
// Do not try to read encrypted files
|
||||||
//noinspection ConstantConditions
|
//noinspection ConstantConditions
|
||||||
|
|
|
@ -90,6 +90,7 @@ import org.junit.runners.Parameterized.Parameters;
|
||||||
@RunWith(Parameterized.class)
|
@RunWith(Parameterized.class)
|
||||||
public class TestAllFiles {
|
public class TestAllFiles {
|
||||||
private static final File ROOT_DIR = new File("test-data");
|
private static final File ROOT_DIR = new File("test-data");
|
||||||
|
private static final boolean IGNORE_SCRATCHPAD = Boolean.getBoolean("scratchpad.ignore");
|
||||||
|
|
||||||
public static final String[] SCAN_EXCLUDES = new String[] { "**/.svn/**", "lost+found", "**/.git/**" };
|
public static final String[] SCAN_EXCLUDES = new String[] { "**/.svn/**", "lost+found", "**/.git/**" };
|
||||||
|
|
||||||
|
@ -98,6 +99,7 @@ public class TestAllFiles {
|
||||||
|
|
||||||
// map file extensions to the actual mappers
|
// map file extensions to the actual mappers
|
||||||
public static final Map<String, FileHandler> HANDLERS = new HashMap<>();
|
public static final Map<String, FileHandler> HANDLERS = new HashMap<>();
|
||||||
|
|
||||||
static {
|
static {
|
||||||
// Excel
|
// Excel
|
||||||
HANDLERS.put(".xls", new HSSFFileHandler());
|
HANDLERS.put(".xls", new HSSFFileHandler());
|
||||||
|
@ -107,17 +109,17 @@ public class TestAllFiles {
|
||||||
HANDLERS.put(".xlsb", new XSSFBFileHandler());
|
HANDLERS.put(".xlsb", new XSSFBFileHandler());
|
||||||
|
|
||||||
// Word
|
// Word
|
||||||
HANDLERS.put(".doc", new HWPFFileHandler());
|
HANDLERS.put(".doc", IGNORE_SCRATCHPAD ? new HPSFFileHandler() : new HWPFFileHandler());
|
||||||
HANDLERS.put(".docx", new XWPFFileHandler());
|
HANDLERS.put(".docx", new XWPFFileHandler());
|
||||||
HANDLERS.put(".dotx", new XWPFFileHandler());
|
HANDLERS.put(".dotx", new XWPFFileHandler());
|
||||||
HANDLERS.put(".docm", new XWPFFileHandler());
|
HANDLERS.put(".docm", new XWPFFileHandler());
|
||||||
|
|
||||||
// OpenXML4J files
|
// OpenXML4J files
|
||||||
HANDLERS.put(".ooxml", new OPCFileHandler()); // OPCPackage
|
HANDLERS.put(".ooxml", new OPCFileHandler());
|
||||||
HANDLERS.put(".zip", new OPCFileHandler()); // OPCPackage
|
HANDLERS.put(".zip", new OPCFileHandler());
|
||||||
|
|
||||||
// Powerpoint
|
// Powerpoint
|
||||||
HANDLERS.put(".ppt", new HSLFFileHandler());
|
HANDLERS.put(".ppt", IGNORE_SCRATCHPAD ? new HPSFFileHandler() : new HSLFFileHandler());
|
||||||
HANDLERS.put(".pptx", new XSLFFileHandler());
|
HANDLERS.put(".pptx", new XSLFFileHandler());
|
||||||
HANDLERS.put(".pptm", new XSLFFileHandler());
|
HANDLERS.put(".pptm", new XSLFFileHandler());
|
||||||
HANDLERS.put(".ppsm", new XSLFFileHandler());
|
HANDLERS.put(".ppsm", new XSLFFileHandler());
|
||||||
|
@ -126,13 +128,13 @@ public class TestAllFiles {
|
||||||
HANDLERS.put(".potx", new XSLFFileHandler());
|
HANDLERS.put(".potx", new XSLFFileHandler());
|
||||||
|
|
||||||
// Outlook
|
// Outlook
|
||||||
HANDLERS.put(".msg", new HSMFFileHandler());
|
HANDLERS.put(".msg", IGNORE_SCRATCHPAD ? new HPSFFileHandler() : new HSMFFileHandler());
|
||||||
|
|
||||||
// Publisher
|
// Publisher
|
||||||
HANDLERS.put(".pub", new HPBFFileHandler());
|
HANDLERS.put(".pub", IGNORE_SCRATCHPAD ? new HPSFFileHandler() : new HPBFFileHandler());
|
||||||
|
|
||||||
// Visio - binary
|
// Visio - binary
|
||||||
HANDLERS.put(".vsd", new HDGFFileHandler());
|
HANDLERS.put(".vsd", IGNORE_SCRATCHPAD ? new HPSFFileHandler() : new HDGFFileHandler());
|
||||||
|
|
||||||
// Visio - ooxml
|
// Visio - ooxml
|
||||||
HANDLERS.put(".vsdm", new XDGFFileHandler());
|
HANDLERS.put(".vsdm", new XDGFFileHandler());
|
||||||
|
@ -153,7 +155,7 @@ public class TestAllFiles {
|
||||||
HANDLERS.put(".adm", new HPSFFileHandler());
|
HANDLERS.put(".adm", new HPSFFileHandler());
|
||||||
|
|
||||||
// Microsoft TNEF
|
// Microsoft TNEF
|
||||||
HANDLERS.put(".dat", new HMEFFileHandler());
|
HANDLERS.put(".dat", IGNORE_SCRATCHPAD ? new HPSFFileHandler() : new HMEFFileHandler());
|
||||||
|
|
||||||
// TODO: are these readable by some of the formats?
|
// TODO: are these readable by some of the formats?
|
||||||
HANDLERS.put(".wri", new NullFileHandler());
|
HANDLERS.put(".wri", new NullFileHandler());
|
||||||
|
@ -300,7 +302,7 @@ public class TestAllFiles {
|
||||||
"spreadsheet/54764-2.xlsx", // see TestXSSFBugs.bug54764()
|
"spreadsheet/54764-2.xlsx", // see TestXSSFBugs.bug54764()
|
||||||
"spreadsheet/54764.xlsx", // see TestXSSFBugs.bug54764()
|
"spreadsheet/54764.xlsx", // see TestXSSFBugs.bug54764()
|
||||||
"poifs/unknown_properties.msg", // POIFS properties corrupted
|
"poifs/unknown_properties.msg", // POIFS properties corrupted
|
||||||
"poifs/only-zero-byte-streams.ole2", // No actual contents
|
(IGNORE_SCRATCHPAD ? "" : "poifs/only-zero-byte-streams.ole2"), // No actual contents
|
||||||
"spreadsheet/poc-xmlbomb.xlsx", // contains xml-entity-expansion
|
"spreadsheet/poc-xmlbomb.xlsx", // contains xml-entity-expansion
|
||||||
"spreadsheet/poc-xmlbomb-empty.xlsx", // contains xml-entity-expansion
|
"spreadsheet/poc-xmlbomb-empty.xlsx", // contains xml-entity-expansion
|
||||||
"spreadsheet/poc-shared-strings.xlsx", // contains shared-string-entity-expansion
|
"spreadsheet/poc-shared-strings.xlsx", // contains shared-string-entity-expansion
|
||||||
|
@ -438,8 +440,17 @@ public class TestAllFiles {
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
// let some file handlers do additional stuff
|
try {
|
||||||
handler.handleAdditional(inputFile);
|
// let some file handlers do additional stuff
|
||||||
|
handler.handleAdditional(inputFile);
|
||||||
|
} catch (AssumptionViolatedException e) {
|
||||||
|
// file handler ignored this file
|
||||||
|
} catch (Exception e) {
|
||||||
|
if(!EXPECTED_FAILURES.contains(file) && !AbstractFileHandler.EXPECTED_EXTRACTOR_FAILURES.contains(file)) {
|
||||||
|
System.out.println("Failed: " + file);
|
||||||
|
throw new Exception("While handling " + file, e);
|
||||||
|
}
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
public static String getExtension(String file) {
|
public static String getExtension(String file) {
|
||||||
|
|
|
@ -79,7 +79,7 @@ public abstract class AbstractFileHandler implements FileHandler {
|
||||||
long modified = file.lastModified();
|
long modified = file.lastModified();
|
||||||
|
|
||||||
POITextExtractor extractor = null;
|
POITextExtractor extractor = null;
|
||||||
try {
|
try {
|
||||||
extractor = ExtractorFactory.createExtractor(file);
|
extractor = ExtractorFactory.createExtractor(file);
|
||||||
assertNotNull("Should get a POITextExtractor but had none for file " + file, extractor);
|
assertNotNull("Should get a POITextExtractor but had none for file " + file, extractor);
|
||||||
|
|
||||||
|
@ -98,7 +98,7 @@ public abstract class AbstractFileHandler implements FileHandler {
|
||||||
|
|
||||||
handleExtractingAsStream(file);
|
handleExtractingAsStream(file);
|
||||||
|
|
||||||
if(extractor instanceof POIOLE2TextExtractor) {
|
if (extractor instanceof POIOLE2TextExtractor) {
|
||||||
try (HPSFPropertiesExtractor hpsfExtractor = new HPSFPropertiesExtractor((POIOLE2TextExtractor) extractor)) {
|
try (HPSFPropertiesExtractor hpsfExtractor = new HPSFPropertiesExtractor((POIOLE2TextExtractor) extractor)) {
|
||||||
assertNotNull(hpsfExtractor.getDocumentSummaryInformationText());
|
assertNotNull(hpsfExtractor.getDocumentSummaryInformationText());
|
||||||
assertNotNull(hpsfExtractor.getSummaryInformationText());
|
assertNotNull(hpsfExtractor.getSummaryInformationText());
|
||||||
|
@ -115,6 +115,10 @@ public abstract class AbstractFileHandler implements FileHandler {
|
||||||
String msg = "org.apache.poi.EncryptedDocumentException: Export Restrictions in place - please install JCE Unlimited Strength Jurisdiction Policy files";
|
String msg = "org.apache.poi.EncryptedDocumentException: Export Restrictions in place - please install JCE Unlimited Strength Jurisdiction Policy files";
|
||||||
assumeFalse(msg.equals(e.getMessage()));
|
assumeFalse(msg.equals(e.getMessage()));
|
||||||
throw e;
|
throw e;
|
||||||
|
} catch (IllegalStateException e) {
|
||||||
|
if (!e.getMessage().contains("POI Scratchpad jar missing") || !Boolean.getBoolean("scratchpad.ignore")) {
|
||||||
|
throw e;
|
||||||
|
}
|
||||||
} finally {
|
} finally {
|
||||||
IOUtils.closeQuietly(extractor);
|
IOUtils.closeQuietly(extractor);
|
||||||
}
|
}
|
||||||
|
|
|
@ -94,8 +94,6 @@ public final class MissingRecordAwareHSSFListener implements HSSFListener {
|
||||||
break;
|
break;
|
||||||
case RowRecord.sid:
|
case RowRecord.sid:
|
||||||
RowRecord rowrec = (RowRecord) record;
|
RowRecord rowrec = (RowRecord) record;
|
||||||
//System.out.println("Row " + rowrec.getRowNumber() + " found, first column at "
|
|
||||||
// + rowrec.getFirstCol() + " last column at " + rowrec.getLastCol());
|
|
||||||
|
|
||||||
// If there's a jump in rows, fire off missing row records
|
// If there's a jump in rows, fire off missing row records
|
||||||
if (lastRowRow + 1 < rowrec.getRowNumber()) {
|
if (lastRowRow + 1 < rowrec.getRowNumber()) {
|
||||||
|
|
|
@ -80,13 +80,10 @@ public final class UnknownRecord extends StandardRecord {
|
||||||
public UnknownRecord(RecordInputStream in) {
|
public UnknownRecord(RecordInputStream in) {
|
||||||
_sid = in.getSid();
|
_sid = in.getSid();
|
||||||
_rawData = in.readRemainder();
|
_rawData = in.readRemainder();
|
||||||
// if (false && getBiffName(_sid) == null) {
|
|
||||||
// // unknown sids in the range 0x0004-0x0013 are probably 'sub-records' of ObjectRecord
|
// TODO - put unknown OBJ sub-records in a different class
|
||||||
// // those sids are in a different number space.
|
// unknown sids in the range 0x0004-0x0013 are probably 'sub-records' of ObjectRecord
|
||||||
// // TODO - put unknown OBJ sub-records in a different class
|
// those sids are in a different number space.
|
||||||
// System.out.println("Unknown record 0x" +
|
|
||||||
// Integer.toHexString(_sid).toUpperCase(Locale.ROOT));
|
|
||||||
// }
|
|
||||||
}
|
}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
|
|
|
@ -54,26 +54,22 @@ public class CellFormatPart {
|
||||||
private final CellFormatter format;
|
private final CellFormatter format;
|
||||||
private final CellFormatType type;
|
private final CellFormatType type;
|
||||||
|
|
||||||
private static final Map<String, Color> NAMED_COLORS;
|
static final Map<String, Color> NAMED_COLORS;
|
||||||
|
|
||||||
static {
|
static {
|
||||||
NAMED_COLORS = new TreeMap<>(
|
NAMED_COLORS = new TreeMap<>(
|
||||||
String.CASE_INSENSITIVE_ORDER);
|
String.CASE_INSENSITIVE_ORDER);
|
||||||
|
|
||||||
Map<Integer,HSSFColor> colors = HSSFColor.getIndexHash();
|
for (HSSFColor.HSSFColorPredefined color : HSSFColor.HSSFColorPredefined.values()) {
|
||||||
for (HSSFColor color : colors.values()) {
|
String name = color.name();
|
||||||
Class<? extends HSSFColor> type = color.getClass();
|
short[] rgb = color.getTriplet();
|
||||||
String name = type.getSimpleName();
|
Color c = new Color(rgb[0], rgb[1], rgb[2]);
|
||||||
if (name.equals(name.toUpperCase(Locale.ROOT))) {
|
NAMED_COLORS.put(name, c);
|
||||||
short[] rgb = color.getTriplet();
|
if (name.indexOf('_') > 0)
|
||||||
Color c = new Color(rgb[0], rgb[1], rgb[2]);
|
NAMED_COLORS.put(name.replace('_', ' '), c);
|
||||||
NAMED_COLORS.put(name, c);
|
if (name.indexOf("_PERCENT") > 0)
|
||||||
if (name.indexOf('_') > 0)
|
NAMED_COLORS.put(name.replace("_PERCENT", "%").replace('_',
|
||||||
NAMED_COLORS.put(name.replace('_', ' '), c);
|
' '), c);
|
||||||
if (name.indexOf("_PERCENT") > 0)
|
|
||||||
NAMED_COLORS.put(name.replace("_PERCENT", "%").replace('_',
|
|
||||||
' '), c);
|
|
||||||
}
|
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
|
@ -48,19 +48,15 @@ public class Formula {
|
||||||
private Formula(byte[] byteEncoding, int encodedTokenLen) {
|
private Formula(byte[] byteEncoding, int encodedTokenLen) {
|
||||||
_byteEncoding = byteEncoding.clone();
|
_byteEncoding = byteEncoding.clone();
|
||||||
_encodedTokenLen = encodedTokenLen;
|
_encodedTokenLen = encodedTokenLen;
|
||||||
// if (false) { // set to true to eagerly check Ptg decoding
|
|
||||||
// LittleEndianByteArrayInputStream in = new LittleEndianByteArrayInputStream(byteEncoding);
|
// TODO - this seems to occur when IntersectionPtg is present
|
||||||
// Ptg.readTokens(encodedTokenLen, in);
|
// This example file "IntersectionPtg.xls"
|
||||||
// int nUnusedBytes = _byteEncoding.length - in.getReadIndex();
|
// used by test: TestIntersectionPtg.testReading()
|
||||||
// if (nUnusedBytes > 0) {
|
// has 10 bytes unused at the end of the formula
|
||||||
// // TODO - this seems to occur when IntersectionPtg is present
|
// 10 extra bytes are just 0x01 and 0x00
|
||||||
// // This example file "IntersectionPtg.xls"
|
// LittleEndianByteArrayInputStream in = new LittleEndianByteArrayInputStream(byteEncoding);
|
||||||
// // used by test: TestIntersectionPtg.testReading()
|
// Ptg.readTokens(encodedTokenLen, in);
|
||||||
// // has 10 bytes unused at the end of the formula
|
// int nUnusedBytes = _byteEncoding.length - in.getReadIndex();
|
||||||
// // 10 extra bytes are just 0x01 and 0x00
|
|
||||||
// System.out.println(nUnusedBytes + " unused bytes at end of formula");
|
|
||||||
// }
|
|
||||||
// }
|
|
||||||
}
|
}
|
||||||
/**
|
/**
|
||||||
* Convenience method for {@link #read(int, LittleEndianInput, int)}
|
* Convenience method for {@link #read(int, LittleEndianInput, int)}
|
||||||
|
|
|
@ -234,7 +234,6 @@ public final class FormulaParser {
|
||||||
_inIntersection = false;
|
_inIntersection = false;
|
||||||
}
|
}
|
||||||
_pointer += Character.charCount(look);
|
_pointer += Character.charCount(look);
|
||||||
//System.out.println(new StringBuilder("Got char: ").appendCodePoint(look)).toString();
|
|
||||||
}
|
}
|
||||||
private void resetPointer(int ptr) {
|
private void resetPointer(int ptr) {
|
||||||
_pointer = ptr;
|
_pointer = ptr;
|
||||||
|
|
|
@ -88,7 +88,6 @@ public final class OperandResolver {
|
||||||
CellRangeAddress range = cell.getArrayFormulaRange();
|
CellRangeAddress range = cell.getArrayFormulaRange();
|
||||||
int relativeRowIndex = cell.getRowIndex() - range.getFirstRow();
|
int relativeRowIndex = cell.getRowIndex() - range.getFirstRow();
|
||||||
int relativeColIndex = cell.getColumnIndex() - range.getFirstColumn();
|
int relativeColIndex = cell.getColumnIndex() - range.getFirstColumn();
|
||||||
//System.out.println("Row: " + relativeRowIndex + " Col: " + relativeColIndex);
|
|
||||||
|
|
||||||
if (ae.isColumn()) {
|
if (ae.isColumn()) {
|
||||||
if (ae.isRow()) {
|
if (ae.isRow()) {
|
||||||
|
|
|
@ -450,7 +450,6 @@ public class DataFormatter implements Observer {
|
||||||
|
|
||||||
// Strip custom text in quotes and escaped characters for now as it can cause performance problems in fractions.
|
// Strip custom text in quotes and escaped characters for now as it can cause performance problems in fractions.
|
||||||
//String strippedFormatStr = formatStr.replaceAll("\\\\ ", " ").replaceAll("\\\\.", "").replaceAll("\"[^\"]*\"", " ").replaceAll("\\?", "#");
|
//String strippedFormatStr = formatStr.replaceAll("\\\\ ", " ").replaceAll("\\\\.", "").replaceAll("\"[^\"]*\"", " ").replaceAll("\\?", "#");
|
||||||
//System.out.println("formatStr: "+strippedFormatStr);
|
|
||||||
return new FractionFormat(defaultFractionWholePartFormat, defaultFractionFractionPartFormat);
|
return new FractionFormat(defaultFractionWholePartFormat, defaultFractionFractionPartFormat);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
|
@ -16,24 +16,20 @@
|
||||||
==================================================================== */
|
==================================================================== */
|
||||||
package org.apache.poi.ooxml.extractor;
|
package org.apache.poi.ooxml.extractor;
|
||||||
|
|
||||||
import java.io.ByteArrayInputStream;
|
|
||||||
import java.io.File;
|
import java.io.File;
|
||||||
import java.io.FileNotFoundException;
|
|
||||||
import java.io.IOException;
|
import java.io.IOException;
|
||||||
import java.io.InputStream;
|
import java.io.InputStream;
|
||||||
|
import java.lang.reflect.Method;
|
||||||
import java.util.ArrayList;
|
import java.util.ArrayList;
|
||||||
import java.util.Iterator;
|
import java.util.Iterator;
|
||||||
|
import java.util.List;
|
||||||
|
|
||||||
import org.apache.poi.EncryptedDocumentException;
|
import org.apache.poi.EncryptedDocumentException;
|
||||||
|
import org.apache.poi.extractor.OLE2ExtractorFactory;
|
||||||
import org.apache.poi.extractor.POIOLE2TextExtractor;
|
import org.apache.poi.extractor.POIOLE2TextExtractor;
|
||||||
import org.apache.poi.extractor.POITextExtractor;
|
import org.apache.poi.extractor.POITextExtractor;
|
||||||
import org.apache.poi.extractor.OLE2ExtractorFactory;
|
|
||||||
import org.apache.poi.hsmf.MAPIMessage;
|
|
||||||
import org.apache.poi.hsmf.datatypes.AttachmentChunks;
|
|
||||||
import org.apache.poi.hsmf.extractor.OutlookTextExtactor;
|
|
||||||
import org.apache.poi.hssf.extractor.ExcelExtractor;
|
import org.apache.poi.hssf.extractor.ExcelExtractor;
|
||||||
import org.apache.poi.hssf.record.crypto.Biff8EncryptionKey;
|
import org.apache.poi.hssf.record.crypto.Biff8EncryptionKey;
|
||||||
import org.apache.poi.hwpf.extractor.WordExtractor;
|
|
||||||
import org.apache.poi.openxml4j.exceptions.OpenXML4JException;
|
import org.apache.poi.openxml4j.exceptions.OpenXML4JException;
|
||||||
import org.apache.poi.openxml4j.opc.OPCPackage;
|
import org.apache.poi.openxml4j.opc.OPCPackage;
|
||||||
import org.apache.poi.openxml4j.opc.PackageAccess;
|
import org.apache.poi.openxml4j.opc.PackageAccess;
|
||||||
|
@ -46,9 +42,9 @@ import org.apache.poi.poifs.filesystem.DirectoryEntry;
|
||||||
import org.apache.poi.poifs.filesystem.DirectoryNode;
|
import org.apache.poi.poifs.filesystem.DirectoryNode;
|
||||||
import org.apache.poi.poifs.filesystem.Entry;
|
import org.apache.poi.poifs.filesystem.Entry;
|
||||||
import org.apache.poi.poifs.filesystem.FileMagic;
|
import org.apache.poi.poifs.filesystem.FileMagic;
|
||||||
import org.apache.poi.poifs.filesystem.POIFSFileSystem;
|
|
||||||
import org.apache.poi.poifs.filesystem.NotOLE2FileException;
|
import org.apache.poi.poifs.filesystem.NotOLE2FileException;
|
||||||
import org.apache.poi.poifs.filesystem.OfficeXmlFileException;
|
import org.apache.poi.poifs.filesystem.OfficeXmlFileException;
|
||||||
|
import org.apache.poi.poifs.filesystem.POIFSFileSystem;
|
||||||
import org.apache.poi.sl.extractor.SlideShowExtractor;
|
import org.apache.poi.sl.extractor.SlideShowExtractor;
|
||||||
import org.apache.poi.util.IOUtils;
|
import org.apache.poi.util.IOUtils;
|
||||||
import org.apache.poi.util.NotImplemented;
|
import org.apache.poi.util.NotImplemented;
|
||||||
|
@ -311,6 +307,7 @@ public final class ExtractorFactory {
|
||||||
throw new IllegalStateException("The extractor didn't know which POIFS it came from!");
|
throw new IllegalStateException("The extractor didn't know which POIFS it came from!");
|
||||||
}
|
}
|
||||||
|
|
||||||
|
// provide ExcelExtractor also in OOXML module, because scratchpad is not necessary for it
|
||||||
if (ext instanceof ExcelExtractor) {
|
if (ext instanceof ExcelExtractor) {
|
||||||
// These are in MBD... under the root
|
// These are in MBD... under the root
|
||||||
Iterator<Entry> it = root.getEntries();
|
Iterator<Entry> it = root.getEntries();
|
||||||
|
@ -320,34 +317,14 @@ public final class ExtractorFactory {
|
||||||
dirs.add(entry);
|
dirs.add(entry);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
} else if (ext instanceof WordExtractor) {
|
} else {
|
||||||
// These are in ObjectPool -> _... under the root
|
|
||||||
try {
|
try {
|
||||||
DirectoryEntry op = (DirectoryEntry) root.getEntry("ObjectPool");
|
Class<?> clazz = Class.forName("org.apache.poi.extractor.ole2.OLE2ScratchpadExtractorFactory");
|
||||||
Iterator<Entry> it = op.getEntries();
|
Method m = clazz.getDeclaredMethod("identifyEmbeddedResources", POIOLE2TextExtractor.class, List.class, List.class);
|
||||||
while (it.hasNext()) {
|
m.invoke(null, ext, dirs, nonPOIFS);
|
||||||
Entry entry = it.next();
|
} catch (ReflectiveOperationException e) {
|
||||||
if (entry.getName().startsWith("_")) {
|
logger.log(POILogger.WARN, "POI Scratchpad jar not included ", e.getLocalizedMessage());
|
||||||
dirs.add(entry);
|
return new POITextExtractor[0];
|
||||||
}
|
|
||||||
}
|
|
||||||
} catch (FileNotFoundException e) {
|
|
||||||
logger.log(POILogger.INFO, "Ignoring FileNotFoundException while extracting Word document", e.getLocalizedMessage());
|
|
||||||
// ignored here
|
|
||||||
}
|
|
||||||
//} else if(ext instanceof PowerPointExtractor) {
|
|
||||||
// Tricky, not stored directly in poifs
|
|
||||||
// TODO
|
|
||||||
} else if (ext instanceof OutlookTextExtactor) {
|
|
||||||
// Stored in the Attachment blocks
|
|
||||||
MAPIMessage msg = ((OutlookTextExtactor)ext).getMAPIMessage();
|
|
||||||
for (AttachmentChunks attachment : msg.getAttachmentFiles()) {
|
|
||||||
if (attachment.getAttachData() != null) {
|
|
||||||
byte[] data = attachment.getAttachData().getValue();
|
|
||||||
nonPOIFS.add( new ByteArrayInputStream(data) );
|
|
||||||
} else if (attachment.getAttachmentDirectory() != null) {
|
|
||||||
dirs.add(attachment.getAttachmentDirectory().getDirectory());
|
|
||||||
}
|
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
|
@ -170,16 +170,24 @@ public class XSLFPictureShape extends XSLFSimpleShape
|
||||||
|
|
||||||
@SuppressWarnings("WeakerAccess")
|
@SuppressWarnings("WeakerAccess")
|
||||||
protected String getBlipLink(){
|
protected String getBlipLink(){
|
||||||
String link = getBlip().getLink();
|
CTBlip blip = getBlip();
|
||||||
if (link.isEmpty()) return null;
|
if (blip != null) {
|
||||||
return link;
|
String link = blip.getLink();
|
||||||
|
return (link.isEmpty()) ? null : link;
|
||||||
|
} else {
|
||||||
|
return null;
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
@SuppressWarnings("WeakerAccess")
|
@SuppressWarnings("WeakerAccess")
|
||||||
protected String getBlipId(){
|
protected String getBlipId(){
|
||||||
String id = getBlip().getEmbed();
|
CTBlip blip = getBlip();
|
||||||
if (id.isEmpty()) return null;
|
if (blip != null) {
|
||||||
return id;
|
String id = blip.getEmbed();
|
||||||
|
return (id.isEmpty()) ? null : id;
|
||||||
|
} else {
|
||||||
|
return null;
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
@Override
|
@Override
|
||||||
|
|
|
@ -381,7 +381,10 @@ public class SXSSFWorkbook implements Workbook {
|
||||||
Enumeration<? extends ZipArchiveEntry> en = zipEntrySource.getEntries();
|
Enumeration<? extends ZipArchiveEntry> en = zipEntrySource.getEntries();
|
||||||
while (en.hasMoreElements()) {
|
while (en.hasMoreElements()) {
|
||||||
ZipArchiveEntry ze = en.nextElement();
|
ZipArchiveEntry ze = en.nextElement();
|
||||||
zos.putArchiveEntry(new ZipArchiveEntry(ze.getName()));
|
ZipArchiveEntry zeOut = new ZipArchiveEntry(ze.getName());
|
||||||
|
zeOut.setSize(ze.getSize());
|
||||||
|
zeOut.setTime(ze.getTime());
|
||||||
|
zos.putArchiveEntry(zeOut);
|
||||||
try (final InputStream is = zipEntrySource.getInputStream(ze)) {
|
try (final InputStream is = zipEntrySource.getInputStream(ze)) {
|
||||||
if (is instanceof ZipArchiveThresholdInputStream) {
|
if (is instanceof ZipArchiveThresholdInputStream) {
|
||||||
// #59743 - disable Threshold handling for SXSSF copy
|
// #59743 - disable Threshold handling for SXSSF copy
|
||||||
|
|
|
@ -47,7 +47,7 @@ public class XSSFColor extends ExtendedColor {
|
||||||
* @deprecated 3.17 beta 1 - pass the workbook styles indexed color map, if any
|
* @deprecated 3.17 beta 1 - pass the workbook styles indexed color map, if any
|
||||||
*/
|
*/
|
||||||
@Deprecated
|
@Deprecated
|
||||||
@Removal(version="3.19")
|
@Removal(version="4.2")
|
||||||
public XSSFColor(CTColor color) {
|
public XSSFColor(CTColor color) {
|
||||||
this(color, new DefaultIndexedColorMap());
|
this(color, new DefaultIndexedColorMap());
|
||||||
}
|
}
|
||||||
|
@ -59,6 +59,7 @@ public class XSSFColor extends ExtendedColor {
|
||||||
* @deprecated 4.0.0 - use the factory {@link #from(CTColor, IndexedColorMap)} method instead to check for null CTColor instances. Make private eventually
|
* @deprecated 4.0.0 - use the factory {@link #from(CTColor, IndexedColorMap)} method instead to check for null CTColor instances. Make private eventually
|
||||||
*/
|
*/
|
||||||
@Deprecated
|
@Deprecated
|
||||||
|
@Removal(version = "4.2")
|
||||||
public XSSFColor(CTColor color, IndexedColorMap map) {
|
public XSSFColor(CTColor color, IndexedColorMap map) {
|
||||||
this.ctColor = color;
|
this.ctColor = color;
|
||||||
this.indexedColorMap = map;
|
this.indexedColorMap = map;
|
||||||
|
@ -72,7 +73,7 @@ public class XSSFColor extends ExtendedColor {
|
||||||
* @see #from(CTColor, IndexedColorMap)
|
* @see #from(CTColor, IndexedColorMap)
|
||||||
*/
|
*/
|
||||||
@Deprecated
|
@Deprecated
|
||||||
@Removal(version="4.1")
|
@Removal(version="4.2")
|
||||||
public XSSFColor() {
|
public XSSFColor() {
|
||||||
this(CTColor.Factory.newInstance(), new DefaultIndexedColorMap());
|
this(CTColor.Factory.newInstance(), new DefaultIndexedColorMap());
|
||||||
}
|
}
|
||||||
|
@ -85,6 +86,17 @@ public class XSSFColor extends ExtendedColor {
|
||||||
this(CTColor.Factory.newInstance(), colorMap);
|
this(CTColor.Factory.newInstance(), colorMap);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Create an instance of XSSFColor from the awt Color
|
||||||
|
* @param clr awt Color
|
||||||
|
* @deprecated 3.17 beta 1 - pass the workbook styles indexed color map, if any
|
||||||
|
*/
|
||||||
|
@Deprecated
|
||||||
|
@Removal(version="4.2")
|
||||||
|
public XSSFColor(java.awt.Color clr) {
|
||||||
|
this(clr, new DefaultIndexedColorMap());
|
||||||
|
}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* TEST ONLY
|
* TEST ONLY
|
||||||
* @param clr awt Color
|
* @param clr awt Color
|
||||||
|
|
|
@ -4109,18 +4109,17 @@ public class XSSFSheet extends POIXMLDocumentPart implements Sheet {
|
||||||
int tableNumber = getPackagePart().getPackage().getPartsByContentType(XSSFRelation.TABLE.getContentType()).size() + 1;
|
int tableNumber = getPackagePart().getPackage().getPartsByContentType(XSSFRelation.TABLE.getContentType()).size() + 1;
|
||||||
|
|
||||||
// the id could already be taken after insertion/deletion of different tables
|
// the id could already be taken after insertion/deletion of different tables
|
||||||
outerloop:
|
boolean loop = true;
|
||||||
while(true) {
|
while(loop) {
|
||||||
|
loop = false;
|
||||||
for (PackagePart packagePart : getPackagePart().getPackage().getPartsByContentType(XSSFRelation.TABLE.getContentType())) {
|
for (PackagePart packagePart : getPackagePart().getPackage().getPartsByContentType(XSSFRelation.TABLE.getContentType())) {
|
||||||
String fileName = XSSFRelation.TABLE.getFileName(tableNumber);
|
String fileName = XSSFRelation.TABLE.getFileName(tableNumber);
|
||||||
if(fileName.equals(packagePart.getPartName().getName())) {
|
if(fileName.equals(packagePart.getPartName().getName())) {
|
||||||
// duplicate found, increase the number and start iterating again
|
// duplicate found, increase the number and start iterating again
|
||||||
tableNumber++;
|
tableNumber++;
|
||||||
continue outerloop;
|
loop = true;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
break;
|
|
||||||
}
|
}
|
||||||
|
|
||||||
RelationPart rp = createRelationship(XSSFRelation.TABLE, XSSFFactory.getInstance(), tableNumber, false);
|
RelationPart rp = createRelationship(XSSFRelation.TABLE, XSSFFactory.getInstance(), tableNumber, false);
|
||||||
|
|
|
@ -33,27 +33,18 @@ import org.apache.poi.POIDataSamples;
|
||||||
import org.apache.poi.UnsupportedFileFormatException;
|
import org.apache.poi.UnsupportedFileFormatException;
|
||||||
import org.apache.poi.extractor.POIOLE2TextExtractor;
|
import org.apache.poi.extractor.POIOLE2TextExtractor;
|
||||||
import org.apache.poi.extractor.POITextExtractor;
|
import org.apache.poi.extractor.POITextExtractor;
|
||||||
import org.apache.poi.hdgf.extractor.VisioTextExtractor;
|
|
||||||
import org.apache.poi.hpbf.extractor.PublisherTextExtractor;
|
|
||||||
import org.apache.poi.hsmf.extractor.OutlookTextExtactor;
|
|
||||||
import org.apache.poi.hssf.HSSFTestDataSamples;
|
import org.apache.poi.hssf.HSSFTestDataSamples;
|
||||||
import org.apache.poi.hssf.OldExcelFormatException;
|
import org.apache.poi.hssf.OldExcelFormatException;
|
||||||
import org.apache.poi.hssf.extractor.EventBasedExcelExtractor;
|
import org.apache.poi.hssf.extractor.EventBasedExcelExtractor;
|
||||||
import org.apache.poi.hssf.extractor.ExcelExtractor;
|
import org.apache.poi.hssf.extractor.ExcelExtractor;
|
||||||
import org.apache.poi.hwpf.extractor.Word6Extractor;
|
|
||||||
import org.apache.poi.hwpf.extractor.WordExtractor;
|
|
||||||
import org.apache.poi.ooxml.extractor.ExtractorFactory;
|
import org.apache.poi.ooxml.extractor.ExtractorFactory;
|
||||||
import org.apache.poi.ooxml.extractor.POIXMLTextExtractor;
|
import org.apache.poi.ooxml.extractor.POIXMLTextExtractor;
|
||||||
import org.apache.poi.openxml4j.exceptions.OpenXML4JException;
|
import org.apache.poi.openxml4j.exceptions.OpenXML4JException;
|
||||||
import org.apache.poi.openxml4j.opc.OPCPackage;
|
import org.apache.poi.openxml4j.opc.OPCPackage;
|
||||||
import org.apache.poi.openxml4j.opc.PackageAccess;
|
import org.apache.poi.openxml4j.opc.PackageAccess;
|
||||||
import org.apache.poi.poifs.filesystem.POIFSFileSystem;
|
import org.apache.poi.poifs.filesystem.POIFSFileSystem;
|
||||||
import org.apache.poi.sl.extractor.SlideShowExtractor;
|
|
||||||
import org.apache.poi.xdgf.extractor.XDGFVisioExtractor;
|
|
||||||
import org.apache.poi.xssf.extractor.XSSFBEventBasedExcelExtractor;
|
|
||||||
import org.apache.poi.xssf.extractor.XSSFEventBasedExcelExtractor;
|
import org.apache.poi.xssf.extractor.XSSFEventBasedExcelExtractor;
|
||||||
import org.apache.poi.xssf.extractor.XSSFExcelExtractor;
|
import org.apache.poi.xssf.extractor.XSSFExcelExtractor;
|
||||||
import org.apache.poi.xwpf.extractor.XWPFWordExtractor;
|
|
||||||
import org.apache.xmlbeans.XmlException;
|
import org.apache.xmlbeans.XmlException;
|
||||||
import org.junit.Test;
|
import org.junit.Test;
|
||||||
|
|
||||||
|
@ -108,21 +99,21 @@ public class TestExtractorFactory {
|
||||||
}
|
}
|
||||||
|
|
||||||
private static final Object[] TEST_SET = {
|
private static final Object[] TEST_SET = {
|
||||||
"Excel", xls, ExcelExtractor.class, 200,
|
"Excel", xls, "ExcelExtractor", 200,
|
||||||
"Excel - xlsx", xlsx, XSSFExcelExtractor.class, 200,
|
"Excel - xlsx", xlsx, "XSSFExcelExtractor", 200,
|
||||||
"Excel - xltx", xltx, XSSFExcelExtractor.class, -1,
|
"Excel - xltx", xltx, "XSSFExcelExtractor", -1,
|
||||||
"Excel - xlsb", xlsb, XSSFBEventBasedExcelExtractor.class, -1,
|
"Excel - xlsb", xlsb, "XSSFBEventBasedExcelExtractor", -1,
|
||||||
"Word", doc, WordExtractor.class, 120,
|
"Word", doc, "WordExtractor", 120,
|
||||||
"Word - docx", docx, XWPFWordExtractor.class, 120,
|
"Word - docx", docx, "XWPFWordExtractor", 120,
|
||||||
"Word - dotx", dotx, XWPFWordExtractor.class, -1,
|
"Word - dotx", dotx, "XWPFWordExtractor", -1,
|
||||||
"Word 6", doc6, Word6Extractor.class, 20,
|
"Word 6", doc6, "Word6Extractor", 20,
|
||||||
"Word 95", doc95, Word6Extractor.class, 120,
|
"Word 95", doc95, "Word6Extractor", 120,
|
||||||
"PowerPoint", ppt, SlideShowExtractor.class, 120,
|
"PowerPoint", ppt, "SlideShowExtractor", 120,
|
||||||
"PowerPoint - pptx", pptx, SlideShowExtractor.class, 120,
|
"PowerPoint - pptx", pptx, "SlideShowExtractor", 120,
|
||||||
"Visio", vsd, VisioTextExtractor.class, 50,
|
"Visio", vsd, "VisioTextExtractor", 50,
|
||||||
"Visio - vsdx", vsdx, XDGFVisioExtractor.class, 20,
|
"Visio - vsdx", vsdx, "XDGFVisioExtractor", 20,
|
||||||
"Publisher", pub, PublisherTextExtractor.class, 50,
|
"Publisher", pub, "PublisherTextExtractor", 50,
|
||||||
"Outlook msg", msg, OutlookTextExtactor.class, 50,
|
"Outlook msg", msg, "OutlookTextExtactor", 50,
|
||||||
|
|
||||||
// TODO Support OOXML-Strict, see bug #57699
|
// TODO Support OOXML-Strict, see bug #57699
|
||||||
// xlsxStrict
|
// xlsxStrict
|
||||||
|
@ -138,7 +129,7 @@ public class TestExtractorFactory {
|
||||||
public void testFile() throws Exception {
|
public void testFile() throws Exception {
|
||||||
for (int i = 0; i < TEST_SET.length; i += 4) {
|
for (int i = 0; i < TEST_SET.length; i += 4) {
|
||||||
try (POITextExtractor ext = ExtractorFactory.createExtractor((File) TEST_SET[i + 1])) {
|
try (POITextExtractor ext = ExtractorFactory.createExtractor((File) TEST_SET[i + 1])) {
|
||||||
testExtractor(ext, (String) TEST_SET[i], (Class) TEST_SET[i + 2], (Integer) TEST_SET[i + 3]);
|
testExtractor(ext, (String) TEST_SET[i], (String) TEST_SET[i + 2], (Integer) TEST_SET[i + 3]);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
@ -180,15 +171,15 @@ public class TestExtractorFactory {
|
||||||
}
|
}
|
||||||
try (FileInputStream fis = new FileInputStream(testFile);
|
try (FileInputStream fis = new FileInputStream(testFile);
|
||||||
POITextExtractor ext = poifsIS.apply(fis)) {
|
POITextExtractor ext = poifsIS.apply(fis)) {
|
||||||
testExtractor(ext, (String) TEST_SET[i], (Class) TEST_SET[i + 2], (Integer) TEST_SET[i + 3]);
|
testExtractor(ext, (String) TEST_SET[i], (String) TEST_SET[i + 2], (Integer) TEST_SET[i + 3]);
|
||||||
} catch (IllegalArgumentException e) {
|
} catch (IllegalArgumentException e) {
|
||||||
fail("failed to process "+testFile);
|
fail("failed to process "+testFile);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
private void testExtractor(final POITextExtractor ext, final String testcase, final Class extrClass, final Integer minLength) {
|
private void testExtractor(final POITextExtractor ext, final String testcase, final String extrClass, final Integer minLength) {
|
||||||
assertTrue("invalid extractor for " + testcase, extrClass.isInstance(ext));
|
assertEquals("invalid extractor for " + testcase, extrClass, ext.getClass().getSimpleName());
|
||||||
final String actual = ext.getText();
|
final String actual = ext.getText();
|
||||||
if (minLength == -1) {
|
if (minLength == -1) {
|
||||||
assertContains(actual.toLowerCase(Locale.ROOT), "test");
|
assertContains(actual.toLowerCase(Locale.ROOT), "test");
|
||||||
|
@ -215,7 +206,7 @@ public class TestExtractorFactory {
|
||||||
|
|
||||||
try (final OPCPackage pkg = OPCPackage.open(testFile, PackageAccess.READ);
|
try (final OPCPackage pkg = OPCPackage.open(testFile, PackageAccess.READ);
|
||||||
final POITextExtractor ext = ExtractorFactory.createExtractor(pkg)) {
|
final POITextExtractor ext = ExtractorFactory.createExtractor(pkg)) {
|
||||||
testExtractor(ext, (String) TEST_SET[i], (Class) TEST_SET[i + 2], (Integer) TEST_SET[i + 3]);
|
testExtractor(ext, (String) TEST_SET[i], (String) TEST_SET[i + 2], (Integer) TEST_SET[i + 3]);
|
||||||
pkg.revert();
|
pkg.revert();
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
@ -334,16 +325,22 @@ public class TestExtractorFactory {
|
||||||
int numWord = 0, numXls = 0, numPpt = 0, numMsg = 0, numWordX = 0;
|
int numWord = 0, numXls = 0, numPpt = 0, numMsg = 0, numWordX = 0;
|
||||||
for (POITextExtractor embed : embeds) {
|
for (POITextExtractor embed : embeds) {
|
||||||
assertTrue(embed.getText().length() > 20);
|
assertTrue(embed.getText().length() > 20);
|
||||||
if (embed instanceof SlideShowExtractor) {
|
switch (embed.getClass().getSimpleName()) {
|
||||||
numPpt++;
|
case "SlideShowExtractor":
|
||||||
} else if (embed instanceof ExcelExtractor) {
|
numPpt++;
|
||||||
numXls++;
|
break;
|
||||||
} else if (embed instanceof WordExtractor) {
|
case "ExcelExtractor":
|
||||||
numWord++;
|
numXls++;
|
||||||
} else if (embed instanceof OutlookTextExtactor) {
|
break;
|
||||||
numMsg++;
|
case "WordExtractor":
|
||||||
} else if (embed instanceof XWPFWordExtractor) {
|
numWord++;
|
||||||
numWordX++;
|
break;
|
||||||
|
case "OutlookTextExtactor":
|
||||||
|
numMsg++;
|
||||||
|
break;
|
||||||
|
case "XWPFWordExtractor":
|
||||||
|
numWordX++;
|
||||||
|
break;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
|
@ -1,375 +0,0 @@
|
||||||
/* ====================================================================
|
|
||||||
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.poi.ooxml.util;
|
|
||||||
|
|
||||||
import java.io.File;
|
|
||||||
import java.io.IOException;
|
|
||||||
import java.lang.reflect.Field;
|
|
||||||
import java.lang.reflect.Method;
|
|
||||||
import java.net.URL;
|
|
||||||
import java.security.AccessController;
|
|
||||||
import java.security.CodeSource;
|
|
||||||
import java.security.PrivilegedAction;
|
|
||||||
import java.security.ProtectionDomain;
|
|
||||||
import java.util.ArrayList;
|
|
||||||
import java.util.Enumeration;
|
|
||||||
import java.util.HashSet;
|
|
||||||
import java.util.List;
|
|
||||||
import java.util.Set;
|
|
||||||
import java.util.Vector;
|
|
||||||
import java.util.jar.JarEntry;
|
|
||||||
import java.util.jar.JarFile;
|
|
||||||
import java.util.regex.Pattern;
|
|
||||||
|
|
||||||
import org.apache.poi.util.IOUtils;
|
|
||||||
import org.apache.poi.util.StringUtil;
|
|
||||||
import org.apache.poi.util.SuppressForbidden;
|
|
||||||
import org.apache.xmlbeans.StringEnumAbstractBase;
|
|
||||||
import org.junit.Test;
|
|
||||||
import org.junit.internal.TextListener;
|
|
||||||
import org.junit.runner.Description;
|
|
||||||
import org.junit.runner.JUnitCore;
|
|
||||||
import org.junit.runner.Result;
|
|
||||||
import org.reflections.Reflections;
|
|
||||||
|
|
||||||
import junit.framework.TestCase;
|
|
||||||
|
|
||||||
/**
|
|
||||||
* Build a 'lite' version of the ooxml-schemas.jar
|
|
||||||
*
|
|
||||||
* @author Yegor Kozlov
|
|
||||||
*/
|
|
||||||
public final class OOXMLLite {
|
|
||||||
private static final Pattern SCHEMA_PATTERN = Pattern.compile("schemaorg_apache_xmlbeans/(system|element)/.*\\.xsb");
|
|
||||||
|
|
||||||
/**
|
|
||||||
* Destination directory to copy filtered classes
|
|
||||||
*/
|
|
||||||
private File _destDest;
|
|
||||||
|
|
||||||
/**
|
|
||||||
* Directory with the compiled ooxml tests
|
|
||||||
*/
|
|
||||||
private File _testDir;
|
|
||||||
|
|
||||||
/**
|
|
||||||
* Reference to the ooxml-schemas.jar
|
|
||||||
*/
|
|
||||||
private File _ooxmlJar;
|
|
||||||
|
|
||||||
|
|
||||||
OOXMLLite(String dest, String test, String ooxmlJar) {
|
|
||||||
_destDest = new File(dest);
|
|
||||||
_testDir = new File(test);
|
|
||||||
_ooxmlJar = new File(ooxmlJar);
|
|
||||||
}
|
|
||||||
|
|
||||||
public static void main(String[] args) throws IOException {
|
|
||||||
System.out.println("Free memory (bytes): " +
|
|
||||||
Runtime.getRuntime().freeMemory());
|
|
||||||
long maxMemory = Runtime.getRuntime().maxMemory();
|
|
||||||
System.out.println("Maximum memory (bytes): " +
|
|
||||||
(maxMemory == Long.MAX_VALUE ? "no limit" : maxMemory));
|
|
||||||
System.out.println("Total memory (bytes): " +
|
|
||||||
Runtime.getRuntime().totalMemory());
|
|
||||||
|
|
||||||
String dest = null, test = null, ooxml = null;
|
|
||||||
|
|
||||||
for (int i = 0; i < args.length; i++) {
|
|
||||||
switch (args[i]) {
|
|
||||||
case "-dest":
|
|
||||||
dest = args[++i]; // lgtm[java/index-out-of-bounds]
|
|
||||||
break;
|
|
||||||
case "-test":
|
|
||||||
test = args[++i]; // lgtm[java/index-out-of-bounds]
|
|
||||||
break;
|
|
||||||
case "-ooxml":
|
|
||||||
ooxml = args[++i]; // lgtm[java/index-out-of-bounds]
|
|
||||||
break;
|
|
||||||
}
|
|
||||||
}
|
|
||||||
OOXMLLite builder = new OOXMLLite(dest, test, ooxml);
|
|
||||||
builder.build();
|
|
||||||
}
|
|
||||||
|
|
||||||
void build() throws IOException {
|
|
||||||
List<Class<?>> lst = new ArrayList<>();
|
|
||||||
//collect unit tests
|
|
||||||
String exclude = StringUtil.join("|",
|
|
||||||
"BaseTestXWorkbook",
|
|
||||||
"BaseTestXSheet",
|
|
||||||
"BaseTestXRow",
|
|
||||||
"BaseTestXCell",
|
|
||||||
"BaseTestXSSFPivotTable",
|
|
||||||
"TestSXSSFWorkbook\\$\\d",
|
|
||||||
"TestUnfixedBugs",
|
|
||||||
"MemoryUsage",
|
|
||||||
"TestDataProvider",
|
|
||||||
"TestDataSamples",
|
|
||||||
"All.+Tests",
|
|
||||||
"ZipFileAssert",
|
|
||||||
"AesZipFileZipEntrySource",
|
|
||||||
"TempFileRecordingSXSSFWorkbookWithCustomZipEntrySource",
|
|
||||||
"PkiTestUtils",
|
|
||||||
"TestCellFormatPart\\$\\d",
|
|
||||||
"TestSignatureInfo\\$\\d",
|
|
||||||
"TestCertificateEncryption\\$CertData",
|
|
||||||
"TestPOIXMLDocument\\$OPCParser",
|
|
||||||
"TestPOIXMLDocument\\$TestFactory",
|
|
||||||
"TestXSLFTextParagraph\\$DrawTextParagraphProxy",
|
|
||||||
"TestXSSFExportToXML\\$\\d",
|
|
||||||
"TestXSSFExportToXML\\$DummyEntityResolver",
|
|
||||||
"TestFormulaEvaluatorOnXSSF\\$Result",
|
|
||||||
"TestFormulaEvaluatorOnXSSF\\$SS",
|
|
||||||
"TestMultiSheetFormulaEvaluatorOnXSSF\\$Result",
|
|
||||||
"TestMultiSheetFormulaEvaluatorOnXSSF\\$SS",
|
|
||||||
"TestXSSFBugs\\$\\d",
|
|
||||||
"AddImageBench",
|
|
||||||
"AddImageBench_jmhType_B\\d",
|
|
||||||
"AddImageBench_benchCreatePicture_jmhTest",
|
|
||||||
"TestEvilUnclosedBRFixingInputStream\\$EvilUnclosedBRFixingInputStream",
|
|
||||||
"TempFileRecordingSXSSFWorkbookWithCustomZipEntrySource\\$TempFileRecordingSheetDataWriterWithDecorator",
|
|
||||||
"TestXSSFBReader\\$1",
|
|
||||||
"TestXSSFBReader\\$TestSheetHandler",
|
|
||||||
"TestFormulaEvaluatorOnXSSF\\$1",
|
|
||||||
"TestMultiSheetFormulaEvaluatorOnXSSF\\$1",
|
|
||||||
"TestZipPackagePropertiesMarshaller\\$1",
|
|
||||||
"SLCommonUtils",
|
|
||||||
"TestPPTX2PNG\\$1",
|
|
||||||
"TestMatrixFormulasFromXMLSpreadsheet\\$1",
|
|
||||||
"TestMatrixFormulasFromXMLSpreadsheet\\$Navigator",
|
|
||||||
"TestPOIXMLDocument\\$UncaughtHandler",
|
|
||||||
"TestOleShape\\$Api",
|
|
||||||
"TestOleShape\\$1",
|
|
||||||
"TestPOIXMLDocument\\$1",
|
|
||||||
"TestXMLSlideShow\\$1",
|
|
||||||
"TestXMLSlideShow\\$BufAccessBAOS",
|
|
||||||
"TestXDDFChart\\$1",
|
|
||||||
"TestOOXMLLister\\$1",
|
|
||||||
"TestOOXMLPrettyPrint\\$1"
|
|
||||||
);
|
|
||||||
System.out.println("Collecting unit tests from " + _testDir);
|
|
||||||
collectTests(_testDir, _testDir, lst, ".+.class$", ".+(" + exclude + ").class");
|
|
||||||
System.out.println("Found " + lst.size() + " classes");
|
|
||||||
|
|
||||||
//run tests
|
|
||||||
JUnitCore jUnitCore = new JUnitCore();
|
|
||||||
jUnitCore.addListener(new TextListener(System.out) {
|
|
||||||
private final Set<String> classes = new HashSet<>();
|
|
||||||
private int count;
|
|
||||||
|
|
||||||
@Override
|
|
||||||
public void testStarted(Description description) {
|
|
||||||
// count how many test-classes we already saw
|
|
||||||
classes.add(description.getClassName());
|
|
||||||
count++;
|
|
||||||
if(count % 100 == 0) {
|
|
||||||
System.out.println();
|
|
||||||
System.out.println(classes.size() + "/" + lst.size() + ": " + description.getDisplayName());
|
|
||||||
}
|
|
||||||
|
|
||||||
super.testStarted(description);
|
|
||||||
}
|
|
||||||
});
|
|
||||||
Result result = jUnitCore.run(lst.toArray(new Class<?>[0]));
|
|
||||||
if (!result.wasSuccessful()) {
|
|
||||||
throw new RuntimeException("Tests did not succeed, cannot build ooxml-lite jar");
|
|
||||||
}
|
|
||||||
|
|
||||||
//see what classes from the ooxml-schemas.jar are loaded
|
|
||||||
System.out.println("Copying classes to " + _destDest);
|
|
||||||
Set<Class<?>> classes = getLoadedClasses(_ooxmlJar.getName());
|
|
||||||
Set<String> packages = new HashSet<>();
|
|
||||||
for (Class<?> cls : classes) {
|
|
||||||
copyFile(cls);
|
|
||||||
packages.add(cls.getPackage().getName());
|
|
||||||
|
|
||||||
if (cls.isInterface()) {
|
|
||||||
/// Copy classes and interfaces declared as members of this class
|
|
||||||
for (Class<?> fc : cls.getDeclaredClasses()) {
|
|
||||||
copyFile(fc);
|
|
||||||
}
|
|
||||||
}
|
|
||||||
}
|
|
||||||
for (String pkg : packages) {
|
|
||||||
Reflections reflections = new Reflections(pkg);
|
|
||||||
Set<Class<? extends List>> listClasses = reflections.getSubTypesOf(List.class);
|
|
||||||
listClasses.removeAll(classes);
|
|
||||||
for (Class listClass : listClasses) {
|
|
||||||
for (Class<?> compare : classes) {
|
|
||||||
if (listClass.getName().startsWith(compare.getName())) {
|
|
||||||
copyFile(listClass);
|
|
||||||
}
|
|
||||||
}
|
|
||||||
}
|
|
||||||
Set<Class<? extends StringEnumAbstractBase>> enumClasses = reflections.getSubTypesOf(StringEnumAbstractBase.class);
|
|
||||||
listClasses.removeAll(classes);
|
|
||||||
for (Class enumClass : enumClasses) {
|
|
||||||
for (Class<?> compare : classes) {
|
|
||||||
if (enumClass.getName().startsWith(compare.getName())) {
|
|
||||||
copyFile(enumClass);
|
|
||||||
}
|
|
||||||
}
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
//finally copy the compiled .xsb files
|
|
||||||
System.out.println("Copying .xsb resources");
|
|
||||||
try (JarFile jar = new JarFile(_ooxmlJar)) {
|
|
||||||
for (Enumeration<JarEntry> e = jar.entries(); e.hasMoreElements(); ) {
|
|
||||||
JarEntry je = e.nextElement();
|
|
||||||
if (SCHEMA_PATTERN.matcher(je.getName()).matches()) {
|
|
||||||
File destFile = new File(_destDest, je.getName());
|
|
||||||
IOUtils.copy(jar.getInputStream(je), destFile);
|
|
||||||
}
|
|
||||||
}
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
private void copyFile(Class<?> cls) throws IOException {
|
|
||||||
String className = cls.getName();
|
|
||||||
String classRef = className.replace('.', '/') + ".class";
|
|
||||||
File destFile = new File(_destDest, classRef);
|
|
||||||
IOUtils.copy(cls.getResourceAsStream('/' + classRef), destFile);
|
|
||||||
}
|
|
||||||
|
|
||||||
private static boolean checkForTestAnnotation(Class<?> testclass) {
|
|
||||||
for (Method m : testclass.getDeclaredMethods()) {
|
|
||||||
if(m.isAnnotationPresent(Test.class)) {
|
|
||||||
return true;
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
// also check super classes
|
|
||||||
if(testclass.getSuperclass() != null) {
|
|
||||||
for (Method m : testclass.getSuperclass().getDeclaredMethods()) {
|
|
||||||
if(m.isAnnotationPresent(Test.class)) {
|
|
||||||
return true;
|
|
||||||
}
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
System.out.println("Class " + testclass.getName() + " does not derive from TestCase and does not have a @Test annotation");
|
|
||||||
|
|
||||||
// Should we also look at superclasses to find cases
|
|
||||||
// where we have abstract base classes with derived tests?
|
|
||||||
// if(checkForTestAnnotation(testclass.getSuperclass())) return true;
|
|
||||||
|
|
||||||
return false;
|
|
||||||
}
|
|
||||||
|
|
||||||
/**
|
|
||||||
* Recursively collect classes from the supplied directory
|
|
||||||
*
|
|
||||||
* @param arg the directory to search in
|
|
||||||
* @param out output
|
|
||||||
* @param ptrn the pattern (regexp) to filter found files
|
|
||||||
*/
|
|
||||||
private static void collectTests(File root, File arg, List<Class<?>> out, String ptrn, String exclude) {
|
|
||||||
if (arg.isDirectory()) {
|
|
||||||
File files[] = arg.listFiles();
|
|
||||||
if (files != null) {
|
|
||||||
for (File f : files) {
|
|
||||||
collectTests(root, f, out, ptrn, exclude);
|
|
||||||
}
|
|
||||||
}
|
|
||||||
} else {
|
|
||||||
String path = arg.getAbsolutePath();
|
|
||||||
String prefix = root.getAbsolutePath();
|
|
||||||
String cls = path.substring(prefix.length() + 1).replace(File.separator, ".");
|
|
||||||
if(!cls.matches(ptrn)) {
|
|
||||||
return;
|
|
||||||
}
|
|
||||||
if (cls.matches(exclude)) {
|
|
||||||
return;
|
|
||||||
}
|
|
||||||
//ignore inner classes defined in tests
|
|
||||||
if (cls.indexOf('$') != -1) {
|
|
||||||
System.out.println("Inner class " + cls + " not included");
|
|
||||||
return;
|
|
||||||
}
|
|
||||||
|
|
||||||
cls = cls.replace(".class", "");
|
|
||||||
|
|
||||||
try {
|
|
||||||
Class<?> testclass = Class.forName(cls);
|
|
||||||
if (TestCase.class.isAssignableFrom(testclass)
|
|
||||||
|| checkForTestAnnotation(testclass)) {
|
|
||||||
out.add(testclass);
|
|
||||||
}
|
|
||||||
} catch (Throwable e) { // NOSONAR
|
|
||||||
System.out.println("Class " + cls + " is not in classpath");
|
|
||||||
}
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
/**
|
|
||||||
*
|
|
||||||
* @param ptrn the pattern to filter output
|
|
||||||
* @return the classes loaded by the system class loader
|
|
||||||
*/
|
|
||||||
@SuppressWarnings("unchecked")
|
|
||||||
private static Set<Class<?>> getLoadedClasses(String ptrn) {
|
|
||||||
// make the field accessible, we defer this from static initialization to here to
|
|
||||||
// allow JDKs which do not have this field (e.g. IBM JDK) to at least load the class
|
|
||||||
// without failing, see https://issues.apache.org/bugzilla/show_bug.cgi?id=56550
|
|
||||||
final Field _classes = AccessController.doPrivileged(new PrivilegedAction<Field>() {
|
|
||||||
@Override
|
|
||||||
@SuppressForbidden("TODO: Reflection works until Java 8 on Oracle/Sun JDKs, but breaks afterwards (different classloader types, access checks)")
|
|
||||||
public Field run() {
|
|
||||||
try {
|
|
||||||
Field fld = ClassLoader.class.getDeclaredField("classes");
|
|
||||||
fld.setAccessible(true);
|
|
||||||
return fld;
|
|
||||||
} catch (Exception e) {
|
|
||||||
throw new RuntimeException(e);
|
|
||||||
}
|
|
||||||
|
|
||||||
}
|
|
||||||
});
|
|
||||||
|
|
||||||
ClassLoader appLoader = ClassLoader.getSystemClassLoader();
|
|
||||||
try {
|
|
||||||
Vector<Class<?>> classes = (Vector<Class<?>>) _classes.get(appLoader);
|
|
||||||
Set<Class<?>> set = new HashSet<>();
|
|
||||||
for (Class<?> cls : classes) {
|
|
||||||
// e.g. proxy-classes, ...
|
|
||||||
ProtectionDomain pd = cls.getProtectionDomain();
|
|
||||||
if (pd == null) {
|
|
||||||
continue;
|
|
||||||
}
|
|
||||||
CodeSource cs = pd.getCodeSource();
|
|
||||||
if (cs == null) {
|
|
||||||
continue;
|
|
||||||
}
|
|
||||||
URL loc = cs.getLocation();
|
|
||||||
if (loc == null) {
|
|
||||||
continue;
|
|
||||||
}
|
|
||||||
|
|
||||||
String jar = loc.toString();
|
|
||||||
if (jar.contains(ptrn)) {
|
|
||||||
set.add(cls);
|
|
||||||
}
|
|
||||||
}
|
|
||||||
return set;
|
|
||||||
} catch (IllegalAccessException e) {
|
|
||||||
throw new RuntimeException(e);
|
|
||||||
}
|
|
||||||
}
|
|
||||||
}
|
|
|
@ -0,0 +1,78 @@
|
||||||
|
/* ====================================================================
|
||||||
|
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.poi.ooxml.util;
|
||||||
|
|
||||||
|
import java.io.IOException;
|
||||||
|
import java.lang.instrument.ClassFileTransformer;
|
||||||
|
import java.lang.instrument.Instrumentation;
|
||||||
|
import java.nio.charset.StandardCharsets;
|
||||||
|
import java.nio.file.Files;
|
||||||
|
import java.nio.file.Path;
|
||||||
|
import java.nio.file.Paths;
|
||||||
|
import java.nio.file.StandardOpenOption;
|
||||||
|
import java.security.ProtectionDomain;
|
||||||
|
import java.util.HashSet;
|
||||||
|
import java.util.Set;
|
||||||
|
import java.util.regex.Pattern;
|
||||||
|
import java.util.stream.Stream;
|
||||||
|
|
||||||
|
/**
|
||||||
|
* OOXMLLiteAgent is the replacement for the former OOXMLLite, because in Java 12
|
||||||
|
* it isn't possible to access the privates :) of the ClassLoader
|
||||||
|
*/
|
||||||
|
public class OOXMLLiteAgent {
|
||||||
|
|
||||||
|
static class LoggingTransformer implements ClassFileTransformer {
|
||||||
|
final Path path;
|
||||||
|
final Pattern includes;
|
||||||
|
final Set<Integer> fileHashes = new HashSet<>();
|
||||||
|
|
||||||
|
public LoggingTransformer(String agentArgs) {
|
||||||
|
String args[] = (agentArgs == null ? "" : agentArgs).split("\\|",2);
|
||||||
|
path = Paths.get(args.length >= 1 ? args[0] : "ooxml-lite.out");
|
||||||
|
includes = Pattern.compile(args.length >= 2 ? args[1] : ".*/schemas/.*");
|
||||||
|
|
||||||
|
try {
|
||||||
|
if (Files.exists(path)) {
|
||||||
|
try (Stream<String> stream = Files.lines(path)) {
|
||||||
|
stream.forEach((s) -> fileHashes.add(s.hashCode()));
|
||||||
|
}
|
||||||
|
} else {
|
||||||
|
Files.createFile(path);
|
||||||
|
}
|
||||||
|
} catch (IOException ignored) {
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
public byte[] transform(ClassLoader loader, String className, Class redefiningClass, ProtectionDomain domain, byte[] bytes) {
|
||||||
|
if (path != null && className != null && !fileHashes.contains(className.hashCode()) && includes.matcher(className).find()) {
|
||||||
|
try {
|
||||||
|
// TODO: check if this is atomic ... as transform() is probably called synchronized, it doesn't matter anyway
|
||||||
|
Files.write(path, (className+"\n").getBytes(StandardCharsets.ISO_8859_1), StandardOpenOption.APPEND);
|
||||||
|
fileHashes.add(className.hashCode());
|
||||||
|
} catch (IOException ignroed) {
|
||||||
|
}
|
||||||
|
}
|
||||||
|
return bytes;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
public static void premain(String agentArgs, Instrumentation inst) {
|
||||||
|
inst.addTransformer(new LoggingTransformer(agentArgs));
|
||||||
|
}
|
||||||
|
}
|
|
@ -23,6 +23,7 @@ import static org.apache.poi.POIDataSamples.getSpreadSheetInstance;
|
||||||
import static org.junit.Assert.assertEquals;
|
import static org.junit.Assert.assertEquals;
|
||||||
import static org.junit.Assert.assertNotNull;
|
import static org.junit.Assert.assertNotNull;
|
||||||
import static org.junit.Assert.assertTrue;
|
import static org.junit.Assert.assertTrue;
|
||||||
|
import static org.junit.Assert.fail;
|
||||||
|
|
||||||
import java.io.ByteArrayInputStream;
|
import java.io.ByteArrayInputStream;
|
||||||
import java.io.ByteArrayOutputStream;
|
import java.io.ByteArrayOutputStream;
|
||||||
|
@ -35,9 +36,8 @@ import java.util.Collection;
|
||||||
import org.apache.poi.POIDataSamples;
|
import org.apache.poi.POIDataSamples;
|
||||||
import org.apache.poi.POIDocument;
|
import org.apache.poi.POIDocument;
|
||||||
import org.apache.poi.extractor.POITextExtractor;
|
import org.apache.poi.extractor.POITextExtractor;
|
||||||
import org.apache.poi.ooxml.extractor.ExtractorFactory;
|
|
||||||
import org.apache.poi.hslf.usermodel.HSLFSlideShowImpl;
|
|
||||||
import org.apache.poi.hssf.record.crypto.Biff8EncryptionKey;
|
import org.apache.poi.hssf.record.crypto.Biff8EncryptionKey;
|
||||||
|
import org.apache.poi.ooxml.extractor.ExtractorFactory;
|
||||||
import org.apache.poi.openxml4j.exceptions.OpenXML4JException;
|
import org.apache.poi.openxml4j.exceptions.OpenXML4JException;
|
||||||
import org.apache.poi.poifs.crypt.cryptoapi.CryptoAPIEncryptionHeader;
|
import org.apache.poi.poifs.crypt.cryptoapi.CryptoAPIEncryptionHeader;
|
||||||
import org.apache.poi.poifs.storage.RawDataUtil;
|
import org.apache.poi.poifs.storage.RawDataUtil;
|
||||||
|
@ -64,21 +64,24 @@ public class TestHxxFEncryption {
|
||||||
|
|
||||||
@Parameters(name="{1}")
|
@Parameters(name="{1}")
|
||||||
public static Collection<Object[]> data() throws IOException {
|
public static Collection<Object[]> data() throws IOException {
|
||||||
|
final String base64 =
|
||||||
|
"H4sIAAAAAAAAAF1Uu24bMRDs/RULVwkgCUhSpHaZwkDgpHJH8fZ0G/Nx4ZI6y13yG/mRfIb9R5mlZFlIpdPtcnZmdnjPf57/vvx6+f3h6obuv3"+
|
||||||
|
"ylbY5bEiVHe1fEpUp5pOgkrK0iabehm7FyoZi1ks8xcvHiQu8h5bLnorTlnUvkJ/YPOHKsLVInAqCs91KakuaxLq4w3g00SgCo9Xou1UnCmSBe"+
|
||||||
|
"MhpRY6qHmXVFteQfQJ5yUaaOw4qXwgPVjPGAqhNH5bBHAfTmwqqoSkLdFT/J3nC0eZBRk7yiu5s7yoU+r+9l3tDtm5A3jgt6AQxNOY2ya+U4sK"+
|
||||||
|
"XZ+YczbpfSVVuzFOuunKraqIVD2ND3yVXauT3TNthR/O3IJAM7gzTOGeIcXZvj14ahotW8wSognlMu0Yyp/Fi7O6s+CK6haUUjtPCji7MVcgqH"+
|
||||||
|
"jh+42tqeqPDMroJ/lBAE4AZbJbJu6Fu35ej42Tw9mYeTwVXoBKJiPeFV94q2rZJAyNEPo/qOdWYLBpq3B2JX8GDZeJ14mZf3tOQWBmpd9yQ7kI"+
|
||||||
|
"DCY/jmkj1oGOicFy62r9vutC5uJsVEMFgmAXXfYcC6BRBKNHCybALFJolnrDcPXNLl+K60Vctt09YZT7YgbeOICGJ/ZgC2JztOnm1JhX3eJXni"+
|
||||||
|
"U5Bqhezzlu334vD/Ajr3yDGXw5G9IZ6aLmLfQafY42N3J7cjj1LaXOHihSrcC5ThmuYIB5FX5AU8tKlnNG9Dn1EnsdD4KcnPhsSNPRiXtz461b"+
|
||||||
|
"VZw8Pm6vn0afh4fvr0D5P/+cMuBAAA";
|
||||||
|
final String x = new String(RawDataUtil.decompress(base64), StandardCharsets.UTF_8);
|
||||||
|
|
||||||
return Arrays.asList(
|
return Arrays.asList(
|
||||||
// binary rc4
|
// binary rc4
|
||||||
new Object[]{ getDocumentInstance(), "password_tika_binaryrc4.doc", "tika", "This is an encrypted Word 2007 File." },
|
new Object[]{ getDocumentInstance(), "password_tika_binaryrc4.doc", "tika", "This is an encrypted Word 2007 File." },
|
||||||
// cryptoapi
|
// cryptoapi
|
||||||
new Object[]{ getDocumentInstance(), "password_password_cryptoapi.doc", "password", "This is a test" },
|
new Object[]{ getDocumentInstance(), "password_password_cryptoapi.doc", "password", "This is a test" },
|
||||||
// binary rc4
|
// binary rc4
|
||||||
new Object[]{ getSpreadSheetInstance(), "password.xls", "password",
|
new Object[]{ getSpreadSheetInstance(), "password.xls", "password", x },
|
||||||
x("H4sIAAAAAAAAAF1Uu24bMRDs/RULVwkgCUhSpHaZwkDgpHJH8fZ0G/Nx4ZI6y13yG/mRfIb9R5mlZFlIpdPtcnZmdnjPf57/vvx6+f3h6obuv3"+
|
|
||||||
"ylbY5bEiVHe1fEpUp5pOgkrK0iabehm7FyoZi1ks8xcvHiQu8h5bLnorTlnUvkJ/YPOHKsLVInAqCs91KakuaxLq4w3g00SgCo9Xou1UnCmSBe"+
|
|
||||||
"MhpRY6qHmXVFteQfQJ5yUaaOw4qXwgPVjPGAqhNH5bBHAfTmwqqoSkLdFT/J3nC0eZBRk7yiu5s7yoU+r+9l3tDtm5A3jgt6AQxNOY2ya+U4sK"+
|
|
||||||
"XZ+YczbpfSVVuzFOuunKraqIVD2ND3yVXauT3TNthR/O3IJAM7gzTOGeIcXZvj14ahotW8wSognlMu0Yyp/Fi7O6s+CK6haUUjtPCji7MVcgqH"+
|
|
||||||
"jh+42tqeqPDMroJ/lBAE4AZbJbJu6Fu35ej42Tw9mYeTwVXoBKJiPeFV94q2rZJAyNEPo/qOdWYLBpq3B2JX8GDZeJ14mZf3tOQWBmpd9yQ7kI"+
|
|
||||||
"DCY/jmkj1oGOicFy62r9vutC5uJsVEMFgmAXXfYcC6BRBKNHCybALFJolnrDcPXNLl+K60Vctt09YZT7YgbeOICGJ/ZgC2JztOnm1JhX3eJXni"+
|
|
||||||
"U5Bqhezzlu334vD/Ajr3yDGXw5G9IZ6aLmLfQafY42N3J7cjj1LaXOHihSrcC5ThmuYIB5FX5AU8tKlnNG9Dn1EnsdD4KcnPhsSNPRiXtz461b"+
|
|
||||||
"VZw8Pm6vn0afh4fvr0D5P/+cMuBAAA") },
|
|
||||||
// cryptoapi
|
// cryptoapi
|
||||||
new Object[]{ getSpreadSheetInstance(), "35897-type4.xls", "freedom", "Sheet1\nhello there!" },
|
new Object[]{ getSpreadSheetInstance(), "35897-type4.xls", "freedom", "Sheet1\nhello there!" },
|
||||||
// cryptoapi (PPT only supports cryptoapi...)
|
// cryptoapi (PPT only supports cryptoapi...)
|
||||||
|
@ -86,10 +89,6 @@ public class TestHxxFEncryption {
|
||||||
);
|
);
|
||||||
}
|
}
|
||||||
|
|
||||||
private static String x(String base64) throws IOException {
|
|
||||||
return new String(RawDataUtil.decompress(base64), StandardCharsets.UTF_8);
|
|
||||||
}
|
|
||||||
|
|
||||||
@Test
|
@Test
|
||||||
public void extract() throws IOException, OpenXML4JException, XmlException {
|
public void extract() throws IOException, OpenXML4JException, XmlException {
|
||||||
File f = sampleDir.getFile(file);
|
File f = sampleDir.getFile(file);
|
||||||
|
@ -112,7 +111,7 @@ public class TestHxxFEncryption {
|
||||||
newPassword(null);
|
newPassword(null);
|
||||||
}
|
}
|
||||||
|
|
||||||
public void newPassword(String newPass) throws IOException, OpenXML4JException, XmlException {
|
private void newPassword(String newPass) throws IOException, OpenXML4JException, XmlException {
|
||||||
File f = sampleDir.getFile(file);
|
File f = sampleDir.getFile(file);
|
||||||
Biff8EncryptionKey.setCurrentUserPassword(password);
|
Biff8EncryptionKey.setCurrentUserPassword(password);
|
||||||
try (POITextExtractor te1 = ExtractorFactory.createExtractor(f)) {
|
try (POITextExtractor te1 = ExtractorFactory.createExtractor(f)) {
|
||||||
|
@ -156,10 +155,14 @@ public class TestHxxFEncryption {
|
||||||
try (POITextExtractor te3 = ExtractorFactory.createExtractor(new ByteArrayInputStream(bos.toByteArray()));
|
try (POITextExtractor te3 = ExtractorFactory.createExtractor(new ByteArrayInputStream(bos.toByteArray()));
|
||||||
POIDocument doc = (POIDocument) te3.getDocument()) {
|
POIDocument doc = (POIDocument) te3.getDocument()) {
|
||||||
// need to cache data (i.e. read all data) before changing the key size
|
// need to cache data (i.e. read all data) before changing the key size
|
||||||
if (doc instanceof HSLFSlideShowImpl) {
|
Class<?> clazz = doc.getClass();
|
||||||
HSLFSlideShowImpl hss = (HSLFSlideShowImpl) doc;
|
if ("HSLFSlideShowImpl".equals(clazz.getSimpleName())) {
|
||||||
hss.getPictureData();
|
try {
|
||||||
hss.getDocumentSummaryInformation();
|
clazz.getDeclaredMethod("getPictureData").invoke(doc);
|
||||||
|
} catch (ReflectiveOperationException e) {
|
||||||
|
fail("either scratchpad jar is included and this should work or the clazz should be != HSLFSlideShowImpl");
|
||||||
|
}
|
||||||
|
doc.getDocumentSummaryInformation();
|
||||||
}
|
}
|
||||||
EncryptionInfo ei = doc.getEncryptionInfo();
|
EncryptionInfo ei = doc.getEncryptionInfo();
|
||||||
assertNotNull(ei);
|
assertNotNull(ei);
|
||||||
|
|
|
@ -38,7 +38,6 @@ import java.util.Map;
|
||||||
|
|
||||||
import org.apache.poi.POIDataSamples;
|
import org.apache.poi.POIDataSamples;
|
||||||
import org.apache.poi.common.usermodel.fonts.FontGroup;
|
import org.apache.poi.common.usermodel.fonts.FontGroup;
|
||||||
import org.apache.poi.hslf.usermodel.HSLFSlideShow;
|
|
||||||
import org.apache.poi.sl.draw.DrawFactory;
|
import org.apache.poi.sl.draw.DrawFactory;
|
||||||
import org.apache.poi.sl.draw.Drawable;
|
import org.apache.poi.sl.draw.Drawable;
|
||||||
import org.apache.poi.sl.usermodel.Slide;
|
import org.apache.poi.sl.usermodel.Slide;
|
||||||
|
@ -93,9 +92,9 @@ public class TestFonts {
|
||||||
}
|
}
|
||||||
|
|
||||||
@Test
|
@Test
|
||||||
public void resizeToFitTextHSLF() throws IOException {
|
public void resizeToFitTextHSLF() throws IOException, ReflectiveOperationException {
|
||||||
assumeFalse(xslfOnly());
|
assumeFalse(xslfOnly());
|
||||||
SlideShow<?,?> ppt = new HSLFSlideShow();
|
SlideShow<?,?> ppt = (SlideShow<?,?>)Class.forName("org.apache.poi.hslf.usermodel.HSLFSlideShow").newInstance();
|
||||||
resizeToFitText(ppt);
|
resizeToFitText(ppt);
|
||||||
ppt.close();
|
ppt.close();
|
||||||
}
|
}
|
||||||
|
|
|
@ -20,19 +20,12 @@
|
||||||
package org.apache.poi.sl;
|
package org.apache.poi.sl;
|
||||||
|
|
||||||
import static org.apache.poi.sl.SLCommonUtils.openSampleSlideshow;
|
import static org.apache.poi.sl.SLCommonUtils.openSampleSlideshow;
|
||||||
import static org.apache.poi.sl.SLCommonUtils.xslfOnly;
|
|
||||||
import static org.junit.Assert.assertEquals;
|
import static org.junit.Assert.assertEquals;
|
||||||
import static org.junit.Assert.assertFalse;
|
|
||||||
import static org.junit.Assert.assertNull;
|
|
||||||
import static org.junit.Assert.assertTrue;
|
import static org.junit.Assert.assertTrue;
|
||||||
import static org.junit.Assume.assumeFalse;
|
|
||||||
|
|
||||||
import java.io.IOException;
|
import java.io.IOException;
|
||||||
import java.util.List;
|
import java.util.List;
|
||||||
|
|
||||||
import org.apache.poi.hslf.model.HeadersFooters;
|
|
||||||
import org.apache.poi.hslf.usermodel.HSLFSlide;
|
|
||||||
import org.apache.poi.hslf.usermodel.HSLFTextParagraph;
|
|
||||||
import org.apache.poi.sl.usermodel.Shape;
|
import org.apache.poi.sl.usermodel.Shape;
|
||||||
import org.apache.poi.sl.usermodel.Slide;
|
import org.apache.poi.sl.usermodel.Slide;
|
||||||
import org.apache.poi.sl.usermodel.SlideShow;
|
import org.apache.poi.sl.usermodel.SlideShow;
|
||||||
|
@ -41,33 +34,6 @@ import org.apache.poi.sl.usermodel.TextShape;
|
||||||
import org.junit.Test;
|
import org.junit.Test;
|
||||||
|
|
||||||
public class TestHeadersFooters {
|
public class TestHeadersFooters {
|
||||||
@Test
|
|
||||||
public void bug58144a() throws IOException {
|
|
||||||
assumeFalse(xslfOnly());
|
|
||||||
SlideShow<?,?> ppt = openSampleSlideshow("bug58144-headers-footers-2003.ppt");
|
|
||||||
HSLFSlide sl = (HSLFSlide)ppt.getSlides().get(0);
|
|
||||||
HeadersFooters hfs = sl.getHeadersFooters();
|
|
||||||
assertNull(hfs.getHeaderText());
|
|
||||||
assertEquals("Confidential", hfs.getFooterText());
|
|
||||||
List<List<HSLFTextParagraph>> llp = sl.getTextParagraphs();
|
|
||||||
assertEquals("Test", HSLFTextParagraph.getText(llp.get(0)));
|
|
||||||
assertFalse(llp.get(0).get(0).isHeaderOrFooter());
|
|
||||||
ppt.close();
|
|
||||||
}
|
|
||||||
|
|
||||||
@Test
|
|
||||||
public void bug58144b() throws IOException {
|
|
||||||
assumeFalse(xslfOnly());
|
|
||||||
SlideShow<?,?> ppt = openSampleSlideshow("bug58144-headers-footers-2007.ppt");
|
|
||||||
Slide<?,?> sl = ppt.getSlides().get(0);
|
|
||||||
HeadersFooters hfs2 = ((HSLFSlide)sl).getHeadersFooters();
|
|
||||||
assertNull(hfs2.getHeaderText());
|
|
||||||
assertEquals("Slide footer", hfs2.getFooterText());
|
|
||||||
|
|
||||||
testSlideShow(ppt);
|
|
||||||
ppt.close();
|
|
||||||
}
|
|
||||||
|
|
||||||
@Test
|
@Test
|
||||||
public void bug58144c() throws IOException {
|
public void bug58144c() throws IOException {
|
||||||
SlideShow<?,?> ppt = openSampleSlideshow("bug58144-headers-footers-2007.pptx");
|
SlideShow<?,?> ppt = openSampleSlideshow("bug58144-headers-footers-2007.pptx");
|
||||||
|
|
|
@ -35,13 +35,14 @@ import java.io.File;
|
||||||
import java.io.IOException;
|
import java.io.IOException;
|
||||||
import java.io.InputStream;
|
import java.io.InputStream;
|
||||||
import java.io.OutputStream;
|
import java.io.OutputStream;
|
||||||
|
import java.lang.reflect.Constructor;
|
||||||
|
import java.lang.reflect.Method;
|
||||||
import java.util.Arrays;
|
import java.util.Arrays;
|
||||||
import java.util.Collection;
|
import java.util.Collection;
|
||||||
|
|
||||||
import org.apache.poi.POIDataSamples;
|
import org.apache.poi.POIDataSamples;
|
||||||
import org.apache.poi.hslf.usermodel.HSLFSlideShow;
|
import org.apache.poi.POIDocument;
|
||||||
import org.apache.poi.hssf.usermodel.HSSFWorkbook;
|
import org.apache.poi.hssf.usermodel.HSSFWorkbook;
|
||||||
import org.apache.poi.hwpf.HWPFDocument;
|
|
||||||
import org.apache.poi.openxml4j.exceptions.InvalidFormatException;
|
import org.apache.poi.openxml4j.exceptions.InvalidFormatException;
|
||||||
import org.apache.poi.poifs.storage.RawDataUtil;
|
import org.apache.poi.poifs.storage.RawDataUtil;
|
||||||
import org.apache.poi.sl.usermodel.ObjectMetaData;
|
import org.apache.poi.sl.usermodel.ObjectMetaData;
|
||||||
|
@ -124,7 +125,7 @@ public class TestOleShape {
|
||||||
}
|
}
|
||||||
|
|
||||||
@Test
|
@Test
|
||||||
public void embedData() throws IOException, InvalidFormatException {
|
public void embedData() throws IOException, InvalidFormatException, ReflectiveOperationException {
|
||||||
final ByteArrayInputStream pptBytes;
|
final ByteArrayInputStream pptBytes;
|
||||||
try (SlideShow<?,?> ppt = createSlideShow()) {
|
try (SlideShow<?,?> ppt = createSlideShow()) {
|
||||||
final PictureData picData = ppt.addPicture(pictureFile, PictureType.EMF);
|
final PictureData picData = ppt.addPicture(pictureFile, PictureType.EMF);
|
||||||
|
@ -146,12 +147,12 @@ public class TestOleShape {
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
private SlideShow<?,?> createSlideShow() {
|
private SlideShow<?,?> createSlideShow() throws ReflectiveOperationException {
|
||||||
if (api == Api.XSLF) {
|
if (api == Api.XSLF) {
|
||||||
return new XMLSlideShow();
|
return new XMLSlideShow();
|
||||||
} else {
|
} else {
|
||||||
assumeFalse(xslfOnly());
|
assumeFalse(xslfOnly());
|
||||||
return new HSLFSlideShow();
|
return (SlideShow<?,?>)Class.forName("org.apache.poi.hslf.usermodel.HSLFSlideShow").newInstance();
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -186,7 +187,7 @@ public class TestOleShape {
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
private void validateOleData(final InputStream in) throws IOException, InvalidFormatException {
|
private void validateOleData(final InputStream in) throws IOException, InvalidFormatException, ReflectiveOperationException {
|
||||||
switch (app) {
|
switch (app) {
|
||||||
case EXCEL_V8:
|
case EXCEL_V8:
|
||||||
case EXCEL_V12:
|
case EXCEL_V12:
|
||||||
|
@ -195,8 +196,11 @@ public class TestOleShape {
|
||||||
}
|
}
|
||||||
break;
|
break;
|
||||||
case WORD_V8:
|
case WORD_V8:
|
||||||
try (HWPFDocument doc = new HWPFDocument(in)) {
|
Class<? extends POIDocument> clazz = (Class<? extends POIDocument>)Class.forName("org.apache.poi.hwpf.HWPFDocument");
|
||||||
assertEquals("This is a simple file created with Word 97-SR2.\r", doc.getDocumentText());
|
Constructor<? extends POIDocument> con = clazz.getDeclaredConstructor(InputStream.class);
|
||||||
|
Method m = clazz.getMethod("getDocumentText");
|
||||||
|
try (POIDocument doc = con.newInstance(in)) {
|
||||||
|
assertEquals("This is a simple file created with Word 97-SR2.\r", m.invoke(doc));
|
||||||
}
|
}
|
||||||
break;
|
break;
|
||||||
case WORD_V12:
|
case WORD_V12:
|
||||||
|
|
|
@ -29,7 +29,6 @@ import java.io.ByteArrayOutputStream;
|
||||||
import java.io.IOException;
|
import java.io.IOException;
|
||||||
import java.io.InputStream;
|
import java.io.InputStream;
|
||||||
|
|
||||||
import org.apache.poi.hslf.usermodel.HSLFSlideShow;
|
|
||||||
import org.apache.poi.sl.usermodel.SlideShow;
|
import org.apache.poi.sl.usermodel.SlideShow;
|
||||||
import org.apache.poi.sl.usermodel.SlideShowFactory;
|
import org.apache.poi.sl.usermodel.SlideShowFactory;
|
||||||
import org.apache.poi.xslf.usermodel.XMLSlideShow;
|
import org.apache.poi.xslf.usermodel.XMLSlideShow;
|
||||||
|
@ -38,9 +37,9 @@ import org.junit.Test;
|
||||||
public class TestSlide {
|
public class TestSlide {
|
||||||
|
|
||||||
@Test
|
@Test
|
||||||
public void hideHSLF() throws IOException {
|
public void hideHSLF() throws IOException, ReflectiveOperationException {
|
||||||
assumeFalse(xslfOnly());
|
assumeFalse(xslfOnly());
|
||||||
SlideShow<?,?> ppt1 = new HSLFSlideShow();
|
SlideShow<?,?> ppt1 = (SlideShow<?,?>)Class.forName("org.apache.poi.hslf.usermodel.HSLFSlideShow").newInstance();
|
||||||
hideSlide(ppt1);
|
hideSlide(ppt1);
|
||||||
ppt1.close();
|
ppt1.close();
|
||||||
}
|
}
|
||||||
|
|
|
@ -34,7 +34,6 @@ import java.io.ByteArrayOutputStream;
|
||||||
import java.io.IOException;
|
import java.io.IOException;
|
||||||
import java.io.InputStream;
|
import java.io.InputStream;
|
||||||
|
|
||||||
import org.apache.poi.hslf.usermodel.HSLFSlideShow;
|
|
||||||
import org.apache.poi.sl.usermodel.Slide;
|
import org.apache.poi.sl.usermodel.Slide;
|
||||||
import org.apache.poi.sl.usermodel.SlideShow;
|
import org.apache.poi.sl.usermodel.SlideShow;
|
||||||
import org.apache.poi.sl.usermodel.SlideShowFactory;
|
import org.apache.poi.sl.usermodel.SlideShowFactory;
|
||||||
|
@ -96,9 +95,9 @@ public class TestTable {
|
||||||
}
|
}
|
||||||
|
|
||||||
@Test
|
@Test
|
||||||
public void directionHSLF() throws IOException {
|
public void directionHSLF() throws IOException, ReflectiveOperationException {
|
||||||
assumeFalse(xslfOnly());
|
assumeFalse(xslfOnly());
|
||||||
SlideShow<?,?> ppt1 = new HSLFSlideShow();
|
SlideShow<?,?> ppt1 = (SlideShow<?,?>)Class.forName("org.apache.poi.hslf.usermodel.HSLFSlideShow").newInstance();
|
||||||
testTextDirection(ppt1);
|
testTextDirection(ppt1);
|
||||||
ppt1.close();
|
ppt1.close();
|
||||||
}
|
}
|
||||||
|
|
|
@ -17,12 +17,15 @@
|
||||||
package org.apache.poi.ss.format;
|
package org.apache.poi.ss.format;
|
||||||
|
|
||||||
import static org.junit.Assert.assertEquals;
|
import static org.junit.Assert.assertEquals;
|
||||||
|
import static org.junit.Assert.assertNotNull;
|
||||||
|
import static org.junit.Assert.assertTrue;
|
||||||
|
|
||||||
import java.util.Locale;
|
import java.util.Locale;
|
||||||
import java.util.TimeZone;
|
import java.util.TimeZone;
|
||||||
import java.util.regex.Matcher;
|
import java.util.regex.Matcher;
|
||||||
import java.util.regex.Pattern;
|
import java.util.regex.Pattern;
|
||||||
|
|
||||||
|
import org.apache.poi.hssf.util.HSSFColor;
|
||||||
import org.apache.poi.ss.usermodel.Cell;
|
import org.apache.poi.ss.usermodel.Cell;
|
||||||
import org.apache.poi.util.LocaleUtil;
|
import org.apache.poi.util.LocaleUtil;
|
||||||
import org.apache.poi.xssf.XSSFITestDataProvider;
|
import org.apache.poi.xssf.XSSFITestDataProvider;
|
||||||
|
@ -38,7 +41,7 @@ public class TestCellFormatPart extends CellFormatTestBase {
|
||||||
@BeforeClass
|
@BeforeClass
|
||||||
public static void setLocale() {
|
public static void setLocale() {
|
||||||
userLocale = LocaleUtil.getUserLocale();
|
userLocale = LocaleUtil.getUserLocale();
|
||||||
LocaleUtil.setUserLocale(Locale.ROOT);
|
LocaleUtil.setUserLocale(Locale.UK);
|
||||||
}
|
}
|
||||||
|
|
||||||
@AfterClass
|
@AfterClass
|
||||||
|
@ -153,6 +156,19 @@ public class TestCellFormatPart extends CellFormatTestBase {
|
||||||
});
|
});
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@Test
|
||||||
|
public void testNamedColors() {
|
||||||
|
assertTrue(CellFormatPart.NAMED_COLORS.size() >= HSSFColor.HSSFColorPredefined.values().length);
|
||||||
|
assertNotNull(CellFormatPart.NAMED_COLORS.get("GREEN"));
|
||||||
|
assertNotNull(CellFormatPart.NAMED_COLORS.get("Green"));
|
||||||
|
assertNotNull(CellFormatPart.NAMED_COLORS.get("RED"));
|
||||||
|
assertNotNull(CellFormatPart.NAMED_COLORS.get("Red"));
|
||||||
|
assertNotNull(CellFormatPart.NAMED_COLORS.get("BLUE"));
|
||||||
|
assertNotNull(CellFormatPart.NAMED_COLORS.get("Blue"));
|
||||||
|
assertNotNull(CellFormatPart.NAMED_COLORS.get("YELLOW"));
|
||||||
|
assertNotNull(CellFormatPart.NAMED_COLORS.get("Yellow"));
|
||||||
|
}
|
||||||
|
|
||||||
private double extractNumber(String str) {
|
private double extractNumber(String str) {
|
||||||
Matcher m = NUMBER_EXTRACT_FMT.matcher(str);
|
Matcher m = NUMBER_EXTRACT_FMT.matcher(str);
|
||||||
if (!m.find())
|
if (!m.find())
|
||||||
|
|
|
@ -17,10 +17,11 @@
|
||||||
|
|
||||||
package org.apache.poi.ss.usermodel;
|
package org.apache.poi.ss.usermodel;
|
||||||
|
|
||||||
|
import static org.apache.poi.sl.SLCommonUtils.xslfOnly;
|
||||||
import static org.junit.Assert.assertArrayEquals;
|
import static org.junit.Assert.assertArrayEquals;
|
||||||
import static org.junit.Assert.assertEquals;
|
import static org.junit.Assert.assertEquals;
|
||||||
import static org.junit.Assert.assertTrue;
|
import static org.junit.Assert.assertTrue;
|
||||||
import static org.junit.Assume.assumeTrue;
|
import static org.junit.Assume.assumeFalse;
|
||||||
|
|
||||||
import java.io.ByteArrayOutputStream;
|
import java.io.ByteArrayOutputStream;
|
||||||
import java.io.IOException;
|
import java.io.IOException;
|
||||||
|
@ -48,7 +49,7 @@ public class TestEmbedOLEPackage {
|
||||||
private static byte[] samplePPT, samplePPTX, samplePNG;
|
private static byte[] samplePPT, samplePPTX, samplePNG;
|
||||||
|
|
||||||
@BeforeClass
|
@BeforeClass
|
||||||
public static void init() throws IOException {
|
public static void init() throws IOException, ReflectiveOperationException {
|
||||||
samplePPT = getSamplePPT(false);
|
samplePPT = getSamplePPT(false);
|
||||||
samplePPTX = getSamplePPT(true);
|
samplePPTX = getSamplePPT(true);
|
||||||
samplePNG = POIDataSamples.getSpreadSheetInstance().readFile("logoKarmokar4.png");
|
samplePNG = POIDataSamples.getSpreadSheetInstance().readFile("logoKarmokar4.png");
|
||||||
|
@ -68,11 +69,7 @@ public class TestEmbedOLEPackage {
|
||||||
|
|
||||||
@Test
|
@Test
|
||||||
public void embedHSSF() throws IOException {
|
public void embedHSSF() throws IOException {
|
||||||
try {
|
assumeFalse(xslfOnly());
|
||||||
Class.forName("org.apache.poi.hslf.usermodel.HSLFSlideShow");
|
|
||||||
} catch (Exception e) {
|
|
||||||
assumeTrue(false);
|
|
||||||
}
|
|
||||||
|
|
||||||
Workbook wb1 = new HSSFWorkbook();
|
Workbook wb1 = new HSSFWorkbook();
|
||||||
addEmbeddedObjects(wb1);
|
addEmbeddedObjects(wb1);
|
||||||
|
@ -124,8 +121,9 @@ public class TestEmbedOLEPackage {
|
||||||
pat2.createObjectData(anchor2, oleIdx2, picIdx);
|
pat2.createObjectData(anchor2, oleIdx2, picIdx);
|
||||||
}
|
}
|
||||||
|
|
||||||
static byte[] getSamplePPT(boolean ooxml) throws IOException {
|
static byte[] getSamplePPT(boolean ooxml) throws IOException, ReflectiveOperationException {
|
||||||
SlideShow<?,?> ppt = (ooxml) ? new XMLSlideShow() : new org.apache.poi.hslf.usermodel.HSLFSlideShow();
|
SlideShow<?,?> ppt = (ooxml) ? new XMLSlideShow()
|
||||||
|
: (SlideShow<?,?>)Class.forName("org.apache.poi.hslf.usermodel.HSLFSlideShow").newInstance();
|
||||||
Slide<?,?> slide = ppt.createSlide();
|
Slide<?,?> slide = ppt.createSlide();
|
||||||
|
|
||||||
AutoShape<?,?> sh1 = slide.createAutoShape();
|
AutoShape<?,?> sh1 = slide.createAutoShape();
|
||||||
|
|
|
@ -17,12 +17,7 @@
|
||||||
package org.apache.poi.xslf;
|
package org.apache.poi.xslf;
|
||||||
|
|
||||||
import static org.apache.poi.POITestCase.assertContains;
|
import static org.apache.poi.POITestCase.assertContains;
|
||||||
import static org.junit.Assert.assertArrayEquals;
|
import static org.junit.Assert.*;
|
||||||
import static org.junit.Assert.assertEquals;
|
|
||||||
import static org.junit.Assert.assertNotNull;
|
|
||||||
import static org.junit.Assert.assertNull;
|
|
||||||
import static org.junit.Assert.assertTrue;
|
|
||||||
import static org.junit.Assert.fail;
|
|
||||||
|
|
||||||
import java.awt.Color;
|
import java.awt.Color;
|
||||||
import java.awt.Dimension;
|
import java.awt.Dimension;
|
||||||
|
@ -93,6 +88,25 @@ import org.openxmlformats.schemas.presentationml.x2006.main.CTShape;
|
||||||
public class TestXSLFBugs {
|
public class TestXSLFBugs {
|
||||||
private static final POIDataSamples slTests = POIDataSamples.getSlideShowInstance();
|
private static final POIDataSamples slTests = POIDataSamples.getSlideShowInstance();
|
||||||
|
|
||||||
|
@Test
|
||||||
|
public void bug62929() throws Exception {
|
||||||
|
try(XMLSlideShow ss1 = XSLFTestDataSamples.openSampleDocument("missing-blip-fill.pptx")) {
|
||||||
|
assertEquals(1, ss1.getSlides().size());
|
||||||
|
|
||||||
|
XSLFSlide slide = ss1.getSlides().get(0);
|
||||||
|
|
||||||
|
assertEquals(slide.getShapes().size(), 1);
|
||||||
|
|
||||||
|
XSLFPictureShape picture = (XSLFPictureShape)slide.getShapes().get(0);
|
||||||
|
|
||||||
|
assertEquals(picture.getShapeId(), 662);
|
||||||
|
assertFalse(picture.isExternalLinkedPicture());
|
||||||
|
assertNull(picture.getPictureData());
|
||||||
|
assertNull(picture.getPictureLink());
|
||||||
|
assertNull(picture.getClipping());
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
@Test
|
@Test
|
||||||
public void bug62736() throws Exception {
|
public void bug62736() throws Exception {
|
||||||
XMLSlideShow ss1 = XSLFTestDataSamples.openSampleDocument("bug62736.pptx");
|
XMLSlideShow ss1 = XSLFTestDataSamples.openSampleDocument("bug62736.pptx");
|
||||||
|
|
|
@ -17,6 +17,7 @@
|
||||||
package org.apache.poi.xslf.usermodel;
|
package org.apache.poi.xslf.usermodel;
|
||||||
|
|
||||||
import static org.apache.poi.sl.TestCommonSL.sameColor;
|
import static org.apache.poi.sl.TestCommonSL.sameColor;
|
||||||
|
import static org.apache.poi.xslf.usermodel.TestXSLFSimpleShape.getSpPr;
|
||||||
import static org.junit.Assert.assertEquals;
|
import static org.junit.Assert.assertEquals;
|
||||||
import static org.junit.Assert.assertFalse;
|
import static org.junit.Assert.assertFalse;
|
||||||
import static org.junit.Assert.assertNotNull;
|
import static org.junit.Assert.assertNotNull;
|
||||||
|
@ -24,7 +25,6 @@ import static org.junit.Assert.assertNull;
|
||||||
import static org.junit.Assert.assertSame;
|
import static org.junit.Assert.assertSame;
|
||||||
import static org.junit.Assert.assertTrue;
|
import static org.junit.Assert.assertTrue;
|
||||||
import static org.junit.Assume.assumeFalse;
|
import static org.junit.Assume.assumeFalse;
|
||||||
import static org.apache.poi.xslf.usermodel.TestXSLFSimpleShape.getSpPr;
|
|
||||||
|
|
||||||
import java.awt.Color;
|
import java.awt.Color;
|
||||||
import java.io.File;
|
import java.io.File;
|
||||||
|
@ -33,8 +33,8 @@ import java.util.List;
|
||||||
import java.util.stream.Collectors;
|
import java.util.stream.Collectors;
|
||||||
|
|
||||||
import org.apache.poi.POIDataSamples;
|
import org.apache.poi.POIDataSamples;
|
||||||
import org.apache.poi.hslf.usermodel.HSLFTextShape;
|
|
||||||
import org.apache.poi.sl.usermodel.Placeholder;
|
import org.apache.poi.sl.usermodel.Placeholder;
|
||||||
|
import org.apache.poi.sl.usermodel.Shape;
|
||||||
import org.apache.poi.sl.usermodel.SlideShow;
|
import org.apache.poi.sl.usermodel.SlideShow;
|
||||||
import org.apache.poi.sl.usermodel.SlideShowFactory;
|
import org.apache.poi.sl.usermodel.SlideShowFactory;
|
||||||
import org.apache.poi.sl.usermodel.TextParagraph.TextAlign;
|
import org.apache.poi.sl.usermodel.TextParagraph.TextAlign;
|
||||||
|
@ -950,12 +950,12 @@ public class TestXSLFTextShape {
|
||||||
}
|
}
|
||||||
|
|
||||||
@Test
|
@Test
|
||||||
public void metroBlob() throws IOException {
|
public void metroBlob() throws IOException, ReflectiveOperationException {
|
||||||
assumeFalse(xslfOnly);
|
assumeFalse(xslfOnly);
|
||||||
File f = POIDataSamples.getSlideShowInstance().getFile("bug52297.ppt");
|
File f = POIDataSamples.getSlideShowInstance().getFile("bug52297.ppt");
|
||||||
SlideShow<?,?> ppt = SlideShowFactory.create(f);
|
SlideShow<?,?> ppt = SlideShowFactory.create(f);
|
||||||
HSLFTextShape sh = (HSLFTextShape)ppt.getSlides().get(1).getShapes().get(3);
|
Shape<?, ?> sh = ppt.getSlides().get(1).getShapes().get(3);
|
||||||
XSLFAutoShape xsh = (XSLFAutoShape)sh.getMetroShape();
|
XSLFAutoShape xsh = (XSLFAutoShape)sh.getClass().getMethod("getMetroShape").invoke(sh);
|
||||||
String textExp = " ___ ___ ___ ________ __ _______ ___ ___________ __________ __ _____ ___ ___ ___ _______ ____ ______ ___________ _____________ ___ _______ ______ ____ ______ __ ___________ __________ ___ _________ _____ ________ __________ ___ _______ __________ ";
|
String textExp = " ___ ___ ___ ________ __ _______ ___ ___________ __________ __ _____ ___ ___ ___ _______ ____ ______ ___________ _____________ ___ _______ ______ ____ ______ __ ___________ __________ ___ _________ _____ ________ __________ ___ _______ __________ ";
|
||||||
String textAct = xsh.getText();
|
String textAct = xsh.getText();
|
||||||
ppt.close();
|
ppt.close();
|
||||||
|
|
|
@ -21,7 +21,10 @@ import static org.junit.Assert.assertEquals;
|
||||||
import static org.junit.Assert.assertNotNull;
|
import static org.junit.Assert.assertNotNull;
|
||||||
import static org.junit.Assert.fail;
|
import static org.junit.Assert.fail;
|
||||||
|
|
||||||
|
import java.io.File;
|
||||||
|
import java.io.FileOutputStream;
|
||||||
import java.io.IOException;
|
import java.io.IOException;
|
||||||
|
import java.util.Date;
|
||||||
|
|
||||||
import org.apache.poi.ss.ITestDataProvider;
|
import org.apache.poi.ss.ITestDataProvider;
|
||||||
import org.apache.poi.ss.usermodel.BaseTestBugzillaIssues;
|
import org.apache.poi.ss.usermodel.BaseTestBugzillaIssues;
|
||||||
|
@ -34,6 +37,9 @@ import org.apache.poi.ss.usermodel.Workbook;
|
||||||
import org.apache.poi.ss.util.CellRangeAddress;
|
import org.apache.poi.ss.util.CellRangeAddress;
|
||||||
import org.apache.poi.xssf.SXSSFITestDataProvider;
|
import org.apache.poi.xssf.SXSSFITestDataProvider;
|
||||||
import org.apache.poi.xssf.XSSFITestDataProvider;
|
import org.apache.poi.xssf.XSSFITestDataProvider;
|
||||||
|
import org.apache.poi.xssf.streaming.SXSSFCell;
|
||||||
|
import org.apache.poi.xssf.streaming.SXSSFRow;
|
||||||
|
import org.apache.poi.xssf.streaming.SXSSFSheet;
|
||||||
import org.apache.poi.xssf.streaming.SXSSFWorkbook;
|
import org.apache.poi.xssf.streaming.SXSSFWorkbook;
|
||||||
import org.junit.Ignore;
|
import org.junit.Ignore;
|
||||||
import org.junit.Test;
|
import org.junit.Test;
|
||||||
|
@ -166,4 +172,45 @@ public final class TestSXSSFBugs extends BaseTestBugzillaIssues {
|
||||||
CellRangeAddress range = new CellRangeAddress(rowIndex, rowIndex, colIndex, colIndex);
|
CellRangeAddress range = new CellRangeAddress(rowIndex, rowIndex, colIndex, colIndex);
|
||||||
sheet.setArrayFormula(col1Value, range);
|
sheet.setArrayFormula(col1Value, range);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@Test
|
||||||
|
@Ignore("takes too long for the normal test run")
|
||||||
|
public void test62872() throws Exception {
|
||||||
|
final int COLUMN_COUNT = 300;
|
||||||
|
final int ROW_COUNT = 600000;
|
||||||
|
final int TEN_MINUTES = 1000*60*10;
|
||||||
|
|
||||||
|
SXSSFWorkbook workbook = new SXSSFWorkbook(100);
|
||||||
|
workbook.setCompressTempFiles(true);
|
||||||
|
SXSSFSheet sheet = workbook.createSheet("RawData");
|
||||||
|
|
||||||
|
SXSSFRow row = sheet.createRow(0);
|
||||||
|
SXSSFCell cell;
|
||||||
|
|
||||||
|
for (int i = 1; i <= COLUMN_COUNT; i++) {
|
||||||
|
cell = row.createCell(i - 1);
|
||||||
|
cell.setCellValue("Column " + i);
|
||||||
|
}
|
||||||
|
|
||||||
|
for (int i = 1; i < ROW_COUNT; i++) {
|
||||||
|
row = sheet.createRow(i);
|
||||||
|
for (int j = 1; j <= COLUMN_COUNT; j++) {
|
||||||
|
cell = row.createCell(j - 1);
|
||||||
|
|
||||||
|
//make some noise
|
||||||
|
cell.setCellValue(new Date(i*TEN_MINUTES+(j*TEN_MINUTES)/COLUMN_COUNT));
|
||||||
|
}
|
||||||
|
i++;
|
||||||
|
// if (i % 1000 == 0)
|
||||||
|
// logger.info("Created Row " + i);
|
||||||
|
}
|
||||||
|
|
||||||
|
try (FileOutputStream out = new FileOutputStream(File.createTempFile("test62872", ".xlsx"))) {
|
||||||
|
workbook.write(out);
|
||||||
|
workbook.dispose();
|
||||||
|
workbook.close();
|
||||||
|
out.flush();
|
||||||
|
}
|
||||||
|
// logger.info("File written!");
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
|
|
@ -55,10 +55,7 @@ import org.apache.poi.ss.usermodel.IndexedColors;
|
||||||
import org.apache.poi.ss.usermodel.Row;
|
import org.apache.poi.ss.usermodel.Row;
|
||||||
import org.apache.poi.ss.usermodel.Sheet;
|
import org.apache.poi.ss.usermodel.Sheet;
|
||||||
import org.apache.poi.ss.usermodel.Workbook;
|
import org.apache.poi.ss.usermodel.Workbook;
|
||||||
import org.apache.poi.ss.util.CellAddress;
|
import org.apache.poi.ss.util.*;
|
||||||
import org.apache.poi.ss.util.CellRangeAddress;
|
|
||||||
import org.apache.poi.ss.util.CellReference;
|
|
||||||
import org.apache.poi.ss.util.CellUtil;
|
|
||||||
import org.apache.poi.util.LocaleUtil;
|
import org.apache.poi.util.LocaleUtil;
|
||||||
import org.apache.poi.xssf.XSSFITestDataProvider;
|
import org.apache.poi.xssf.XSSFITestDataProvider;
|
||||||
import org.apache.poi.xssf.XSSFTestDataSamples;
|
import org.apache.poi.xssf.XSSFTestDataSamples;
|
||||||
|
@ -1993,12 +1990,11 @@ public final class TestXSSFSheet extends BaseTestXSheet {
|
||||||
|
|
||||||
@Test
|
@Test
|
||||||
public void testGetHeaderFooterProperties() throws IOException {
|
public void testGetHeaderFooterProperties() throws IOException {
|
||||||
XSSFWorkbook wb = new XSSFWorkbook();
|
try (XSSFWorkbook wb = new XSSFWorkbook()) {
|
||||||
XSSFSheet sh = wb.createSheet();
|
XSSFSheet sh = wb.createSheet();
|
||||||
|
|
||||||
XSSFHeaderFooterProperties hfProp = sh.getHeaderFooterProperties();
|
XSSFHeaderFooterProperties hfProp = sh.getHeaderFooterProperties();
|
||||||
assertNotNull(hfProp);
|
assertNotNull(hfProp);
|
||||||
|
}
|
||||||
wb.close();
|
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
|
@ -349,9 +349,41 @@ public final class TestXSSFTable {
|
||||||
IOUtils.closeQuietly(wb);
|
IOUtils.closeQuietly(wb);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@Test
|
||||||
|
public void testCreateTableIds() throws IOException {
|
||||||
|
try (XSSFWorkbook wb = new XSSFWorkbook()) {
|
||||||
|
XSSFSheet sheet = wb.createSheet();
|
||||||
|
|
||||||
|
AreaReference reference1 = wb.getCreationHelper().createAreaReference(
|
||||||
|
new CellReference(0, 0), new CellReference(2, 2));
|
||||||
|
|
||||||
|
XSSFTable table1 = sheet.createTable(reference1);
|
||||||
|
assertEquals("A1:C3", table1.getCTTable().getRef());
|
||||||
|
|
||||||
|
assertEquals(1, table1.getCTTable().getTableColumns().getTableColumnArray(0).getId());
|
||||||
|
assertEquals(2, table1.getCTTable().getTableColumns().getTableColumnArray(1).getId());
|
||||||
|
assertEquals(3, table1.getCTTable().getTableColumns().getTableColumnArray(2).getId());
|
||||||
|
|
||||||
|
assertEquals(1, table1.getCTTable().getId());
|
||||||
|
|
||||||
|
AreaReference reference2 = wb.getCreationHelper().createAreaReference(
|
||||||
|
new CellReference(10, 10), new CellReference(12, 12));
|
||||||
|
|
||||||
|
XSSFTable table2 = sheet.createTable(reference2);
|
||||||
|
assertEquals("K11:M13", table2.getCTTable().getRef());
|
||||||
|
|
||||||
|
// these IDs duplicate those from table1 and may be cause of https://bz.apache.org/bugzilla/show_bug.cgi?id=62906
|
||||||
|
assertEquals(1, table2.getCTTable().getTableColumns().getTableColumnArray(0).getId());
|
||||||
|
assertEquals(2, table2.getCTTable().getTableColumns().getTableColumnArray(1).getId());
|
||||||
|
assertEquals(3, table2.getCTTable().getTableColumns().getTableColumnArray(2).getId());
|
||||||
|
|
||||||
|
assertEquals(2, table2.getCTTable().getId());
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
@Test
|
@Test
|
||||||
public void testSetArea() throws IOException {
|
public void testSetArea() throws IOException {
|
||||||
XSSFWorkbook wb = new XSSFWorkbook();
|
try (XSSFWorkbook wb = new XSSFWorkbook()) {
|
||||||
XSSFSheet sh = wb.createSheet();
|
XSSFSheet sh = wb.createSheet();
|
||||||
|
|
||||||
AreaReference tableArea = new AreaReference("B10:D12", wb.getSpreadsheetVersion());
|
AreaReference tableArea = new AreaReference("B10:D12", wb.getSpreadsheetVersion());
|
||||||
|
@ -380,43 +412,41 @@ public final class TestXSSFTable {
|
||||||
|
|
||||||
assertEquals(2, table.getColumnCount());
|
assertEquals(2, table.getColumnCount());
|
||||||
assertEquals(2, table.getRowCount());
|
assertEquals(2, table.getRowCount());
|
||||||
|
}
|
||||||
IOUtils.closeQuietly(wb);
|
|
||||||
}
|
}
|
||||||
|
|
||||||
@Test
|
@Test
|
||||||
public void testCreateColumn() {
|
public void testCreateColumn() throws IOException {
|
||||||
XSSFWorkbook wb = new XSSFWorkbook();
|
try (XSSFWorkbook wb = new XSSFWorkbook()) {
|
||||||
XSSFSheet sh = wb.createSheet();
|
XSSFSheet sh = wb.createSheet();
|
||||||
|
|
||||||
AreaReference tableArea = new AreaReference("A2:A3", wb.getSpreadsheetVersion());
|
AreaReference tableArea = new AreaReference("A2:A3", wb.getSpreadsheetVersion());
|
||||||
XSSFTable table = sh.createTable(tableArea);
|
XSSFTable table = sh.createTable(tableArea);
|
||||||
|
|
||||||
assertEquals(1, table.getColumnCount());
|
assertEquals(1, table.getColumnCount());
|
||||||
assertEquals(2, table.getRowCount());
|
assertEquals(2, table.getRowCount());
|
||||||
|
|
||||||
// add columns
|
// add columns
|
||||||
XSSFTableColumn c1 = table.getColumns().get(0);
|
XSSFTableColumn c1 = table.getColumns().get(0);
|
||||||
XSSFTableColumn cB = table.createColumn("Column B");
|
XSSFTableColumn cB = table.createColumn("Column B");
|
||||||
XSSFTableColumn cD = table.createColumn("Column D");
|
XSSFTableColumn cD = table.createColumn("Column D");
|
||||||
XSSFTableColumn cC = table.createColumn("Column C", 2); // add between B and D
|
XSSFTableColumn cC = table.createColumn("Column C", 2); // add between B and D
|
||||||
table.updateReferences();
|
table.updateReferences();
|
||||||
table.updateHeaders();
|
table.updateHeaders();
|
||||||
|
|
||||||
assertEquals(4, table.getColumnCount());
|
assertEquals(4, table.getColumnCount());
|
||||||
assertEquals(2, table.getRowCount());
|
assertEquals(2, table.getRowCount());
|
||||||
|
|
||||||
// column IDs start at 1, and increase in the order columns are added (see bug #62740)
|
// column IDs start at 1, and increase in the order columns are added (see bug #62740)
|
||||||
assertEquals("Column c ID", 1, c1.getId());
|
assertEquals("Column c ID", 1, c1.getId());
|
||||||
assertTrue("Column B ID", c1.getId() < cB.getId());
|
assertTrue("Column B ID", c1.getId() < cB.getId());
|
||||||
assertTrue("Column D ID", cB.getId() < cD.getId());
|
assertTrue("Column D ID", cB.getId() < cD.getId());
|
||||||
assertTrue("Column C ID", cD.getId() < cC.getId());
|
assertTrue("Column C ID", cD.getId() < cC.getId());
|
||||||
assertEquals("Column 1", table.getColumns().get(0).getName()); // generated name
|
assertEquals("Column 1", table.getColumns().get(0).getName()); // generated name
|
||||||
assertEquals("Column B", table.getColumns().get(1).getName());
|
assertEquals("Column B", table.getColumns().get(1).getName());
|
||||||
assertEquals("Column C", table.getColumns().get(2).getName());
|
assertEquals("Column C", table.getColumns().get(2).getName());
|
||||||
assertEquals("Column D", table.getColumns().get(3).getName());
|
assertEquals("Column D", table.getColumns().get(3).getName());
|
||||||
|
}
|
||||||
IOUtils.closeQuietly(wb);
|
|
||||||
}
|
}
|
||||||
|
|
||||||
@Test(expected = IllegalArgumentException.class)
|
@Test(expected = IllegalArgumentException.class)
|
||||||
|
|
|
@ -32,6 +32,7 @@ import org.apache.poi.hslf.usermodel.HSLFSlideShow;
|
||||||
import org.apache.poi.hsmf.MAPIMessage;
|
import org.apache.poi.hsmf.MAPIMessage;
|
||||||
import org.apache.poi.hsmf.datatypes.AttachmentChunks;
|
import org.apache.poi.hsmf.datatypes.AttachmentChunks;
|
||||||
import org.apache.poi.hsmf.extractor.OutlookTextExtactor;
|
import org.apache.poi.hsmf.extractor.OutlookTextExtactor;
|
||||||
|
import org.apache.poi.hssf.extractor.ExcelExtractor;
|
||||||
import org.apache.poi.hwpf.OldWordFileFormatException;
|
import org.apache.poi.hwpf.OldWordFileFormatException;
|
||||||
import org.apache.poi.hwpf.extractor.Word6Extractor;
|
import org.apache.poi.hwpf.extractor.Word6Extractor;
|
||||||
import org.apache.poi.hwpf.extractor.WordExtractor;
|
import org.apache.poi.hwpf.extractor.WordExtractor;
|
||||||
|
@ -40,6 +41,8 @@ import org.apache.poi.poifs.filesystem.DirectoryNode;
|
||||||
import org.apache.poi.poifs.filesystem.Entry;
|
import org.apache.poi.poifs.filesystem.Entry;
|
||||||
import org.apache.poi.sl.extractor.SlideShowExtractor;
|
import org.apache.poi.sl.extractor.SlideShowExtractor;
|
||||||
import org.apache.poi.sl.usermodel.SlideShowFactory;
|
import org.apache.poi.sl.usermodel.SlideShowFactory;
|
||||||
|
import org.apache.poi.util.POILogFactory;
|
||||||
|
import org.apache.poi.util.POILogger;
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Scratchpad-specific logic for {@link OLE2ExtractorFactory} and
|
* Scratchpad-specific logic for {@link OLE2ExtractorFactory} and
|
||||||
|
@ -50,6 +53,8 @@ import org.apache.poi.sl.usermodel.SlideShowFactory;
|
||||||
*/
|
*/
|
||||||
@SuppressWarnings("WeakerAccess")
|
@SuppressWarnings("WeakerAccess")
|
||||||
public class OLE2ScratchpadExtractorFactory {
|
public class OLE2ScratchpadExtractorFactory {
|
||||||
|
private static final POILogger logger = POILogFactory.getLogger(OLE2ScratchpadExtractorFactory.class);
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Look for certain entries in the stream, to figure it
|
* Look for certain entries in the stream, to figure it
|
||||||
* out what format is desired
|
* out what format is desired
|
||||||
|
@ -125,7 +130,16 @@ public class OLE2ScratchpadExtractorFactory {
|
||||||
throw new IllegalStateException("The extractor didn't know which POIFS it came from!");
|
throw new IllegalStateException("The extractor didn't know which POIFS it came from!");
|
||||||
}
|
}
|
||||||
|
|
||||||
if (ext instanceof WordExtractor) {
|
if (ext instanceof ExcelExtractor) {
|
||||||
|
// These are in MBD... under the root
|
||||||
|
Iterator<Entry> it = root.getEntries();
|
||||||
|
while (it.hasNext()) {
|
||||||
|
Entry entry = it.next();
|
||||||
|
if (entry.getName().startsWith("MBD")) {
|
||||||
|
dirs.add(entry);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
} else if (ext instanceof WordExtractor) {
|
||||||
// These are in ObjectPool -> _... under the root
|
// These are in ObjectPool -> _... under the root
|
||||||
try {
|
try {
|
||||||
DirectoryEntry op = (DirectoryEntry)
|
DirectoryEntry op = (DirectoryEntry)
|
||||||
|
@ -138,6 +152,7 @@ public class OLE2ScratchpadExtractorFactory {
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
} catch(FileNotFoundException e) {
|
} catch(FileNotFoundException e) {
|
||||||
|
logger.log(POILogger.INFO, "Ignoring FileNotFoundException while extracting Word document", e.getLocalizedMessage());
|
||||||
// ignored here
|
// ignored here
|
||||||
}
|
}
|
||||||
//} else if(ext instanceof PowerPointExtractor) {
|
//} else if(ext instanceof PowerPointExtractor) {
|
||||||
|
|
|
@ -63,7 +63,6 @@ public final class Notes extends SheetContainer
|
||||||
for(int i=0; i<_children.length; i++) {
|
for(int i=0; i<_children.length; i++) {
|
||||||
if(_children[i] instanceof NotesAtom) {
|
if(_children[i] instanceof NotesAtom) {
|
||||||
notesAtom = (NotesAtom)_children[i];
|
notesAtom = (NotesAtom)_children[i];
|
||||||
//System.out.println("Found notes for sheet " + notesAtom.getSlideID());
|
|
||||||
}
|
}
|
||||||
if(_children[i] instanceof PPDrawing) {
|
if(_children[i] instanceof PPDrawing) {
|
||||||
ppDrawing = (PPDrawing)_children[i];
|
ppDrawing = (PPDrawing)_children[i];
|
||||||
|
|
|
@ -18,6 +18,7 @@
|
||||||
package org.apache.poi.hmef;
|
package org.apache.poi.hmef;
|
||||||
|
|
||||||
import java.text.DateFormat;
|
import java.text.DateFormat;
|
||||||
|
import java.text.SimpleDateFormat;
|
||||||
import java.util.List;
|
import java.util.List;
|
||||||
import java.util.Locale;
|
import java.util.Locale;
|
||||||
|
|
||||||
|
@ -83,9 +84,7 @@ public final class TestAttachments extends HMEFTest {
|
||||||
List<Attachment> attachments = quick.getAttachments();
|
List<Attachment> attachments = quick.getAttachments();
|
||||||
|
|
||||||
// Pick a predictable date format + timezone
|
// Pick a predictable date format + timezone
|
||||||
DateFormat fmt = DateFormat.getDateTimeInstance(
|
DateFormat fmt = new SimpleDateFormat("dd-MMM-yyyy hh:mm:ss", Locale.UK);
|
||||||
DateFormat.MEDIUM, DateFormat.MEDIUM, Locale.UK
|
|
||||||
);
|
|
||||||
fmt.setTimeZone(LocaleUtil.TIMEZONE_UTC);
|
fmt.setTimeZone(LocaleUtil.TIMEZONE_UTC);
|
||||||
|
|
||||||
// They should all have the same date on them
|
// They should all have the same date on them
|
||||||
|
|
|
@ -20,6 +20,7 @@ package org.apache.poi.hmef.attribute;
|
||||||
import java.io.ByteArrayInputStream;
|
import java.io.ByteArrayInputStream;
|
||||||
import java.io.InputStream;
|
import java.io.InputStream;
|
||||||
import java.text.DateFormat;
|
import java.text.DateFormat;
|
||||||
|
import java.text.SimpleDateFormat;
|
||||||
import java.util.Locale;
|
import java.util.Locale;
|
||||||
|
|
||||||
import org.apache.poi.POIDataSamples;
|
import org.apache.poi.POIDataSamples;
|
||||||
|
@ -159,9 +160,7 @@ protected void tearDown() throws Exception {
|
||||||
assertEquals(MAPIDateAttribute.class, attr.getClass());
|
assertEquals(MAPIDateAttribute.class, attr.getClass());
|
||||||
|
|
||||||
MAPIDateAttribute date = (MAPIDateAttribute)attr;
|
MAPIDateAttribute date = (MAPIDateAttribute)attr;
|
||||||
DateFormat fmt = DateFormat.getDateTimeInstance(
|
DateFormat fmt = new SimpleDateFormat("dd-MMM-yyyy HH:mm:ss", Locale.UK);
|
||||||
DateFormat.MEDIUM, DateFormat.MEDIUM, Locale.UK
|
|
||||||
);
|
|
||||||
fmt.setTimeZone(LocaleUtil.TIMEZONE_UTC);
|
fmt.setTimeZone(LocaleUtil.TIMEZONE_UTC);
|
||||||
assertEquals("15-Dec-2010 14:46:31", fmt.format(date.getDate()));
|
assertEquals("15-Dec-2010 14:46:31", fmt.format(date.getDate()));
|
||||||
|
|
||||||
|
|
|
@ -19,6 +19,7 @@ package org.apache.poi.hmef.attribute;
|
||||||
|
|
||||||
import java.io.ByteArrayInputStream;
|
import java.io.ByteArrayInputStream;
|
||||||
import java.text.DateFormat;
|
import java.text.DateFormat;
|
||||||
|
import java.text.SimpleDateFormat;
|
||||||
import java.util.Locale;
|
import java.util.Locale;
|
||||||
|
|
||||||
import org.apache.poi.POIDataSamples;
|
import org.apache.poi.POIDataSamples;
|
||||||
|
@ -159,9 +160,7 @@ public final class TestTNEFAttributes extends TestCase {
|
||||||
// Ask for it as a Java date, and have it converted
|
// Ask for it as a Java date, and have it converted
|
||||||
// Pick a predictable format + location + timezone
|
// Pick a predictable format + location + timezone
|
||||||
TNEFDateAttribute date = (TNEFDateAttribute)attr;
|
TNEFDateAttribute date = (TNEFDateAttribute)attr;
|
||||||
DateFormat fmt = DateFormat.getDateTimeInstance(
|
DateFormat fmt = new SimpleDateFormat("dd-MMM-yyyy HH:mm:ss", Locale.UK);
|
||||||
DateFormat.MEDIUM, DateFormat.MEDIUM, Locale.UK
|
|
||||||
);
|
|
||||||
fmt.setTimeZone(LocaleUtil.TIMEZONE_UTC);
|
fmt.setTimeZone(LocaleUtil.TIMEZONE_UTC);
|
||||||
assertEquals("28-Apr-2010 12:40:56", fmt.format(date.getDate()));
|
assertEquals("28-Apr-2010 12:40:56", fmt.format(date.getDate()));
|
||||||
}
|
}
|
||||||
|
|
|
@ -30,6 +30,12 @@ import org.apache.poi.POIDataSamples;
|
||||||
import org.apache.poi.hslf.HSLFTestDataSamples;
|
import org.apache.poi.hslf.HSLFTestDataSamples;
|
||||||
import org.apache.poi.hslf.usermodel.HSLFSlide;
|
import org.apache.poi.hslf.usermodel.HSLFSlide;
|
||||||
import org.apache.poi.hslf.usermodel.HSLFSlideShow;
|
import org.apache.poi.hslf.usermodel.HSLFSlideShow;
|
||||||
|
import org.apache.poi.hslf.usermodel.HSLFTextParagraph;
|
||||||
|
import org.apache.poi.sl.usermodel.Shape;
|
||||||
|
import org.apache.poi.sl.usermodel.Slide;
|
||||||
|
import org.apache.poi.sl.usermodel.SlideShow;
|
||||||
|
import org.apache.poi.sl.usermodel.TextParagraph;
|
||||||
|
import org.apache.poi.sl.usermodel.TextShape;
|
||||||
import org.junit.Test;
|
import org.junit.Test;
|
||||||
|
|
||||||
/**
|
/**
|
||||||
|
@ -228,4 +234,45 @@ public final class TestHeadersFooters
|
||||||
ppt2.close();
|
ppt2.close();
|
||||||
ppt1.close();
|
ppt1.close();
|
||||||
}
|
}
|
||||||
|
@Test
|
||||||
|
public void bug58144a() throws IOException {
|
||||||
|
try (InputStream is = _slTests.openResourceAsStream("bug58144-headers-footers-2003.ppt");
|
||||||
|
SlideShow<?,?> ppt = new HSLFSlideShow(is)) {
|
||||||
|
HSLFSlide sl = (HSLFSlide) ppt.getSlides().get(0);
|
||||||
|
HeadersFooters hfs = sl.getHeadersFooters();
|
||||||
|
assertNull(hfs.getHeaderText());
|
||||||
|
assertEquals("Confidential", hfs.getFooterText());
|
||||||
|
List<List<HSLFTextParagraph>> llp = sl.getTextParagraphs();
|
||||||
|
assertEquals("Test", HSLFTextParagraph.getText(llp.get(0)));
|
||||||
|
assertFalse(llp.get(0).get(0).isHeaderOrFooter());
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
@Test
|
||||||
|
public void bug58144b() throws IOException {
|
||||||
|
try (InputStream is = _slTests.openResourceAsStream("bug58144-headers-footers-2007.ppt");
|
||||||
|
SlideShow<?,?> ppt = new HSLFSlideShow(is)) {
|
||||||
|
Slide<?, ?> sl = ppt.getSlides().get(0);
|
||||||
|
HeadersFooters hfs2 = ((HSLFSlide) sl).getHeadersFooters();
|
||||||
|
assertNull(hfs2.getHeaderText());
|
||||||
|
assertEquals("Slide footer", hfs2.getFooterText());
|
||||||
|
|
||||||
|
testSlideShow(ppt);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
// copied from org.apache.poi.sl.TestHeadersFooters because of scratchpad.ignore option
|
||||||
|
private void testSlideShow(SlideShow<?,?> ppt) {
|
||||||
|
Slide<?,?> sl = ppt.getSlides().get(0);
|
||||||
|
|
||||||
|
List<? extends Shape<?,?>> shapes = sl.getShapes();
|
||||||
|
TextShape<?,?> ts0 = (TextShape<?,?>)shapes.get(0);
|
||||||
|
assertEquals("Test file", ts0.getText());
|
||||||
|
TextShape<?,?> ts1 = (TextShape<?,?>)shapes.get(1);
|
||||||
|
assertEquals("Has some text in the headers and footers", ts1.getText());
|
||||||
|
TextShape<?,?> ts2 = (TextShape<?,?>)shapes.get(2);
|
||||||
|
assertEquals("Slide footer", ts2.getText());
|
||||||
|
List<? extends TextParagraph<?,?,?>> ltp = ts2.getTextParagraphs();
|
||||||
|
assertTrue(ltp.get(0).isHeaderOrFooter());
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
|
|
@ -206,7 +206,7 @@ public final class POIDataSamples {
|
||||||
}
|
}
|
||||||
File dataDir = new File(dataDirName, _moduleDir);
|
File dataDir = new File(dataDirName, _moduleDir);
|
||||||
if (!dataDir.exists()) {
|
if (!dataDir.exists()) {
|
||||||
throw new RuntimeException("Data dir '" + _moduleDir + "' does not exist");
|
throw new RuntimeException("Data dir '" + dataDir + "' does not exist");
|
||||||
}
|
}
|
||||||
// convert to canonical file, to make any subsequent error messages
|
// convert to canonical file, to make any subsequent error messages
|
||||||
// clearer.
|
// clearer.
|
||||||
|
|
|
@ -19,6 +19,7 @@ package org.apache.poi.hssf.usermodel;
|
||||||
|
|
||||||
import java.awt.image.BufferedImage;
|
import java.awt.image.BufferedImage;
|
||||||
import java.io.ByteArrayInputStream;
|
import java.io.ByteArrayInputStream;
|
||||||
|
import java.io.File;
|
||||||
import java.io.IOException;
|
import java.io.IOException;
|
||||||
import java.util.List;
|
import java.util.List;
|
||||||
|
|
||||||
|
@ -27,6 +28,7 @@ import javax.imageio.ImageIO;
|
||||||
import junit.framework.TestCase;
|
import junit.framework.TestCase;
|
||||||
|
|
||||||
import org.apache.poi.hssf.HSSFTestDataSamples;
|
import org.apache.poi.hssf.HSSFTestDataSamples;
|
||||||
|
import org.junit.BeforeClass;
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Test <code>HSSFPictureData</code>.
|
* Test <code>HSSFPictureData</code>.
|
||||||
|
@ -36,7 +38,19 @@ import org.apache.poi.hssf.HSSFTestDataSamples;
|
||||||
* @author Trejkaz (trejkaz at trypticon dot org)
|
* @author Trejkaz (trejkaz at trypticon dot org)
|
||||||
*/
|
*/
|
||||||
public final class TestHSSFPictureData extends TestCase{
|
public final class TestHSSFPictureData extends TestCase{
|
||||||
|
@BeforeClass
|
||||||
|
public static void setUpClass() {
|
||||||
|
final String tmpDirProperty = System.getProperty("java.io.tmpdir");
|
||||||
|
if(tmpDirProperty == null || "".equals(tmpDirProperty)) {
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
// ensure that temp-dir exists because ImageIO requires it
|
||||||
|
final File tmpDir = new File(tmpDirProperty);
|
||||||
|
if(!tmpDir.exists() && !tmpDir.mkdirs()) {
|
||||||
|
throw new IllegalStateException("Could not create temporary directory " + tmpDirProperty + ", full path " + tmpDir.getAbsolutePath());
|
||||||
|
}
|
||||||
|
ImageIO.setCacheDirectory(tmpDir);
|
||||||
|
}
|
||||||
|
|
||||||
public void testPictures() throws IOException {
|
public void testPictures() throws IOException {
|
||||||
HSSFWorkbook wb = HSSFTestDataSamples.openSampleWorkbook("SimpleWithImages.xls");
|
HSSFWorkbook wb = HSSFTestDataSamples.openSampleWorkbook("SimpleWithImages.xls");
|
||||||
|
@ -64,8 +78,8 @@ public final class TestHSSFPictureData extends TestCase{
|
||||||
assertEquals(300, png.getHeight());
|
assertEquals(300, png.getHeight());
|
||||||
assertEquals(HSSFWorkbook.PICTURE_TYPE_PNG, pict.getFormat());
|
assertEquals(HSSFWorkbook.PICTURE_TYPE_PNG, pict.getFormat());
|
||||||
assertEquals("image/png", pict.getMimeType());
|
assertEquals("image/png", pict.getMimeType());
|
||||||
} else {
|
/*} else {
|
||||||
//TODO: test code for PICT, WMF and EMF
|
//TODO: test code for PICT, WMF and EMF*/
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
@ -93,7 +107,7 @@ public final class TestHSSFPictureData extends TestCase{
|
||||||
assertEquals("image/png", pict.getMimeType());
|
assertEquals("image/png", pict.getMimeType());
|
||||||
}
|
}
|
||||||
|
|
||||||
public void testNotNullPictures() throws IOException {
|
public void testNotNullPictures() {
|
||||||
|
|
||||||
HSSFWorkbook wb = HSSFTestDataSamples.openSampleWorkbook("SheetWithDrawing.xls");
|
HSSFWorkbook wb = HSSFTestDataSamples.openSampleWorkbook("SheetWithDrawing.xls");
|
||||||
|
|
||||||
|
@ -103,5 +117,4 @@ public final class TestHSSFPictureData extends TestCase{
|
||||||
assertNotNull(pict);
|
assertNotNull(pict);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
}
|
}
|
||||||
|
|
|
@ -18,124 +18,122 @@
|
||||||
package org.apache.poi.ss.usermodel;
|
package org.apache.poi.ss.usermodel;
|
||||||
|
|
||||||
import static org.junit.Assert.assertEquals;
|
import static org.junit.Assert.assertEquals;
|
||||||
|
import static org.junit.Assert.assertNotNull;
|
||||||
|
import static org.junit.Assert.assertTrue;
|
||||||
|
|
||||||
import java.text.DateFormatSymbols;
|
import java.text.DateFormatSymbols;
|
||||||
import java.text.FieldPosition;
|
import java.text.FieldPosition;
|
||||||
import java.text.ParseException;
|
import java.text.ParseException;
|
||||||
import java.text.SimpleDateFormat;
|
import java.text.SimpleDateFormat;
|
||||||
import java.util.Arrays;
|
|
||||||
import java.util.Date;
|
import java.util.Date;
|
||||||
import java.util.HashMap;
|
import java.util.HashMap;
|
||||||
import java.util.List;
|
import java.util.List;
|
||||||
import java.util.Locale;
|
import java.util.Locale;
|
||||||
import java.util.Map;
|
import java.util.Map;
|
||||||
|
import java.util.stream.Collectors;
|
||||||
|
import java.util.stream.Stream;
|
||||||
|
|
||||||
import org.apache.poi.util.LocaleUtil;
|
import org.apache.poi.util.LocaleUtil;
|
||||||
import org.junit.Test;
|
import org.junit.Test;
|
||||||
|
|
||||||
public class TestExcelStyleDateFormatter {
|
public class TestExcelStyleDateFormatter {
|
||||||
private static final String EXCEL_DATE_FORMAT = "MMMMM";
|
private static final String EXCEL_DATE_FORMAT = "MMMMM";
|
||||||
|
private static final SimpleDateFormat DATE_FORMAT = new SimpleDateFormat("yyyy-MM-dd", Locale.ROOT);
|
||||||
|
private final int jreVersion;
|
||||||
|
|
||||||
|
public TestExcelStyleDateFormatter() {
|
||||||
|
jreVersion = Integer.parseInt(System.getProperty("java.version")
|
||||||
|
.replace("1.8", "8").replaceAll("(\\d+).*", "$1"));
|
||||||
|
}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* [Bug 60369] Month format 'MMMMM' issue with TEXT-formula and Java 8
|
* [Bug 60369] Month format 'MMMMM' issue with TEXT-formula and Java 8
|
||||||
*/
|
*/
|
||||||
@Test
|
@Test
|
||||||
public void test60369() throws ParseException {
|
public void test60369() {
|
||||||
Map<Locale, List<String>> testMap = initializeLocales();
|
Map<Locale, String> testMap = initializeLocales();
|
||||||
|
|
||||||
// We have to set up dates as well.
|
// We have to set up dates as well.
|
||||||
SimpleDateFormat testDateFormat = new SimpleDateFormat("dd.MM.yyyy", Locale.ROOT);
|
List<Date> testDates = Stream.of("1980-01-12", "1995-02-11", "2045-03-10", "2016-04-09", "2017-05-08",
|
||||||
List<Date> testDates = Arrays.asList(
|
"1945-06-07", "1998-07-06", "2099-08-05", "1988-09-04", "2023-10-03", "1978-11-02", "1890-12-01")
|
||||||
testDateFormat.parse("12.01.1980"),
|
.map(this::parseDate).collect(Collectors.toList());
|
||||||
testDateFormat.parse("11.02.1995"),
|
|
||||||
testDateFormat.parse("10.03.2045"),
|
|
||||||
testDateFormat.parse("09.04.2016"),
|
|
||||||
testDateFormat.parse("08.05.2017"),
|
|
||||||
testDateFormat.parse("07.06.1945"),
|
|
||||||
testDateFormat.parse("06.07.1998"),
|
|
||||||
testDateFormat.parse("05.08.2099"),
|
|
||||||
testDateFormat.parse("04.09.1988"),
|
|
||||||
testDateFormat.parse("03.10.2023"),
|
|
||||||
testDateFormat.parse("02.11.1978"),
|
|
||||||
testDateFormat.parse("01.12.1890"));
|
|
||||||
|
|
||||||
// Let's iterate over the test setup.
|
// Let's iterate over the test setup.
|
||||||
for (Locale locale : testMap.keySet()) {
|
final String provider = System.getProperty("java.locale.providers");
|
||||||
ExcelStyleDateFormatter formatter = new ExcelStyleDateFormatter(EXCEL_DATE_FORMAT, new DateFormatSymbols(locale));
|
final FieldPosition fp = new FieldPosition(java.text.DateFormat.MONTH_FIELD);
|
||||||
for (int i = 0; i < testDates.size(); i++) {
|
final ExcelStyleDateFormatter formatter = new ExcelStyleDateFormatter(EXCEL_DATE_FORMAT);
|
||||||
// Call the method to be tested!
|
final StringBuffer sb = new StringBuffer();
|
||||||
String result =
|
|
||||||
formatter.format(testDates.get(i),
|
for (Map.Entry<Locale,String> me : testMap.entrySet()) {
|
||||||
new StringBuffer(),
|
final Locale locale = me.getKey();
|
||||||
new FieldPosition(java.text.DateFormat.MONTH_FIELD)).toString();
|
final String expected = me.getValue();
|
||||||
//System.err.println(result + " - " + getUnicode(result.charAt(0)));
|
formatter.setDateFormatSymbols(DateFormatSymbols.getInstance(locale));
|
||||||
assertEquals("Failed for locale " + locale + ", provider: " + System.getProperty("java.locale.providers") +
|
int month = 0;
|
||||||
" and date " + testDates.get(i) + ", having: " + result,
|
for (Date d : testDates) {
|
||||||
getUnicode(testMap.get(locale).get(i).charAt(0)), getUnicode(result.charAt(0)));
|
sb.setLength(0);
|
||||||
|
String result = formatter.format(d, sb, fp).toString();
|
||||||
|
String msg = "Failed testDates for locale " + locale + ", provider: " + provider +
|
||||||
|
" and date " + d + ", having: " + result;
|
||||||
|
|
||||||
|
int actIdx = localeIndex(locale);
|
||||||
|
|
||||||
|
assertNotNull(msg, result);
|
||||||
|
assertTrue(msg, result.length() > actIdx);
|
||||||
|
assertEquals(msg, expected.charAt(month), result.charAt(actIdx));
|
||||||
|
month++;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
private Map<Locale, List<String>> initializeLocales() {
|
/**
|
||||||
// Setting up the locale to be tested together with a list of asserted unicode-formatted results and put them in a map.
|
* Depending on the JRE version, the provider setting and the locale, a different result
|
||||||
Locale germanLocale = Locale.GERMAN;
|
* is expected and selected via an index
|
||||||
List<String> germanResultList = Arrays.asList("\u004a", "\u0046", "\u004d", "\u0041", "\u004d",
|
*/
|
||||||
"\u004a", "\u004a", "\u0041", "\u0053", "\u004f", "\u004e", "\u0044");
|
private int localeIndex(Locale locale) {
|
||||||
|
final String provider = System.getProperty("java.locale.providers");
|
||||||
Locale russianLocale = new Locale("ru", "RU");
|
return jreVersion < 12 ||
|
||||||
List<String> russianResultList = Arrays.asList("\u044f", "\u0444", "\u043c", "\u0430", "\u043c",
|
!locale.equals (Locale.CHINESE) ||
|
||||||
"\u0438", "\u0438", "\u0430", "\u0441", "\u043e", "\u043d", "\u0434");
|
(provider != null && provider.startsWith("JRE"))
|
||||||
|
? 0 : 1;
|
||||||
Locale austrianLocale = new Locale("de", "AT");
|
|
||||||
List<String> austrianResultList = Arrays.asList("\u004a", "\u0046", "\u004d", "\u0041", "\u004d",
|
|
||||||
"\u004a", "\u004a", "\u0041", "\u0053", "\u004f", "\u004e", "\u0044");
|
|
||||||
|
|
||||||
Locale englishLocale = Locale.UK;
|
|
||||||
List<String> englishResultList = Arrays.asList("\u004a", "\u0046", "\u004d", "\u0041", "\u004d",
|
|
||||||
"\u004a", "\u004a", "\u0041", "\u0053", "\u004f", "\u004e", "\u0044");
|
|
||||||
|
|
||||||
Locale frenchLocale = Locale.FRENCH;
|
|
||||||
List<String> frenchResultList = Arrays.asList("\u006a", "\u0066", "\u006d", "\u0061", "\u006d",
|
|
||||||
"\u006a", "\u006a", "\u0061", "\u0073", "\u006f", "\u006e", "\u0064");
|
|
||||||
|
|
||||||
Locale chineseLocale = Locale.CHINESE;
|
|
||||||
List<String> chineseResultList = Arrays.asList("\u4e00", "\u4e8c", "\u4e09", "\u56db", "\u4e94",
|
|
||||||
"\u516d", "\u4e03", "\u516b", "\u4e5d", "\u5341", "\u5341", "\u5341");
|
|
||||||
|
|
||||||
Locale turkishLocale = new Locale("tr", "TR");
|
|
||||||
List<String> turkishResultList = Arrays.asList("\u004f", "\u015e", "\u004d", "\u004e", "\u004d",
|
|
||||||
"\u0048", "\u0054", "\u0041", "\u0045", "\u0045", "\u004b", "\u0041");
|
|
||||||
|
|
||||||
Locale hungarianLocale = new Locale("hu", "HU");
|
|
||||||
List<String> hungarianResultList = Arrays.asList("\u006a", "\u0066", "\u006d", "\u00e1", "\u006d",
|
|
||||||
"\u006a", "\u006a", "\u0061", "\u0073", "\u006f", "\u006e", "\u0064");
|
|
||||||
|
|
||||||
Locale indianLocale = new Locale("en", "IN");
|
|
||||||
List<String> indianResultList = Arrays.asList("\u004a", "\u0046", "\u004d", "\u0041", "\u004d",
|
|
||||||
"\u004a", "\u004a", "\u0041", "\u0053", "\u004f", "\u004e", "\u0044");
|
|
||||||
|
|
||||||
Locale indonesianLocale = new Locale("in", "ID");
|
|
||||||
List<String> indonesianResultList = Arrays.asList("\u004a", "\u0046", "\u004d", "\u0041", "\u004d",
|
|
||||||
"\u004a", "\u004a", "\u0041", "\u0053", "\u004f", "\u004e", "\u0044");
|
|
||||||
|
|
||||||
|
|
||||||
Map<Locale, List<String>> testMap = new HashMap<>();
|
|
||||||
testMap.put(germanLocale, germanResultList);
|
|
||||||
testMap.put(russianLocale, russianResultList);
|
|
||||||
testMap.put(austrianLocale, austrianResultList);
|
|
||||||
testMap.put(englishLocale, englishResultList);
|
|
||||||
testMap.put(frenchLocale, frenchResultList);
|
|
||||||
testMap.put(chineseLocale, chineseResultList);
|
|
||||||
testMap.put(turkishLocale, turkishResultList);
|
|
||||||
testMap.put(hungarianLocale, hungarianResultList);
|
|
||||||
testMap.put(indianLocale, indianResultList);
|
|
||||||
testMap.put(indonesianLocale, indonesianResultList);
|
|
||||||
|
|
||||||
return testMap;
|
|
||||||
}
|
}
|
||||||
|
|
||||||
private String getUnicode(char c) {
|
private Date parseDate(String dateStr) {
|
||||||
return "\\u" + Integer.toHexString(c | 0x10000).substring(1);
|
try {
|
||||||
|
return DATE_FORMAT.parse(dateStr);
|
||||||
|
} catch (ParseException e) {
|
||||||
|
return new Date(0);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Setting up the locale to be tested together with a list of asserted
|
||||||
|
* unicode-formatted results and put them in a map.
|
||||||
|
*/
|
||||||
|
private Map<Locale, String> initializeLocales() {
|
||||||
|
Map<Locale, String> testMap = new HashMap<>();
|
||||||
|
|
||||||
|
testMap.put(Locale.GERMAN, "JFMAMJJASOND");
|
||||||
|
testMap.put(new Locale("de", "AT"), "JFMAMJJASOND");
|
||||||
|
testMap.put(Locale.UK, "JFMAMJJASOND");
|
||||||
|
testMap.put(new Locale("en", "IN"), "JFMAMJJASOND");
|
||||||
|
testMap.put(new Locale("in", "ID"), "JFMAMJJASOND");
|
||||||
|
testMap.put(Locale.FRENCH, "jfmamjjasond");
|
||||||
|
|
||||||
|
testMap.put(new Locale("ru", "RU"),
|
||||||
|
"\u044f\u0444\u043c\u0430\u043c\u0438\u0438\u0430\u0441\u043e\u043d\u0434");
|
||||||
|
|
||||||
|
testMap.put(Locale.CHINESE, new String[]{
|
||||||
|
"\u4e00\u4e8c\u4e09\u56db\u4e94\u516d\u4e03\u516b\u4e5d\u5341\u5341\u5341",
|
||||||
|
"123456789111"
|
||||||
|
}[localeIndex(Locale.CHINESE)]);
|
||||||
|
|
||||||
|
testMap.put(new Locale("tr", "TR"),
|
||||||
|
"\u004f\u015e\u004d\u004e\u004d\u0048\u0054\u0041\u0045\u0045\u004b\u0041");
|
||||||
|
|
||||||
|
testMap.put(new Locale("hu", "HU"),
|
||||||
|
"\u006a\u0066\u006d\u00e1\u006d\u006a\u006a\u0061\u0073\u006f\u006e\u0064");
|
||||||
|
|
||||||
|
return testMap;
|
||||||
}
|
}
|
||||||
|
|
||||||
@Test
|
@Test
|
||||||
|
@ -150,7 +148,7 @@ public class TestExcelStyleDateFormatter {
|
||||||
try {
|
try {
|
||||||
LocaleUtil.setUserLocale(Locale.GERMAN);
|
LocaleUtil.setUserLocale(Locale.GERMAN);
|
||||||
String dateStr = new ExcelStyleDateFormatter(EXCEL_DATE_FORMAT).format(
|
String dateStr = new ExcelStyleDateFormatter(EXCEL_DATE_FORMAT).format(
|
||||||
new SimpleDateFormat("yyyy-MM-dd", Locale.ROOT).parse("2016-03-26"));
|
DATE_FORMAT.parse("2016-03-26"));
|
||||||
assertEquals("M", dateStr);
|
assertEquals("M", dateStr);
|
||||||
} finally {
|
} finally {
|
||||||
LocaleUtil.setUserLocale(before);
|
LocaleUtil.setUserLocale(before);
|
||||||
|
@ -160,7 +158,7 @@ public class TestExcelStyleDateFormatter {
|
||||||
@Test
|
@Test
|
||||||
public void testWithPattern() throws ParseException {
|
public void testWithPattern() throws ParseException {
|
||||||
String dateStr = new ExcelStyleDateFormatter("yyyy|" + EXCEL_DATE_FORMAT + "|").format(
|
String dateStr = new ExcelStyleDateFormatter("yyyy|" + EXCEL_DATE_FORMAT + "|").format(
|
||||||
new SimpleDateFormat("yyyy-MM-dd", Locale.ROOT).parse("2016-03-26"));
|
DATE_FORMAT.parse("2016-03-26"));
|
||||||
assertEquals("2016|M|", dateStr);
|
assertEquals("2016|M|", dateStr);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
Binary file not shown.
Loading…
Reference in New Issue