mirror of https://github.com/apache/poi.git
fix eclipse warnings
close resources git-svn-id: https://svn.apache.org/repos/asf/poi/trunk@1735912 13f79535-47bb-0310-9956-ffa450edef68
This commit is contained in:
parent
e826364ac2
commit
fe653de0e6
|
@ -28,7 +28,6 @@ import java.io.InputStream;
|
|||
import java.io.OutputStream;
|
||||
import java.io.UnsupportedEncodingException;
|
||||
import java.util.HashMap;
|
||||
import java.util.Iterator;
|
||||
import java.util.Map;
|
||||
|
||||
import org.apache.poi.hpsf.HPSFRuntimeException;
|
||||
|
@ -109,20 +108,15 @@ public class CopyCompare
|
|||
String copyFileName = null;
|
||||
|
||||
/* Check the command-line arguments. */
|
||||
if (args.length == 1)
|
||||
{
|
||||
if (args.length == 1) {
|
||||
originalFileName = args[0];
|
||||
File f = TempFile.createTempFile("CopyOfPOIFileSystem-", ".ole2");
|
||||
f.deleteOnExit();
|
||||
copyFileName = f.getAbsolutePath();
|
||||
}
|
||||
else if (args.length == 2)
|
||||
{
|
||||
} else if (args.length == 2) {
|
||||
originalFileName = args[0];
|
||||
copyFileName = args[1];
|
||||
}
|
||||
else
|
||||
{
|
||||
} else {
|
||||
System.err.println("Usage: " + CopyCompare.class.getName() +
|
||||
"originPOIFS [copyPOIFS]");
|
||||
System.exit(1);
|
||||
|
@ -133,25 +127,28 @@ public class CopyCompare
|
|||
final POIFSReader r = new POIFSReader();
|
||||
final CopyFile cf = new CopyFile(copyFileName);
|
||||
r.registerListener(cf);
|
||||
r.read(new FileInputStream(originalFileName));
|
||||
FileInputStream fis = new FileInputStream(originalFileName);
|
||||
r.read(fis);
|
||||
fis.close();
|
||||
|
||||
/* Write the new POIFS to disk. */
|
||||
cf.close();
|
||||
|
||||
/* Read all documents from the original POI file system and compare them
|
||||
* with the equivalent document from the copy. */
|
||||
final POIFSFileSystem opfs =
|
||||
new POIFSFileSystem(new FileInputStream(originalFileName));
|
||||
final POIFSFileSystem cpfs =
|
||||
new POIFSFileSystem(new FileInputStream(copyFileName));
|
||||
final POIFSFileSystem opfs = new POIFSFileSystem(new File(originalFileName));
|
||||
final POIFSFileSystem cpfs = new POIFSFileSystem(new File(copyFileName));
|
||||
|
||||
final DirectoryEntry oRoot = opfs.getRoot();
|
||||
final DirectoryEntry cRoot = cpfs.getRoot();
|
||||
final StringBuffer messages = new StringBuffer();
|
||||
if (equal(oRoot, cRoot, messages))
|
||||
if (equal(oRoot, cRoot, messages)) {
|
||||
System.out.println("Equal");
|
||||
else
|
||||
} else {
|
||||
System.out.println("Not equal: " + messages.toString());
|
||||
}
|
||||
cpfs.close();
|
||||
opfs.close();
|
||||
}
|
||||
|
||||
|
||||
|
@ -183,29 +180,23 @@ public class CopyCompare
|
|||
{
|
||||
boolean equal = true;
|
||||
/* Iterate over d1 and compare each entry with its counterpart in d2. */
|
||||
for (final Iterator i = d1.getEntries(); equal && i.hasNext();)
|
||||
{
|
||||
final Entry e1 = (Entry) i.next();
|
||||
for (final Entry e1 : d1) {
|
||||
final String n1 = e1.getName();
|
||||
Entry e2 = null;
|
||||
try
|
||||
{
|
||||
try {
|
||||
e2 = d2.getEntry(n1);
|
||||
}
|
||||
catch (FileNotFoundException ex)
|
||||
{
|
||||
} catch (FileNotFoundException ex) {
|
||||
msg.append("Document \"" + e1 + "\" exists, document \"" +
|
||||
e2 + "\" does not.\n");
|
||||
equal = false;
|
||||
break;
|
||||
}
|
||||
|
||||
if (e1.isDirectoryEntry() && e2.isDirectoryEntry())
|
||||
if (e1.isDirectoryEntry() && e2.isDirectoryEntry()) {
|
||||
equal = equal((DirectoryEntry) e1, (DirectoryEntry) e2, msg);
|
||||
else if (e1.isDocumentEntry() && e2.isDocumentEntry())
|
||||
} else if (e1.isDocumentEntry() && e2.isDocumentEntry()) {
|
||||
equal = equal((DocumentEntry) e1, (DocumentEntry) e2, msg);
|
||||
else
|
||||
{
|
||||
} else {
|
||||
msg.append("One of \"" + e1 + "\" and \"" + e2 + "\" is a " +
|
||||
"document while the other one is a directory.\n");
|
||||
equal = false;
|
||||
|
@ -214,17 +205,12 @@ public class CopyCompare
|
|||
|
||||
/* Iterate over d2 just to make sure that there are no entries in d2
|
||||
* that are not in d1. */
|
||||
for (final Iterator i = d2.getEntries(); equal && i.hasNext();)
|
||||
{
|
||||
final Entry e2 = (Entry) i.next();
|
||||
for (final Entry e2 : d2) {
|
||||
final String n2 = e2.getName();
|
||||
Entry e1 = null;
|
||||
try
|
||||
{
|
||||
try {
|
||||
e1 = d1.getEntry(n2);
|
||||
}
|
||||
catch (FileNotFoundException ex)
|
||||
{
|
||||
} catch (FileNotFoundException ex) {
|
||||
msg.append("Document \"" + e2 + "\" exitsts, document \"" +
|
||||
e1 + "\" does not.\n");
|
||||
equal = false;
|
||||
|
@ -263,34 +249,32 @@ public class CopyCompare
|
|||
boolean equal = true;
|
||||
final DocumentInputStream dis1 = new DocumentInputStream(d1);
|
||||
final DocumentInputStream dis2 = new DocumentInputStream(d2);
|
||||
if (PropertySet.isPropertySetStream(dis1) &&
|
||||
PropertySet.isPropertySetStream(dis2))
|
||||
{
|
||||
final PropertySet ps1 = PropertySetFactory.create(dis1);
|
||||
final PropertySet ps2 = PropertySetFactory.create(dis2);
|
||||
equal = ps1.equals(ps2);
|
||||
if (!equal)
|
||||
{
|
||||
msg.append("Property sets are not equal.\n");
|
||||
return equal;
|
||||
}
|
||||
}
|
||||
else
|
||||
{
|
||||
int i1;
|
||||
int i2;
|
||||
do
|
||||
{
|
||||
i1 = dis1.read();
|
||||
i2 = dis2.read();
|
||||
if (i1 != i2)
|
||||
{
|
||||
equal = false;
|
||||
msg.append("Documents are not equal.\n");
|
||||
break;
|
||||
try {
|
||||
if (PropertySet.isPropertySetStream(dis1) &&
|
||||
PropertySet.isPropertySetStream(dis2)) {
|
||||
final PropertySet ps1 = PropertySetFactory.create(dis1);
|
||||
final PropertySet ps2 = PropertySetFactory.create(dis2);
|
||||
equal = ps1.equals(ps2);
|
||||
if (!equal) {
|
||||
msg.append("Property sets are not equal.\n");
|
||||
return equal;
|
||||
}
|
||||
} else {
|
||||
int i1;
|
||||
int i2;
|
||||
do {
|
||||
i1 = dis1.read();
|
||||
i2 = dis2.read();
|
||||
if (i1 != i2) {
|
||||
equal = false;
|
||||
msg.append("Documents are not equal.\n");
|
||||
break;
|
||||
}
|
||||
} while (equal && i1 == -1);
|
||||
}
|
||||
while (equal && i1 == -1);
|
||||
} finally {
|
||||
dis2.close();
|
||||
dis1.close();
|
||||
}
|
||||
return true;
|
||||
}
|
||||
|
@ -306,8 +290,7 @@ public class CopyCompare
|
|||
* original property set by using the {@link
|
||||
* MutablePropertySet#MutablePropertySet(PropertySet)} constructor.</p>
|
||||
*/
|
||||
static class CopyFile implements POIFSReaderListener
|
||||
{
|
||||
static class CopyFile implements POIFSReaderListener {
|
||||
String dstName;
|
||||
OutputStream out;
|
||||
POIFSFileSystem poiFs;
|
||||
|
@ -321,8 +304,7 @@ public class CopyCompare
|
|||
* @param dstName The name of the disk file the destination POIFS is to
|
||||
* be written to.
|
||||
*/
|
||||
public CopyFile(final String dstName)
|
||||
{
|
||||
public CopyFile(final String dstName) {
|
||||
this.dstName = dstName;
|
||||
poiFs = new POIFSFileSystem();
|
||||
}
|
||||
|
@ -332,8 +314,7 @@ public class CopyCompare
|
|||
* <p>The method is called by POI's eventing API for each file in the
|
||||
* origin POIFS.</p>
|
||||
*/
|
||||
public void processPOIFSReaderEvent(final POIFSReaderEvent event)
|
||||
{
|
||||
public void processPOIFSReaderEvent(final POIFSReaderEvent event) {
|
||||
/* The following declarations are shortcuts for accessing the
|
||||
* "event" object. */
|
||||
final POIFSDocumentPath path = event.getPath();
|
||||
|
@ -342,21 +323,16 @@ public class CopyCompare
|
|||
|
||||
Throwable t = null;
|
||||
|
||||
try
|
||||
{
|
||||
try {
|
||||
/* Find out whether the current document is a property set
|
||||
* stream or not. */
|
||||
if (PropertySet.isPropertySetStream(stream))
|
||||
{
|
||||
if (PropertySet.isPropertySetStream(stream)) {
|
||||
/* Yes, the current document is a property set stream.
|
||||
* Let's create a PropertySet instance from it. */
|
||||
PropertySet ps = null;
|
||||
try
|
||||
{
|
||||
try {
|
||||
ps = PropertySetFactory.create(stream);
|
||||
}
|
||||
catch (NoPropertySetStreamException ex)
|
||||
{
|
||||
} catch (NoPropertySetStreamException ex) {
|
||||
/* This exception will not be thrown because we already
|
||||
* checked above. */
|
||||
}
|
||||
|
@ -364,22 +340,16 @@ public class CopyCompare
|
|||
/* Copy the property set to the destination POI file
|
||||
* system. */
|
||||
copy(poiFs, path, name, ps);
|
||||
}
|
||||
else
|
||||
} else {
|
||||
/* No, the current document is not a property set stream. We
|
||||
* copy it unmodified to the destination POIFS. */
|
||||
copy(poiFs, event.getPath(), event.getName(), stream);
|
||||
}
|
||||
catch (MarkUnsupportedException ex)
|
||||
{
|
||||
}
|
||||
} catch (MarkUnsupportedException ex) {
|
||||
t = ex;
|
||||
}
|
||||
catch (IOException ex)
|
||||
{
|
||||
} catch (IOException ex) {
|
||||
t = ex;
|
||||
}
|
||||
catch (WritingNotSupportedException ex)
|
||||
{
|
||||
} catch (WritingNotSupportedException ex) {
|
||||
t = ex;
|
||||
}
|
||||
|
||||
|
@ -388,8 +358,7 @@ public class CopyCompare
|
|||
* lines check whether a checked exception occured and throws an
|
||||
* unchecked exception. The message of that exception is that of
|
||||
* the underlying checked exception. */
|
||||
if (t != null)
|
||||
{
|
||||
if (t != null) {
|
||||
throw new HPSFRuntimeException
|
||||
("Could not read file \"" + path + "/" + name +
|
||||
"\". Reason: " + Util.toString(t));
|
||||
|
@ -412,8 +381,7 @@ public class CopyCompare
|
|||
final POIFSDocumentPath path,
|
||||
final String name,
|
||||
final PropertySet ps)
|
||||
throws WritingNotSupportedException, IOException
|
||||
{
|
||||
throws WritingNotSupportedException, IOException {
|
||||
final DirectoryEntry de = getPath(poiFs, path);
|
||||
final MutablePropertySet mps = new MutablePropertySet(ps);
|
||||
de.createDocument(name, mps.toInputStream());
|
||||
|
@ -434,13 +402,14 @@ public class CopyCompare
|
|||
public void copy(final POIFSFileSystem poiFs,
|
||||
final POIFSDocumentPath path,
|
||||
final String name,
|
||||
final DocumentInputStream stream) throws IOException
|
||||
{
|
||||
final DocumentInputStream stream)
|
||||
throws IOException {
|
||||
final DirectoryEntry de = getPath(poiFs, path);
|
||||
final ByteArrayOutputStream out = new ByteArrayOutputStream();
|
||||
int c;
|
||||
while ((c = stream.read()) != -1)
|
||||
while ((c = stream.read()) != -1) {
|
||||
out.write(c);
|
||||
}
|
||||
stream.close();
|
||||
out.close();
|
||||
final InputStream in =
|
||||
|
@ -455,8 +424,7 @@ public class CopyCompare
|
|||
* @throws FileNotFoundException
|
||||
* @throws IOException
|
||||
*/
|
||||
public void close() throws FileNotFoundException, IOException
|
||||
{
|
||||
public void close() throws FileNotFoundException, IOException {
|
||||
out = new FileOutputStream(dstName);
|
||||
poiFs.writeFilesystem(out);
|
||||
out.close();
|
||||
|
@ -467,7 +435,7 @@ public class CopyCompare
|
|||
/** Contains the directory paths that have already been created in the
|
||||
* output POI filesystem and maps them to their corresponding
|
||||
* {@link org.apache.poi.poifs.filesystem.DirectoryNode}s. */
|
||||
private final Map paths = new HashMap();
|
||||
private final Map<String,DirectoryEntry> paths = new HashMap<String,DirectoryEntry>();
|
||||
|
||||
|
||||
|
||||
|
@ -495,13 +463,11 @@ public class CopyCompare
|
|||
* should use this {@link DirectoryEntry} to create documents in it.
|
||||
*/
|
||||
public DirectoryEntry getPath(final POIFSFileSystem poiFs,
|
||||
final POIFSDocumentPath path)
|
||||
{
|
||||
try
|
||||
{
|
||||
final POIFSDocumentPath path) {
|
||||
try {
|
||||
/* Check whether this directory has already been created. */
|
||||
final String s = path.toString();
|
||||
DirectoryEntry de = (DirectoryEntry) paths.get(s);
|
||||
DirectoryEntry de = paths.get(s);
|
||||
if (de != null)
|
||||
/* Yes: return the corresponding DirectoryEntry. */
|
||||
return de;
|
||||
|
@ -509,12 +475,11 @@ public class CopyCompare
|
|||
/* No: We have to create the directory - or return the root's
|
||||
* DirectoryEntry. */
|
||||
int l = path.length();
|
||||
if (l == 0)
|
||||
if (l == 0) {
|
||||
/* Get the root directory. It does not have to be created
|
||||
* since it always exists in a POIFS. */
|
||||
de = poiFs.getRoot();
|
||||
else
|
||||
{
|
||||
} else {
|
||||
/* Create a subordinate directory. The first step is to
|
||||
* ensure that the parent directory exists: */
|
||||
de = getPath(poiFs, path.getParent());
|
||||
|
@ -524,9 +489,7 @@ public class CopyCompare
|
|||
}
|
||||
paths.put(s, de);
|
||||
return de;
|
||||
}
|
||||
catch (IOException ex)
|
||||
{
|
||||
} catch (IOException ex) {
|
||||
/* This exception will be thrown if the directory already
|
||||
* exists. However, since we have full control about directory
|
||||
* creation we can ensure that this will never happen. */
|
||||
|
|
|
@ -114,7 +114,9 @@ public class WriteAuthorAndTitle
|
|||
final POIFSReader r = new POIFSReader();
|
||||
final ModifySICopyTheRest msrl = new ModifySICopyTheRest(dstName);
|
||||
r.registerListener(msrl);
|
||||
r.read(new FileInputStream(srcName));
|
||||
FileInputStream fis = new FileInputStream(srcName);
|
||||
r.read(fis);
|
||||
fis.close();
|
||||
|
||||
/* Write the new POIFS to disk. */
|
||||
msrl.close();
|
||||
|
|
|
@ -201,6 +201,8 @@ public class BusinessPlan {
|
|||
FileOutputStream out = new FileOutputStream(file);
|
||||
wb.write(out);
|
||||
out.close();
|
||||
|
||||
wb.close();
|
||||
}
|
||||
|
||||
/**
|
||||
|
|
|
@ -80,6 +80,8 @@ public class CellStyleDetails {
|
|||
|
||||
System.out.println();
|
||||
}
|
||||
|
||||
wb.close();
|
||||
}
|
||||
|
||||
private static String renderColor(Color color) {
|
||||
|
|
|
@ -91,6 +91,8 @@ public class BigGridDemo {
|
|||
FileOutputStream out = new FileOutputStream("big-grid.xlsx");
|
||||
substitute(new File("template.xlsx"), tmp, sheetRef.substring(1), out);
|
||||
out.close();
|
||||
|
||||
wb.close();
|
||||
}
|
||||
|
||||
/**
|
||||
|
|
|
@ -89,6 +89,7 @@ public abstract class AbstractFileHandler implements FileHandler {
|
|||
assertNotNull(extractor.getText());
|
||||
|
||||
// also try metadata
|
||||
@SuppressWarnings("resource")
|
||||
POITextExtractor metadataExtractor = extractor.getMetadataTextExtractor();
|
||||
assertNotNull(metadataExtractor.getText());
|
||||
|
||||
|
|
|
@ -32,7 +32,6 @@ import org.apache.poi.hssf.model.InternalWorkbook;
|
|||
import org.apache.poi.hssf.record.DrawingGroupRecord;
|
||||
import org.apache.poi.hssf.usermodel.HSSFPatriarch;
|
||||
import org.apache.poi.hssf.usermodel.HSSFWorkbook;
|
||||
import org.apache.poi.poifs.filesystem.NPOIFSFileSystem;
|
||||
import org.apache.poi.util.StringUtil;
|
||||
|
||||
/**
|
||||
|
@ -133,16 +132,15 @@ public class BiffDrawingToXml {
|
|||
}
|
||||
|
||||
public static void writeToFile(OutputStream fos, InputStream xlsWorkbook, boolean excludeWorkbookRecords, String[] params) throws IOException {
|
||||
NPOIFSFileSystem fs = new NPOIFSFileSystem(xlsWorkbook);
|
||||
HSSFWorkbook workbook = new HSSFWorkbook(fs);
|
||||
HSSFWorkbook workbook = new HSSFWorkbook(xlsWorkbook);
|
||||
InternalWorkbook internalWorkbook = workbook.getInternalWorkbook();
|
||||
DrawingGroupRecord r = (DrawingGroupRecord) internalWorkbook.findFirstRecordBySid(DrawingGroupRecord.sid);
|
||||
r.decode();
|
||||
|
||||
StringBuilder builder = new StringBuilder();
|
||||
builder.append("<workbook>\n");
|
||||
String tab = "\t";
|
||||
if (!excludeWorkbookRecords) {
|
||||
if (!excludeWorkbookRecords && r != null) {
|
||||
r.decode();
|
||||
List<EscherRecord> escherRecords = r.getEscherRecords();
|
||||
for (EscherRecord record : escherRecords) {
|
||||
builder.append(record.toXml(tab));
|
||||
|
@ -160,6 +158,7 @@ public class BiffDrawingToXml {
|
|||
builder.append("</workbook>\n");
|
||||
fos.write(builder.toString().getBytes(StringUtil.UTF8));
|
||||
fos.close();
|
||||
workbook.close();
|
||||
}
|
||||
|
||||
}
|
||||
|
|
|
@ -116,6 +116,7 @@ public class BinaryRC4Decryptor extends Decryptor {
|
|||
return skey;
|
||||
}
|
||||
|
||||
@SuppressWarnings("resource")
|
||||
public InputStream getDataStream(DirectoryNode dir) throws IOException,
|
||||
GeneralSecurityException {
|
||||
DocumentInputStream dis = dir.createDocumentInputStream(DEFAULT_POIFS_ENTRY);
|
||||
|
|
|
@ -57,13 +57,13 @@ public class CryptoAPIDecryptor extends Decryptor {
|
|||
Cipher cipher;
|
||||
byte oneByte[] = { 0 };
|
||||
|
||||
public void seek(int pos) {
|
||||
if (pos > count) {
|
||||
throw new ArrayIndexOutOfBoundsException(pos);
|
||||
public void seek(int newpos) {
|
||||
if (newpos > count) {
|
||||
throw new ArrayIndexOutOfBoundsException(newpos);
|
||||
}
|
||||
|
||||
this.pos = pos;
|
||||
mark = pos;
|
||||
this.pos = newpos;
|
||||
mark = newpos;
|
||||
}
|
||||
|
||||
public void setBlock(int block) throws GeneralSecurityException {
|
||||
|
@ -233,9 +233,11 @@ public class CryptoAPIDecryptor extends Decryptor {
|
|||
sbis.setBlock(entry.block);
|
||||
InputStream is = new BoundedInputStream(sbis, entry.streamSize);
|
||||
fsOut.createDocument(is, entry.streamName);
|
||||
is.close();
|
||||
}
|
||||
|
||||
leis.close();
|
||||
sbis.close();
|
||||
sbis = null;
|
||||
bos.reset();
|
||||
fsOut.writeFilesystem(bos);
|
||||
|
|
|
@ -122,6 +122,7 @@ public class StandardDecryptor extends Decryptor {
|
|||
return CryptoFunctions.getCipher(key, em.getCipherAlgorithm(), cm, null, Cipher.DECRYPT_MODE);
|
||||
}
|
||||
|
||||
@SuppressWarnings("resource")
|
||||
public InputStream getDataStream(DirectoryNode dir) throws IOException {
|
||||
DocumentInputStream dis = dir.createDocumentInputStream(DEFAULT_POIFS_ENTRY);
|
||||
|
||||
|
|
|
@ -123,14 +123,9 @@ public class StandardEncryptor extends Encryptor {
|
|||
protected long countBytes;
|
||||
protected final File fileOut;
|
||||
protected final DirectoryNode dir;
|
||||
|
||||
protected StandardCipherOutputStream(DirectoryNode dir) throws IOException {
|
||||
super(null);
|
||||
|
||||
this.dir = dir;
|
||||
fileOut = TempFile.createTempFile("encrypted_package", "crypt");
|
||||
FileOutputStream rawStream = new FileOutputStream(fileOut);
|
||||
|
||||
@SuppressWarnings("resource")
|
||||
private StandardCipherOutputStream(DirectoryNode dir, File fileOut) throws IOException {
|
||||
// although not documented, we need the same padding as with agile encryption
|
||||
// and instead of calculating the missing bytes for the block size ourselves
|
||||
// we leave it up to the CipherOutputStream, which generates/saves them on close()
|
||||
|
@ -141,9 +136,15 @@ public class StandardEncryptor extends Encryptor {
|
|||
// KeyData.blockSize value. Any padding bytes can be used. Note that the StreamSize
|
||||
// field of the EncryptedPackage field specifies the number of bytes of
|
||||
// unencrypted data as specified in section 2.3.4.4.
|
||||
CipherOutputStream cryptStream = new CipherOutputStream(rawStream, getCipher(getSecretKey(), "PKCS5Padding"));
|
||||
|
||||
this.out = cryptStream;
|
||||
super(
|
||||
new CipherOutputStream(new FileOutputStream(fileOut), getCipher(getSecretKey(), "PKCS5Padding"))
|
||||
);
|
||||
this.fileOut = fileOut;
|
||||
this.dir = dir;
|
||||
}
|
||||
|
||||
protected StandardCipherOutputStream(DirectoryNode dir) throws IOException {
|
||||
this(dir, TempFile.createTempFile("encrypted_package", "crypt"));
|
||||
}
|
||||
|
||||
@Override
|
||||
|
|
|
@ -212,13 +212,13 @@ public class POIFSReader
|
|||
|
||||
private void processProperties(final BlockList small_blocks,
|
||||
final BlockList big_blocks,
|
||||
final Iterator properties,
|
||||
final Iterator<Property> properties,
|
||||
final POIFSDocumentPath path)
|
||||
throws IOException
|
||||
{
|
||||
while (properties.hasNext())
|
||||
{
|
||||
Property property = ( Property ) properties.next();
|
||||
Property property = properties.next();
|
||||
String name = property.getName();
|
||||
|
||||
if (property.isDirectory())
|
||||
|
@ -235,8 +235,8 @@ public class POIFSReader
|
|||
}
|
||||
else
|
||||
{
|
||||
int startBlock = property.getStartBlock();
|
||||
Iterator listeners = registry.getListeners(path, name);
|
||||
int startBlock = property.getStartBlock();
|
||||
Iterator<POIFSReaderListener> listeners = registry.getListeners(path, name);
|
||||
|
||||
if (listeners.hasNext())
|
||||
{
|
||||
|
@ -257,8 +257,7 @@ public class POIFSReader
|
|||
}
|
||||
while (listeners.hasNext())
|
||||
{
|
||||
POIFSReaderListener listener =
|
||||
( POIFSReaderListener ) listeners.next();
|
||||
POIFSReaderListener listener = listeners.next();
|
||||
|
||||
listener.processPOIFSReaderEvent(
|
||||
new POIFSReaderEvent(
|
||||
|
@ -303,6 +302,7 @@ public class POIFSReader
|
|||
|
||||
public void processPOIFSReaderEvent(final POIFSReaderEvent event)
|
||||
{
|
||||
@SuppressWarnings("resource")
|
||||
DocumentInputStream istream = event.getStream();
|
||||
POIFSDocumentPath path = event.getPath();
|
||||
String name = event.getName();
|
||||
|
|
|
@ -205,7 +205,8 @@ public final class CellUtil {
|
|||
* @since POI 3.14 beta 2
|
||||
*/
|
||||
public static void setCellStyleProperties(Cell cell, Map<String, Object> properties) {
|
||||
Workbook workbook = cell.getSheet().getWorkbook();
|
||||
@SuppressWarnings("resource")
|
||||
Workbook workbook = cell.getSheet().getWorkbook();
|
||||
CellStyle originalStyle = cell.getCellStyle();
|
||||
CellStyle newStyle = null;
|
||||
Map<String, Object> values = getFormatProperties(originalStyle);
|
||||
|
|
|
@ -19,6 +19,8 @@ package org.apache.poi.ss.usermodel;
|
|||
|
||||
import static org.junit.Assert.assertEquals;
|
||||
|
||||
import java.io.IOException;
|
||||
|
||||
import org.apache.poi.hssf.usermodel.HSSFCell;
|
||||
import org.apache.poi.ss.ITestDataProvider;
|
||||
import org.apache.poi.xssf.streaming.SXSSFCell;
|
||||
|
@ -38,17 +40,19 @@ public abstract class BaseTestXCell extends BaseTestCell {
|
|||
}
|
||||
|
||||
@Test
|
||||
public void testXmlEncoding(){
|
||||
Workbook wb = _testDataProvider.createWorkbook();
|
||||
Sheet sh = wb.createSheet();
|
||||
public void testXmlEncoding() throws IOException {
|
||||
Workbook wb1 = _testDataProvider.createWorkbook();
|
||||
Sheet sh = wb1.createSheet();
|
||||
Row row = sh.createRow(0);
|
||||
Cell cell = row.createCell(0);
|
||||
String sval = "\u0000\u0002\u0012<>\t\n\u00a0 &\"POI\'\u2122";
|
||||
cell.setCellValue(sval);
|
||||
|
||||
wb = _testDataProvider.writeOutAndReadBack(wb);
|
||||
Workbook wb2 = _testDataProvider.writeOutAndReadBack(wb1);
|
||||
wb1.close();
|
||||
|
||||
// invalid characters are replaced with question marks
|
||||
assertEquals("???<>\t\n\u00a0 &\"POI\'\u2122", wb.getSheetAt(0).getRow(0).getCell(0).getStringCellValue());
|
||||
assertEquals("???<>\t\n\u00a0 &\"POI\'\u2122", wb2.getSheetAt(0).getRow(0).getCell(0).getStringCellValue());
|
||||
wb2.close();
|
||||
}
|
||||
}
|
||||
|
|
|
@ -20,9 +20,6 @@ package org.apache.poi.xssf.usermodel;
|
|||
import org.apache.poi.xssf.XSSFITestDataProvider;
|
||||
import org.apache.poi.ss.usermodel.BaseTestSheetHiding;
|
||||
|
||||
/**
|
||||
* @author Yegor Kozlov
|
||||
*/
|
||||
public final class TestSheetHiding extends BaseTestSheetHiding {
|
||||
public TestSheetHiding() {
|
||||
super(XSSFITestDataProvider.instance,
|
||||
|
|
|
@ -66,7 +66,7 @@ public final class TestXSSFCell extends BaseTestXCell {
|
|||
* Shared String Table
|
||||
*/
|
||||
@Test
|
||||
public void test47026_1() throws Exception {
|
||||
public void test47026_1() throws IOException {
|
||||
Workbook wb = _testDataProvider.openSampleWorkbook("47026.xlsm");
|
||||
Sheet sheet = wb.getSheetAt(0);
|
||||
Row row = sheet.getRow(0);
|
||||
|
@ -77,7 +77,7 @@ public final class TestXSSFCell extends BaseTestXCell {
|
|||
}
|
||||
|
||||
@Test
|
||||
public void test47026_2() throws Exception {
|
||||
public void test47026_2() throws IOException {
|
||||
Workbook wb = _testDataProvider.openSampleWorkbook("47026.xlsm");
|
||||
Sheet sheet = wb.getSheetAt(0);
|
||||
Row row = sheet.getRow(0);
|
||||
|
@ -95,7 +95,7 @@ public final class TestXSSFCell extends BaseTestXCell {
|
|||
* instead of using the shared string table. See bug 47206
|
||||
*/
|
||||
@Test
|
||||
public void testInlineString() throws Exception {
|
||||
public void testInlineString() throws IOException {
|
||||
XSSFWorkbook wb = (XSSFWorkbook)_testDataProvider.openSampleWorkbook("xlsx-jdbc.xlsx");
|
||||
XSSFSheet sheet = wb.getSheetAt(0);
|
||||
XSSFRow row = sheet.getRow(1);
|
||||
|
@ -121,7 +121,7 @@ public final class TestXSSFCell extends BaseTestXCell {
|
|||
* Bug 47278 - xsi:nil attribute for <t> tag caused Excel 2007 to fail to open workbook
|
||||
*/
|
||||
@Test
|
||||
public void test47278() throws Exception {
|
||||
public void test47278() throws IOException {
|
||||
XSSFWorkbook wb = (XSSFWorkbook)_testDataProvider.createWorkbook();
|
||||
Sheet sheet = wb.createSheet();
|
||||
Row row = sheet.createRow(0);
|
||||
|
@ -187,7 +187,7 @@ public final class TestXSSFCell extends BaseTestXCell {
|
|||
* Bug 47889: problems when calling XSSFCell.getStringCellValue() on a workbook created in Gnumeric
|
||||
*/
|
||||
@Test
|
||||
public void test47889() throws Exception {
|
||||
public void test47889() throws IOException {
|
||||
XSSFWorkbook wb = (XSSFWorkbook)_testDataProvider.openSampleWorkbook("47889.xlsx");
|
||||
XSSFSheet sh = wb.getSheetAt(0);
|
||||
|
||||
|
@ -214,7 +214,7 @@ public final class TestXSSFCell extends BaseTestXCell {
|
|||
}
|
||||
|
||||
@Test
|
||||
public void testMissingRAttribute() throws Exception {
|
||||
public void testMissingRAttribute() throws IOException {
|
||||
XSSFWorkbook wb1 = new XSSFWorkbook();
|
||||
XSSFSheet sheet = wb1.createSheet();
|
||||
XSSFRow row = sheet.createRow(0);
|
||||
|
@ -269,7 +269,7 @@ public final class TestXSSFCell extends BaseTestXCell {
|
|||
}
|
||||
|
||||
@Test
|
||||
public void testMissingRAttributeBug54288() throws Exception {
|
||||
public void testMissingRAttributeBug54288() throws IOException {
|
||||
// workbook with cells missing the R attribute
|
||||
XSSFWorkbook wb = (XSSFWorkbook)_testDataProvider.openSampleWorkbook("54288.xlsx");
|
||||
// same workbook re-saved in Excel 2010, the R attribute is updated for every cell with the right value.
|
||||
|
@ -453,7 +453,7 @@ public final class TestXSSFCell extends BaseTestXCell {
|
|||
}
|
||||
|
||||
@Test
|
||||
public void testEncodingbeloAscii() throws Exception {
|
||||
public void testEncodingbeloAscii() throws IOException {
|
||||
StringBuffer sb = new StringBuffer();
|
||||
// test all possible characters
|
||||
for(int i = 0; i < Character.MAX_VALUE; i++) {
|
||||
|
|
|
@ -24,12 +24,7 @@ import org.apache.poi.xssf.XSSFITestDataProvider;
|
|||
* Tests setting and evaluating user-defined functions in HSSF
|
||||
*/
|
||||
public final class TestXSSFExternalFunctions extends BaseTestExternalFunctions {
|
||||
|
||||
public TestXSSFExternalFunctions() {
|
||||
super(XSSFITestDataProvider.instance);
|
||||
super(XSSFITestDataProvider.instance, "atp.xlsx");
|
||||
}
|
||||
|
||||
public void testATP(){
|
||||
baseTestInvokeATP("atp.xlsx");
|
||||
}
|
||||
}
|
||||
|
|
|
@ -17,7 +17,10 @@
|
|||
|
||||
package org.apache.poi.xssf.usermodel;
|
||||
|
||||
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.fail;
|
||||
|
||||
import java.io.IOException;
|
||||
|
||||
|
@ -27,14 +30,12 @@ import org.apache.poi.ss.usermodel.Comment;
|
|||
import org.apache.poi.ss.usermodel.Row;
|
||||
import org.apache.poi.ss.usermodel.Sheet;
|
||||
import org.apache.poi.ss.usermodel.Workbook;
|
||||
import org.apache.poi.ss.util.CellAddress;
|
||||
import org.apache.poi.ss.util.CellUtil;
|
||||
import org.apache.poi.xssf.XSSFITestDataProvider;
|
||||
import org.apache.poi.xssf.XSSFTestDataSamples;
|
||||
import org.junit.Test;
|
||||
|
||||
/**
|
||||
* @author Yegor Kozlov
|
||||
*/
|
||||
public final class TestXSSFSheetShiftRows extends BaseTestSheetShiftRows {
|
||||
|
||||
public TestXSSFSheetShiftRows(){
|
||||
|
@ -43,7 +44,8 @@ public final class TestXSSFSheetShiftRows extends BaseTestSheetShiftRows {
|
|||
|
||||
@Override
|
||||
@Test
|
||||
public void testShiftRowBreaks() { // disabled test from superclass
|
||||
public void testShiftRowBreaks() {
|
||||
// disabled test from superclass
|
||||
// TODO - support shifting of page breaks
|
||||
}
|
||||
|
||||
|
@ -85,10 +87,10 @@ public final class TestXSSFSheetShiftRows extends BaseTestSheetShiftRows {
|
|||
// org.apache.xmlbeans.impl.values.XmlValueDisconnectedException.
|
||||
// NOTE: another negative shift on another group of rows is successful, provided no new rows in
|
||||
// place of previously shifted rows were attempted to be created as explained above.
|
||||
testSheet.shiftRows(6, 7, 1); // -- CHANGE the shift to positive once the behaviour of
|
||||
// the above has been tested
|
||||
|
||||
// -- CHANGE the shift to positive once the behaviour of the above has been tested
|
||||
testSheet.shiftRows(6, 7, 1);
|
||||
|
||||
//saveReport(wb, new File("/tmp/53798.xlsx"));
|
||||
Workbook read = XSSFTestDataSamples.writeOutAndReadBack(wb);
|
||||
wb.close();
|
||||
assertNotNull(read);
|
||||
|
@ -131,7 +133,6 @@ public final class TestXSSFSheetShiftRows extends BaseTestSheetShiftRows {
|
|||
}
|
||||
testSheet.shiftRows(6, 6, 1);
|
||||
|
||||
//saveReport(wb, new File("/tmp/53798.xlsx"));
|
||||
Workbook read = XSSFTestDataSamples.writeOutAndReadBack(wb);
|
||||
wb.close();
|
||||
assertNotNull(read);
|
||||
|
@ -155,7 +156,7 @@ public final class TestXSSFSheetShiftRows extends BaseTestSheetShiftRows {
|
|||
|
||||
Sheet sheet = wb.getSheetAt(0);
|
||||
|
||||
Comment comment = sheet.getCellComment(0, 0);
|
||||
Comment comment = sheet.getCellComment(new CellAddress(0, 0));
|
||||
assertNotNull(comment);
|
||||
assertEquals("Amdocs", comment.getAuthor());
|
||||
assertEquals("Amdocs:\ntest\n", comment.getString().getString());
|
||||
|
@ -163,22 +164,15 @@ public final class TestXSSFSheetShiftRows extends BaseTestSheetShiftRows {
|
|||
sheet.shiftRows(0, 1, 1);
|
||||
|
||||
// comment in row 0 is gone
|
||||
comment = sheet.getCellComment(0, 0);
|
||||
comment = sheet.getCellComment(new CellAddress(0, 0));
|
||||
assertNull(comment);
|
||||
|
||||
// comment is now in row 1
|
||||
comment = sheet.getCellComment(1, 0);
|
||||
comment = sheet.getCellComment(new CellAddress(1, 0));
|
||||
assertNotNull(comment);
|
||||
assertEquals("Amdocs", comment.getAuthor());
|
||||
assertEquals("Amdocs:\ntest\n", comment.getString().getString());
|
||||
|
||||
// FileOutputStream outputStream = new FileOutputStream("/tmp/56017.xlsx");
|
||||
// try {
|
||||
// wb.write(outputStream);
|
||||
// } finally {
|
||||
// outputStream.close();
|
||||
// }
|
||||
|
||||
Workbook wbBack = XSSFTestDataSamples.writeOutAndReadBack(wb);
|
||||
wb.close();
|
||||
assertNotNull(wbBack);
|
||||
|
@ -186,11 +180,11 @@ public final class TestXSSFSheetShiftRows extends BaseTestSheetShiftRows {
|
|||
Sheet sheetBack = wbBack.getSheetAt(0);
|
||||
|
||||
// comment in row 0 is gone
|
||||
comment = sheetBack.getCellComment(0, 0);
|
||||
comment = sheetBack.getCellComment(new CellAddress(0, 0));
|
||||
assertNull(comment);
|
||||
|
||||
// comment is now in row 1
|
||||
comment = sheetBack.getCellComment(1, 0);
|
||||
comment = sheetBack.getCellComment(new CellAddress(1, 0));
|
||||
assertNotNull(comment);
|
||||
assertEquals("Amdocs", comment.getAuthor());
|
||||
assertEquals("Amdocs:\ntest\n", comment.getString().getString());
|
||||
|
@ -211,7 +205,6 @@ public final class TestXSSFSheetShiftRows extends BaseTestSheetShiftRows {
|
|||
wbRead.removeSheetAt(0);
|
||||
assertEquals(0, wbRead.getActiveSheetIndex());
|
||||
|
||||
//wb.write(new FileOutputStream("/tmp/57171.xls"));
|
||||
wbRead.close();
|
||||
}
|
||||
|
||||
|
@ -222,7 +215,6 @@ public final class TestXSSFSheetShiftRows extends BaseTestSheetShiftRows {
|
|||
wb.removeSheetAt(0);
|
||||
assertEquals(4, wb.getActiveSheetIndex());
|
||||
|
||||
//wb.write(new FileOutputStream("/tmp/57163.xls"));
|
||||
wb.close();
|
||||
}
|
||||
|
||||
|
@ -320,7 +312,6 @@ public final class TestXSSFSheetShiftRows extends BaseTestSheetShiftRows {
|
|||
wb.close();
|
||||
}
|
||||
|
||||
// TODO: enable when bug 57165 is fixed
|
||||
@Test
|
||||
public void test57165() throws IOException {
|
||||
Workbook wb = XSSFTestDataSamples.openSampleWorkbook("57171_57163_57165.xlsx");
|
||||
|
@ -333,29 +324,17 @@ public final class TestXSSFSheetShiftRows extends BaseTestSheetShiftRows {
|
|||
wb.setSheetName(1, "New Sheet");
|
||||
assertEquals(0, wb.getActiveSheetIndex());
|
||||
|
||||
//wb.write(new FileOutputStream("/tmp/57165.xls"));
|
||||
wb.close();
|
||||
}
|
||||
|
||||
// public void test57165b() throws IOException {
|
||||
// Workbook wb = new XSSFWorkbook();
|
||||
// try {
|
||||
// wb.createSheet("New Sheet 1");
|
||||
// wb.createSheet("New Sheet 2");
|
||||
// } finally {
|
||||
// wb.close();
|
||||
// }
|
||||
// }
|
||||
|
||||
private static void removeAllSheetsBut(int sheetIndex, Workbook wb) {
|
||||
int sheetNb = wb.getNumberOfSheets();
|
||||
// Move this sheet at the first position
|
||||
wb.setSheetOrder(wb.getSheetName(sheetIndex), 0);
|
||||
// Must make this sheet active (otherwise, for XLSX, Excel might protest that active sheet no longer exists)
|
||||
// I think POI should automatically handle this case when deleting sheets...
|
||||
// wb.setActiveSheet(0);
|
||||
for (int sn = sheetNb - 1; sn > 0; sn--)
|
||||
{
|
||||
// wb.setActiveSheet(0);
|
||||
for (int sn = sheetNb - 1; sn > 0; sn--) {
|
||||
wb.removeSheetAt(sn);
|
||||
}
|
||||
}
|
||||
|
@ -365,33 +344,26 @@ public final class TestXSSFSheetShiftRows extends BaseTestSheetShiftRows {
|
|||
XSSFWorkbook wb = XSSFTestDataSamples.openSampleWorkbook("57828.xlsx");
|
||||
XSSFSheet sheet = wb.getSheetAt(0);
|
||||
|
||||
Comment comment1 = sheet.getCellComment(2, 1);
|
||||
Comment comment1 = sheet.getCellComment(new CellAddress(2, 1));
|
||||
assertNotNull(comment1);
|
||||
|
||||
Comment comment2 = sheet.getCellComment(2, 2);
|
||||
Comment comment2 = sheet.getCellComment(new CellAddress(2, 2));
|
||||
assertNotNull(comment2);
|
||||
|
||||
Comment comment3 = sheet.getCellComment(1, 1);
|
||||
Comment comment3 = sheet.getCellComment(new CellAddress(1, 1));
|
||||
assertNull("NO comment in (1,1) and it should be null", comment3);
|
||||
|
||||
sheet.shiftRows(2, 2, -1);
|
||||
|
||||
comment3 = sheet.getCellComment(1, 1);
|
||||
comment3 = sheet.getCellComment(new CellAddress(1, 1));
|
||||
assertNotNull("Comment in (2,1) moved to (1,1) so its not null now.", comment3);
|
||||
|
||||
comment1 = sheet.getCellComment(2, 1);
|
||||
comment1 = sheet.getCellComment(new CellAddress(2, 1));
|
||||
assertNull("No comment currently in (2,1) and hence it is null", comment1);
|
||||
|
||||
comment2 = sheet.getCellComment(1, 2);
|
||||
comment2 = sheet.getCellComment(new CellAddress(1, 2));
|
||||
assertNotNull("Comment in (2,2) should have moved as well because of shift rows. But its not", comment2);
|
||||
|
||||
// OutputStream stream = new FileOutputStream("/tmp/57828.xlsx");
|
||||
// try {
|
||||
// wb.write(stream);
|
||||
// } finally {
|
||||
// stream.close();
|
||||
// }
|
||||
|
||||
wb.close();
|
||||
}
|
||||
}
|
||||
|
|
|
@ -30,29 +30,37 @@ import org.apache.poi.POIDataSamples;
|
|||
import org.apache.poi.hssf.HSSFTestDataSamples;
|
||||
import org.apache.poi.util.IOUtils;
|
||||
import org.apache.poi.util.LocaleUtil;
|
||||
import org.junit.BeforeClass;
|
||||
import org.junit.Test;
|
||||
|
||||
public class TestEscherDump {
|
||||
static NullPrinterStream nullPS;
|
||||
|
||||
@BeforeClass
|
||||
public static void init() throws UnsupportedEncodingException {
|
||||
nullPS = new NullPrinterStream();
|
||||
}
|
||||
|
||||
@Test
|
||||
public void testSimple() throws Exception {
|
||||
// simple test to at least cover some parts of the class
|
||||
EscherDump.main(new String[] {}, new NullPrinterStream());
|
||||
EscherDump.main(new String[] {}, nullPS);
|
||||
|
||||
new EscherDump().dump(0, new byte[] {}, new NullPrinterStream());
|
||||
new EscherDump().dump(new byte[] {}, 0, 0, new NullPrinterStream());
|
||||
new EscherDump().dumpOld(0, new ByteArrayInputStream(new byte[] {}), new NullPrinterStream());
|
||||
new EscherDump().dump(0, new byte[] {}, nullPS);
|
||||
new EscherDump().dump(new byte[] {}, 0, 0, nullPS);
|
||||
new EscherDump().dumpOld(0, new ByteArrayInputStream(new byte[] {}), nullPS);
|
||||
}
|
||||
|
||||
@Test
|
||||
public void testWithData() throws Exception {
|
||||
new EscherDump().dumpOld(8, new ByteArrayInputStream(new byte[] { 00, 00, 00, 00, 00, 00, 00, 00 }), new NullPrinterStream());
|
||||
new EscherDump().dumpOld(8, new ByteArrayInputStream(new byte[] { 00, 00, 00, 00, 00, 00, 00, 00 }), nullPS);
|
||||
}
|
||||
|
||||
@Test
|
||||
public void testWithSamplefile() throws Exception {
|
||||
//InputStream stream = HSSFTestDataSamples.openSampleFileStream(")
|
||||
byte[] data = POIDataSamples.getDDFInstance().readFile("Container.dat");
|
||||
new EscherDump().dump(data.length, data, new NullPrinterStream());
|
||||
new EscherDump().dump(data.length, data, nullPS);
|
||||
//new EscherDump().dumpOld(data.length, new ByteArrayInputStream(data), System.out);
|
||||
|
||||
data = new byte[2586114];
|
||||
|
@ -72,6 +80,7 @@ public class TestEscherDump {
|
|||
* to redirect stdout to avoid spamming the console with output
|
||||
*/
|
||||
private static class NullPrinterStream extends PrintStream {
|
||||
@SuppressWarnings("resource")
|
||||
private NullPrinterStream() throws UnsupportedEncodingException {
|
||||
super(new NullOutputStream(),true,LocaleUtil.CHARSET_1252.name());
|
||||
}
|
||||
|
|
|
@ -849,10 +849,14 @@ public class TestWrite
|
|||
sinfDoc = (DocumentNode)root.getEntry(SummaryInformation.DEFAULT_STREAM_NAME);
|
||||
dinfDoc = (DocumentNode)root.getEntry(DocumentSummaryInformation.DEFAULT_STREAM_NAME);
|
||||
|
||||
sinf = (SummaryInformation)PropertySetFactory.create(new NDocumentInputStream(sinfDoc));
|
||||
InputStream sinfStream = new NDocumentInputStream(sinfDoc);
|
||||
sinf = (SummaryInformation)PropertySetFactory.create(sinfStream);
|
||||
sinfStream.close();
|
||||
assertEquals(131077, sinf.getOSVersion());
|
||||
|
||||
dinf = (DocumentSummaryInformation)PropertySetFactory.create(new NDocumentInputStream(dinfDoc));
|
||||
InputStream dinfStream = new NDocumentInputStream(dinfDoc);
|
||||
dinf = (DocumentSummaryInformation)PropertySetFactory.create(dinfStream);
|
||||
dinfStream.close();
|
||||
assertEquals(131077, dinf.getOSVersion());
|
||||
|
||||
|
||||
|
@ -874,10 +878,14 @@ public class TestWrite
|
|||
sinfDoc = (DocumentNode)root.getEntry(SummaryInformation.DEFAULT_STREAM_NAME);
|
||||
dinfDoc = (DocumentNode)root.getEntry(DocumentSummaryInformation.DEFAULT_STREAM_NAME);
|
||||
|
||||
sinf = (SummaryInformation)PropertySetFactory.create(new NDocumentInputStream(sinfDoc));
|
||||
InputStream sinfStream2 = new NDocumentInputStream(sinfDoc);
|
||||
sinf = (SummaryInformation)PropertySetFactory.create(sinfStream2);
|
||||
sinfStream2.close();
|
||||
assertEquals(131077, sinf.getOSVersion());
|
||||
|
||||
dinf = (DocumentSummaryInformation)PropertySetFactory.create(new NDocumentInputStream(dinfDoc));
|
||||
InputStream dinfStream2 = new NDocumentInputStream(dinfDoc);
|
||||
dinf = (DocumentSummaryInformation)PropertySetFactory.create(dinfStream2);
|
||||
dinfStream2.close();
|
||||
assertEquals(131077, dinf.getOSVersion());
|
||||
|
||||
|
||||
|
@ -896,16 +904,24 @@ public class TestWrite
|
|||
sinfDoc = (DocumentNode)root.getEntry(SummaryInformation.DEFAULT_STREAM_NAME);
|
||||
dinfDoc = (DocumentNode)root.getEntry(DocumentSummaryInformation.DEFAULT_STREAM_NAME);
|
||||
|
||||
sinf = (SummaryInformation)PropertySetFactory.create(new NDocumentInputStream(sinfDoc));
|
||||
InputStream sinfStream3 = new NDocumentInputStream(sinfDoc);
|
||||
sinf = (SummaryInformation)PropertySetFactory.create(sinfStream3);
|
||||
sinfStream3.close();
|
||||
assertEquals(131077, sinf.getOSVersion());
|
||||
|
||||
dinf = (DocumentSummaryInformation)PropertySetFactory.create(new NDocumentInputStream(dinfDoc));
|
||||
InputStream dinfStream3 = new NDocumentInputStream(dinfDoc);
|
||||
dinf = (DocumentSummaryInformation)PropertySetFactory.create(dinfStream3);
|
||||
dinfStream3.close();
|
||||
assertEquals(131077, dinf.getOSVersion());
|
||||
|
||||
|
||||
// Have them write themselves in-place with no changes, as an OutputStream
|
||||
sinf.write(new NDocumentOutputStream(sinfDoc));
|
||||
dinf.write(new NDocumentOutputStream(dinfDoc));
|
||||
OutputStream soufStream = new NDocumentOutputStream(sinfDoc);
|
||||
sinf.write(soufStream);
|
||||
soufStream.close();
|
||||
OutputStream doufStream = new NDocumentOutputStream(dinfDoc);
|
||||
dinf.write(doufStream);
|
||||
doufStream.close();
|
||||
|
||||
// And also write to some bytes for checking
|
||||
ByteArrayOutputStream sinfBytes = new ByteArrayOutputStream();
|
||||
|
@ -918,17 +934,25 @@ public class TestWrite
|
|||
sinfDoc = (DocumentNode)root.getEntry(SummaryInformation.DEFAULT_STREAM_NAME);
|
||||
dinfDoc = (DocumentNode)root.getEntry(DocumentSummaryInformation.DEFAULT_STREAM_NAME);
|
||||
|
||||
byte[] sinfData = IOUtils.toByteArray(new NDocumentInputStream(sinfDoc));
|
||||
byte[] dinfData = IOUtils.toByteArray(new NDocumentInputStream(dinfDoc));
|
||||
InputStream sinfStream4 = new NDocumentInputStream(sinfDoc);
|
||||
byte[] sinfData = IOUtils.toByteArray(sinfStream4);
|
||||
sinfStream4.close();
|
||||
InputStream dinfStream4 = new NDocumentInputStream(dinfDoc);
|
||||
byte[] dinfData = IOUtils.toByteArray(dinfStream4);
|
||||
dinfStream4.close();
|
||||
assertThat(sinfBytes.toByteArray(), equalTo(sinfData));
|
||||
assertThat(dinfBytes.toByteArray(), equalTo(dinfData));
|
||||
|
||||
|
||||
// Read back in as-is
|
||||
sinf = (SummaryInformation)PropertySetFactory.create(new NDocumentInputStream(sinfDoc));
|
||||
InputStream sinfStream5 = new NDocumentInputStream(sinfDoc);
|
||||
sinf = (SummaryInformation)PropertySetFactory.create(sinfStream5);
|
||||
sinfStream5.close();
|
||||
assertEquals(131077, sinf.getOSVersion());
|
||||
|
||||
dinf = (DocumentSummaryInformation)PropertySetFactory.create(new NDocumentInputStream(dinfDoc));
|
||||
InputStream dinfStream5 = new NDocumentInputStream(dinfDoc);
|
||||
dinf = (DocumentSummaryInformation)PropertySetFactory.create(dinfStream5);
|
||||
dinfStream5.close();
|
||||
assertEquals(131077, dinf.getOSVersion());
|
||||
|
||||
assertEquals("Reiichiro Hori", sinf.getAuthor());
|
||||
|
@ -946,17 +970,25 @@ public class TestWrite
|
|||
|
||||
|
||||
// Save this into the filesystem
|
||||
sinf.write(new NDocumentOutputStream(sinfDoc));
|
||||
dinf.write(new NDocumentOutputStream(dinfDoc));
|
||||
OutputStream soufStream2 = new NDocumentOutputStream(sinfDoc);
|
||||
sinf.write(soufStream2);
|
||||
soufStream2.close();
|
||||
OutputStream doufStream2 = new NDocumentOutputStream(dinfDoc);
|
||||
dinf.write(doufStream2);
|
||||
doufStream2.close();
|
||||
|
||||
|
||||
// Read them back in again
|
||||
sinfDoc = (DocumentNode)root.getEntry(SummaryInformation.DEFAULT_STREAM_NAME);
|
||||
sinf = (SummaryInformation)PropertySetFactory.create(new NDocumentInputStream(sinfDoc));
|
||||
InputStream sinfStream6 = new NDocumentInputStream(sinfDoc);
|
||||
sinf = (SummaryInformation)PropertySetFactory.create(sinfStream6);
|
||||
sinfStream6.close();
|
||||
assertEquals(131077, sinf.getOSVersion());
|
||||
|
||||
dinfDoc = (DocumentNode)root.getEntry(DocumentSummaryInformation.DEFAULT_STREAM_NAME);
|
||||
dinf = (DocumentSummaryInformation)PropertySetFactory.create(new NDocumentInputStream(dinfDoc));
|
||||
InputStream dinfStream6 = new NDocumentInputStream(dinfDoc);
|
||||
dinf = (DocumentSummaryInformation)PropertySetFactory.create(dinfStream6);
|
||||
dinfStream6.close();
|
||||
assertEquals(131077, dinf.getOSVersion());
|
||||
|
||||
assertEquals("Changed Author", sinf.getAuthor());
|
||||
|
@ -976,11 +1008,15 @@ public class TestWrite
|
|||
|
||||
// Re-check on load
|
||||
sinfDoc = (DocumentNode)root.getEntry(SummaryInformation.DEFAULT_STREAM_NAME);
|
||||
sinf = (SummaryInformation)PropertySetFactory.create(new NDocumentInputStream(sinfDoc));
|
||||
InputStream sinfStream7 = new NDocumentInputStream(sinfDoc);
|
||||
sinf = (SummaryInformation)PropertySetFactory.create(sinfStream7);
|
||||
sinfStream7.close();
|
||||
assertEquals(131077, sinf.getOSVersion());
|
||||
|
||||
dinfDoc = (DocumentNode)root.getEntry(DocumentSummaryInformation.DEFAULT_STREAM_NAME);
|
||||
dinf = (DocumentSummaryInformation)PropertySetFactory.create(new NDocumentInputStream(dinfDoc));
|
||||
InputStream dinfStream7 = new NDocumentInputStream(dinfDoc);
|
||||
dinf = (DocumentSummaryInformation)PropertySetFactory.create(dinfStream7);
|
||||
dinfStream7.close();
|
||||
assertEquals(131077, dinf.getOSVersion());
|
||||
|
||||
assertEquals("Changed Author", sinf.getAuthor());
|
||||
|
|
|
@ -97,15 +97,20 @@ public abstract class BaseXLSIteratingTest {
|
|||
|
||||
// try to read it in HSSFWorkbook to quickly fail if we cannot read the file there at all and thus probably should use EXCLUDED instead
|
||||
FileInputStream stream = new FileInputStream(file);
|
||||
HSSFWorkbook wb = null;
|
||||
try {
|
||||
assertNotNull(new HSSFWorkbook(stream));
|
||||
wb = new HSSFWorkbook(stream);
|
||||
assertNotNull(wb);
|
||||
} finally {
|
||||
if (wb != null) {
|
||||
wb.close();
|
||||
}
|
||||
stream.close();
|
||||
}
|
||||
}
|
||||
}
|
||||
|
||||
abstract void runOneFile(File file) throws Exception;
|
||||
abstract void runOneFile(File pFile) throws Exception;
|
||||
|
||||
/**
|
||||
* Implementation of an OutputStream which does nothing, used
|
||||
|
|
|
@ -21,33 +21,30 @@ import java.io.FileInputStream;
|
|||
import java.io.InputStream;
|
||||
import java.io.PrintStream;
|
||||
|
||||
import org.junit.Ignore;
|
||||
import org.junit.Test;
|
||||
|
||||
public class TestBiffDrawingToXml extends BaseXLSIteratingTest {
|
||||
static {
|
||||
// TODO: is it ok to fail these?
|
||||
// Look at the output of the test for the detailed stacktrace of the failures...
|
||||
// EXCLUDED.add("password.xls");
|
||||
// EXCLUDED.add("XRefCalc.xls");
|
||||
// EXCLUDED.add("43493.xls");
|
||||
// EXCLUDED.add("51832.xls");
|
||||
EXCLUDED.add("35897-type4.xls"); // unsupported crypto api header
|
||||
EXCLUDED.add("43493.xls"); // HSSFWorkbook cannot open it as well
|
||||
EXCLUDED.add("46904.xls");
|
||||
EXCLUDED.add("44958_1.xls");
|
||||
EXCLUDED.add("51832.xls");
|
||||
EXCLUDED.add("59074.xls");
|
||||
EXCLUDED.add("password.xls");
|
||||
EXCLUDED.add("testEXCEL_2.xls"); // Biff 2 / Excel 2, pre-OLE2
|
||||
EXCLUDED.add("testEXCEL_3.xls"); // Biff 3 / Excel 3, pre-OLE2
|
||||
EXCLUDED.add("testEXCEL_4.xls"); // Biff 4 / Excel 4, pre-OLE2
|
||||
EXCLUDED.add("testEXCEL_5.xls"); // Biff 5 / Excel 5
|
||||
EXCLUDED.add("testEXCEL_95.xls"); // Biff 5 / Excel 95
|
||||
EXCLUDED.add("xor-encryption-abc.xls");
|
||||
}
|
||||
|
||||
@Override
|
||||
@Ignore("Not yet done, nearly all files fail with various errors, remove this method when done to use the one from the abstract base class!...")
|
||||
@Test
|
||||
public void testMain() throws Exception {
|
||||
}
|
||||
|
||||
@Override
|
||||
void runOneFile(File file)
|
||||
throws Exception {
|
||||
void runOneFile(File pFile) throws Exception {
|
||||
PrintStream save = System.out;
|
||||
try {
|
||||
//System.setOut(new PrintStream(TestBiffViewer.NULL_OUTPUT_STREAM));
|
||||
// use a NullOutputStream to not write the bytes anywhere for best runtime
|
||||
InputStream wb = new FileInputStream(file);
|
||||
InputStream wb = new FileInputStream(pFile);
|
||||
try {
|
||||
BiffDrawingToXml.writeToFile(NULL_OUTPUT_STREAM, wb, false, new String[] {});
|
||||
} finally {
|
||||
|
|
File diff suppressed because it is too large
Load Diff
|
@ -17,11 +17,15 @@
|
|||
|
||||
package org.apache.poi.hssf.model;
|
||||
|
||||
import static org.junit.Assert.assertEquals;
|
||||
import static org.junit.Assert.assertFalse;
|
||||
import static org.junit.Assert.assertNotNull;
|
||||
import static org.junit.Assert.assertSame;
|
||||
import static org.junit.Assert.assertTrue;
|
||||
|
||||
import java.io.IOException;
|
||||
import java.util.List;
|
||||
|
||||
import junit.framework.TestCase;
|
||||
|
||||
import org.apache.poi.ddf.EscherBoolProperty;
|
||||
import org.apache.poi.ddf.EscherContainerRecord;
|
||||
import org.apache.poi.ddf.EscherDgRecord;
|
||||
|
@ -34,21 +38,33 @@ import org.apache.poi.hssf.HSSFTestDataSamples;
|
|||
import org.apache.poi.hssf.record.CommonObjectDataSubRecord;
|
||||
import org.apache.poi.hssf.record.EscherAggregate;
|
||||
import org.apache.poi.hssf.record.ObjRecord;
|
||||
import org.apache.poi.hssf.usermodel.*;
|
||||
import org.apache.poi.hssf.usermodel.HSSFAnchor;
|
||||
import org.apache.poi.hssf.usermodel.HSSFChildAnchor;
|
||||
import org.apache.poi.hssf.usermodel.HSSFClientAnchor;
|
||||
import org.apache.poi.hssf.usermodel.HSSFComment;
|
||||
import org.apache.poi.hssf.usermodel.HSSFPatriarch;
|
||||
import org.apache.poi.hssf.usermodel.HSSFPicture;
|
||||
import org.apache.poi.hssf.usermodel.HSSFPolygon;
|
||||
import org.apache.poi.hssf.usermodel.HSSFRichTextString;
|
||||
import org.apache.poi.hssf.usermodel.HSSFShape;
|
||||
import org.apache.poi.hssf.usermodel.HSSFShapeGroup;
|
||||
import org.apache.poi.hssf.usermodel.HSSFSheet;
|
||||
import org.apache.poi.hssf.usermodel.HSSFSimpleShape;
|
||||
import org.apache.poi.hssf.usermodel.HSSFTestHelper;
|
||||
import org.apache.poi.hssf.usermodel.HSSFTextbox;
|
||||
import org.apache.poi.hssf.usermodel.HSSFWorkbook;
|
||||
import org.apache.poi.ss.usermodel.ClientAnchor.AnchorType;
|
||||
import org.apache.poi.ss.usermodel.Workbook;
|
||||
import org.apache.poi.util.HexDump;
|
||||
import org.junit.Test;
|
||||
|
||||
|
||||
/**
|
||||
* @author Evgeniy Berlog
|
||||
* date: 12.06.12
|
||||
* Test escher drawing
|
||||
*
|
||||
* optionally the system setting "poi.deserialize.escher" can be set to {@code true}
|
||||
*/
|
||||
public class TestDrawingShapes extends TestCase {
|
||||
static {
|
||||
//System.setProperty("poi.deserialize.escher", "true");
|
||||
}
|
||||
|
||||
public class TestDrawingShapes {
|
||||
/**
|
||||
* HSSFShape tree bust be built correctly
|
||||
* Check file with such records structure:
|
||||
|
@ -63,7 +79,8 @@ public class TestDrawingShapes extends TestCase {
|
|||
* ----shape
|
||||
* ----shape
|
||||
*/
|
||||
public void testDrawingGroups() {
|
||||
@Test
|
||||
public void testDrawingGroups() throws IOException {
|
||||
HSSFWorkbook wb = HSSFTestDataSamples.openSampleWorkbook("drawings.xls");
|
||||
HSSFSheet sheet = wb.getSheet("groups");
|
||||
HSSFPatriarch patriarch = sheet.getDrawingPatriarch();
|
||||
|
@ -74,8 +91,10 @@ public class TestDrawingShapes extends TestCase {
|
|||
assertEquals(2, group1.getChildren().size());
|
||||
group1 = (HSSFShapeGroup) group.getChildren().get(2);
|
||||
assertEquals(2, group1.getChildren().size());
|
||||
wb.close();
|
||||
}
|
||||
|
||||
@Test
|
||||
public void testHSSFShapeCompatibility() {
|
||||
HSSFSimpleShape shape = new HSSFSimpleShape(null, new HSSFClientAnchor());
|
||||
shape.setShapeType(HSSFSimpleShape.OBJECT_TYPE_LINE);
|
||||
|
@ -91,35 +110,33 @@ public class TestDrawingShapes extends TestCase {
|
|||
spContainer.getChildById(EscherOptRecord.RECORD_ID);
|
||||
|
||||
assertEquals(7, opt.getEscherProperties().size());
|
||||
assertEquals(true,
|
||||
((EscherBoolProperty) opt.lookup(EscherProperties.TEXT__SIZE_TEXT_TO_FIT_SHAPE)).isTrue());
|
||||
assertTrue(((EscherBoolProperty) opt.lookup(EscherProperties.TEXT__SIZE_TEXT_TO_FIT_SHAPE)).isTrue());
|
||||
assertEquals(0x00000004,
|
||||
((EscherSimpleProperty) opt.lookup(EscherProperties.GEOMETRY__SHAPEPATH)).getPropertyValue());
|
||||
assertEquals(0x08000009,
|
||||
((EscherSimpleProperty) opt.lookup(EscherProperties.FILL__FILLCOLOR)).getPropertyValue());
|
||||
assertEquals(true,
|
||||
((EscherBoolProperty) opt.lookup(EscherProperties.FILL__NOFILLHITTEST)).isTrue());
|
||||
assertTrue(((EscherBoolProperty) opt.lookup(EscherProperties.FILL__NOFILLHITTEST)).isTrue());
|
||||
assertEquals(0x08000040,
|
||||
((EscherSimpleProperty) opt.lookup(EscherProperties.LINESTYLE__COLOR)).getPropertyValue());
|
||||
assertEquals(true,
|
||||
((EscherBoolProperty) opt.lookup(EscherProperties.LINESTYLE__NOLINEDRAWDASH)).isTrue());
|
||||
assertEquals(true,
|
||||
((EscherBoolProperty) opt.lookup(EscherProperties.GROUPSHAPE__PRINT)).isTrue());
|
||||
assertTrue(((EscherBoolProperty) opt.lookup(EscherProperties.LINESTYLE__NOLINEDRAWDASH)).isTrue());
|
||||
assertTrue(((EscherBoolProperty) opt.lookup(EscherProperties.GROUPSHAPE__PRINT)).isTrue());
|
||||
}
|
||||
|
||||
@Test
|
||||
public void testDefaultPictureSettings() {
|
||||
HSSFPicture picture = new HSSFPicture(null, new HSSFClientAnchor());
|
||||
assertEquals(picture.getLineWidth(), HSSFShape.LINEWIDTH_DEFAULT);
|
||||
assertEquals(picture.getFillColor(), HSSFShape.FILL__FILLCOLOR_DEFAULT);
|
||||
assertEquals(picture.getLineStyle(), HSSFShape.LINESTYLE_NONE);
|
||||
assertEquals(picture.getLineStyleColor(), HSSFShape.LINESTYLE__COLOR_DEFAULT);
|
||||
assertEquals(picture.isNoFill(), false);
|
||||
assertFalse(picture.isNoFill());
|
||||
assertEquals(picture.getPictureIndex(), -1);//not set yet
|
||||
}
|
||||
|
||||
/**
|
||||
* No NullPointerException should appear
|
||||
*/
|
||||
@Test
|
||||
public void testDefaultSettingsWithEmptyContainer() {
|
||||
EscherContainerRecord container = new EscherContainerRecord();
|
||||
EscherOptRecord opt = new EscherOptRecord();
|
||||
|
@ -142,10 +159,10 @@ public class TestDrawingShapes extends TestCase {
|
|||
/**
|
||||
* create a rectangle, save the workbook, read back and verify that all shape properties are there
|
||||
*/
|
||||
@Test
|
||||
public void testReadWriteRectangle() throws IOException {
|
||||
|
||||
HSSFWorkbook wb = new HSSFWorkbook();
|
||||
HSSFSheet sheet = wb.createSheet();
|
||||
HSSFWorkbook wb1 = new HSSFWorkbook();
|
||||
HSSFSheet sheet = wb1.createSheet();
|
||||
|
||||
HSSFPatriarch drawing = sheet.createDrawingPatriarch();
|
||||
HSSFClientAnchor anchor = new HSSFClientAnchor(10, 10, 50, 50, (short) 2, 2, (short) 4, 4);
|
||||
|
@ -172,8 +189,9 @@ public class TestDrawingShapes extends TestCase {
|
|||
assertEquals(rectangle.getWrapText(), HSSFSimpleShape.WRAP_NONE);
|
||||
assertEquals(rectangle.getString().getString(), "teeeest");
|
||||
|
||||
wb = HSSFTestDataSamples.writeOutAndReadBack(wb);
|
||||
sheet = wb.getSheetAt(0);
|
||||
HSSFWorkbook wb2 = HSSFTestDataSamples.writeOutAndReadBack(wb1);
|
||||
wb1.close();
|
||||
sheet = wb2.getSheetAt(0);
|
||||
drawing = sheet.getDrawingPatriarch();
|
||||
assertEquals(1, drawing.getChildren().size());
|
||||
|
||||
|
@ -202,8 +220,9 @@ public class TestDrawingShapes extends TestCase {
|
|||
rectangle.setWrapText(HSSFSimpleShape.WRAP_BY_POINTS);
|
||||
rectangle2.setString(new HSSFRichTextString("test22"));
|
||||
|
||||
wb = HSSFTestDataSamples.writeOutAndReadBack(wb);
|
||||
sheet = wb.getSheetAt(0);
|
||||
HSSFWorkbook wb3 = HSSFTestDataSamples.writeOutAndReadBack(wb2);
|
||||
wb2.close();
|
||||
sheet = wb3.getSheetAt(0);
|
||||
drawing = sheet.getDrawingPatriarch();
|
||||
assertEquals(1, drawing.getChildren().size());
|
||||
rectangle2 = (HSSFSimpleShape) drawing.getChildren().get(0);
|
||||
|
@ -222,13 +241,16 @@ public class TestDrawingShapes extends TestCase {
|
|||
|
||||
HSSFSimpleShape rect3 = drawing.createSimpleShape(new HSSFClientAnchor());
|
||||
rect3.setShapeType(HSSFSimpleShape.OBJECT_TYPE_RECTANGLE);
|
||||
wb = HSSFTestDataSamples.writeOutAndReadBack(wb);
|
||||
HSSFWorkbook wb4 = HSSFTestDataSamples.writeOutAndReadBack(wb3);
|
||||
wb3.close();
|
||||
|
||||
drawing = wb.getSheetAt(0).getDrawingPatriarch();
|
||||
drawing = wb4.getSheetAt(0).getDrawingPatriarch();
|
||||
assertEquals(drawing.getChildren().size(), 2);
|
||||
wb4.close();
|
||||
}
|
||||
|
||||
public void testReadExistingImage() {
|
||||
@Test
|
||||
public void testReadExistingImage() throws IOException {
|
||||
HSSFWorkbook wb = HSSFTestDataSamples.openSampleWorkbook("drawings.xls");
|
||||
HSSFSheet sheet = wb.getSheet("pictures");
|
||||
HSSFPatriarch drawing = sheet.getDrawingPatriarch();
|
||||
|
@ -244,11 +266,13 @@ public class TestDrawingShapes extends TestCase {
|
|||
|
||||
picture.setPictureIndex(2);
|
||||
assertEquals(picture.getPictureIndex(), 2);
|
||||
wb.close();
|
||||
}
|
||||
|
||||
|
||||
/* assert shape properties when reading shapes from a existing workbook */
|
||||
public void testReadExistingRectangle() {
|
||||
@Test
|
||||
public void testReadExistingRectangle() throws IOException {
|
||||
HSSFWorkbook wb = HSSFTestDataSamples.openSampleWorkbook("drawings.xls");
|
||||
HSSFSheet sheet = wb.getSheet("rectangles");
|
||||
HSSFPatriarch drawing = sheet.getDrawingPatriarch();
|
||||
|
@ -262,18 +286,21 @@ public class TestDrawingShapes extends TestCase {
|
|||
assertEquals(shape.getLineWidth(), HSSFShape.LINEWIDTH_ONE_PT * 2);
|
||||
assertEquals(shape.getString().getString(), "POItest");
|
||||
assertEquals(shape.getRotationDegree(), 27);
|
||||
wb.close();
|
||||
}
|
||||
|
||||
public void testShapeIds() {
|
||||
HSSFWorkbook wb = new HSSFWorkbook();
|
||||
HSSFSheet sheet1 = wb.createSheet();
|
||||
@Test
|
||||
public void testShapeIds() throws IOException {
|
||||
HSSFWorkbook wb1 = new HSSFWorkbook();
|
||||
HSSFSheet sheet1 = wb1.createSheet();
|
||||
HSSFPatriarch patriarch1 = sheet1.createDrawingPatriarch();
|
||||
for (int i = 0; i < 2; i++) {
|
||||
patriarch1.createSimpleShape(new HSSFClientAnchor());
|
||||
}
|
||||
|
||||
wb = HSSFTestDataSamples.writeOutAndReadBack(wb);
|
||||
sheet1 = wb.getSheetAt(0);
|
||||
HSSFWorkbook wb2 = HSSFTestDataSamples.writeOutAndReadBack(wb1);
|
||||
wb1.close();
|
||||
sheet1 = wb2.getSheetAt(0);
|
||||
patriarch1 = sheet1.getDrawingPatriarch();
|
||||
|
||||
EscherAggregate agg1 = HSSFTestHelper.getEscherAggregate(patriarch1);
|
||||
|
@ -299,13 +326,15 @@ public class TestDrawingShapes extends TestCase {
|
|||
EscherSpRecord sp2 =
|
||||
((EscherContainerRecord) spgrContainer.getChild(2)).getChildById(EscherSpRecord.RECORD_ID);
|
||||
assertEquals(1026, sp2.getShapeId());
|
||||
wb2.close();
|
||||
}
|
||||
|
||||
/**
|
||||
* Test get new id for shapes from existing file
|
||||
* File already have for 1 shape on each sheet, because document must contain EscherDgRecord for each sheet
|
||||
*/
|
||||
public void testAllocateNewIds() {
|
||||
@Test
|
||||
public void testAllocateNewIds() throws IOException {
|
||||
HSSFWorkbook wb = HSSFTestDataSamples.openSampleWorkbook("empty.xls");
|
||||
HSSFSheet sheet = wb.getSheetAt(0);
|
||||
HSSFPatriarch patriarch = sheet.getDrawingPatriarch();
|
||||
|
@ -336,79 +365,76 @@ public class TestDrawingShapes extends TestCase {
|
|||
assertEquals(HSSFTestHelper.allocateNewShapeId(patriarch), 1026);
|
||||
assertEquals(HSSFTestHelper.allocateNewShapeId(patriarch), 1027);
|
||||
assertEquals(HSSFTestHelper.allocateNewShapeId(patriarch), 1028);
|
||||
wb.close();
|
||||
}
|
||||
|
||||
public void testOpt() throws Exception {
|
||||
@Test
|
||||
public void testOpt() throws IOException {
|
||||
HSSFWorkbook wb = new HSSFWorkbook();
|
||||
|
||||
try {
|
||||
// create a sheet with a text box
|
||||
HSSFSheet sheet = wb.createSheet();
|
||||
HSSFPatriarch patriarch = sheet.createDrawingPatriarch();
|
||||
|
||||
HSSFTextbox textbox = patriarch.createTextbox(new HSSFClientAnchor());
|
||||
EscherOptRecord opt1 = HSSFTestHelper.getOptRecord(textbox);
|
||||
EscherOptRecord opt2 = HSSFTestHelper.getEscherContainer(textbox).getChildById(EscherOptRecord.RECORD_ID);
|
||||
assertSame(opt1, opt2);
|
||||
} finally {
|
||||
wb.close();
|
||||
}
|
||||
// create a sheet with a text box
|
||||
HSSFSheet sheet = wb.createSheet();
|
||||
HSSFPatriarch patriarch = sheet.createDrawingPatriarch();
|
||||
|
||||
HSSFTextbox textbox = patriarch.createTextbox(new HSSFClientAnchor());
|
||||
EscherOptRecord opt1 = HSSFTestHelper.getOptRecord(textbox);
|
||||
EscherOptRecord opt2 = HSSFTestHelper.getEscherContainer(textbox).getChildById(EscherOptRecord.RECORD_ID);
|
||||
assertSame(opt1, opt2);
|
||||
wb.close();
|
||||
}
|
||||
|
||||
@Test
|
||||
public void testCorrectOrderInOptRecord() throws IOException{
|
||||
HSSFWorkbook wb = new HSSFWorkbook();
|
||||
|
||||
try {
|
||||
HSSFSheet sheet = wb.createSheet();
|
||||
HSSFPatriarch patriarch = sheet.createDrawingPatriarch();
|
||||
|
||||
HSSFTextbox textbox = patriarch.createTextbox(new HSSFClientAnchor());
|
||||
EscherOptRecord opt = HSSFTestHelper.getOptRecord(textbox);
|
||||
|
||||
String opt1Str = opt.toXml();
|
||||
|
||||
textbox.setFillColor(textbox.getFillColor());
|
||||
EscherContainerRecord container = HSSFTestHelper.getEscherContainer(textbox);
|
||||
EscherOptRecord optRecord = container.getChildById(EscherOptRecord.RECORD_ID);
|
||||
assertEquals(opt1Str, optRecord.toXml());
|
||||
textbox.setLineStyle(textbox.getLineStyle());
|
||||
assertEquals(opt1Str, optRecord.toXml());
|
||||
textbox.setLineWidth(textbox.getLineWidth());
|
||||
assertEquals(opt1Str, optRecord.toXml());
|
||||
textbox.setLineStyleColor(textbox.getLineStyleColor());
|
||||
assertEquals(opt1Str, optRecord.toXml());
|
||||
} finally {
|
||||
wb.close();
|
||||
}
|
||||
HSSFSheet sheet = wb.createSheet();
|
||||
HSSFPatriarch patriarch = sheet.createDrawingPatriarch();
|
||||
|
||||
HSSFTextbox textbox = patriarch.createTextbox(new HSSFClientAnchor());
|
||||
EscherOptRecord opt = HSSFTestHelper.getOptRecord(textbox);
|
||||
|
||||
String opt1Str = opt.toXml();
|
||||
|
||||
textbox.setFillColor(textbox.getFillColor());
|
||||
EscherContainerRecord container = HSSFTestHelper.getEscherContainer(textbox);
|
||||
EscherOptRecord optRecord = container.getChildById(EscherOptRecord.RECORD_ID);
|
||||
assertEquals(opt1Str, optRecord.toXml());
|
||||
textbox.setLineStyle(textbox.getLineStyle());
|
||||
assertEquals(opt1Str, optRecord.toXml());
|
||||
textbox.setLineWidth(textbox.getLineWidth());
|
||||
assertEquals(opt1Str, optRecord.toXml());
|
||||
textbox.setLineStyleColor(textbox.getLineStyleColor());
|
||||
assertEquals(opt1Str, optRecord.toXml());
|
||||
wb.close();
|
||||
}
|
||||
|
||||
public void testDgRecordNumShapes() throws IOException{
|
||||
HSSFWorkbook wb = new HSSFWorkbook();
|
||||
try {
|
||||
HSSFSheet sheet = wb.createSheet();
|
||||
HSSFPatriarch patriarch = sheet.createDrawingPatriarch();
|
||||
|
||||
EscherAggregate aggregate = HSSFTestHelper.getEscherAggregate(patriarch);
|
||||
EscherDgRecord dgRecord = (EscherDgRecord) aggregate.getEscherRecord(0).getChild(0);
|
||||
assertEquals(dgRecord.getNumShapes(), 1);
|
||||
} finally {
|
||||
wb.close();
|
||||
}
|
||||
}
|
||||
|
||||
public void testTextForSimpleShape(){
|
||||
@Test
|
||||
public void testDgRecordNumShapes() throws IOException {
|
||||
HSSFWorkbook wb = new HSSFWorkbook();
|
||||
HSSFSheet sheet = wb.createSheet();
|
||||
HSSFPatriarch patriarch = sheet.createDrawingPatriarch();
|
||||
|
||||
EscherAggregate aggregate = HSSFTestHelper.getEscherAggregate(patriarch);
|
||||
EscherDgRecord dgRecord = (EscherDgRecord) aggregate.getEscherRecord(0).getChild(0);
|
||||
assertEquals(dgRecord.getNumShapes(), 1);
|
||||
wb.close();
|
||||
}
|
||||
|
||||
@Test
|
||||
public void testTextForSimpleShape() throws IOException {
|
||||
HSSFWorkbook wb1 = new HSSFWorkbook();
|
||||
HSSFSheet sheet = wb1.createSheet();
|
||||
HSSFPatriarch patriarch = sheet.createDrawingPatriarch();
|
||||
|
||||
HSSFSimpleShape shape = patriarch.createSimpleShape(new HSSFClientAnchor());
|
||||
shape.setShapeType(HSSFSimpleShape.OBJECT_TYPE_RECTANGLE);
|
||||
|
||||
EscherAggregate agg = HSSFTestHelper.getEscherAggregate(patriarch);
|
||||
assertEquals(agg.getShapeToObjMapping().size(), 2);
|
||||
|
||||
wb = HSSFTestDataSamples.writeOutAndReadBack(wb);
|
||||
sheet = wb.getSheetAt(0);
|
||||
HSSFWorkbook wb2 = HSSFTestDataSamples.writeOutAndReadBack(wb1);
|
||||
wb1.close();
|
||||
sheet = wb2.getSheetAt(0);
|
||||
patriarch = sheet.getDrawingPatriarch();
|
||||
|
||||
shape = (HSSFSimpleShape) patriarch.getChildren().get(0);
|
||||
|
@ -422,10 +448,12 @@ public class TestDrawingShapes extends TestCase {
|
|||
assertNotNull(HSSFTestHelper.getEscherContainer(shape).getChildById(EscherTextboxRecord.RECORD_ID));
|
||||
assertEquals(agg.getShapeToObjMapping().size(), 2);
|
||||
|
||||
wb = HSSFTestDataSamples.writeOutAndReadBack(wb);
|
||||
HSSFWorkbook wb3 = HSSFTestDataSamples.writeOutAndReadBack(wb2);
|
||||
wb2.close();
|
||||
|
||||
wb = HSSFTestDataSamples.writeOutAndReadBack(wb);
|
||||
sheet = wb.getSheetAt(0);
|
||||
HSSFWorkbook wb4 = HSSFTestDataSamples.writeOutAndReadBack(wb3);
|
||||
wb3.close();
|
||||
sheet = wb4.getSheetAt(0);
|
||||
patriarch = sheet.getDrawingPatriarch();
|
||||
|
||||
shape = (HSSFSimpleShape) patriarch.getChildren().get(0);
|
||||
|
@ -434,17 +462,19 @@ public class TestDrawingShapes extends TestCase {
|
|||
assertEquals(shape.getString().getString(), "string1");
|
||||
assertNotNull(HSSFTestHelper.getEscherContainer(shape).getChildById(EscherTextboxRecord.RECORD_ID));
|
||||
assertEquals(agg.getShapeToObjMapping().size(), 2);
|
||||
wb4.close();
|
||||
}
|
||||
|
||||
public void testRemoveShapes(){
|
||||
HSSFWorkbook wb = new HSSFWorkbook();
|
||||
HSSFSheet sheet = wb.createSheet();
|
||||
@Test
|
||||
public void testRemoveShapes() throws IOException {
|
||||
HSSFWorkbook wb1 = new HSSFWorkbook();
|
||||
HSSFSheet sheet = wb1.createSheet();
|
||||
HSSFPatriarch patriarch = sheet.createDrawingPatriarch();
|
||||
|
||||
HSSFSimpleShape rectangle = patriarch.createSimpleShape(new HSSFClientAnchor());
|
||||
rectangle.setShapeType(HSSFSimpleShape.OBJECT_TYPE_RECTANGLE);
|
||||
|
||||
int idx = wb.addPicture(new byte[]{1,2,3}, Workbook.PICTURE_TYPE_JPEG);
|
||||
int idx = wb1.addPicture(new byte[]{1,2,3}, Workbook.PICTURE_TYPE_JPEG);
|
||||
patriarch.createPicture(new HSSFClientAnchor(), idx);
|
||||
|
||||
patriarch.createCellComment(new HSSFClientAnchor());
|
||||
|
@ -464,8 +494,9 @@ public class TestDrawingShapes extends TestCase {
|
|||
assertEquals(HSSFTestHelper.getEscherAggregate(patriarch).getShapeToObjMapping().size(), 12);
|
||||
assertEquals(HSSFTestHelper.getEscherAggregate(patriarch).getTailRecords().size(), 1);
|
||||
|
||||
wb = HSSFTestDataSamples.writeOutAndReadBack(wb);
|
||||
sheet = wb.getSheetAt(0);
|
||||
HSSFWorkbook wb2 = HSSFTestDataSamples.writeOutAndReadBack(wb1);
|
||||
wb1.close();
|
||||
sheet = wb2.getSheetAt(0);
|
||||
patriarch = sheet.getDrawingPatriarch();
|
||||
|
||||
assertEquals(HSSFTestHelper.getEscherAggregate(patriarch).getShapeToObjMapping().size(), 12);
|
||||
|
@ -479,8 +510,9 @@ public class TestDrawingShapes extends TestCase {
|
|||
assertEquals(HSSFTestHelper.getEscherAggregate(patriarch).getShapeToObjMapping().size(), 10);
|
||||
assertEquals(HSSFTestHelper.getEscherAggregate(patriarch).getTailRecords().size(), 1);
|
||||
|
||||
wb = HSSFTestDataSamples.writeOutAndReadBack(wb);
|
||||
sheet = wb.getSheetAt(0);
|
||||
HSSFWorkbook wb3 = HSSFTestDataSamples.writeOutAndReadBack(wb2);
|
||||
wb2.close();
|
||||
sheet = wb3.getSheetAt(0);
|
||||
patriarch = sheet.getDrawingPatriarch();
|
||||
|
||||
assertEquals(HSSFTestHelper.getEscherAggregate(patriarch).getShapeToObjMapping().size(), 10);
|
||||
|
@ -492,8 +524,9 @@ public class TestDrawingShapes extends TestCase {
|
|||
assertEquals(HSSFTestHelper.getEscherAggregate(patriarch).getShapeToObjMapping().size(), 8);
|
||||
assertEquals(HSSFTestHelper.getEscherAggregate(patriarch).getTailRecords().size(), 1);
|
||||
|
||||
wb = HSSFTestDataSamples.writeOutAndReadBack(wb);
|
||||
sheet = wb.getSheetAt(0);
|
||||
HSSFWorkbook wb4 = HSSFTestDataSamples.writeOutAndReadBack(wb3);
|
||||
wb3.close();
|
||||
sheet = wb4.getSheetAt(0);
|
||||
patriarch = sheet.getDrawingPatriarch();
|
||||
|
||||
assertEquals(HSSFTestHelper.getEscherAggregate(patriarch).getShapeToObjMapping().size(), 8);
|
||||
|
@ -507,8 +540,9 @@ public class TestDrawingShapes extends TestCase {
|
|||
assertEquals(HSSFTestHelper.getEscherAggregate(patriarch).getTailRecords().size(), 1);
|
||||
assertEquals(patriarch.getChildren().size(), 4);
|
||||
|
||||
wb = HSSFTestDataSamples.writeOutAndReadBack(wb);
|
||||
sheet = wb.getSheetAt(0);
|
||||
HSSFWorkbook wb5 = HSSFTestDataSamples.writeOutAndReadBack(wb4);
|
||||
wb4.close();
|
||||
sheet = wb5.getSheetAt(0);
|
||||
patriarch = sheet.getDrawingPatriarch();
|
||||
|
||||
assertEquals(HSSFTestHelper.getEscherAggregate(patriarch).getShapeToObjMapping().size(), 6);
|
||||
|
@ -522,8 +556,9 @@ public class TestDrawingShapes extends TestCase {
|
|||
assertEquals(HSSFTestHelper.getEscherAggregate(patriarch).getTailRecords().size(), 1);
|
||||
assertEquals(patriarch.getChildren().size(), 3);
|
||||
|
||||
wb = HSSFTestDataSamples.writeOutAndReadBack(wb);
|
||||
sheet = wb.getSheetAt(0);
|
||||
HSSFWorkbook wb6 = HSSFTestDataSamples.writeOutAndReadBack(wb5);
|
||||
wb5.close();
|
||||
sheet = wb6.getSheetAt(0);
|
||||
patriarch = sheet.getDrawingPatriarch();
|
||||
|
||||
assertEquals(HSSFTestHelper.getEscherAggregate(patriarch).getShapeToObjMapping().size(), 5);
|
||||
|
@ -537,8 +572,9 @@ public class TestDrawingShapes extends TestCase {
|
|||
assertEquals(HSSFTestHelper.getEscherAggregate(patriarch).getTailRecords().size(), 0);
|
||||
assertEquals(patriarch.getChildren().size(), 2);
|
||||
|
||||
wb = HSSFTestDataSamples.writeOutAndReadBack(wb);
|
||||
sheet = wb.getSheetAt(0);
|
||||
HSSFWorkbook wb7 = HSSFTestDataSamples.writeOutAndReadBack(wb6);
|
||||
wb6.close();
|
||||
sheet = wb7.getSheetAt(0);
|
||||
patriarch = sheet.getDrawingPatriarch();
|
||||
|
||||
assertEquals(HSSFTestHelper.getEscherAggregate(patriarch).getShapeToObjMapping().size(), 3);
|
||||
|
@ -552,8 +588,9 @@ public class TestDrawingShapes extends TestCase {
|
|||
assertEquals(HSSFTestHelper.getEscherAggregate(patriarch).getTailRecords().size(), 0);
|
||||
assertEquals(patriarch.getChildren().size(), 1);
|
||||
|
||||
wb = HSSFTestDataSamples.writeOutAndReadBack(wb);
|
||||
sheet = wb.getSheetAt(0);
|
||||
HSSFWorkbook wb8 = HSSFTestDataSamples.writeOutAndReadBack(wb7);
|
||||
wb7.close();
|
||||
sheet = wb8.getSheetAt(0);
|
||||
patriarch = sheet.getDrawingPatriarch();
|
||||
|
||||
assertEquals(HSSFTestHelper.getEscherAggregate(patriarch).getShapeToObjMapping().size(), 2);
|
||||
|
@ -567,18 +604,21 @@ public class TestDrawingShapes extends TestCase {
|
|||
assertEquals(HSSFTestHelper.getEscherAggregate(patriarch).getTailRecords().size(), 0);
|
||||
assertEquals(patriarch.getChildren().size(), 0);
|
||||
|
||||
wb = HSSFTestDataSamples.writeOutAndReadBack(wb);
|
||||
sheet = wb.getSheetAt(0);
|
||||
HSSFWorkbook wb9 = HSSFTestDataSamples.writeOutAndReadBack(wb8);
|
||||
wb8.close();
|
||||
sheet = wb9.getSheetAt(0);
|
||||
patriarch = sheet.getDrawingPatriarch();
|
||||
|
||||
assertEquals(HSSFTestHelper.getEscherAggregate(patriarch).getShapeToObjMapping().size(), 0);
|
||||
assertEquals(HSSFTestHelper.getEscherAggregate(patriarch).getTailRecords().size(), 0);
|
||||
assertEquals(patriarch.getChildren().size(), 0);
|
||||
wb9.close();
|
||||
}
|
||||
|
||||
public void testShapeFlip(){
|
||||
HSSFWorkbook wb = new HSSFWorkbook();
|
||||
HSSFSheet sheet = wb.createSheet();
|
||||
@Test
|
||||
public void testShapeFlip() throws IOException {
|
||||
HSSFWorkbook wb1 = new HSSFWorkbook();
|
||||
HSSFSheet sheet = wb1.createSheet();
|
||||
HSSFPatriarch patriarch = sheet.createDrawingPatriarch();
|
||||
|
||||
HSSFSimpleShape rectangle = patriarch.createSimpleShape(new HSSFClientAnchor());
|
||||
|
@ -592,8 +632,9 @@ public class TestDrawingShapes extends TestCase {
|
|||
rectangle.setFlipHorizontal(true);
|
||||
assertEquals(rectangle.isFlipHorizontal(), true);
|
||||
|
||||
wb = HSSFTestDataSamples.writeOutAndReadBack(wb);
|
||||
sheet = wb.getSheetAt(0);
|
||||
HSSFWorkbook wb2 = HSSFTestDataSamples.writeOutAndReadBack(wb1);
|
||||
wb1.close();
|
||||
sheet = wb2.getSheetAt(0);
|
||||
patriarch = sheet.getDrawingPatriarch();
|
||||
|
||||
rectangle = (HSSFSimpleShape) patriarch.getChildren().get(0);
|
||||
|
@ -606,19 +647,22 @@ public class TestDrawingShapes extends TestCase {
|
|||
rectangle.setFlipVertical(false);
|
||||
assertEquals(rectangle.isFlipVertical(), false);
|
||||
|
||||
wb = HSSFTestDataSamples.writeOutAndReadBack(wb);
|
||||
sheet = wb.getSheetAt(0);
|
||||
HSSFWorkbook wb3 = HSSFTestDataSamples.writeOutAndReadBack(wb2);
|
||||
wb2.close();
|
||||
sheet = wb3.getSheetAt(0);
|
||||
patriarch = sheet.getDrawingPatriarch();
|
||||
|
||||
rectangle = (HSSFSimpleShape) patriarch.getChildren().get(0);
|
||||
|
||||
assertEquals(rectangle.isFlipVertical(), false);
|
||||
assertEquals(rectangle.isFlipHorizontal(), false);
|
||||
wb3.close();
|
||||
}
|
||||
|
||||
public void testRotation() {
|
||||
HSSFWorkbook wb = new HSSFWorkbook();
|
||||
HSSFSheet sheet = wb.createSheet();
|
||||
@Test
|
||||
public void testRotation() throws IOException {
|
||||
HSSFWorkbook wb1 = new HSSFWorkbook();
|
||||
HSSFSheet sheet = wb1.createSheet();
|
||||
HSSFPatriarch patriarch = sheet.createDrawingPatriarch();
|
||||
|
||||
HSSFSimpleShape rectangle = patriarch.createSimpleShape(new HSSFClientAnchor(0,0,100,100, (short) 0,0,(short)5,5));
|
||||
|
@ -629,8 +673,9 @@ public class TestDrawingShapes extends TestCase {
|
|||
assertEquals(rectangle.getRotationDegree(), 45);
|
||||
rectangle.setFlipHorizontal(true);
|
||||
|
||||
wb = HSSFTestDataSamples.writeOutAndReadBack(wb);
|
||||
sheet = wb.getSheetAt(0);
|
||||
HSSFWorkbook wb2 = HSSFTestDataSamples.writeOutAndReadBack(wb1);
|
||||
wb1.close();
|
||||
sheet = wb2.getSheetAt(0);
|
||||
patriarch = sheet.getDrawingPatriarch();
|
||||
rectangle = (HSSFSimpleShape) patriarch.getChildren().get(0);
|
||||
assertEquals(rectangle.getRotationDegree(), 45);
|
||||
|
@ -639,32 +684,33 @@ public class TestDrawingShapes extends TestCase {
|
|||
|
||||
patriarch.setCoordinates(0, 0, 10, 10);
|
||||
rectangle.setString(new HSSFRichTextString("1234"));
|
||||
wb2.close();
|
||||
}
|
||||
|
||||
public void testShapeContainerImplementsIterable() throws IOException{
|
||||
@SuppressWarnings("unused")
|
||||
@Test
|
||||
public void testShapeContainerImplementsIterable() throws IOException {
|
||||
HSSFWorkbook wb = new HSSFWorkbook();
|
||||
|
||||
try {
|
||||
HSSFSheet sheet = wb.createSheet();
|
||||
HSSFPatriarch patriarch = sheet.createDrawingPatriarch();
|
||||
|
||||
patriarch.createSimpleShape(new HSSFClientAnchor());
|
||||
patriarch.createSimpleShape(new HSSFClientAnchor());
|
||||
|
||||
int i=2;
|
||||
|
||||
for (HSSFShape shape: patriarch){
|
||||
i--;
|
||||
}
|
||||
assertEquals(i, 0);
|
||||
} finally {
|
||||
wb.close();
|
||||
HSSFSheet sheet = wb.createSheet();
|
||||
HSSFPatriarch patriarch = sheet.createDrawingPatriarch();
|
||||
|
||||
patriarch.createSimpleShape(new HSSFClientAnchor());
|
||||
patriarch.createSimpleShape(new HSSFClientAnchor());
|
||||
|
||||
int i=2;
|
||||
|
||||
for (HSSFShape shape: patriarch){
|
||||
i--;
|
||||
}
|
||||
assertEquals(i, 0);
|
||||
wb.close();
|
||||
}
|
||||
|
||||
public void testClearShapesForPatriarch(){
|
||||
HSSFWorkbook wb = new HSSFWorkbook();
|
||||
HSSFSheet sheet = wb.createSheet();
|
||||
@Test
|
||||
public void testClearShapesForPatriarch() throws IOException {
|
||||
HSSFWorkbook wb1 = new HSSFWorkbook();
|
||||
HSSFSheet sheet = wb1.createSheet();
|
||||
HSSFPatriarch patriarch = sheet.createDrawingPatriarch();
|
||||
|
||||
patriarch.createSimpleShape(new HSSFClientAnchor());
|
||||
|
@ -683,15 +729,18 @@ public class TestDrawingShapes extends TestCase {
|
|||
assertEquals(agg.getTailRecords().size(), 0);
|
||||
assertEquals(patriarch.getChildren().size(), 0);
|
||||
|
||||
wb = HSSFTestDataSamples.writeOutAndReadBack(wb);
|
||||
sheet = wb.getSheetAt(0);
|
||||
HSSFWorkbook wb2 = HSSFTestDataSamples.writeOutAndReadBack(wb1);
|
||||
wb1.close();
|
||||
sheet = wb2.getSheetAt(0);
|
||||
patriarch = sheet.getDrawingPatriarch();
|
||||
|
||||
assertEquals(agg.getShapeToObjMapping().size(), 0);
|
||||
assertEquals(agg.getTailRecords().size(), 0);
|
||||
assertEquals(patriarch.getChildren().size(), 0);
|
||||
wb2.close();
|
||||
}
|
||||
|
||||
@Test
|
||||
public void testBug45312() throws Exception {
|
||||
HSSFWorkbook wb = new HSSFWorkbook();
|
||||
try {
|
||||
|
@ -739,7 +788,7 @@ public class TestDrawingShapes extends TestCase {
|
|||
}
|
||||
}
|
||||
|
||||
private void checkWorkbookBack(HSSFWorkbook wb) {
|
||||
private void checkWorkbookBack(HSSFWorkbook wb) throws IOException {
|
||||
HSSFWorkbook wbBack = HSSFTestDataSamples.writeOutAndReadBack(wb);
|
||||
assertNotNull(wbBack);
|
||||
|
||||
|
@ -806,5 +855,7 @@ public class TestDrawingShapes extends TestCase {
|
|||
assertEquals(2, cAnchor.getCol2());
|
||||
assertEquals(2, cAnchor.getRow1());
|
||||
assertEquals(2, cAnchor.getRow2());
|
||||
|
||||
wbBack.close();
|
||||
}
|
||||
}
|
||||
|
|
|
@ -62,7 +62,7 @@ public final class TestHSSFCell extends BaseTestCell {
|
|||
* but there's a separate unit test for that.
|
||||
*/
|
||||
@Test
|
||||
public void testDateWindowingRead() throws Exception {
|
||||
public void testDateWindowingRead() throws IOException {
|
||||
Calendar cal = LocaleUtil.getLocaleCalendar(2000, 0, 1, 0, 0, 0);// Jan. 1, 2000
|
||||
Date date = cal.getTime();
|
||||
|
||||
|
@ -94,7 +94,7 @@ public final class TestHSSFCell extends BaseTestCell {
|
|||
* results of this test are meaningless.
|
||||
*/
|
||||
@Test
|
||||
public void testDateWindowingWrite() throws Exception {
|
||||
public void testDateWindowingWrite() throws IOException {
|
||||
Calendar cal = LocaleUtil.getLocaleCalendar(2000,0,1,0,0,0); // Jan. 1, 2000
|
||||
Date date = cal.getTime();
|
||||
|
||||
|
@ -143,7 +143,7 @@ public final class TestHSSFCell extends BaseTestCell {
|
|||
* Tests that the active cell can be correctly read and set
|
||||
*/
|
||||
@Test
|
||||
public void testActiveCell() throws Exception {
|
||||
public void testActiveCell() throws IOException {
|
||||
//read in sample
|
||||
HSSFWorkbook wb1 = HSSFTestDataSamples.openSampleWorkbook("Simple.xls");
|
||||
|
||||
|
@ -235,7 +235,7 @@ public final class TestHSSFCell extends BaseTestCell {
|
|||
* Test reading hyperlinks
|
||||
*/
|
||||
@Test
|
||||
public void testWithHyperlink() throws Exception {
|
||||
public void testWithHyperlink() throws IOException {
|
||||
|
||||
HSSFWorkbook wb = HSSFTestDataSamples.openSampleWorkbook("WithHyperlink.xls");
|
||||
|
||||
|
@ -256,7 +256,7 @@ public final class TestHSSFCell extends BaseTestCell {
|
|||
* Test reading hyperlinks
|
||||
*/
|
||||
@Test
|
||||
public void testWithTwoHyperlinks() throws Exception {
|
||||
public void testWithTwoHyperlinks() throws IOException {
|
||||
|
||||
HSSFWorkbook wb = HSSFTestDataSamples.openSampleWorkbook("WithTwoHyperLinks.xls");
|
||||
|
||||
|
@ -286,7 +286,7 @@ public final class TestHSSFCell extends BaseTestCell {
|
|||
* to our workbook, and not those from other workbooks.
|
||||
*/
|
||||
@Test
|
||||
public void testCellStyleWorkbookMatch() throws Exception {
|
||||
public void testCellStyleWorkbookMatch() throws IOException {
|
||||
HSSFWorkbook wbA = new HSSFWorkbook();
|
||||
HSSFWorkbook wbB = new HSSFWorkbook();
|
||||
|
||||
|
@ -386,14 +386,14 @@ public final class TestHSSFCell extends BaseTestCell {
|
|||
* HSSF prior to version 3.7 had a bug: it could write a NaN but could not read such a file back.
|
||||
*/
|
||||
@Test
|
||||
public void testReadNaN() throws Exception {
|
||||
public void testReadNaN() throws IOException {
|
||||
HSSFWorkbook wb = HSSFTestDataSamples.openSampleWorkbook("49761.xls");
|
||||
assertNotNull(wb);
|
||||
wb.close();
|
||||
}
|
||||
|
||||
@Test
|
||||
public void testHSSFCell() throws Exception {
|
||||
public void testHSSFCell() throws IOException {
|
||||
HSSFWorkbook wb = new HSSFWorkbook();
|
||||
HSSFSheet sheet = wb.createSheet();
|
||||
HSSFRow row = sheet.createRow(0);
|
||||
|
@ -403,9 +403,8 @@ public final class TestHSSFCell extends BaseTestCell {
|
|||
wb.close();
|
||||
}
|
||||
|
||||
@SuppressWarnings("deprecation")
|
||||
@Test
|
||||
public void testDeprecatedMethods() throws Exception {
|
||||
public void testDeprecatedMethods() throws IOException {
|
||||
HSSFWorkbook wb = new HSSFWorkbook();
|
||||
HSSFSheet sheet = wb.createSheet();
|
||||
HSSFRow row = sheet.createRow(0);
|
||||
|
|
|
@ -24,13 +24,7 @@ import org.apache.poi.ss.formula.BaseTestExternalFunctions;
|
|||
* Tests setting and evaluating user-defined functions in HSSF
|
||||
*/
|
||||
public final class TestHSSFExternalFunctions extends BaseTestExternalFunctions {
|
||||
|
||||
public TestHSSFExternalFunctions() {
|
||||
super(HSSFITestDataProvider.instance);
|
||||
super(HSSFITestDataProvider.instance, "atp.xls");
|
||||
}
|
||||
|
||||
public void testATP(){
|
||||
baseTestInvokeATP("atp.xls");
|
||||
}
|
||||
|
||||
}
|
||||
|
|
|
@ -20,9 +20,6 @@ package org.apache.poi.hssf.usermodel;
|
|||
import org.apache.poi.hssf.HSSFITestDataProvider;
|
||||
import org.apache.poi.ss.usermodel.BaseTestSheetHiding;
|
||||
|
||||
/**
|
||||
* @author Yegor Kozlov
|
||||
*/
|
||||
public final class TestSheetHiding extends BaseTestSheetHiding {
|
||||
public TestSheetHiding() {
|
||||
super(HSSFITestDataProvider.instance,
|
||||
|
|
|
@ -16,7 +16,10 @@
|
|||
==================================================================== */
|
||||
package org.apache.poi.ss.formula;
|
||||
|
||||
import junit.framework.TestCase;
|
||||
import static org.junit.Assert.*;
|
||||
|
||||
import java.io.IOException;
|
||||
|
||||
import org.apache.poi.ss.ITestDataProvider;
|
||||
import org.apache.poi.ss.formula.eval.ErrorEval;
|
||||
import org.apache.poi.ss.formula.eval.NotImplementedException;
|
||||
|
@ -30,13 +33,12 @@ import org.apache.poi.ss.usermodel.Cell;
|
|||
import org.apache.poi.ss.usermodel.FormulaEvaluator;
|
||||
import org.apache.poi.ss.usermodel.Sheet;
|
||||
import org.apache.poi.ss.usermodel.Workbook;
|
||||
import org.junit.Test;
|
||||
|
||||
/**
|
||||
* Test setting / evaluating of Analysis Toolpack and user-defined functions
|
||||
*
|
||||
* @author Yegor Kozlov
|
||||
*/
|
||||
public class BaseTestExternalFunctions extends TestCase {
|
||||
public class BaseTestExternalFunctions {
|
||||
// define two custom user-defined functions
|
||||
private static class MyFunc implements FreeRefFunction {
|
||||
public MyFunc() {
|
||||
|
@ -75,34 +77,37 @@ public class BaseTestExternalFunctions extends TestCase {
|
|||
);
|
||||
|
||||
|
||||
protected final ITestDataProvider _testDataProvider;
|
||||
private final ITestDataProvider _testDataProvider;
|
||||
private final String atpFile;
|
||||
|
||||
/**
|
||||
* @param testDataProvider an object that provides test data in HSSF / XSSF specific way
|
||||
*/
|
||||
protected BaseTestExternalFunctions(ITestDataProvider testDataProvider) {
|
||||
protected BaseTestExternalFunctions(ITestDataProvider testDataProvider, String atpFile) {
|
||||
_testDataProvider = testDataProvider;
|
||||
this.atpFile = atpFile;
|
||||
}
|
||||
|
||||
public void testExternalFunctions() {
|
||||
@Test
|
||||
public void testExternalFunctions() throws IOException {
|
||||
Workbook wb = _testDataProvider.createWorkbook();
|
||||
FormulaEvaluator evaluator = wb.getCreationHelper().createFormulaEvaluator();
|
||||
|
||||
Sheet sh = wb.createSheet();
|
||||
|
||||
Cell cell1 = sh.createRow(0).createCell(0);
|
||||
cell1.setCellFormula("ISODD(1)+ISEVEN(2)"); // functions from the Excel Analysis Toolpack
|
||||
// functions from the Excel Analysis Toolpack
|
||||
cell1.setCellFormula("ISODD(1)+ISEVEN(2)");
|
||||
assertEquals("ISODD(1)+ISEVEN(2)", cell1.getCellFormula());
|
||||
|
||||
Cell cell2 = sh.createRow(1).createCell(0);
|
||||
cell2.setCellFormula("MYFUNC(\"B1\")"); //unregistered functions are parseable and renderable, but may not be evaluateable
|
||||
// unregistered functions are parseable and renderable, but may not be evaluateable
|
||||
cell2.setCellFormula("MYFUNC(\"B1\")");
|
||||
try {
|
||||
evaluator.evaluate(cell2);
|
||||
fail("Expected NotImplementedFunctionException/NotImplementedException");
|
||||
} catch (final NotImplementedException e) {
|
||||
if (!(e.getCause() instanceof NotImplementedFunctionException))
|
||||
throw e;
|
||||
// expected
|
||||
assertTrue(e.getCause() instanceof NotImplementedFunctionException);
|
||||
// Alternatively, a future implementation of evaluate could return #NAME? error to align behavior with Excel
|
||||
// assertEquals(ErrorEval.NAME_INVALID, ErrorEval.valueOf(evaluator.evaluate(cell2).getErrorValue()));
|
||||
}
|
||||
|
@ -116,10 +121,11 @@ public class BaseTestExternalFunctions extends TestCase {
|
|||
cell3.setCellFormula("MYFUNC2(\"C1\")&\"-\"&A2"); //where A2 is defined above
|
||||
assertEquals("MYFUNC2(\"C1\")&\"-\"&A2", cell3.getCellFormula());
|
||||
|
||||
assertEquals(2.0, evaluator.evaluate(cell1).getNumberValue());
|
||||
assertEquals(2.0, evaluator.evaluate(cell1).getNumberValue(), 0);
|
||||
assertEquals("B1abc", evaluator.evaluate(cell2).getStringValue());
|
||||
assertEquals("C1abc2-B1abc", evaluator.evaluate(cell3).getStringValue());
|
||||
|
||||
wb.close();
|
||||
}
|
||||
|
||||
/**
|
||||
|
@ -127,12 +133,13 @@ public class BaseTestExternalFunctions extends TestCase {
|
|||
*
|
||||
* @param testFile either atp.xls or atp.xlsx
|
||||
*/
|
||||
public void baseTestInvokeATP(String testFile){
|
||||
Workbook wb = _testDataProvider.openSampleWorkbook(testFile);
|
||||
@Test
|
||||
public void baseTestInvokeATP() throws IOException {
|
||||
Workbook wb = _testDataProvider.openSampleWorkbook(atpFile);
|
||||
FormulaEvaluator evaluator = wb.getCreationHelper().createFormulaEvaluator();
|
||||
|
||||
Sheet sh = wb.getSheetAt(0);
|
||||
// these two are not imlemented in r
|
||||
// these two are not implemented in r
|
||||
assertEquals("DELTA(1.3,1.5)", sh.getRow(0).getCell(1).getCellFormula());
|
||||
assertEquals("COMPLEX(2,4)", sh.getRow(1).getCell(1).getCellFormula());
|
||||
|
||||
|
@ -146,6 +153,7 @@ public class BaseTestExternalFunctions extends TestCase {
|
|||
assertEquals(true, evaluator.evaluate(cell3).getBooleanValue());
|
||||
assertEquals(Cell.CELL_TYPE_BOOLEAN, evaluator.evaluateFormulaCell(cell3));
|
||||
|
||||
wb.close();
|
||||
}
|
||||
|
||||
}
|
||||
|
|
|
@ -17,6 +17,7 @@
|
|||
|
||||
package org.apache.poi.ss.usermodel;
|
||||
|
||||
import static org.apache.poi.ss.usermodel.FormulaError.forInt;
|
||||
import static org.junit.Assert.assertEquals;
|
||||
import static org.junit.Assert.assertFalse;
|
||||
import static org.junit.Assert.assertNotNull;
|
||||
|
@ -25,38 +26,22 @@ import static org.junit.Assert.assertTrue;
|
|||
import static org.junit.Assert.fail;
|
||||
|
||||
import java.io.IOException;
|
||||
import java.util.ArrayList;
|
||||
import java.util.Calendar;
|
||||
import java.util.List;
|
||||
|
||||
import org.apache.poi.hssf.usermodel.HSSFWorkbook;
|
||||
import org.apache.poi.ss.ITestDataProvider;
|
||||
import org.apache.poi.ss.SpreadsheetVersion;
|
||||
import org.apache.poi.util.LocaleUtil;
|
||||
import org.junit.After;
|
||||
import org.junit.Test;
|
||||
|
||||
import junit.framework.AssertionFailedError;
|
||||
|
||||
/**
|
||||
* Common superclass for testing implementations of
|
||||
* {@link org.apache.poi.ss.usermodel.Cell}
|
||||
*/
|
||||
@SuppressWarnings("deprecation")
|
||||
public abstract class BaseTestCell {
|
||||
|
||||
protected final ITestDataProvider _testDataProvider;
|
||||
|
||||
private List<Workbook> workbooksToClose = new ArrayList<Workbook>();
|
||||
|
||||
@After
|
||||
public void tearDown() throws IOException {
|
||||
// free resources correctly
|
||||
for(Workbook wb : workbooksToClose) {
|
||||
wb.close();
|
||||
}
|
||||
}
|
||||
|
||||
/**
|
||||
* @param testDataProvider an object that provides test data in HSSF / XSSF specific way
|
||||
*/
|
||||
|
@ -307,7 +292,7 @@ public abstract class BaseTestCell {
|
|||
r.createCell(0).setCellValue(true);
|
||||
r.createCell(1).setCellValue(1.5);
|
||||
r.createCell(2).setCellValue(factory.createRichTextString("Astring"));
|
||||
r.createCell(3).setCellErrorValue((byte)ErrorConstants.ERROR_DIV_0);
|
||||
r.createCell(3).setCellErrorValue(FormulaError.DIV0.getCode());
|
||||
r.createCell(4).setCellFormula("A1+B1");
|
||||
|
||||
assertEquals("Boolean", "TRUE", r.getCell(0).toString());
|
||||
|
@ -364,9 +349,7 @@ public abstract class BaseTestCell {
|
|||
|
||||
}
|
||||
|
||||
private Cell createACell() {
|
||||
Workbook wb = _testDataProvider.createWorkbook();
|
||||
workbooksToClose.add(wb);
|
||||
private Cell createACell(Workbook wb) {
|
||||
return wb.createSheet("Sheet1").createRow(0).createCell(0);
|
||||
}
|
||||
|
||||
|
@ -410,17 +393,15 @@ public abstract class BaseTestCell {
|
|||
}
|
||||
|
||||
@Test
|
||||
public void testChangeTypeStringToBool() {
|
||||
Cell cell = createACell();
|
||||
public void testChangeTypeStringToBool() throws IOException {
|
||||
Workbook wb = _testDataProvider.createWorkbook();
|
||||
|
||||
Cell cell = createACell(wb);
|
||||
|
||||
cell.setCellValue("TRUE");
|
||||
assertEquals(Cell.CELL_TYPE_STRING, cell.getCellType());
|
||||
try {
|
||||
cell.setCellType(Cell.CELL_TYPE_BOOLEAN);
|
||||
} catch (ClassCastException e) {
|
||||
throw new AssertionFailedError(
|
||||
"Identified bug in conversion of cell from text to boolean");
|
||||
}
|
||||
// test conversion of cell from text to boolean
|
||||
cell.setCellType(Cell.CELL_TYPE_BOOLEAN);
|
||||
|
||||
assertEquals(Cell.CELL_TYPE_BOOLEAN, cell.getCellType());
|
||||
assertEquals(true, cell.getBooleanCellValue());
|
||||
|
@ -434,52 +415,51 @@ public abstract class BaseTestCell {
|
|||
assertEquals(false, cell.getBooleanCellValue());
|
||||
cell.setCellType(Cell.CELL_TYPE_STRING);
|
||||
assertEquals("FALSE", cell.getRichStringCellValue().getString());
|
||||
|
||||
wb.close();
|
||||
}
|
||||
|
||||
@Test
|
||||
public void testChangeTypeBoolToString() {
|
||||
Cell cell = createACell();
|
||||
public void testChangeTypeBoolToString() throws IOException {
|
||||
Workbook wb = _testDataProvider.createWorkbook();
|
||||
|
||||
Cell cell = createACell(wb);
|
||||
|
||||
cell.setCellValue(true);
|
||||
try {
|
||||
cell.setCellType(Cell.CELL_TYPE_STRING);
|
||||
} catch (IllegalStateException e) {
|
||||
if (e.getMessage().equals("Cannot get a text value from a boolean cell")) {
|
||||
throw new AssertionFailedError(
|
||||
"Identified bug in conversion of cell from boolean to text");
|
||||
}
|
||||
throw e;
|
||||
}
|
||||
// test conversion of cell from boolean to text
|
||||
cell.setCellType(Cell.CELL_TYPE_STRING);
|
||||
assertEquals("TRUE", cell.getRichStringCellValue().getString());
|
||||
|
||||
wb.close();
|
||||
}
|
||||
|
||||
@Test
|
||||
public void testChangeTypeErrorToNumber() {
|
||||
Cell cell = createACell();
|
||||
cell.setCellErrorValue((byte)ErrorConstants.ERROR_NAME);
|
||||
public void testChangeTypeErrorToNumber() throws IOException {
|
||||
Workbook wb = _testDataProvider.createWorkbook();
|
||||
|
||||
Cell cell = createACell(wb);
|
||||
cell.setCellErrorValue(FormulaError.NAME.getCode());
|
||||
try {
|
||||
cell.setCellValue(2.5);
|
||||
} catch (ClassCastException e) {
|
||||
throw new AssertionFailedError("Identified bug 46479b");
|
||||
fail("Identified bug 46479b");
|
||||
}
|
||||
assertEquals(2.5, cell.getNumericCellValue(), 0.0);
|
||||
|
||||
wb.close();
|
||||
}
|
||||
|
||||
@Test
|
||||
public void testChangeTypeErrorToBoolean() {
|
||||
Cell cell = createACell();
|
||||
cell.setCellErrorValue((byte)ErrorConstants.ERROR_NAME);
|
||||
cell.setCellValue(true);
|
||||
try {
|
||||
cell.getBooleanCellValue();
|
||||
} catch (IllegalStateException e) {
|
||||
if (e.getMessage().equals("Cannot get a boolean value from a error cell")) {
|
||||
public void testChangeTypeErrorToBoolean() throws IOException {
|
||||
Workbook wb = _testDataProvider.createWorkbook();
|
||||
|
||||
throw new AssertionFailedError("Identified bug 46479c");
|
||||
}
|
||||
throw e;
|
||||
}
|
||||
Cell cell = createACell(wb);
|
||||
cell.setCellErrorValue(FormulaError.NAME.getCode());
|
||||
cell.setCellValue(true);
|
||||
// Identify bug 46479c
|
||||
assertEquals(true, cell.getBooleanCellValue());
|
||||
|
||||
wb.close();
|
||||
}
|
||||
|
||||
/**
|
||||
|
@ -488,8 +468,10 @@ public abstract class BaseTestCell {
|
|||
* string result type.
|
||||
*/
|
||||
@Test
|
||||
public void testConvertStringFormulaCell() {
|
||||
Cell cellA1 = createACell();
|
||||
public void testConvertStringFormulaCell() throws IOException {
|
||||
Workbook wb = _testDataProvider.createWorkbook();
|
||||
|
||||
Cell cellA1 = createACell(wb);
|
||||
cellA1.setCellFormula("\"abc\"");
|
||||
|
||||
// default cached formula result is numeric zero
|
||||
|
@ -501,10 +483,10 @@ public abstract class BaseTestCell {
|
|||
assertEquals("abc", cellA1.getStringCellValue());
|
||||
|
||||
fe.evaluateInCell(cellA1);
|
||||
if (cellA1.getStringCellValue().equals("")) {
|
||||
throw new AssertionFailedError("Identified bug with writing back formula result of type string");
|
||||
}
|
||||
assertFalse("Identified bug with writing back formula result of type string", cellA1.getStringCellValue().equals(""));
|
||||
assertEquals("abc", cellA1.getStringCellValue());
|
||||
|
||||
wb.close();
|
||||
}
|
||||
|
||||
/**
|
||||
|
@ -512,8 +494,10 @@ public abstract class BaseTestCell {
|
|||
* lower level that {#link {@link Cell#setCellType(int)} works properly
|
||||
*/
|
||||
@Test
|
||||
public void testSetTypeStringOnFormulaCell() {
|
||||
Cell cellA1 = createACell();
|
||||
public void testSetTypeStringOnFormulaCell() throws IOException {
|
||||
Workbook wb = _testDataProvider.createWorkbook();
|
||||
|
||||
Cell cellA1 = createACell(wb);
|
||||
FormulaEvaluator fe = cellA1.getSheet().getWorkbook().getCreationHelper().createFormulaEvaluator();
|
||||
|
||||
cellA1.setCellFormula("\"DEF\"");
|
||||
|
@ -543,9 +527,11 @@ public abstract class BaseTestCell {
|
|||
fe.clearAllCachedResultValues();
|
||||
fe.evaluateFormulaCell(cellA1);
|
||||
confirmCannotReadString(cellA1);
|
||||
assertEquals(ErrorConstants.ERROR_NAME, cellA1.getErrorCellValue());
|
||||
assertEquals(FormulaError.NAME, forInt(cellA1.getErrorCellValue()));
|
||||
cellA1.setCellType(Cell.CELL_TYPE_STRING);
|
||||
assertEquals("#NAME?", cellA1.getStringCellValue());
|
||||
|
||||
wb.close();
|
||||
}
|
||||
|
||||
private static void confirmCannotReadString(Cell cell) {
|
||||
|
@ -556,15 +542,17 @@ public abstract class BaseTestCell {
|
|||
* Test for bug in convertCellValueToBoolean to make sure that formula results get converted
|
||||
*/
|
||||
@Test
|
||||
public void testChangeTypeFormulaToBoolean() {
|
||||
Cell cell = createACell();
|
||||
public void testChangeTypeFormulaToBoolean() throws IOException {
|
||||
Workbook wb = _testDataProvider.createWorkbook();
|
||||
|
||||
Cell cell = createACell(wb);
|
||||
cell.setCellFormula("1=1");
|
||||
cell.setCellValue(true);
|
||||
cell.setCellType(Cell.CELL_TYPE_BOOLEAN);
|
||||
if (cell.getBooleanCellValue() == false) {
|
||||
throw new AssertionFailedError("Identified bug 46479d");
|
||||
}
|
||||
assertTrue("Identified bug 46479d", cell.getBooleanCellValue());
|
||||
assertEquals(true, cell.getBooleanCellValue());
|
||||
|
||||
wb.close();
|
||||
}
|
||||
|
||||
/**
|
||||
|
@ -664,17 +652,17 @@ public abstract class BaseTestCell {
|
|||
Cell cell0 = row.createCell(0);
|
||||
cell0.setCellValue(Double.NaN);
|
||||
assertEquals("Double.NaN should change cell type to CELL_TYPE_ERROR", Cell.CELL_TYPE_ERROR, cell0.getCellType());
|
||||
assertEquals("Double.NaN should change cell value to #NUM!", ErrorConstants.ERROR_NUM, cell0.getErrorCellValue());
|
||||
assertEquals("Double.NaN should change cell value to #NUM!", FormulaError.NUM, forInt(cell0.getErrorCellValue()));
|
||||
|
||||
Cell cell1 = row.createCell(1);
|
||||
cell1.setCellValue(Double.POSITIVE_INFINITY);
|
||||
assertEquals("Double.POSITIVE_INFINITY should change cell type to CELL_TYPE_ERROR", Cell.CELL_TYPE_ERROR, cell1.getCellType());
|
||||
assertEquals("Double.POSITIVE_INFINITY should change cell value to #DIV/0!", ErrorConstants.ERROR_DIV_0, cell1.getErrorCellValue());
|
||||
assertEquals("Double.POSITIVE_INFINITY should change cell value to #DIV/0!", FormulaError.DIV0, forInt(cell1.getErrorCellValue()));
|
||||
|
||||
Cell cell2 = row.createCell(2);
|
||||
cell2.setCellValue(Double.NEGATIVE_INFINITY);
|
||||
assertEquals("Double.NEGATIVE_INFINITY should change cell type to CELL_TYPE_ERROR", Cell.CELL_TYPE_ERROR, cell2.getCellType());
|
||||
assertEquals("Double.NEGATIVE_INFINITY should change cell value to #DIV/0!", ErrorConstants.ERROR_DIV_0, cell2.getErrorCellValue());
|
||||
assertEquals("Double.NEGATIVE_INFINITY should change cell value to #DIV/0!", FormulaError.DIV0, forInt(cell2.getErrorCellValue()));
|
||||
|
||||
Workbook wb2 = _testDataProvider.writeOutAndReadBack(wb1);
|
||||
wb1.close();
|
||||
|
@ -682,15 +670,15 @@ public abstract class BaseTestCell {
|
|||
|
||||
cell0 = row.getCell(0);
|
||||
assertEquals(Cell.CELL_TYPE_ERROR, cell0.getCellType());
|
||||
assertEquals(ErrorConstants.ERROR_NUM, cell0.getErrorCellValue());
|
||||
assertEquals(FormulaError.NUM, forInt(cell0.getErrorCellValue()));
|
||||
|
||||
cell1 = row.getCell(1);
|
||||
assertEquals(Cell.CELL_TYPE_ERROR, cell1.getCellType());
|
||||
assertEquals(ErrorConstants.ERROR_DIV_0, cell1.getErrorCellValue());
|
||||
assertEquals(FormulaError.DIV0, forInt(cell1.getErrorCellValue()));
|
||||
|
||||
cell2 = row.getCell(2);
|
||||
assertEquals(Cell.CELL_TYPE_ERROR, cell2.getCellType());
|
||||
assertEquals(ErrorConstants.ERROR_DIV_0, cell2.getErrorCellValue());
|
||||
assertEquals(FormulaError.DIV0, forInt(cell2.getErrorCellValue()));
|
||||
wb2.close();
|
||||
}
|
||||
|
||||
|
|
|
@ -24,13 +24,14 @@ import static org.junit.Assert.assertNull;
|
|||
import static org.junit.Assert.assertTrue;
|
||||
import static org.junit.Assert.fail;
|
||||
|
||||
import java.io.IOException;
|
||||
import java.util.List;
|
||||
|
||||
import org.apache.poi.ss.ITestDataProvider;
|
||||
import org.apache.poi.ss.util.AreaReference;
|
||||
import org.apache.poi.ss.util.CellReference;
|
||||
import org.junit.Test;
|
||||
|
||||
import java.util.List;
|
||||
|
||||
/**
|
||||
* Tests of implementations of {@link org.apache.poi.ss.usermodel.Name}.
|
||||
*
|
||||
|
@ -647,7 +648,7 @@ public abstract class BaseTestNamedRange {
|
|||
}
|
||||
|
||||
@Test
|
||||
public void testBug56930() {
|
||||
public void testBug56930() throws IOException {
|
||||
Workbook wb = _testDataProvider.createWorkbook();
|
||||
|
||||
// x1 on sheet1 defines "x=1"
|
||||
|
@ -673,5 +674,7 @@ public abstract class BaseTestNamedRange {
|
|||
assertEquals("1", wb.getName("x").getRefersToFormula());
|
||||
wb.removeName("x");
|
||||
assertEquals("2", wb.getName("x").getRefersToFormula());
|
||||
|
||||
wb.close();
|
||||
}
|
||||
}
|
||||
|
|
|
@ -17,9 +17,13 @@
|
|||
|
||||
package org.apache.poi.ss.usermodel;
|
||||
|
||||
import static junit.framework.TestCase.assertNotNull;
|
||||
import static junit.framework.TestCase.assertTrue;
|
||||
import static org.junit.Assert.*;
|
||||
import static org.junit.Assert.assertEquals;
|
||||
import static org.junit.Assert.assertFalse;
|
||||
import static org.junit.Assert.assertNotNull;
|
||||
import static org.junit.Assert.assertNull;
|
||||
import static org.junit.Assert.assertSame;
|
||||
import static org.junit.Assert.assertTrue;
|
||||
import static org.junit.Assert.fail;
|
||||
|
||||
import java.io.IOException;
|
||||
import java.util.Iterator;
|
||||
|
@ -266,11 +270,11 @@ public abstract class BaseTestSheet {
|
|||
}
|
||||
|
||||
/**
|
||||
* Dissallow creating wholly or partially overlapping merged regions
|
||||
* Disallow creating wholly or partially overlapping merged regions
|
||||
* as this results in a corrupted workbook
|
||||
*/
|
||||
@Test
|
||||
public void addOverlappingMergedRegions() {
|
||||
public void addOverlappingMergedRegions() throws IOException {
|
||||
final Workbook wb = _testDataProvider.createWorkbook();
|
||||
final Sheet sheet = wb.createSheet();
|
||||
|
||||
|
@ -282,14 +286,14 @@ public abstract class BaseTestSheet {
|
|||
sheet.addMergedRegion(duplicateRegion);
|
||||
fail("Should not be able to add a merged region (" + duplicateRegion.formatAsString() + ") " +
|
||||
"if sheet already contains the same merged region (" + baseRegion.formatAsString() + ")");
|
||||
} catch (final IllegalStateException e) { } //expected
|
||||
} catch (final IllegalStateException e) { }
|
||||
|
||||
try {
|
||||
final CellRangeAddress partiallyOverlappingRegion = new CellRangeAddress(1, 2, 1, 2); //B2:C3
|
||||
sheet.addMergedRegion(partiallyOverlappingRegion);
|
||||
fail("Should not be able to add a merged region (" + partiallyOverlappingRegion.formatAsString() + ") " +
|
||||
"if it partially overlaps with an existing merged region (" + baseRegion.formatAsString() + ")");
|
||||
} catch (final IllegalStateException e) { } //expected
|
||||
} catch (final IllegalStateException e) { }
|
||||
|
||||
try {
|
||||
final CellRangeAddress subsetRegion = new CellRangeAddress(0, 1, 0, 0); //A1:A2
|
||||
|
@ -303,10 +307,12 @@ public abstract class BaseTestSheet {
|
|||
sheet.addMergedRegion(supersetRegion);
|
||||
fail("Should not be able to add a merged region (" + supersetRegion.formatAsString() + ") " +
|
||||
"if it is a formal superset of an existing merged region (" + baseRegion.formatAsString() + ")");
|
||||
} catch (final IllegalStateException e) { } //expected
|
||||
} catch (final IllegalStateException e) { }
|
||||
|
||||
final CellRangeAddress disjointRegion = new CellRangeAddress(10, 11, 10, 11);
|
||||
sheet.addMergedRegion(disjointRegion); //allowed
|
||||
sheet.addMergedRegion(disjointRegion);
|
||||
|
||||
wb.close();
|
||||
}
|
||||
|
||||
/*
|
||||
|
|
|
@ -17,13 +17,19 @@
|
|||
|
||||
package org.apache.poi.ss.usermodel;
|
||||
|
||||
import junit.framework.TestCase;
|
||||
import static org.junit.Assert.assertEquals;
|
||||
import static org.junit.Assert.assertFalse;
|
||||
import static org.junit.Assert.assertTrue;
|
||||
import static org.junit.Assert.fail;
|
||||
|
||||
import java.io.IOException;
|
||||
|
||||
import org.apache.poi.ss.ITestDataProvider;
|
||||
import org.junit.After;
|
||||
import org.junit.Before;
|
||||
import org.junit.Test;
|
||||
|
||||
/**
|
||||
*/
|
||||
public abstract class BaseTestSheetHiding extends TestCase {
|
||||
public abstract class BaseTestSheetHiding {
|
||||
|
||||
protected final ITestDataProvider _testDataProvider;
|
||||
protected Workbook wbH;
|
||||
|
@ -41,15 +47,22 @@ public abstract class BaseTestSheetHiding extends TestCase {
|
|||
_file2 = file2;
|
||||
}
|
||||
|
||||
protected void setUp() {
|
||||
@Before
|
||||
public void setUp() {
|
||||
wbH = _testDataProvider.openSampleWorkbook(_file1);
|
||||
wbU = _testDataProvider.openSampleWorkbook(_file2);
|
||||
}
|
||||
|
||||
|
||||
public final void testSheetHidden() {
|
||||
@After
|
||||
public void teadDown() throws IOException {
|
||||
wbH.close();
|
||||
wbU.close();
|
||||
}
|
||||
|
||||
@Test
|
||||
public final void testSheetHidden() throws IOException {
|
||||
Workbook wb = _testDataProvider.createWorkbook();
|
||||
Sheet sh = wb.createSheet("MySheet");
|
||||
wb.createSheet("MySheet");
|
||||
|
||||
assertFalse(wb.isSheetHidden(0));
|
||||
assertFalse(wb.isSheetVeryHidden(0));
|
||||
|
@ -78,6 +91,8 @@ public abstract class BaseTestSheetHiding extends TestCase {
|
|||
} catch (IllegalArgumentException e){
|
||||
// ok
|
||||
}
|
||||
|
||||
wb.close();
|
||||
}
|
||||
|
||||
/**
|
||||
|
@ -85,6 +100,7 @@ public abstract class BaseTestSheetHiding extends TestCase {
|
|||
* with the right text on them, no matter what
|
||||
* the hidden flags are
|
||||
*/
|
||||
@Test
|
||||
public void testTextSheets() {
|
||||
// Both should have two sheets
|
||||
assertEquals(2, wbH.getNumberOfSheets());
|
||||
|
@ -113,6 +129,7 @@ public abstract class BaseTestSheetHiding extends TestCase {
|
|||
* Check that we can get and set the hidden flags
|
||||
* as expected
|
||||
*/
|
||||
@Test
|
||||
public void testHideUnHideFlags() {
|
||||
assertTrue(wbH.isSheetHidden(0));
|
||||
assertFalse(wbH.isSheetHidden(1));
|
||||
|
@ -124,25 +141,29 @@ public abstract class BaseTestSheetHiding extends TestCase {
|
|||
* Turn the sheet with none hidden into the one with
|
||||
* one hidden
|
||||
*/
|
||||
public void testHide() {
|
||||
@Test
|
||||
public void testHide() throws IOException {
|
||||
wbU.setSheetHidden(0, true);
|
||||
assertTrue(wbU.isSheetHidden(0));
|
||||
assertFalse(wbU.isSheetHidden(1));
|
||||
Workbook wb2 = _testDataProvider.writeOutAndReadBack(wbU);
|
||||
assertTrue(wb2.isSheetHidden(0));
|
||||
assertFalse(wb2.isSheetHidden(1));
|
||||
wb2.close();
|
||||
}
|
||||
|
||||
/**
|
||||
* Turn the sheet with one hidden into the one with
|
||||
* none hidden
|
||||
*/
|
||||
public void testUnHide() {
|
||||
@Test
|
||||
public void testUnHide() throws IOException {
|
||||
wbH.setSheetHidden(0, false);
|
||||
assertFalse(wbH.isSheetHidden(0));
|
||||
assertFalse(wbH.isSheetHidden(1));
|
||||
Workbook wb2 = _testDataProvider.writeOutAndReadBack(wbH);
|
||||
assertFalse(wb2.isSheetHidden(0));
|
||||
assertFalse(wb2.isSheetHidden(1));
|
||||
wb2.close();
|
||||
}
|
||||
}
|
Loading…
Reference in New Issue