123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124 |
- /* ====================================================================
- 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.ss.tests.util;
-
- import org.apache.commons.codec.DecoderException;
- import org.apache.commons.codec.binary.Hex;
- import org.apache.poi.ss.usermodel.Cell;
- import org.apache.poi.ss.usermodel.FillPatternType;
- import org.apache.poi.ss.usermodel.IndexedColors;
- 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.BaseTestCellUtil;
- import org.apache.poi.ss.util.CellUtil;
- import org.apache.poi.xssf.XSSFITestDataProvider;
- import org.apache.poi.xssf.usermodel.XSSFColor;
- import org.apache.poi.xssf.usermodel.XSSFWorkbook;
- import org.junit.jupiter.api.Test;
-
- import java.io.FileOutputStream;
- import java.io.IOException;
- import java.io.OutputStream;
- import java.util.LinkedHashMap;
- import java.util.Map;
-
- import static org.junit.jupiter.api.Assertions.*;
-
- class TestXSSFCellUtil extends BaseTestCellUtil {
- public TestXSSFCellUtil() {
- super(XSSFITestDataProvider.instance);
- }
-
- @Test
- public void testSetForegroundColorCellStyleProperty() throws IOException, DecoderException {
- try (Workbook workbook = new XSSFWorkbook()) {
-
- final Sheet sheet = workbook.createSheet("Sheet");
- final Row row = sheet.createRow(0);
- final Cell cell = row.createCell(0);
- final XSSFColor color = new XSSFColor(Hex.decodeHex("AAAAAA"));
-
- assertNull(cell.getCellStyle().getFillForegroundColorColor());
-
- CellUtil.setCellStyleProperty(
- cell, CellUtil.FILL_FOREGROUND_COLOR_COLOR, color);
-
- assertEquals(color, cell.getCellStyle().getFillForegroundColorColor());
- }
- }
-
- @Test
- public void testSetForegroundColorCellStylePropertyToNull() throws IOException, DecoderException {
-
- try (Workbook workbook = new XSSFWorkbook()) {
-
- final Sheet sheet = workbook.createSheet("Sheet");
- final Row row = sheet.createRow(0);
- final Cell cell = row.createCell(0);
- final XSSFColor color = new XSSFColor(Hex.decodeHex("AAAAAA"));
-
- assertNull(cell.getCellStyle().getFillForegroundColorColor());
-
- CellUtil.setCellStyleProperty(
- cell, CellUtil.FILL_FOREGROUND_COLOR_COLOR, color);
-
- assertEquals(color, cell.getCellStyle().getFillForegroundColorColor());
-
- CellUtil.setCellStyleProperty(
- cell, CellUtil.FILL_FOREGROUND_COLOR_COLOR, null);
-
- assertNotEquals(color, cell.getCellStyle().getFillForegroundColorColor());
- assertNull(cell.getCellStyle().getFillForegroundColorColor());
- assertEquals(IndexedColors.AUTOMATIC.getIndex(), cell.getCellStyle().getFillForegroundColor());
- }
- }
-
- @Test
- public void testSetForegroundColorCellStylePropertiesToNull() throws IOException, DecoderException {
-
- try (Workbook workbook = new XSSFWorkbook()) {
-
- final Sheet sheet = workbook.createSheet("Sheet");
- final Row row = sheet.createRow(0);
- final Cell cell = row.createCell(0);
- final XSSFColor color = new XSSFColor(Hex.decodeHex("FF0000"));
-
- {
- final Map<String, Object> properties = new LinkedHashMap<>();
-
- properties.put(CellUtil.FILL_FOREGROUND_COLOR_COLOR, color);
- properties.put(CellUtil.FILL_PATTERN, FillPatternType.SOLID_FOREGROUND);
-
- CellUtil.setCellStyleProperties(cell, properties);
- }
- assertEquals(color, cell.getCellStyle().getFillForegroundColorColor());
-
- {
- final Map<String, Object> properties = new LinkedHashMap<>();
-
- properties.put(CellUtil.FILL_FOREGROUND_COLOR_COLOR, null);
- properties.put(CellUtil.FILL_PATTERN, FillPatternType.NO_FILL);
-
- CellUtil.setCellStyleProperties(cell, properties);
- }
- assertNull(cell.getCellStyle().getFillForegroundColorColor());
- assertEquals(IndexedColors.AUTOMATIC.getIndex(), cell.getCellStyle().getFillForegroundColor());
- }
- }
- }
|