mirror of https://github.com/apache/poi.git
adjust tests, javadoc, ...
git-svn-id: https://svn.apache.org/repos/asf/poi/trunk@1811865 13f79535-47bb-0310-9956-ffa450edef68
This commit is contained in:
parent
d9a818dc22
commit
2dc64ebbcc
|
@ -130,7 +130,7 @@ public interface BorderFormatting {
|
||||||
/**
|
/**
|
||||||
* Set bottom border.
|
* Set bottom border.
|
||||||
*
|
*
|
||||||
* @param border
|
* @param border The style of border to set.
|
||||||
*/
|
*/
|
||||||
void setBorderBottom(BorderStyle border);
|
void setBorderBottom(BorderStyle border);
|
||||||
|
|
||||||
|
@ -145,7 +145,7 @@ public interface BorderFormatting {
|
||||||
/**
|
/**
|
||||||
* Set diagonal border.
|
* Set diagonal border.
|
||||||
*
|
*
|
||||||
* @param border
|
* @param border The style of border to set.
|
||||||
*/
|
*/
|
||||||
void setBorderDiagonal(BorderStyle border);
|
void setBorderDiagonal(BorderStyle border);
|
||||||
|
|
||||||
|
@ -160,7 +160,7 @@ public interface BorderFormatting {
|
||||||
/**
|
/**
|
||||||
* Set left border.
|
* Set left border.
|
||||||
*
|
*
|
||||||
* @param border
|
* @param border The style of border to set.
|
||||||
*/
|
*/
|
||||||
void setBorderLeft(BorderStyle border);
|
void setBorderLeft(BorderStyle border);
|
||||||
|
|
||||||
|
@ -175,7 +175,7 @@ public interface BorderFormatting {
|
||||||
/**
|
/**
|
||||||
* Set right border.
|
* Set right border.
|
||||||
*
|
*
|
||||||
* @param border
|
* @param border The style of border to set.
|
||||||
*/
|
*/
|
||||||
void setBorderRight(BorderStyle border);
|
void setBorderRight(BorderStyle border);
|
||||||
|
|
||||||
|
@ -190,7 +190,7 @@ public interface BorderFormatting {
|
||||||
/**
|
/**
|
||||||
* Set top border.
|
* Set top border.
|
||||||
*
|
*
|
||||||
* @param border
|
* @param border The style of border to set.
|
||||||
*/
|
*/
|
||||||
void setBorderTop(BorderStyle border);
|
void setBorderTop(BorderStyle border);
|
||||||
|
|
||||||
|
@ -198,7 +198,7 @@ public interface BorderFormatting {
|
||||||
* Set range internal horizontal borders.
|
* Set range internal horizontal borders.
|
||||||
*
|
*
|
||||||
* @since 3.17 beta 1
|
* @since 3.17 beta 1
|
||||||
* @param border
|
* @param border The style of border to set.
|
||||||
*/
|
*/
|
||||||
void setBorderHorizontal(BorderStyle border);
|
void setBorderHorizontal(BorderStyle border);
|
||||||
|
|
||||||
|
@ -206,7 +206,7 @@ public interface BorderFormatting {
|
||||||
* Set range internal vertical borders.
|
* Set range internal vertical borders.
|
||||||
*
|
*
|
||||||
* @since 3.17 beta 1
|
* @since 3.17 beta 1
|
||||||
* @param border
|
* @param border The style of border to set.
|
||||||
*/
|
*/
|
||||||
void setBorderVertical(BorderStyle border);
|
void setBorderVertical(BorderStyle border);
|
||||||
|
|
||||||
|
|
|
@ -269,7 +269,7 @@ public class StylesTable extends POIXMLDocumentPart {
|
||||||
}
|
}
|
||||||
|
|
||||||
private short getNumberFormatId(String fmt) {
|
private short getNumberFormatId(String fmt) {
|
||||||
// Find the key, and return that
|
// Find the key, and return that
|
||||||
for (Entry<Short,String> numFmt : numberFormats.entrySet()) {
|
for (Entry<Short,String> numFmt : numberFormats.entrySet()) {
|
||||||
if(numFmt.getValue().equals(fmt)) {
|
if(numFmt.getValue().equals(fmt)) {
|
||||||
return numFmt.getKey();
|
return numFmt.getKey();
|
||||||
|
|
|
@ -34,7 +34,7 @@ public class XSSFColor extends ExtendedColor {
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Create an instance of XSSFColor from the supplied XML bean, with default color indexes
|
* Create an instance of XSSFColor from the supplied XML bean, with default color indexes
|
||||||
* @param color
|
* @param color The {@link CTColor} to use as color-value.
|
||||||
* @deprecated 3.17 beta 1 - pass the workbook styles indexed color map, if any
|
* @deprecated 3.17 beta 1 - pass the workbook styles indexed color map, if any
|
||||||
*/
|
*/
|
||||||
@Deprecated
|
@Deprecated
|
||||||
|
@ -45,8 +45,8 @@ public class XSSFColor extends ExtendedColor {
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Create an instance of XSSFColor from the supplied XML bean, with the given color indexes
|
* Create an instance of XSSFColor from the supplied XML bean, with the given color indexes
|
||||||
* @param color
|
* @param color The {@link CTColor} to use as color-value.
|
||||||
* @param map
|
* @param map The IndexedColorMap to use instead of the default one
|
||||||
*/
|
*/
|
||||||
public XSSFColor(CTColor color, IndexedColorMap map) {
|
public XSSFColor(CTColor color, IndexedColorMap map) {
|
||||||
this.ctColor = color;
|
this.ctColor = color;
|
||||||
|
@ -72,8 +72,8 @@ public class XSSFColor extends ExtendedColor {
|
||||||
|
|
||||||
/**
|
/**
|
||||||
*
|
*
|
||||||
* @param rgb bytes
|
* @param rgb The RGB-byte-values for the Color
|
||||||
* @param colorMap
|
* @param colorMap The IndexedColorMap to use instead of the default one
|
||||||
*/
|
*/
|
||||||
public XSSFColor(byte[] rgb, IndexedColorMap colorMap) {
|
public XSSFColor(byte[] rgb, IndexedColorMap colorMap) {
|
||||||
this(CTColor.Factory.newInstance(), colorMap);
|
this(CTColor.Factory.newInstance(), colorMap);
|
||||||
|
@ -82,7 +82,7 @@ public class XSSFColor extends ExtendedColor {
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* @param indexedColor color index (Enum named for default colors)
|
* @param indexedColor color index (Enum named for default colors)
|
||||||
* @param colorMap
|
* @param colorMap The IndexedColorMap to use instead of the default one
|
||||||
*/
|
*/
|
||||||
public XSSFColor(IndexedColors indexedColor, IndexedColorMap colorMap) {
|
public XSSFColor(IndexedColors indexedColor, IndexedColorMap colorMap) {
|
||||||
this(CTColor.Factory.newInstance(), colorMap);
|
this(CTColor.Factory.newInstance(), colorMap);
|
||||||
|
@ -131,20 +131,14 @@ public class XSSFColor extends ExtendedColor {
|
||||||
* @return true if the ctColor has a alpha
|
* @return true if the ctColor has a alpha
|
||||||
*/
|
*/
|
||||||
public boolean hasAlpha() {
|
public boolean hasAlpha() {
|
||||||
if (! ctColor.isSetRgb()) {
|
return ctColor.isSetRgb() && ctColor.getRgb().length == 4;
|
||||||
return false;
|
|
||||||
}
|
|
||||||
return ctColor.getRgb().length == 4;
|
|
||||||
}
|
}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* @return true if the ctColor has a tint
|
* @return true if the ctColor has a tint
|
||||||
*/
|
*/
|
||||||
public boolean hasTint() {
|
public boolean hasTint() {
|
||||||
if (!ctColor.isSetTint()) {
|
return ctColor.isSetTint() && ctColor.getTint() != 0;
|
||||||
return false;
|
|
||||||
}
|
|
||||||
return ctColor.getTint() != 0;
|
|
||||||
}
|
}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
|
@ -377,37 +371,25 @@ public class XSSFColor extends ExtendedColor {
|
||||||
// Helper methods for {@link #equals(Object)}
|
// Helper methods for {@link #equals(Object)}
|
||||||
private boolean sameIndexed(XSSFColor other) {
|
private boolean sameIndexed(XSSFColor other) {
|
||||||
if (isIndexed() == other.isIndexed()) {
|
if (isIndexed() == other.isIndexed()) {
|
||||||
if (isIndexed()) {
|
return !isIndexed() || getIndexed() == other.getIndexed();
|
||||||
return getIndexed() == other.getIndexed();
|
|
||||||
}
|
|
||||||
return true;
|
|
||||||
}
|
}
|
||||||
return false;
|
return false;
|
||||||
}
|
}
|
||||||
private boolean sameARGB(XSSFColor other) {
|
private boolean sameARGB(XSSFColor other) {
|
||||||
if (isRGB() == other.isRGB()) {
|
if (isRGB() == other.isRGB()) {
|
||||||
if (isRGB()) {
|
return !isRGB() || Arrays.equals(getARGB(), other.getARGB());
|
||||||
return Arrays.equals(getARGB(), other.getARGB());
|
|
||||||
}
|
|
||||||
return true;
|
|
||||||
}
|
}
|
||||||
return false;
|
return false;
|
||||||
}
|
}
|
||||||
private boolean sameTheme(XSSFColor other) {
|
private boolean sameTheme(XSSFColor other) {
|
||||||
if (isThemed() == other.isThemed()) {
|
if (isThemed() == other.isThemed()) {
|
||||||
if (isThemed()) {
|
return !isThemed() || getTheme() == other.getTheme();
|
||||||
return getTheme() == other.getTheme();
|
|
||||||
}
|
|
||||||
return true;
|
|
||||||
}
|
}
|
||||||
return false;
|
return false;
|
||||||
}
|
}
|
||||||
private boolean sameTint(XSSFColor other) {
|
private boolean sameTint(XSSFColor other) {
|
||||||
if (hasTint() == other.hasTint()) {
|
if (hasTint() == other.hasTint()) {
|
||||||
if (hasTint()) {
|
return !hasTint() || getTint() == other.getTint();
|
||||||
return getTint() == other.getTint();
|
|
||||||
}
|
|
||||||
return true;
|
|
||||||
}
|
}
|
||||||
return false;
|
return false;
|
||||||
}
|
}
|
||||||
|
|
|
@ -118,7 +118,7 @@ public class XSSFFont implements Font {
|
||||||
* get character-set to use.
|
* get character-set to use.
|
||||||
*
|
*
|
||||||
* @return int - character-set (0-255)
|
* @return int - character-set (0-255)
|
||||||
* @see org.apache.poi.ss.usermodel.FontCharset
|
* @see FontCharset
|
||||||
*/
|
*/
|
||||||
public int getCharSet() {
|
public int getCharSet() {
|
||||||
CTIntProperty charset = _ctFont.sizeOfCharsetArray() == 0 ? null : _ctFont.getCharsetArray(0);
|
CTIntProperty charset = _ctFont.sizeOfCharsetArray() == 0 ? null : _ctFont.getCharsetArray(0);
|
||||||
|
@ -297,7 +297,7 @@ public class XSSFFont implements Font {
|
||||||
public void setBold(boolean bold) {
|
public void setBold(boolean bold) {
|
||||||
if(bold){
|
if(bold){
|
||||||
CTBooleanProperty ctBold = _ctFont.sizeOfBArray() == 0 ? _ctFont.addNewB() : _ctFont.getBArray(0);
|
CTBooleanProperty ctBold = _ctFont.sizeOfBArray() == 0 ? _ctFont.addNewB() : _ctFont.getBArray(0);
|
||||||
ctBold.setVal(bold);
|
ctBold.setVal(true);
|
||||||
} else {
|
} else {
|
||||||
_ctFont.setBArray(null);
|
_ctFont.setBArray(null);
|
||||||
}
|
}
|
||||||
|
@ -448,7 +448,7 @@ public class XSSFFont implements Font {
|
||||||
public void setItalic(boolean italic) {
|
public void setItalic(boolean italic) {
|
||||||
if(italic){
|
if(italic){
|
||||||
CTBooleanProperty bool = _ctFont.sizeOfIArray() == 0 ? _ctFont.addNewI() : _ctFont.getIArray(0);
|
CTBooleanProperty bool = _ctFont.sizeOfIArray() == 0 ? _ctFont.addNewI() : _ctFont.getIArray(0);
|
||||||
bool.setVal(italic);
|
bool.setVal(true);
|
||||||
} else {
|
} else {
|
||||||
_ctFont.setIArray(null);
|
_ctFont.setIArray(null);
|
||||||
}
|
}
|
||||||
|
@ -462,10 +462,11 @@ public class XSSFFont implements Font {
|
||||||
* @param strikeout - value for strikeout or not
|
* @param strikeout - value for strikeout or not
|
||||||
*/
|
*/
|
||||||
public void setStrikeout(boolean strikeout) {
|
public void setStrikeout(boolean strikeout) {
|
||||||
if(!strikeout) _ctFont.setStrikeArray(null);
|
if(strikeout) {
|
||||||
else {
|
|
||||||
CTBooleanProperty strike = _ctFont.sizeOfStrikeArray() == 0 ? _ctFont.addNewStrike() : _ctFont.getStrikeArray(0);
|
CTBooleanProperty strike = _ctFont.sizeOfStrikeArray() == 0 ? _ctFont.addNewStrike() : _ctFont.getStrikeArray(0);
|
||||||
strike.setVal(strikeout);
|
strike.setVal(true);
|
||||||
|
} else {
|
||||||
|
_ctFont.setStrikeArray(null);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
|
@ -1,4 +1,3 @@
|
||||||
|
|
||||||
/* ====================================================================
|
/* ====================================================================
|
||||||
Licensed to the Apache Software Foundation (ASF) under one or more
|
Licensed to the Apache Software Foundation (ASF) under one or more
|
||||||
contributor license agreements. See the NOTICE file distributed with
|
contributor license agreements. See the NOTICE file distributed with
|
||||||
|
@ -15,14 +14,11 @@
|
||||||
See the License for the specific language governing permissions and
|
See the License for the specific language governing permissions and
|
||||||
limitations under the License.
|
limitations under the License.
|
||||||
==================================================================== */
|
==================================================================== */
|
||||||
|
|
||||||
|
|
||||||
package org.apache.poi;
|
package org.apache.poi;
|
||||||
|
|
||||||
import static org.junit.Assert.assertArrayEquals;
|
import static org.junit.Assert.assertArrayEquals;
|
||||||
import static org.junit.Assert.assertEquals;
|
import static org.junit.Assert.assertEquals;
|
||||||
import static org.junit.Assert.assertFalse;
|
import static org.junit.Assert.assertFalse;
|
||||||
import static org.junit.Assert.assertTrue;
|
|
||||||
|
|
||||||
import java.io.ByteArrayInputStream;
|
import java.io.ByteArrayInputStream;
|
||||||
import java.io.IOException;
|
import java.io.IOException;
|
||||||
|
@ -40,6 +36,7 @@ import org.junit.Test;
|
||||||
* Class to test that HXF correctly detects OOXML
|
* Class to test that HXF correctly detects OOXML
|
||||||
* documents
|
* documents
|
||||||
*/
|
*/
|
||||||
|
@SuppressWarnings("deprecation")
|
||||||
public class TestDetectAsOOXML {
|
public class TestDetectAsOOXML {
|
||||||
@Test
|
@Test
|
||||||
public void testOpensProperly() throws IOException, InvalidFormatException {
|
public void testOpensProperly() throws IOException, InvalidFormatException {
|
||||||
|
@ -59,10 +56,9 @@ public class TestDetectAsOOXML {
|
||||||
is = FileMagic.prepareToCheckMagic(is);
|
is = FileMagic.prepareToCheckMagic(is);
|
||||||
FileMagic act = FileMagic.valueOf(is);
|
FileMagic act = FileMagic.valueOf(is);
|
||||||
|
|
||||||
if (act == FileMagic.OOXML) {
|
assertEquals("OOXML files should be detected, others not",
|
||||||
assertTrue(DocumentFactoryHelper.hasOOXMLHeader(is));
|
act == FileMagic.OOXML, DocumentFactoryHelper.hasOOXMLHeader(is));
|
||||||
}
|
|
||||||
|
|
||||||
assertEquals("file magic failed for "+fm[0], fm[1], act);
|
assertEquals("file magic failed for "+fm[0], fm[1], act);
|
||||||
is.close();
|
is.close();
|
||||||
}
|
}
|
||||||
|
@ -70,7 +66,6 @@ public class TestDetectAsOOXML {
|
||||||
|
|
||||||
@Test
|
@Test
|
||||||
public void testFileCorruption() throws Exception {
|
public void testFileCorruption() throws Exception {
|
||||||
|
|
||||||
// create test InputStream
|
// create test InputStream
|
||||||
byte[] testData = { 1, 2, 3 };
|
byte[] testData = { 1, 2, 3 };
|
||||||
ByteArrayInputStream testInput = new ByteArrayInputStream(testData);
|
ByteArrayInputStream testInput = new ByteArrayInputStream(testData);
|
||||||
|
|
|
@ -124,6 +124,7 @@ public final class TestStylesTable {
|
||||||
assertEquals(165, st.getStyleAt(3).getDataFormat());
|
assertEquals(165, st.getStyleAt(3).getDataFormat());
|
||||||
|
|
||||||
assertEquals("yyyy/mm/dd", st.getStyleAt(3).getDataFormatString());
|
assertEquals("yyyy/mm/dd", st.getStyleAt(3).getDataFormatString());
|
||||||
|
assertEquals("[]", st.getExplicitTableStyleNames().toString());
|
||||||
}
|
}
|
||||||
|
|
||||||
@Test
|
@Test
|
||||||
|
@ -186,8 +187,7 @@ public final class TestStylesTable {
|
||||||
|
|
||||||
@Test
|
@Test
|
||||||
public void exceedNumberFormatLimit() throws IOException {
|
public void exceedNumberFormatLimit() throws IOException {
|
||||||
XSSFWorkbook wb = new XSSFWorkbook();
|
try (XSSFWorkbook wb = new XSSFWorkbook()) {
|
||||||
try {
|
|
||||||
StylesTable styles = wb.getStylesSource();
|
StylesTable styles = wb.getStylesSource();
|
||||||
for (int i = 0; i < styles.getMaxNumberOfDataFormats(); i++) {
|
for (int i = 0; i < styles.getMaxNumberOfDataFormats(); i++) {
|
||||||
wb.getStylesSource().putNumberFormat("\"test" + i + " \"0");
|
wb.getStylesSource().putNumberFormat("\"test" + i + " \"0");
|
||||||
|
@ -195,15 +195,10 @@ public final class TestStylesTable {
|
||||||
try {
|
try {
|
||||||
wb.getStylesSource().putNumberFormat("\"anotherformat \"0");
|
wb.getStylesSource().putNumberFormat("\"anotherformat \"0");
|
||||||
} catch (final IllegalStateException e) {
|
} catch (final IllegalStateException e) {
|
||||||
if (e.getMessage().startsWith("The maximum number of Data Formats was exceeded.")) {
|
if (!e.getMessage().startsWith("The maximum number of Data Formats was exceeded.")) {
|
||||||
//expected
|
|
||||||
}
|
|
||||||
else {
|
|
||||||
throw e;
|
throw e;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
} finally {
|
|
||||||
wb.close();
|
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -216,145 +211,127 @@ public final class TestStylesTable {
|
||||||
|
|
||||||
@Test
|
@Test
|
||||||
public void removeNumberFormat() throws IOException {
|
public void removeNumberFormat() throws IOException {
|
||||||
XSSFWorkbook wb1 = new XSSFWorkbook();
|
try (XSSFWorkbook wb1 = new XSSFWorkbook()) {
|
||||||
try {
|
|
||||||
final String fmt = customDataFormat;
|
final String fmt = customDataFormat;
|
||||||
final short fmtIdx = (short) wb1.getStylesSource().putNumberFormat(fmt);
|
final short fmtIdx = (short) wb1.getStylesSource().putNumberFormat(fmt);
|
||||||
|
|
||||||
Cell cell = wb1.createSheet("test").createRow(0).createCell(0);
|
Cell cell = wb1.createSheet("test").createRow(0).createCell(0);
|
||||||
cell.setCellValue(5.25);
|
cell.setCellValue(5.25);
|
||||||
CellStyle style = wb1.createCellStyle();
|
CellStyle style = wb1.createCellStyle();
|
||||||
style.setDataFormat(fmtIdx);
|
style.setDataFormat(fmtIdx);
|
||||||
cell.setCellStyle(style);
|
cell.setCellStyle(style);
|
||||||
|
|
||||||
assertEquals(fmt, cell.getCellStyle().getDataFormatString());
|
assertEquals(fmt, cell.getCellStyle().getDataFormatString());
|
||||||
assertEquals(fmt, wb1.getStylesSource().getNumberFormatAt(fmtIdx));
|
assertEquals(fmt, wb1.getStylesSource().getNumberFormatAt(fmtIdx));
|
||||||
|
|
||||||
// remove the number format from the workbook
|
// remove the number format from the workbook
|
||||||
wb1.getStylesSource().removeNumberFormat(fmt);
|
assertTrue("The format is removed on first call",
|
||||||
|
wb1.getStylesSource().removeNumberFormat(fmt));
|
||||||
|
try {
|
||||||
|
wb1.getStylesSource().removeNumberFormat(fmt);
|
||||||
|
fail("Should fail here");
|
||||||
|
} catch (IllegalStateException e) {
|
||||||
|
// expected here
|
||||||
|
}
|
||||||
|
|
||||||
// number format in CellStyles should be restored to default number format
|
// number format in CellStyles should be restored to default number format
|
||||||
final short defaultFmtIdx = 0;
|
final short defaultFmtIdx = 0;
|
||||||
final String defaultFmt = BuiltinFormats.getBuiltinFormat(0);
|
final String defaultFmt = BuiltinFormats.getBuiltinFormat(0);
|
||||||
assertEquals(defaultFmtIdx, style.getDataFormat());
|
assertEquals(defaultFmtIdx, style.getDataFormat());
|
||||||
assertEquals(defaultFmt, style.getDataFormatString());
|
assertEquals(defaultFmt, style.getDataFormatString());
|
||||||
|
|
||||||
// The custom number format should be entirely removed from the workbook
|
// The custom number format should be entirely removed from the workbook
|
||||||
Map<Short,String> numberFormats = wb1.getStylesSource().getNumberFormats();
|
Map<Short, String> numberFormats = wb1.getStylesSource().getNumberFormats();
|
||||||
assertNotContainsKey(numberFormats, fmtIdx);
|
assertNotContainsKey(numberFormats, fmtIdx);
|
||||||
assertNotContainsValue(numberFormats, fmt);
|
assertNotContainsValue(numberFormats, fmt);
|
||||||
|
|
||||||
// The default style shouldn't be added back to the styles source because it's built-in
|
// The default style shouldn't be added back to the styles source because it's built-in
|
||||||
assertEquals(0, wb1.getStylesSource().getNumDataFormats());
|
assertEquals(0, wb1.getStylesSource().getNumDataFormats());
|
||||||
|
|
||||||
cell = null; style = null; numberFormats = null;
|
try (XSSFWorkbook wb2 = XSSFTestDataSamples.writeOutCloseAndReadBack(wb1)) {
|
||||||
XSSFWorkbook wb2 = XSSFTestDataSamples.writeOutCloseAndReadBack(wb1);
|
|
||||||
|
cell = wb2.getSheet("test").getRow(0).getCell(0);
|
||||||
cell = wb2.getSheet("test").getRow(0).getCell(0);
|
style = cell.getCellStyle();
|
||||||
style = cell.getCellStyle();
|
|
||||||
|
// number format in CellStyles should be restored to default number format
|
||||||
// number format in CellStyles should be restored to default number format
|
assertEquals(defaultFmtIdx, style.getDataFormat());
|
||||||
assertEquals(defaultFmtIdx, style.getDataFormat());
|
assertEquals(defaultFmt, style.getDataFormatString());
|
||||||
assertEquals(defaultFmt, style.getDataFormatString());
|
|
||||||
|
// The custom number format should be entirely removed from the workbook
|
||||||
// The custom number format should be entirely removed from the workbook
|
numberFormats = wb2.getStylesSource().getNumberFormats();
|
||||||
numberFormats = wb2.getStylesSource().getNumberFormats();
|
assertNotContainsKey(numberFormats, fmtIdx);
|
||||||
assertNotContainsKey(numberFormats, fmtIdx);
|
assertNotContainsValue(numberFormats, fmt);
|
||||||
assertNotContainsValue(numberFormats, fmt);
|
|
||||||
|
// The default style shouldn't be added back to the styles source because it's built-in
|
||||||
// The default style shouldn't be added back to the styles source because it's built-in
|
assertEquals(0, wb2.getStylesSource().getNumDataFormats());
|
||||||
assertEquals(0, wb2.getStylesSource().getNumDataFormats());
|
}
|
||||||
|
|
||||||
wb2.close();
|
|
||||||
|
|
||||||
} finally {
|
|
||||||
wb1.close();
|
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
@Test
|
@Test
|
||||||
public void maxNumberOfDataFormats() throws IOException {
|
public void maxNumberOfDataFormats() throws IOException {
|
||||||
XSSFWorkbook wb = new XSSFWorkbook();
|
try (XSSFWorkbook wb = new XSSFWorkbook()) {
|
||||||
|
|
||||||
try {
|
|
||||||
StylesTable styles = wb.getStylesSource();
|
StylesTable styles = wb.getStylesSource();
|
||||||
|
|
||||||
// Check default limit
|
// Check default limit
|
||||||
int n = styles.getMaxNumberOfDataFormats();
|
int n = styles.getMaxNumberOfDataFormats();
|
||||||
// https://support.office.com/en-us/article/excel-specifications-and-limits-1672b34d-7043-467e-8e27-269d656771c3
|
// https://support.office.com/en-us/article/excel-specifications-and-limits-1672b34d-7043-467e-8e27-269d656771c3
|
||||||
assertTrue(200 <= n);
|
assertTrue(200 <= n);
|
||||||
assertTrue(n <= 250);
|
assertTrue(n <= 250);
|
||||||
|
|
||||||
// Check upper limit
|
// Check upper limit
|
||||||
n = Integer.MAX_VALUE;
|
n = Integer.MAX_VALUE;
|
||||||
styles.setMaxNumberOfDataFormats(n);
|
styles.setMaxNumberOfDataFormats(n);
|
||||||
assertEquals(n, styles.getMaxNumberOfDataFormats());
|
assertEquals(n, styles.getMaxNumberOfDataFormats());
|
||||||
|
|
||||||
// Check negative (illegal) limits
|
// Check negative (illegal) limits
|
||||||
try {
|
try {
|
||||||
styles.setMaxNumberOfDataFormats(-1);
|
styles.setMaxNumberOfDataFormats(-1);
|
||||||
fail("Expected to get an IllegalArgumentException(\"Maximum Number of Data Formats must be greater than or equal to 0\")");
|
fail("Expected to get an IllegalArgumentException(\"Maximum Number of Data Formats must be greater than or equal to 0\")");
|
||||||
} catch (final IllegalArgumentException e) {
|
} catch (final IllegalArgumentException e) {
|
||||||
if (e.getMessage().startsWith("Maximum Number of Data Formats must be greater than or equal to 0")) {
|
if (!e.getMessage().startsWith("Maximum Number of Data Formats must be greater than or equal to 0")) {
|
||||||
// expected
|
|
||||||
} else {
|
|
||||||
throw e;
|
throw e;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
finally {
|
|
||||||
wb.close();
|
|
||||||
}
|
|
||||||
}
|
}
|
||||||
|
|
||||||
@Test
|
@Test
|
||||||
public void addDataFormatsBeyondUpperLimit() throws IOException {
|
public void addDataFormatsBeyondUpperLimit() throws IOException {
|
||||||
XSSFWorkbook wb = new XSSFWorkbook();
|
|
||||||
|
try (XSSFWorkbook wb = new XSSFWorkbook()) {
|
||||||
try {
|
|
||||||
StylesTable styles = wb.getStylesSource();
|
StylesTable styles = wb.getStylesSource();
|
||||||
styles.setMaxNumberOfDataFormats(0);
|
styles.setMaxNumberOfDataFormats(0);
|
||||||
|
|
||||||
// Try adding a format beyond the upper limit
|
// Try adding a format beyond the upper limit
|
||||||
try {
|
try {
|
||||||
styles.putNumberFormat("\"test \"0");
|
styles.putNumberFormat("\"test \"0");
|
||||||
fail("Expected to raise IllegalStateException");
|
fail("Expected to raise IllegalStateException");
|
||||||
} catch (final IllegalStateException e) {
|
} catch (final IllegalStateException e) {
|
||||||
if (e.getMessage().startsWith("The maximum number of Data Formats was exceeded.")) {
|
if (!e.getMessage().startsWith("The maximum number of Data Formats was exceeded.")) {
|
||||||
// expected
|
|
||||||
} else {
|
|
||||||
throw e;
|
throw e;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
finally {
|
|
||||||
wb.close();
|
|
||||||
}
|
|
||||||
}
|
}
|
||||||
|
|
||||||
@Test
|
@Test
|
||||||
public void decreaseUpperLimitBelowCurrentNumDataFormats() throws IOException {
|
public void decreaseUpperLimitBelowCurrentNumDataFormats() throws IOException {
|
||||||
XSSFWorkbook wb = new XSSFWorkbook();
|
|
||||||
|
try (XSSFWorkbook wb = new XSSFWorkbook()) {
|
||||||
try {
|
|
||||||
StylesTable styles = wb.getStylesSource();
|
StylesTable styles = wb.getStylesSource();
|
||||||
styles.putNumberFormat(customDataFormat);
|
styles.putNumberFormat(customDataFormat);
|
||||||
|
|
||||||
// Try decreasing the upper limit below the current number of formats
|
// Try decreasing the upper limit below the current number of formats
|
||||||
try {
|
try {
|
||||||
styles.setMaxNumberOfDataFormats(0);
|
styles.setMaxNumberOfDataFormats(0);
|
||||||
fail("Expected to raise IllegalStateException");
|
fail("Expected to raise IllegalStateException");
|
||||||
} catch (final IllegalStateException e) {
|
} catch (final IllegalStateException e) {
|
||||||
if (e.getMessage().startsWith("Cannot set the maximum number of data formats less than the current quantity.")) {
|
if (!e.getMessage().startsWith("Cannot set the maximum number of data formats less than the current quantity.")) {
|
||||||
// expected
|
|
||||||
} else {
|
|
||||||
throw e;
|
throw e;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
finally {
|
|
||||||
wb.close();
|
|
||||||
}
|
|
||||||
}
|
}
|
||||||
|
|
||||||
@Test
|
@Test
|
||||||
|
@ -363,6 +340,21 @@ public final class TestStylesTable {
|
||||||
assertNotNull(workbook.getStylesSource());
|
assertNotNull(workbook.getStylesSource());
|
||||||
|
|
||||||
StylesTable st = workbook.getStylesSource();
|
StylesTable st = workbook.getStylesSource();
|
||||||
|
assertNotNull(st);
|
||||||
|
|
||||||
|
assertNotNull(XSSFTestDataSamples.writeOutAndReadBack(workbook));
|
||||||
|
}
|
||||||
|
|
||||||
|
@Test
|
||||||
|
public void testReplaceStyle() {
|
||||||
|
XSSFWorkbook workbook = XSSFTestDataSamples.openSampleWorkbook("style-alternate-content.xlsx");
|
||||||
|
assertNotNull(workbook.getStylesSource());
|
||||||
|
|
||||||
|
StylesTable st = workbook.getStylesSource();
|
||||||
|
assertNotNull(st);
|
||||||
|
|
||||||
|
st.replaceCellStyleXfAt(0, st.getCellStyleXfAt(1));
|
||||||
|
st.replaceCellStyleXfAt(1, st.getCellStyleXfAt(1));
|
||||||
|
|
||||||
assertNotNull(XSSFTestDataSamples.writeOutAndReadBack(workbook));
|
assertNotNull(XSSFTestDataSamples.writeOutAndReadBack(workbook));
|
||||||
}
|
}
|
||||||
|
|
|
@ -2524,20 +2524,20 @@ public final class TestXSSFBugs extends BaseTestBugzillaIssues {
|
||||||
wb.getCreationHelper().createFormulaEvaluator().evaluateAll();
|
wb.getCreationHelper().createFormulaEvaluator().evaluateAll();
|
||||||
|
|
||||||
CalculationChain chain = ((XSSFWorkbook) wb).getCalculationChain();
|
CalculationChain chain = ((XSSFWorkbook) wb).getCalculationChain();
|
||||||
for (CTCalcCell calc : chain.getCTCalcChain().getCList()) {
|
checkCellsAreGone(chain);
|
||||||
// A2 to A6 should be gone
|
|
||||||
assertFalse(calc.getR().equals("A2"));
|
|
||||||
assertFalse(calc.getR().equals("A3"));
|
|
||||||
assertFalse(calc.getR().equals("A4"));
|
|
||||||
assertFalse(calc.getR().equals("A5"));
|
|
||||||
assertFalse(calc.getR().equals("A6"));
|
|
||||||
}
|
|
||||||
|
|
||||||
Workbook wbBack = XSSFTestDataSamples.writeOutAndReadBack(wb);
|
Workbook wbBack = XSSFTestDataSamples.writeOutAndReadBack(wb);
|
||||||
Sheet sheetBack = wbBack.getSheet("Func");
|
Sheet sheetBack = wbBack.getSheet("Func");
|
||||||
assertNotNull(sheetBack);
|
assertNotNull(sheetBack);
|
||||||
|
|
||||||
chain = ((XSSFWorkbook) wbBack).getCalculationChain();
|
chain = ((XSSFWorkbook) wbBack).getCalculationChain();
|
||||||
|
checkCellsAreGone(chain);
|
||||||
|
|
||||||
|
wbBack.close();
|
||||||
|
wb.close();
|
||||||
|
}
|
||||||
|
|
||||||
|
private void checkCellsAreGone(CalculationChain chain) {
|
||||||
for (CTCalcCell calc : chain.getCTCalcChain().getCList()) {
|
for (CTCalcCell calc : chain.getCTCalcChain().getCList()) {
|
||||||
// A2 to A6 should be gone
|
// A2 to A6 should be gone
|
||||||
assertFalse(calc.getR().equals("A2"));
|
assertFalse(calc.getR().equals("A2"));
|
||||||
|
@ -2546,9 +2546,6 @@ public final class TestXSSFBugs extends BaseTestBugzillaIssues {
|
||||||
assertFalse(calc.getR().equals("A5"));
|
assertFalse(calc.getR().equals("A5"));
|
||||||
assertFalse(calc.getR().equals("A6"));
|
assertFalse(calc.getR().equals("A6"));
|
||||||
}
|
}
|
||||||
|
|
||||||
wbBack.close();
|
|
||||||
wb.close();
|
|
||||||
}
|
}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
|
@ -2571,22 +2568,6 @@ public final class TestXSSFBugs extends BaseTestBugzillaIssues {
|
||||||
wb.close();
|
wb.close();
|
||||||
}
|
}
|
||||||
|
|
||||||
private void assertFormula(Workbook wb, Cell intF, String expectedFormula, String expectedResultOrNull) {
|
|
||||||
assertEquals(CellType.FORMULA, intF.getCellType());
|
|
||||||
if (null == expectedResultOrNull) {
|
|
||||||
assertEquals(CellType.ERROR, intF.getCachedFormulaResultType());
|
|
||||||
expectedResultOrNull = "#VALUE!";
|
|
||||||
} else {
|
|
||||||
assertEquals(CellType.NUMERIC, intF.getCachedFormulaResultType());
|
|
||||||
}
|
|
||||||
|
|
||||||
assertEquals(expectedFormula, intF.getCellFormula());
|
|
||||||
|
|
||||||
// Check we can evaluate it correctly
|
|
||||||
FormulaEvaluator eval = wb.getCreationHelper().createFormulaEvaluator();
|
|
||||||
assertEquals(expectedResultOrNull, eval.evaluate(intF).formatAsString());
|
|
||||||
}
|
|
||||||
|
|
||||||
@Test
|
@Test
|
||||||
public void test48962() throws IOException {
|
public void test48962() throws IOException {
|
||||||
Workbook wb = XSSFTestDataSamples.openSampleWorkbook("48962.xlsx");
|
Workbook wb = XSSFTestDataSamples.openSampleWorkbook("48962.xlsx");
|
||||||
|
|
|
@ -17,14 +17,6 @@
|
||||||
|
|
||||||
package org.apache.poi.xssf.usermodel;
|
package org.apache.poi.xssf.usermodel;
|
||||||
|
|
||||||
import static org.junit.Assert.assertEquals;
|
|
||||||
import static org.junit.Assert.assertNotEquals;
|
|
||||||
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.assertFalse;
|
|
||||||
|
|
||||||
import java.io.IOException;
|
import java.io.IOException;
|
||||||
import java.util.List;
|
import java.util.List;
|
||||||
|
|
||||||
|
@ -58,6 +50,8 @@ import org.junit.Test;
|
||||||
import org.openxmlformats.schemas.spreadsheetml.x2006.main.CTCell;
|
import org.openxmlformats.schemas.spreadsheetml.x2006.main.CTCell;
|
||||||
import org.openxmlformats.schemas.spreadsheetml.x2006.main.STCellType;
|
import org.openxmlformats.schemas.spreadsheetml.x2006.main.STCellType;
|
||||||
|
|
||||||
|
import static org.junit.Assert.*;
|
||||||
|
|
||||||
public final class TestXSSFCell extends BaseTestXCell {
|
public final class TestXSSFCell extends BaseTestXCell {
|
||||||
|
|
||||||
public TestXSSFCell() {
|
public TestXSSFCell() {
|
||||||
|
@ -149,17 +143,16 @@ public final class TestXSSFCell extends BaseTestXCell {
|
||||||
|
|
||||||
@Test
|
@Test
|
||||||
public void testFormulaString() throws IOException {
|
public void testFormulaString() throws IOException {
|
||||||
XSSFWorkbook wb = (XSSFWorkbook)_testDataProvider.createWorkbook();
|
try (XSSFWorkbook wb = (XSSFWorkbook) _testDataProvider.createWorkbook()) {
|
||||||
try {
|
|
||||||
XSSFCell cell = wb.createSheet().createRow(0).createCell(0);
|
XSSFCell cell = wb.createSheet().createRow(0).createCell(0);
|
||||||
CTCell ctCell = cell.getCTCell(); //low-level bean holding cell's xml
|
CTCell ctCell = cell.getCTCell(); //low-level bean holding cell's xml
|
||||||
|
|
||||||
cell.setCellFormula("A2");
|
cell.setCellFormula("A2");
|
||||||
assertEquals(CellType.FORMULA, cell.getCellType());
|
assertEquals(CellType.FORMULA, cell.getCellType());
|
||||||
assertEquals("A2", cell.getCellFormula());
|
assertEquals("A2", cell.getCellFormula());
|
||||||
//the value is not set and cell's type='N' which means blank
|
//the value is not set and cell's type='N' which means blank
|
||||||
assertEquals(STCellType.N, ctCell.getT());
|
assertEquals(STCellType.N, ctCell.getT());
|
||||||
|
|
||||||
//set cached formula value
|
//set cached formula value
|
||||||
cell.setCellValue("t='str'");
|
cell.setCellValue("t='str'");
|
||||||
//we are still of 'formula' type
|
//we are still of 'formula' type
|
||||||
|
@ -168,57 +161,44 @@ public final class TestXSSFCell extends BaseTestXCell {
|
||||||
//cached formula value is set and cell's type='STR'
|
//cached formula value is set and cell's type='STR'
|
||||||
assertEquals(STCellType.STR, ctCell.getT());
|
assertEquals(STCellType.STR, ctCell.getT());
|
||||||
assertEquals("t='str'", cell.getStringCellValue());
|
assertEquals("t='str'", cell.getStringCellValue());
|
||||||
|
|
||||||
//now remove the formula, the cached formula result remains
|
//now remove the formula, the cached formula result remains
|
||||||
cell.setCellFormula(null);
|
cell.setCellFormula(null);
|
||||||
assertEquals(CellType.STRING, cell.getCellType());
|
assertEquals(CellType.STRING, cell.getCellType());
|
||||||
assertEquals(STCellType.STR, ctCell.getT());
|
assertEquals(STCellType.STR, ctCell.getT());
|
||||||
//the line below failed prior to fix of Bug #47889
|
//the line below failed prior to fix of Bug #47889
|
||||||
assertEquals("t='str'", cell.getStringCellValue());
|
assertEquals("t='str'", cell.getStringCellValue());
|
||||||
|
|
||||||
//revert to a blank cell
|
//revert to a blank cell
|
||||||
cell.setCellValue((String)null);
|
cell.setCellValue((String) null);
|
||||||
assertEquals(CellType.BLANK, cell.getCellType());
|
assertEquals(CellType.BLANK, cell.getCellType());
|
||||||
assertEquals(STCellType.N, ctCell.getT());
|
assertEquals(STCellType.N, ctCell.getT());
|
||||||
assertEquals("", cell.getStringCellValue());
|
assertEquals("", cell.getStringCellValue());
|
||||||
|
|
||||||
// check behavior with setCellFormulaValidation
|
// check behavior with setCellFormulaValidation
|
||||||
final String invalidFormula = "A", validFormula = "A2";
|
final String invalidFormula = "A", validFormula = "A2";
|
||||||
FormulaParseException fpe = null;
|
|
||||||
// check that default is true
|
// check that default is true
|
||||||
assertTrue(wb.getCellFormulaValidation());
|
assertTrue(wb.getCellFormulaValidation());
|
||||||
|
|
||||||
// check that valid formula does not throw exception
|
// check that valid formula does not throw exception
|
||||||
try {
|
cell.setCellFormula(validFormula);
|
||||||
cell.setCellFormula(validFormula);
|
|
||||||
} catch(FormulaParseException e) {
|
|
||||||
fpe = e;
|
|
||||||
}
|
|
||||||
assertNull(fpe);
|
|
||||||
|
|
||||||
// check that invalid formula does throw exception
|
// check that invalid formula does throw exception
|
||||||
try {
|
try {
|
||||||
cell.setCellFormula(invalidFormula);
|
cell.setCellFormula(invalidFormula);
|
||||||
} catch(FormulaParseException e) {
|
fail("Should catch exception here");
|
||||||
fpe = e;
|
} catch (FormulaParseException e) {
|
||||||
|
// expected here
|
||||||
}
|
}
|
||||||
assertNotNull(fpe);
|
|
||||||
fpe = null;
|
|
||||||
|
|
||||||
// set cell formula validation to false
|
// set cell formula validation to false
|
||||||
wb.setCellFormulaValidation(false);
|
wb.setCellFormulaValidation(false);
|
||||||
assertFalse(wb.getCellFormulaValidation());
|
assertFalse(wb.getCellFormulaValidation());
|
||||||
|
|
||||||
// check that neither valid nor invalid formula throw an exception
|
// check that neither valid nor invalid formula throw an exception
|
||||||
try {
|
cell.setCellFormula(validFormula);
|
||||||
cell.setCellFormula(validFormula);
|
cell.setCellFormula(invalidFormula);
|
||||||
cell.setCellFormula(invalidFormula);
|
|
||||||
} catch(FormulaParseException e) {
|
|
||||||
fpe = e;
|
|
||||||
}
|
|
||||||
assertNull(fpe);
|
|
||||||
} finally {
|
|
||||||
wb.close();
|
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -409,37 +389,34 @@ public final class TestXSSFCell extends BaseTestXCell {
|
||||||
|
|
||||||
@Test
|
@Test
|
||||||
public void test56170Reproduce() throws IOException {
|
public void test56170Reproduce() throws IOException {
|
||||||
final Workbook wb = new XSSFWorkbook();
|
try (Workbook wb = new XSSFWorkbook()) {
|
||||||
try {
|
|
||||||
final Sheet sheet = wb.createSheet();
|
final Sheet sheet = wb.createSheet();
|
||||||
Row row = sheet.createRow(0);
|
Row row = sheet.createRow(0);
|
||||||
|
|
||||||
// by creating Cells out of order we trigger the handling in onDocumentWrite()
|
// by creating Cells out of order we trigger the handling in onDocumentWrite()
|
||||||
Cell cell1 = row.createCell(1);
|
Cell cell1 = row.createCell(1);
|
||||||
Cell cell2 = row.createCell(0);
|
Cell cell2 = row.createCell(0);
|
||||||
|
|
||||||
validateRow(row);
|
validateRow(row);
|
||||||
|
|
||||||
validateRow(row);
|
validateRow(row);
|
||||||
|
|
||||||
// once again with removing one cell
|
// once again with removing one cell
|
||||||
row.removeCell(cell1);
|
row.removeCell(cell1);
|
||||||
|
|
||||||
validateRow(row);
|
validateRow(row);
|
||||||
|
|
||||||
// once again with removing one cell
|
// once again with removing one cell
|
||||||
row.removeCell(cell1);
|
row.removeCell(cell1);
|
||||||
|
|
||||||
// now check again
|
// now check again
|
||||||
validateRow(row);
|
validateRow(row);
|
||||||
|
|
||||||
// once again with removing one cell
|
// once again with removing one cell
|
||||||
row.removeCell(cell2);
|
row.removeCell(cell2);
|
||||||
|
|
||||||
// now check again
|
// now check again
|
||||||
validateRow(row);
|
validateRow(row);
|
||||||
} finally {
|
|
||||||
wb.close();
|
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -454,40 +431,31 @@ public final class TestXSSFCell extends BaseTestXCell {
|
||||||
|
|
||||||
@Test
|
@Test
|
||||||
public void testBug56644ReturnNull() throws IOException {
|
public void testBug56644ReturnNull() throws IOException {
|
||||||
Workbook wb = XSSFTestDataSamples.openSampleWorkbook("56644.xlsx");
|
try (Workbook wb = XSSFTestDataSamples.openSampleWorkbook("56644.xlsx")) {
|
||||||
try {
|
|
||||||
wb.setMissingCellPolicy(MissingCellPolicy.RETURN_BLANK_AS_NULL);
|
wb.setMissingCellPolicy(MissingCellPolicy.RETURN_BLANK_AS_NULL);
|
||||||
Sheet sheet = wb.getSheet("samplelist");
|
Sheet sheet = wb.getSheet("samplelist");
|
||||||
Row row = sheet.getRow(20);
|
Row row = sheet.getRow(20);
|
||||||
row.createCell(2);
|
row.createCell(2);
|
||||||
} finally {
|
|
||||||
wb.close();
|
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
@Test
|
@Test
|
||||||
public void testBug56644ReturnBlank() throws IOException {
|
public void testBug56644ReturnBlank() throws IOException {
|
||||||
Workbook wb = XSSFTestDataSamples.openSampleWorkbook("56644.xlsx");
|
try (Workbook wb = XSSFTestDataSamples.openSampleWorkbook("56644.xlsx")) {
|
||||||
try {
|
|
||||||
wb.setMissingCellPolicy(MissingCellPolicy.RETURN_NULL_AND_BLANK);
|
wb.setMissingCellPolicy(MissingCellPolicy.RETURN_NULL_AND_BLANK);
|
||||||
Sheet sheet = wb.getSheet("samplelist");
|
Sheet sheet = wb.getSheet("samplelist");
|
||||||
Row row = sheet.getRow(20);
|
Row row = sheet.getRow(20);
|
||||||
row.createCell(2);
|
row.createCell(2);
|
||||||
} finally {
|
|
||||||
wb.close();
|
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
@Test
|
@Test
|
||||||
public void testBug56644CreateBlank() throws IOException {
|
public void testBug56644CreateBlank() throws IOException {
|
||||||
Workbook wb = XSSFTestDataSamples.openSampleWorkbook("56644.xlsx");
|
try (Workbook wb = XSSFTestDataSamples.openSampleWorkbook("56644.xlsx")) {
|
||||||
try {
|
|
||||||
wb.setMissingCellPolicy(MissingCellPolicy.CREATE_NULL_AS_BLANK);
|
wb.setMissingCellPolicy(MissingCellPolicy.CREATE_NULL_AS_BLANK);
|
||||||
Sheet sheet = wb.getSheet("samplelist");
|
Sheet sheet = wb.getSheet("samplelist");
|
||||||
Row row = sheet.getRow(20);
|
Row row = sheet.getRow(20);
|
||||||
row.createCell(2);
|
row.createCell(2);
|
||||||
} finally {
|
|
||||||
wb.close();
|
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
|
@ -93,8 +93,8 @@ public class TestXSSFCellStyle {
|
||||||
cellXf.setBorderId(1);
|
cellXf.setBorderId(1);
|
||||||
cellXf.setFillId(1);
|
cellXf.setFillId(1);
|
||||||
cellXf.setFontId(1);
|
cellXf.setFontId(1);
|
||||||
stylesTable.putCellStyleXf(cellStyleXf);
|
assertEquals(2, stylesTable.putCellStyleXf(cellStyleXf));
|
||||||
stylesTable.putCellXf(cellXf);
|
assertEquals(2, stylesTable.putCellXf(cellXf));
|
||||||
cellStyle = new XSSFCellStyle(1, 1, stylesTable, null);
|
cellStyle = new XSSFCellStyle(1, 1, stylesTable, null);
|
||||||
|
|
||||||
assertNotNull(stylesTable.getFillAt(1).getCTFill().getPatternFill());
|
assertNotNull(stylesTable.getFillAt(1).getCTFill().getPatternFill());
|
||||||
|
@ -537,7 +537,8 @@ public class TestXSSFCellStyle {
|
||||||
assertEquals(IndexedColors.AUTOMATIC.getIndex(), cellStyle.getFillBackgroundColor());
|
assertEquals(IndexedColors.AUTOMATIC.getIndex(), cellStyle.getFillBackgroundColor());
|
||||||
}
|
}
|
||||||
|
|
||||||
@Test
|
@SuppressWarnings("deprecation")
|
||||||
|
@Test
|
||||||
public void testDefaultStyles() throws IOException {
|
public void testDefaultStyles() throws IOException {
|
||||||
|
|
||||||
XSSFWorkbook wb1 = new XSSFWorkbook();
|
XSSFWorkbook wb1 = new XSSFWorkbook();
|
||||||
|
@ -569,7 +570,8 @@ public class TestXSSFCellStyle {
|
||||||
wb2.close();
|
wb2.close();
|
||||||
}
|
}
|
||||||
|
|
||||||
@Test
|
@SuppressWarnings("deprecation")
|
||||||
|
@Test
|
||||||
public void testGetFillForegroundColor() throws IOException {
|
public void testGetFillForegroundColor() throws IOException {
|
||||||
XSSFWorkbook wb = new XSSFWorkbook();
|
XSSFWorkbook wb = new XSSFWorkbook();
|
||||||
StylesTable styles = wb.getStylesSource();
|
StylesTable styles = wb.getStylesSource();
|
||||||
|
@ -610,6 +612,7 @@ public class TestXSSFCellStyle {
|
||||||
wb.close();
|
wb.close();
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@SuppressWarnings("deprecation")
|
||||||
@Test
|
@Test
|
||||||
public void testGetFillPattern() {
|
public void testGetFillPattern() {
|
||||||
|
|
||||||
|
@ -674,7 +677,8 @@ public class TestXSSFCellStyle {
|
||||||
assertEquals((short)13, cellStyle.getIndention());
|
assertEquals((short)13, cellStyle.getIndention());
|
||||||
}
|
}
|
||||||
|
|
||||||
@Test
|
@SuppressWarnings("deprecation")
|
||||||
|
@Test
|
||||||
public void testGetSetAlignment() {
|
public void testGetSetAlignment() {
|
||||||
assertNull(cellStyle.getCellAlignment().getCTCellAlignment().getHorizontal());
|
assertNull(cellStyle.getCellAlignment().getCTCellAlignment().getHorizontal());
|
||||||
assertEquals(HorizontalAlignment.GENERAL, cellStyle.getAlignmentEnum());
|
assertEquals(HorizontalAlignment.GENERAL, cellStyle.getAlignmentEnum());
|
||||||
|
@ -695,7 +699,8 @@ public class TestXSSFCellStyle {
|
||||||
assertEquals(STHorizontalAlignment.CENTER, cellStyle.getCellAlignment().getCTCellAlignment().getHorizontal());
|
assertEquals(STHorizontalAlignment.CENTER, cellStyle.getCellAlignment().getCTCellAlignment().getHorizontal());
|
||||||
}
|
}
|
||||||
|
|
||||||
@Test
|
@SuppressWarnings("deprecation")
|
||||||
|
@Test
|
||||||
public void testGetSetVerticalAlignment() {
|
public void testGetSetVerticalAlignment() {
|
||||||
assertEquals(VerticalAlignment.BOTTOM, cellStyle.getVerticalAlignmentEnum());
|
assertEquals(VerticalAlignment.BOTTOM, cellStyle.getVerticalAlignmentEnum());
|
||||||
assertEquals(VerticalAlignment.BOTTOM.getCode(), cellStyle.getVerticalAlignment());
|
assertEquals(VerticalAlignment.BOTTOM.getCode(), cellStyle.getVerticalAlignment());
|
||||||
|
@ -958,6 +963,7 @@ public class TestXSSFCellStyle {
|
||||||
assertEquals(HorizontalAlignment.RIGHT, styleBack.getAlignmentEnum());
|
assertEquals(HorizontalAlignment.RIGHT, styleBack.getAlignmentEnum());
|
||||||
assertEquals(VerticalAlignment.TOP, styleBack.getVerticalAlignmentEnum());
|
assertEquals(VerticalAlignment.TOP, styleBack.getVerticalAlignmentEnum());
|
||||||
assertEquals(FillPatternType.SOLID_FOREGROUND, styleBack.getFillPatternEnum());
|
assertEquals(FillPatternType.SOLID_FOREGROUND, styleBack.getFillPatternEnum());
|
||||||
|
//noinspection deprecation
|
||||||
assertEquals(FillPatternType.SOLID_FOREGROUND.getCode(), styleBack.getFillPattern());
|
assertEquals(FillPatternType.SOLID_FOREGROUND.getCode(), styleBack.getFillPattern());
|
||||||
|
|
||||||
wbBack.close();
|
wbBack.close();
|
||||||
|
|
|
@ -85,7 +85,6 @@ import org.openxmlformats.schemas.spreadsheetml.x2006.main.STUnsignedShortHex;
|
||||||
|
|
||||||
|
|
||||||
public final class TestXSSFSheet extends BaseTestXSheet {
|
public final class TestXSSFSheet extends BaseTestXSheet {
|
||||||
|
|
||||||
public TestXSSFSheet() {
|
public TestXSSFSheet() {
|
||||||
super(XSSFITestDataProvider.instance);
|
super(XSSFITestDataProvider.instance);
|
||||||
}
|
}
|
||||||
|
@ -319,7 +318,7 @@ public final class TestXSSFSheet extends BaseTestXSheet {
|
||||||
cellStyleXf.setFillId(0);
|
cellStyleXf.setFillId(0);
|
||||||
cellStyleXf.setBorderId(0);
|
cellStyleXf.setBorderId(0);
|
||||||
cellStyleXf.setNumFmtId(0);
|
cellStyleXf.setNumFmtId(0);
|
||||||
stylesTable.putCellStyleXf(cellStyleXf);
|
assertEquals(2, stylesTable.putCellStyleXf(cellStyleXf));
|
||||||
CTXf cellXf = CTXf.Factory.newInstance();
|
CTXf cellXf = CTXf.Factory.newInstance();
|
||||||
cellXf.setXfId(1);
|
cellXf.setXfId(1);
|
||||||
stylesTable.putCellXf(cellXf);
|
stylesTable.putCellXf(cellXf);
|
||||||
|
@ -367,7 +366,7 @@ public final class TestXSSFSheet extends BaseTestXSheet {
|
||||||
|
|
||||||
sheet.ungroupColumn(8, 10);
|
sheet.ungroupColumn(8, 10);
|
||||||
colArray = cols.getColArray();
|
colArray = cols.getColArray();
|
||||||
//assertEquals(3, colArray[1].getOutlineLevel());
|
assertEquals(3, colArray[1].getOutlineLevel());
|
||||||
|
|
||||||
sheet.ungroupColumn(4, 6);
|
sheet.ungroupColumn(4, 6);
|
||||||
sheet.ungroupColumn(2, 2);
|
sheet.ungroupColumn(2, 2);
|
||||||
|
@ -564,6 +563,7 @@ public final class TestXSSFSheet extends BaseTestXSheet {
|
||||||
* @param fromColumnIndex 0-indexed
|
* @param fromColumnIndex 0-indexed
|
||||||
* @param toColumnIndex 0-indexed
|
* @param toColumnIndex 0-indexed
|
||||||
*/
|
*/
|
||||||
|
@SuppressWarnings("SameParameterValue")
|
||||||
private static void checkColumnGroup(
|
private static void checkColumnGroup(
|
||||||
CTCol col,
|
CTCol col,
|
||||||
int fromColumnIndex, int toColumnIndex,
|
int fromColumnIndex, int toColumnIndex,
|
||||||
|
@ -615,6 +615,7 @@ public final class TestXSSFSheet extends BaseTestXSheet {
|
||||||
* @param fromColumnIndex 0-indexed
|
* @param fromColumnIndex 0-indexed
|
||||||
* @param toColumnIndex 0-indexed
|
* @param toColumnIndex 0-indexed
|
||||||
*/
|
*/
|
||||||
|
@SuppressWarnings("SameParameterValue")
|
||||||
private static void checkColumnGroupIsExpanded(
|
private static void checkColumnGroupIsExpanded(
|
||||||
CTCol col,
|
CTCol col,
|
||||||
int fromColumnIndex, int toColumnIndex
|
int fromColumnIndex, int toColumnIndex
|
||||||
|
@ -992,6 +993,7 @@ public final class TestXSSFSheet extends BaseTestXSheet {
|
||||||
wb1.close();
|
wb1.close();
|
||||||
sheet = wb2.getSheetAt(0);
|
sheet = wb2.getSheetAt(0);
|
||||||
wsh = sheet.getCTWorksheet();
|
wsh = sheet.getCTWorksheet();
|
||||||
|
assertNotNull(wsh);
|
||||||
xrow = sheetData.getRowArray();
|
xrow = sheetData.getRowArray();
|
||||||
assertEquals(3, xrow.length);
|
assertEquals(3, xrow.length);
|
||||||
|
|
||||||
|
@ -1888,52 +1890,43 @@ public final class TestXSSFSheet extends BaseTestXSheet {
|
||||||
|
|
||||||
@Test
|
@Test
|
||||||
public void setTabColor() throws IOException {
|
public void setTabColor() throws IOException {
|
||||||
XSSFWorkbook wb = new XSSFWorkbook();
|
try (XSSFWorkbook wb = new XSSFWorkbook()) {
|
||||||
try {
|
|
||||||
XSSFSheet sh = wb.createSheet();
|
XSSFSheet sh = wb.createSheet();
|
||||||
assertTrue(sh.getCTWorksheet().getSheetPr() == null || !sh.getCTWorksheet().getSheetPr().isSetTabColor());
|
assertTrue(sh.getCTWorksheet().getSheetPr() == null || !sh.getCTWorksheet().getSheetPr().isSetTabColor());
|
||||||
sh.setTabColor(new XSSFColor(IndexedColors.RED, null));
|
sh.setTabColor(new XSSFColor(IndexedColors.RED, null));
|
||||||
assertTrue(sh.getCTWorksheet().getSheetPr().isSetTabColor());
|
assertTrue(sh.getCTWorksheet().getSheetPr().isSetTabColor());
|
||||||
assertEquals(IndexedColors.RED.index,
|
assertEquals(IndexedColors.RED.index,
|
||||||
sh.getCTWorksheet().getSheetPr().getTabColor().getIndexed());
|
sh.getCTWorksheet().getSheetPr().getTabColor().getIndexed());
|
||||||
} finally {
|
|
||||||
wb.close();
|
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
@Test
|
@Test
|
||||||
public void getTabColor() throws IOException {
|
public void getTabColor() throws IOException {
|
||||||
XSSFWorkbook wb = new XSSFWorkbook();
|
try (XSSFWorkbook wb = new XSSFWorkbook()) {
|
||||||
try {
|
|
||||||
XSSFSheet sh = wb.createSheet();
|
XSSFSheet sh = wb.createSheet();
|
||||||
assertTrue(sh.getCTWorksheet().getSheetPr() == null || !sh.getCTWorksheet().getSheetPr().isSetTabColor());
|
assertTrue(sh.getCTWorksheet().getSheetPr() == null || !sh.getCTWorksheet().getSheetPr().isSetTabColor());
|
||||||
assertNull(sh.getTabColor());
|
assertNull(sh.getTabColor());
|
||||||
sh.setTabColor(new XSSFColor(IndexedColors.RED, null));
|
sh.setTabColor(new XSSFColor(IndexedColors.RED, null));
|
||||||
XSSFColor expected = new XSSFColor(IndexedColors.RED, null);
|
XSSFColor expected = new XSSFColor(IndexedColors.RED, null);
|
||||||
assertEquals(expected, sh.getTabColor());
|
assertEquals(expected, sh.getTabColor());
|
||||||
} finally {
|
|
||||||
wb.close();
|
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
// Test using an existing workbook saved by Excel
|
// Test using an existing workbook saved by Excel
|
||||||
@Test
|
@Test
|
||||||
public void tabColor() throws IOException {
|
public void tabColor() throws IOException {
|
||||||
XSSFWorkbook wb = openSampleWorkbook("SheetTabColors.xlsx");
|
try (XSSFWorkbook wb = openSampleWorkbook("SheetTabColors.xlsx")) {
|
||||||
try {
|
|
||||||
// non-colored sheets do not have a color
|
// non-colored sheets do not have a color
|
||||||
assertNull(wb.getSheet("default").getTabColor());
|
assertNull(wb.getSheet("default").getTabColor());
|
||||||
|
|
||||||
// test indexed-colored sheet
|
// test indexed-colored sheet
|
||||||
XSSFColor expected = new XSSFColor(IndexedColors.RED, null);
|
XSSFColor expected = new XSSFColor(IndexedColors.RED, null);
|
||||||
assertEquals(expected, wb.getSheet("indexedRed").getTabColor());
|
assertEquals(expected, wb.getSheet("indexedRed").getTabColor());
|
||||||
|
|
||||||
// test regular-colored (non-indexed, ARGB) sheet
|
// test regular-colored (non-indexed, ARGB) sheet
|
||||||
expected = new XSSFColor();
|
expected = new XSSFColor();
|
||||||
expected.setARGBHex("FF7F2700");
|
expected.setARGBHex("FF7F2700");
|
||||||
assertEquals(expected, wb.getSheet("customOrange").getTabColor());
|
assertEquals(expected, wb.getSheet("customOrange").getTabColor());
|
||||||
} finally {
|
|
||||||
wb.close();
|
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
|
@ -1872,7 +1872,7 @@ public final class TestBugs extends BaseTestBugzillaIssues {
|
||||||
// Link our new workbook
|
// Link our new workbook
|
||||||
Workbook externalWb1 = new HSSFWorkbook();
|
Workbook externalWb1 = new HSSFWorkbook();
|
||||||
externalWb1.createSheet("Sheet1");
|
externalWb1.createSheet("Sheet1");
|
||||||
wb1.linkExternalWorkbook("$http://gagravarr.org/FormulaRefs2.xls", externalWb1);
|
assertEquals(4, wb1.linkExternalWorkbook("$http://gagravarr.org/FormulaRefs2.xls", externalWb1));
|
||||||
|
|
||||||
// Change 4
|
// Change 4
|
||||||
row.getCell(1).setCellFormula("'[$http://gagravarr.org/FormulaRefs2.xls]Sheet1'!B2");
|
row.getCell(1).setCellFormula("'[$http://gagravarr.org/FormulaRefs2.xls]Sheet1'!B2");
|
||||||
|
@ -1881,7 +1881,7 @@ public final class TestBugs extends BaseTestBugzillaIssues {
|
||||||
// Link our new workbook
|
// Link our new workbook
|
||||||
Workbook externalWb2 = new HSSFWorkbook();
|
Workbook externalWb2 = new HSSFWorkbook();
|
||||||
externalWb2.createSheet("Sheet1");
|
externalWb2.createSheet("Sheet1");
|
||||||
wb1.linkExternalWorkbook("$http://example.com/FormulaRefs.xls", externalWb2);
|
assertEquals(5, wb1.linkExternalWorkbook("$http://example.com/FormulaRefs.xls", externalWb2));
|
||||||
|
|
||||||
// Add 5
|
// Add 5
|
||||||
row = s.createRow(5);
|
row = s.createRow(5);
|
||||||
|
@ -2782,22 +2782,6 @@ public final class TestBugs extends BaseTestBugzillaIssues {
|
||||||
wb.close();
|
wb.close();
|
||||||
}
|
}
|
||||||
|
|
||||||
private void assertFormula(Workbook wb, Cell intF, String expectedFormula, String expectedResultOrNull) {
|
|
||||||
assertEquals(CellType.FORMULA, intF.getCellType());
|
|
||||||
if (null == expectedResultOrNull) {
|
|
||||||
assertEquals(CellType.ERROR, intF.getCachedFormulaResultType());
|
|
||||||
expectedResultOrNull = "#VALUE!";
|
|
||||||
} else {
|
|
||||||
assertEquals(CellType.NUMERIC, intF.getCachedFormulaResultType());
|
|
||||||
}
|
|
||||||
|
|
||||||
assertEquals(expectedFormula, intF.getCellFormula());
|
|
||||||
|
|
||||||
// Check we can evaluate it correctly
|
|
||||||
FormulaEvaluator eval = wb.getCreationHelper().createFormulaEvaluator();
|
|
||||||
assertEquals(expectedResultOrNull, eval.evaluate(intF).formatAsString());
|
|
||||||
}
|
|
||||||
|
|
||||||
@Test
|
@Test
|
||||||
public void bug42016() throws Exception {
|
public void bug42016() throws Exception {
|
||||||
Workbook wb = openSample("42016.xls");
|
Workbook wb = openSample("42016.xls");
|
||||||
|
|
|
@ -224,8 +224,7 @@ public final class TestHSSFFormulaEvaluator extends BaseTestFormulaEvaluator {
|
||||||
// Check it evaluates correctly
|
// Check it evaluates correctly
|
||||||
eval.evaluateFormulaCell(cell);
|
eval.evaluateFormulaCell(cell);
|
||||||
assertEquals(24.60*1.8, cell.getNumericCellValue(), 0);
|
assertEquals(24.60*1.8, cell.getNumericCellValue(), 0);
|
||||||
|
|
||||||
|
|
||||||
// Try to add a formula for a new external workbook, won't be allowed to start
|
// Try to add a formula for a new external workbook, won't be allowed to start
|
||||||
try {
|
try {
|
||||||
cell = wb1.getSheetAt(0).getRow(1).createCell(42);
|
cell = wb1.getSheetAt(0).getRow(1).createCell(42);
|
||||||
|
@ -238,7 +237,7 @@ public final class TestHSSFFormulaEvaluator extends BaseTestFormulaEvaluator {
|
||||||
// Link our new workbook
|
// Link our new workbook
|
||||||
HSSFWorkbook wb3 = new HSSFWorkbook();
|
HSSFWorkbook wb3 = new HSSFWorkbook();
|
||||||
wb3.createSheet().createRow(0).createCell(0).setCellValue("In another workbook");
|
wb3.createSheet().createRow(0).createCell(0).setCellValue("In another workbook");
|
||||||
wb1.linkExternalWorkbook("alt.xls", wb3);
|
assertEquals(2, wb1.linkExternalWorkbook("alt.xls", wb3));
|
||||||
|
|
||||||
// Now add a formula that refers to our new workbook
|
// Now add a formula that refers to our new workbook
|
||||||
cell.setCellFormula("[alt.xls]Sheet0!$A$1");
|
cell.setCellFormula("[alt.xls]Sheet0!$A$1");
|
||||||
|
|
|
@ -1896,4 +1896,20 @@ public abstract class BaseTestBugzillaIssues {
|
||||||
|
|
||||||
wb.close();
|
wb.close();
|
||||||
}
|
}
|
||||||
|
|
||||||
|
protected void assertFormula(Workbook wb, Cell intF, String expectedFormula, String expectedResultOrNull) {
|
||||||
|
assertEquals(CellType.FORMULA, intF.getCellType());
|
||||||
|
if (null == expectedResultOrNull) {
|
||||||
|
assertEquals(CellType.ERROR, intF.getCachedFormulaResultType());
|
||||||
|
expectedResultOrNull = "#VALUE!";
|
||||||
|
} else {
|
||||||
|
assertEquals(CellType.NUMERIC, intF.getCachedFormulaResultType());
|
||||||
|
}
|
||||||
|
|
||||||
|
assertEquals(expectedFormula, intF.getCellFormula());
|
||||||
|
|
||||||
|
// Check we can evaluate it correctly
|
||||||
|
FormulaEvaluator eval = wb.getCreationHelper().createFormulaEvaluator();
|
||||||
|
assertEquals(expectedResultOrNull, eval.evaluate(intF).formatAsString());
|
||||||
|
}
|
||||||
}
|
}
|
|
@ -133,6 +133,7 @@ public abstract class BaseTestFont {
|
||||||
Workbook wb3 = _testDataProvider.writeOutAndReadBack(wb2);
|
Workbook wb3 = _testDataProvider.writeOutAndReadBack(wb2);
|
||||||
wb2.close();
|
wb2.close();
|
||||||
s1 = wb3.getSheetAt(0);
|
s1 = wb3.getSheetAt(0);
|
||||||
|
assertNotNull(s1);
|
||||||
|
|
||||||
assertEquals(num0 + 2, wb3.getNumberOfFonts());
|
assertEquals(num0 + 2, wb3.getNumberOfFonts());
|
||||||
assertNotNull(wb3.getFontAt(font1Idx));
|
assertNotNull(wb3.getFontAt(font1Idx));
|
||||||
|
@ -145,8 +146,6 @@ public abstract class BaseTestFont {
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Test that fonts get added properly
|
* Test that fonts get added properly
|
||||||
*
|
|
||||||
* @see org.apache.poi.hssf.usermodel.TestBugs#test45338()
|
|
||||||
*/
|
*/
|
||||||
@Test
|
@Test
|
||||||
public final void test45338() throws IOException {
|
public final void test45338() throws IOException {
|
||||||
|
|
Loading…
Reference in New Issue