123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869 |
- /* ====================================================================
- Licensed to the Apache Software Foundation (ASF) under one or more
- contributor license agreements. See the NOTICE file distributed with
- this work for additional information regarding copyright ownership.
- The ASF licenses this file to You under the Apache License, Version 2.0
- (the "License"); you may not use this file except in compliance with
- the License. You may obtain a copy of the License at
-
- http://www.apache.org/licenses/LICENSE-2.0
-
- Unless required by applicable law or agreed to in writing, software
- distributed under the License is distributed on an "AS IS" BASIS,
- WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
- See the License for the specific language governing permissions and
- limitations under the License.
- ==================================================================== */
-
- package org.apache.poi.xssf.usermodel;
-
- import org.apache.poi.ss.usermodel.BaseTestDataFormat;
- import org.apache.poi.ss.usermodel.BuiltinFormats;
- import org.apache.poi.ss.usermodel.DataFormatter;
- import org.apache.poi.xssf.XSSFITestDataProvider;
- import org.apache.poi.xssf.XSSFTestDataSamples;
-
- /**
- * Tests for {@link XSSFDataFormat}
- */
- public final class TestXSSFDataFormat extends BaseTestDataFormat {
-
- public TestXSSFDataFormat() {
- super(XSSFITestDataProvider.instance);
- }
-
- /**
- * [Bug 49928] formatCellValue returns incorrect value for \u00a3 formatted cells
- */
- public void test49928(){
- XSSFWorkbook wb = XSSFTestDataSamples.openSampleWorkbook("49928.xlsx");
- DataFormatter df = new DataFormatter();
-
- XSSFSheet sheet = wb.getSheetAt(0);
- XSSFCell cell = sheet.getRow(0).getCell(0);
- XSSFCellStyle style = cell.getCellStyle();
-
- String poundFmt = "\"\u00a3\"#,##0;[Red]\\-\"\u00a3\"#,##0";
- // not expected normally, id of a custom format should be gerater
- // than BuiltinFormats.FIRST_USER_DEFINED_FORMAT_INDEX
- short poundFmtIdx = 6;
-
- assertEquals(poundFmt, style.getDataFormatString());
- assertEquals(poundFmtIdx, style.getDataFormat());
- assertEquals("\u00a31", df.formatCellValue(cell));
-
-
- XSSFDataFormat dataFormat = wb.createDataFormat();
- assertEquals(poundFmtIdx, dataFormat.getFormat(poundFmt));
- assertEquals(poundFmt, dataFormat.getFormat(poundFmtIdx));
-
- // an attempt to register an existing format returns its index
- assertEquals(poundFmtIdx, wb.getStylesSource().putNumberFormat(poundFmt));
-
- // now create a custom format with Pound (\u00a3)
- short customFmtIdx = dataFormat.getFormat("\u00a3##.00[Yellow]");
- assertTrue(customFmtIdx > BuiltinFormats.FIRST_USER_DEFINED_FORMAT_INDEX );
- assertEquals("\u00a3##.00[Yellow]", dataFormat.getFormat(customFmtIdx));
-
- }
- }
|