You can not select more than 25 topics Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.

BaseTestWorkbook.java 26KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426427428429430431432433434435436437438439440441442443444445446447448449450451452453454455456457458459460461462463464465466467468469470471472473474475476477478479480481482483484485486487488489490491492493494495496497498499500501502503504505506507508509510511512513514515516517518519520521522523524525526527528529530531532533534535536537538539540541542543544545546547548549550551552553554555556557558559560561562563564565566567568569570571572573574575576577578579580581582583584585586587588589590591592593594595596597598599600601602603604605606607608609610611612613614615616617618619620621622623624625626627628629630631632633634635636637638639640641642643644645646647648649650651652653654655656657658659660661662663664665666667668669670671672673674
  1. /* ====================================================================
  2. Licensed to the Apache Software Foundation (ASF) under one or more
  3. contributor license agreements. See the NOTICE file distributed with
  4. this work for additional information regarding copyright ownership.
  5. The ASF licenses this file to You under the Apache License, Version 2.0
  6. (the "License"); you may not use this file except in compliance with
  7. the License. You may obtain a copy of the License at
  8. http://www.apache.org/licenses/LICENSE-2.0
  9. Unless required by applicable law or agreed to in writing, software
  10. distributed under the License is distributed on an "AS IS" BASIS,
  11. WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
  12. See the License for the specific language governing permissions and
  13. limitations under the License.
  14. ==================================================================== */
  15. package org.apache.poi.ss.usermodel;
  16. import static org.junit.Assert.assertEquals;
  17. import static org.junit.Assert.assertFalse;
  18. import static org.junit.Assert.assertNotNull;
  19. import static org.junit.Assert.assertNull;
  20. import static org.junit.Assert.assertSame;
  21. import static org.junit.Assert.assertTrue;
  22. import static org.junit.Assert.fail;
  23. import junit.framework.AssertionFailedError;
  24. import org.apache.poi.ss.ITestDataProvider;
  25. import org.apache.poi.ss.util.CellRangeAddress;
  26. import org.junit.Test;
  27. /**
  28. * @author Yegor Kozlov
  29. */
  30. public abstract class BaseTestWorkbook {
  31. private final ITestDataProvider _testDataProvider;
  32. protected BaseTestWorkbook(ITestDataProvider testDataProvider) {
  33. _testDataProvider = testDataProvider;
  34. }
  35. @Test
  36. public void createSheet() {
  37. Workbook wb = _testDataProvider.createWorkbook();
  38. assertEquals(0, wb.getNumberOfSheets());
  39. //getting a sheet by invalid index or non-existing name
  40. assertNull(wb.getSheet("Sheet1"));
  41. try {
  42. wb.getSheetAt(0);
  43. fail("should have thrown exceptiuon due to invalid sheet index");
  44. } catch (IllegalArgumentException e) {
  45. // expected during successful test
  46. // no negative index in the range message
  47. assertFalse(e.getMessage().contains("-1"));
  48. }
  49. Sheet sheet0 = wb.createSheet();
  50. Sheet sheet1 = wb.createSheet();
  51. assertEquals("Sheet0", sheet0.getSheetName());
  52. assertEquals("Sheet1", sheet1.getSheetName());
  53. assertEquals(2, wb.getNumberOfSheets());
  54. //fetching sheets by name is case-insensitive
  55. Sheet originalSheet = wb.createSheet("Sheet3");
  56. Sheet fetchedSheet = wb.getSheet("sheet3");
  57. if (fetchedSheet == null) {
  58. throw new AssertionFailedError("Identified bug 44892");
  59. }
  60. assertEquals("Sheet3", fetchedSheet.getSheetName());
  61. assertEquals(3, wb.getNumberOfSheets());
  62. assertSame(originalSheet, fetchedSheet);
  63. try {
  64. wb.createSheet("sHeeT3");
  65. fail("should have thrown exceptiuon due to duplicate sheet name");
  66. } catch (IllegalArgumentException e) {
  67. // expected during successful test
  68. assertEquals("The workbook already contains a sheet of this name", e.getMessage());
  69. }
  70. //names cannot be blank or contain any of /\*?[]
  71. String[] invalidNames = {"", "Sheet/", "Sheet\\",
  72. "Sheet?", "Sheet*", "Sheet[", "Sheet]", "'Sheet'",
  73. "My:Sheet"};
  74. for (String sheetName : invalidNames) {
  75. try {
  76. wb.createSheet(sheetName);
  77. fail("should have thrown exception due to invalid sheet name: " + sheetName);
  78. } catch (IllegalArgumentException e) {
  79. // expected during successful test
  80. }
  81. }
  82. //still have 3 sheets
  83. assertEquals(3, wb.getNumberOfSheets());
  84. //change the name of the 3rd sheet
  85. wb.setSheetName(2, "I changed!");
  86. //try to assign an invalid name to the 2nd sheet
  87. try {
  88. wb.setSheetName(1, "[I'm invalid]");
  89. fail("should have thrown exceptiuon due to invalid sheet name");
  90. } catch (IllegalArgumentException e) {
  91. // expected during successful test
  92. }
  93. //try to assign an invalid name to the 2nd sheet
  94. try {
  95. wb.createSheet(null);
  96. fail("should have thrown exceptiuon due to invalid sheet name");
  97. } catch (IllegalArgumentException e) {
  98. // expected during successful test
  99. }
  100. try {
  101. wb.setSheetName(2, null);
  102. fail("should have thrown exceptiuon due to invalid sheet name");
  103. } catch (IllegalArgumentException e) {
  104. // expected during successful test
  105. }
  106. //check
  107. assertEquals(0, wb.getSheetIndex("sheet0"));
  108. assertEquals(1, wb.getSheetIndex("sheet1"));
  109. assertEquals(2, wb.getSheetIndex("I changed!"));
  110. assertSame(sheet0, wb.getSheet("sheet0"));
  111. assertSame(sheet1, wb.getSheet("sheet1"));
  112. assertSame(originalSheet, wb.getSheet("I changed!"));
  113. assertNull(wb.getSheet("unknown"));
  114. //serialize and read again
  115. wb = _testDataProvider.writeOutAndReadBack(wb);
  116. assertEquals(3, wb.getNumberOfSheets());
  117. assertEquals(0, wb.getSheetIndex("sheet0"));
  118. assertEquals(1, wb.getSheetIndex("sheet1"));
  119. assertEquals(2, wb.getSheetIndex("I changed!"));
  120. }
  121. /**
  122. * POI allows creating sheets with names longer than 31 characters.
  123. *
  124. * Excel opens files with long sheet names without error or warning.
  125. * However, long sheet names are silently truncated to 31 chars. In order to
  126. * avoid funny duplicate sheet name errors, POI enforces uniqueness on only the first 31 chars.
  127. * but for the purpose of uniqueness long sheet names are silently truncated to 31 chars.
  128. */
  129. @Test
  130. public void createSheetWithLongNames() {
  131. Workbook wb = _testDataProvider.createWorkbook();
  132. String sheetName1 = "My very long sheet name which is longer than 31 chars";
  133. String truncatedSheetName1 = sheetName1.substring(0, 31);
  134. Sheet sh1 = wb.createSheet(sheetName1);
  135. assertEquals(truncatedSheetName1, sh1.getSheetName());
  136. assertSame(sh1, wb.getSheet(truncatedSheetName1));
  137. // now via wb.setSheetName
  138. wb.setSheetName(0, sheetName1);
  139. assertEquals(truncatedSheetName1, sh1.getSheetName());
  140. assertSame(sh1, wb.getSheet(truncatedSheetName1));
  141. String sheetName2 = "My very long sheet name which is longer than 31 chars " +
  142. "and sheetName2.substring(0, 31) == sheetName1.substring(0, 31)";
  143. try {
  144. /*Sheet sh2 =*/ wb.createSheet(sheetName2);
  145. fail("expected exception");
  146. } catch (IllegalArgumentException e) {
  147. // expected during successful test
  148. assertEquals("The workbook already contains a sheet of this name", e.getMessage());
  149. }
  150. String sheetName3 = "POI allows creating sheets with names longer than 31 characters";
  151. String truncatedSheetName3 = sheetName3.substring(0, 31);
  152. Sheet sh3 = wb.createSheet(sheetName3);
  153. assertEquals(truncatedSheetName3, sh3.getSheetName());
  154. assertSame(sh3, wb.getSheet(truncatedSheetName3));
  155. //serialize and read again
  156. wb = _testDataProvider.writeOutAndReadBack(wb);
  157. assertEquals(2, wb.getNumberOfSheets());
  158. assertEquals(0, wb.getSheetIndex(truncatedSheetName1));
  159. assertEquals(1, wb.getSheetIndex(truncatedSheetName3));
  160. }
  161. @Test
  162. public void removeSheetAt() {
  163. Workbook workbook = _testDataProvider.createWorkbook();
  164. workbook.createSheet("sheet1");
  165. workbook.createSheet("sheet2");
  166. workbook.createSheet("sheet3");
  167. assertEquals(3, workbook.getNumberOfSheets());
  168. assertEquals(0, workbook.getActiveSheetIndex());
  169. workbook.removeSheetAt(1);
  170. assertEquals(2, workbook.getNumberOfSheets());
  171. assertEquals("sheet3", workbook.getSheetName(1));
  172. assertEquals(0, workbook.getActiveSheetIndex());
  173. workbook.removeSheetAt(0);
  174. assertEquals(1, workbook.getNumberOfSheets());
  175. assertEquals("sheet3", workbook.getSheetName(0));
  176. assertEquals(0, workbook.getActiveSheetIndex());
  177. workbook.removeSheetAt(0);
  178. assertEquals(0, workbook.getNumberOfSheets());
  179. assertEquals(0, workbook.getActiveSheetIndex());
  180. //re-create the sheets
  181. workbook.createSheet("sheet1");
  182. workbook.createSheet("sheet2");
  183. workbook.createSheet("sheet3");
  184. workbook.createSheet("sheet4");
  185. assertEquals(4, workbook.getNumberOfSheets());
  186. assertEquals(0, workbook.getActiveSheetIndex());
  187. workbook.setActiveSheet(2);
  188. assertEquals(2, workbook.getActiveSheetIndex());
  189. workbook.removeSheetAt(2);
  190. assertEquals(2, workbook.getActiveSheetIndex());
  191. workbook.removeSheetAt(1);
  192. assertEquals(1, workbook.getActiveSheetIndex());
  193. workbook.removeSheetAt(0);
  194. assertEquals(0, workbook.getActiveSheetIndex());
  195. workbook.removeSheetAt(0);
  196. assertEquals(0, workbook.getActiveSheetIndex());
  197. }
  198. @Test
  199. public void defaultValues() {
  200. Workbook b = _testDataProvider.createWorkbook();
  201. assertEquals(0, b.getActiveSheetIndex());
  202. assertEquals(0, b.getFirstVisibleTab());
  203. assertEquals(0, b.getNumberOfNames());
  204. assertEquals(0, b.getNumberOfSheets());
  205. }
  206. @Test
  207. public void sheetSelection() {
  208. Workbook b = _testDataProvider.createWorkbook();
  209. b.createSheet("Sheet One");
  210. b.createSheet("Sheet Two");
  211. b.setActiveSheet(1);
  212. b.setSelectedTab(1);
  213. b.setFirstVisibleTab(1);
  214. assertEquals(1, b.getActiveSheetIndex());
  215. assertEquals(1, b.getFirstVisibleTab());
  216. }
  217. @Test
  218. public void printArea() {
  219. Workbook workbook = _testDataProvider.createWorkbook();
  220. Sheet sheet1 = workbook.createSheet("Test Print Area");
  221. String sheetName1 = sheet1.getSheetName();
  222. // workbook.setPrintArea(0, reference);
  223. workbook.setPrintArea(0, 1, 5, 4, 9);
  224. String retrievedPrintArea = workbook.getPrintArea(0);
  225. assertEquals("'" + sheetName1 + "'!$B$5:$F$10", retrievedPrintArea);
  226. String reference = "$A$1:$B$1";
  227. workbook.setPrintArea(0, reference);
  228. retrievedPrintArea = workbook.getPrintArea(0);
  229. assertEquals("'" + sheetName1 + "'!" + reference, retrievedPrintArea);
  230. workbook.removePrintArea(0);
  231. assertNull(workbook.getPrintArea(0));
  232. }
  233. @Test
  234. public void getSetActiveSheet(){
  235. Workbook workbook = _testDataProvider.createWorkbook();
  236. assertEquals(0, workbook.getActiveSheetIndex());
  237. workbook.createSheet("sheet1");
  238. workbook.createSheet("sheet2");
  239. workbook.createSheet("sheet3");
  240. // set second sheet
  241. workbook.setActiveSheet(1);
  242. // test if second sheet is set up
  243. assertEquals(1, workbook.getActiveSheetIndex());
  244. workbook.setActiveSheet(0);
  245. // test if second sheet is set up
  246. assertEquals(0, workbook.getActiveSheetIndex());
  247. }
  248. @Test
  249. public void setSheetOrder() {
  250. Workbook wb = _testDataProvider.createWorkbook();
  251. for (int i=0; i < 10; i++) {
  252. wb.createSheet("Sheet " + i);
  253. }
  254. // Check the initial order
  255. assertEquals(0, wb.getSheetIndex("Sheet 0"));
  256. assertEquals(1, wb.getSheetIndex("Sheet 1"));
  257. assertEquals(2, wb.getSheetIndex("Sheet 2"));
  258. assertEquals(3, wb.getSheetIndex("Sheet 3"));
  259. assertEquals(4, wb.getSheetIndex("Sheet 4"));
  260. assertEquals(5, wb.getSheetIndex("Sheet 5"));
  261. assertEquals(6, wb.getSheetIndex("Sheet 6"));
  262. assertEquals(7, wb.getSheetIndex("Sheet 7"));
  263. assertEquals(8, wb.getSheetIndex("Sheet 8"));
  264. assertEquals(9, wb.getSheetIndex("Sheet 9"));
  265. // check active sheet
  266. assertEquals(0, wb.getActiveSheetIndex());
  267. // Change
  268. wb.setSheetOrder("Sheet 6", 0);
  269. assertEquals(1, wb.getActiveSheetIndex());
  270. wb.setSheetOrder("Sheet 3", 7);
  271. wb.setSheetOrder("Sheet 1", 9);
  272. // now the first sheet is at index 1
  273. assertEquals(1, wb.getActiveSheetIndex());
  274. // Check they're currently right
  275. assertEquals(0, wb.getSheetIndex("Sheet 6"));
  276. assertEquals(1, wb.getSheetIndex("Sheet 0"));
  277. assertEquals(2, wb.getSheetIndex("Sheet 2"));
  278. assertEquals(3, wb.getSheetIndex("Sheet 4"));
  279. assertEquals(4, wb.getSheetIndex("Sheet 5"));
  280. assertEquals(5, wb.getSheetIndex("Sheet 7"));
  281. assertEquals(6, wb.getSheetIndex("Sheet 3"));
  282. assertEquals(7, wb.getSheetIndex("Sheet 8"));
  283. assertEquals(8, wb.getSheetIndex("Sheet 9"));
  284. assertEquals(9, wb.getSheetIndex("Sheet 1"));
  285. Workbook wbr = _testDataProvider.writeOutAndReadBack(wb);
  286. assertEquals(0, wbr.getSheetIndex("Sheet 6"));
  287. assertEquals(1, wbr.getSheetIndex("Sheet 0"));
  288. assertEquals(2, wbr.getSheetIndex("Sheet 2"));
  289. assertEquals(3, wbr.getSheetIndex("Sheet 4"));
  290. assertEquals(4, wbr.getSheetIndex("Sheet 5"));
  291. assertEquals(5, wbr.getSheetIndex("Sheet 7"));
  292. assertEquals(6, wbr.getSheetIndex("Sheet 3"));
  293. assertEquals(7, wbr.getSheetIndex("Sheet 8"));
  294. assertEquals(8, wbr.getSheetIndex("Sheet 9"));
  295. assertEquals(9, wbr.getSheetIndex("Sheet 1"));
  296. assertEquals(1, wb.getActiveSheetIndex());
  297. // Now get the index by the sheet, not the name
  298. for(int i=0; i<10; i++) {
  299. Sheet s = wbr.getSheetAt(i);
  300. assertEquals(i, wbr.getSheetIndex(s));
  301. }
  302. }
  303. @Test
  304. public void cloneSheet() {
  305. Workbook book = _testDataProvider.createWorkbook();
  306. Sheet sheet = book.createSheet("TEST");
  307. sheet.createRow(0).createCell(0).setCellValue("Test");
  308. sheet.createRow(1).createCell(0).setCellValue(36.6);
  309. sheet.addMergedRegion(new CellRangeAddress(0, 1, 0, 2));
  310. sheet.addMergedRegion(new CellRangeAddress(1, 2, 0, 2));
  311. assertTrue(sheet.isSelected());
  312. Sheet clonedSheet = book.cloneSheet(0);
  313. assertEquals("TEST (2)", clonedSheet.getSheetName());
  314. assertEquals(2, clonedSheet.getPhysicalNumberOfRows());
  315. assertEquals(2, clonedSheet.getNumMergedRegions());
  316. assertFalse(clonedSheet.isSelected());
  317. //cloned sheet is a deep copy, adding rows in the original does not affect the clone
  318. sheet.createRow(2).createCell(0).setCellValue(1);
  319. sheet.addMergedRegion(new CellRangeAddress(0, 2, 0, 2));
  320. assertEquals(2, clonedSheet.getPhysicalNumberOfRows());
  321. assertEquals(2, clonedSheet.getPhysicalNumberOfRows());
  322. clonedSheet.createRow(2).createCell(0).setCellValue(1);
  323. clonedSheet.addMergedRegion(new CellRangeAddress(0, 2, 0, 2));
  324. assertEquals(3, clonedSheet.getPhysicalNumberOfRows());
  325. assertEquals(3, clonedSheet.getPhysicalNumberOfRows());
  326. }
  327. @Test
  328. public void parentReferences(){
  329. Workbook workbook = _testDataProvider.createWorkbook();
  330. Sheet sheet = workbook.createSheet();
  331. assertSame(workbook, sheet.getWorkbook());
  332. Row row = sheet.createRow(0);
  333. assertSame(sheet, row.getSheet());
  334. Cell cell = row.createCell(1);
  335. assertSame(sheet, cell.getSheet());
  336. assertSame(row, cell.getRow());
  337. workbook = _testDataProvider.writeOutAndReadBack(workbook);
  338. sheet = workbook.getSheetAt(0);
  339. assertSame(workbook, sheet.getWorkbook());
  340. row = sheet.getRow(0);
  341. assertSame(sheet, row.getSheet());
  342. cell = row.getCell(1);
  343. assertSame(sheet, cell.getSheet());
  344. assertSame(row, cell.getRow());
  345. }
  346. /**
  347. * Test is kept to ensure stub for deprecated business method passes test.
  348. *
  349. * @Deprecated remove this test when
  350. * {@link Workbook#setRepeatingRowsAndColumns(int, int, int, int, int)}
  351. * is removed
  352. */
  353. @Deprecated
  354. @Test
  355. public void setRepeatingRowsAnsColumns(){
  356. Workbook wb = _testDataProvider.createWorkbook();
  357. Sheet sheet1 = wb.createSheet();
  358. wb.setRepeatingRowsAndColumns(wb.getSheetIndex(sheet1), 0, 0, 0, 3);
  359. assertEquals("1:4", sheet1.getRepeatingRows().formatAsString());
  360. assertEquals("A:A", sheet1.getRepeatingColumns().formatAsString());
  361. //must handle sheets with quotas, see Bugzilla #47294
  362. Sheet sheet2 = wb.createSheet("My' Sheet");
  363. wb.setRepeatingRowsAndColumns(wb.getSheetIndex(sheet2), 0, 0, 0, 3);
  364. assertEquals("1:4", sheet2.getRepeatingRows().formatAsString());
  365. assertEquals("A:A", sheet1.getRepeatingColumns().formatAsString());
  366. }
  367. /**
  368. * Tests that all of the unicode capable string fields can be set, written and then read back
  369. */
  370. @Test
  371. public void unicodeInAll() {
  372. Workbook wb = _testDataProvider.createWorkbook();
  373. CreationHelper factory = wb.getCreationHelper();
  374. //Create a unicode dataformat (contains euro symbol)
  375. DataFormat df = wb.createDataFormat();
  376. final String formatStr = "_([$\u20ac-2]\\\\\\ * #,##0.00_);_([$\u20ac-2]\\\\\\ * \\\\\\(#,##0.00\\\\\\);_([$\u20ac-2]\\\\\\ *\\\"\\-\\\\\"??_);_(@_)";
  377. short fmt = df.getFormat(formatStr);
  378. //Create a unicode sheet name (euro symbol)
  379. Sheet s = wb.createSheet("\u20ac");
  380. //Set a unicode header (you guessed it the euro symbol)
  381. Header h = s.getHeader();
  382. h.setCenter("\u20ac");
  383. h.setLeft("\u20ac");
  384. h.setRight("\u20ac");
  385. //Set a unicode footer
  386. Footer f = s.getFooter();
  387. f.setCenter("\u20ac");
  388. f.setLeft("\u20ac");
  389. f.setRight("\u20ac");
  390. Row r = s.createRow(0);
  391. Cell c = r.createCell(1);
  392. c.setCellValue(12.34);
  393. c.getCellStyle().setDataFormat(fmt);
  394. /*Cell c2 =*/ r.createCell(2); // TODO - c2 unused but changing next line ('c'->'c2') causes test to fail
  395. c.setCellValue(factory.createRichTextString("\u20ac"));
  396. Cell c3 = r.createCell(3);
  397. String formulaString = "TEXT(12.34,\"\u20ac###,##\")";
  398. c3.setCellFormula(formulaString);
  399. wb = _testDataProvider.writeOutAndReadBack(wb);
  400. //Test the sheetname
  401. s = wb.getSheet("\u20ac");
  402. assertNotNull(s);
  403. //Test the header
  404. h = s.getHeader();
  405. assertEquals(h.getCenter(), "\u20ac");
  406. assertEquals(h.getLeft(), "\u20ac");
  407. assertEquals(h.getRight(), "\u20ac");
  408. //Test the footer
  409. f = s.getFooter();
  410. assertEquals(f.getCenter(), "\u20ac");
  411. assertEquals(f.getLeft(), "\u20ac");
  412. assertEquals(f.getRight(), "\u20ac");
  413. //Test the dataformat
  414. r = s.getRow(0);
  415. c = r.getCell(1);
  416. df = wb.createDataFormat();
  417. assertEquals(formatStr, df.getFormat(c.getCellStyle().getDataFormat()));
  418. //Test the cell string value
  419. /*c2 =*/ r.getCell(2);
  420. assertEquals(c.getRichStringCellValue().getString(), "\u20ac");
  421. //Test the cell formula
  422. c3 = r.getCell(3);
  423. assertEquals(c3.getCellFormula(), formulaString);
  424. }
  425. private Workbook newSetSheetNameTestingWorkbook() throws Exception {
  426. Workbook wb = _testDataProvider.createWorkbook();
  427. Sheet sh1 = wb.createSheet("Worksheet");
  428. Sheet sh2 = wb.createSheet("Testing 47100");
  429. Sheet sh3 = wb.createSheet("To be renamed");
  430. Name name1 = wb.createName();
  431. name1.setNameName("sale_1");
  432. name1.setRefersToFormula("Worksheet!$A$1");
  433. Name name2 = wb.createName();
  434. name2.setNameName("sale_2");
  435. name2.setRefersToFormula("'Testing 47100'!$A$1");
  436. Name name3 = wb.createName();
  437. name3.setNameName("sale_3");
  438. name3.setRefersToFormula("'Testing 47100'!$B$1");
  439. Name name4 = wb.createName();
  440. name4.setNameName("sale_4");
  441. name4.setRefersToFormula("'To be renamed'!$A$3");
  442. sh1.createRow(0).createCell(0).setCellFormula("SUM('Testing 47100'!A1:C1)");
  443. sh1.createRow(1).createCell(0).setCellFormula("SUM('Testing 47100'!A1:C1,'To be renamed'!A1:A5)");
  444. sh1.createRow(2).createCell(0).setCellFormula("sale_2+sale_3+'Testing 47100'!C1");
  445. sh2.createRow(0).createCell(0).setCellValue(1);
  446. sh2.getRow(0).createCell(1).setCellValue(2);
  447. sh2.getRow(0).createCell(2).setCellValue(3);
  448. sh3.createRow(0).createCell(0).setCellValue(1);
  449. sh3.createRow(1).createCell(0).setCellValue(2);
  450. sh3.createRow(2).createCell(0).setCellValue(3);
  451. sh3.createRow(3).createCell(0).setCellValue(4);
  452. sh3.createRow(4).createCell(0).setCellValue(5);
  453. sh3.createRow(5).createCell(0).setCellFormula("sale_3");
  454. sh3.createRow(6).createCell(0).setCellFormula("'Testing 47100'!C1");
  455. return wb;
  456. }
  457. /**
  458. * Ensure that Workbook#setSheetName updates all dependent formulas and named ranges
  459. *
  460. * @see <a href="https://issues.apache.org/bugzilla/show_bug.cgi?id=47100">Bugzilla 47100</a>
  461. */
  462. @Test
  463. public void setSheetName() throws Exception {
  464. Workbook wb = newSetSheetNameTestingWorkbook();
  465. Sheet sh1 = wb.getSheetAt(0);
  466. Name sale_2 = wb.getNameAt(1);
  467. Name sale_3 = wb.getNameAt(2);
  468. Name sale_4 = wb.getNameAt(3);
  469. assertEquals("sale_2", sale_2.getNameName());
  470. assertEquals("'Testing 47100'!$A$1", sale_2.getRefersToFormula());
  471. assertEquals("sale_3", sale_3.getNameName());
  472. assertEquals("'Testing 47100'!$B$1", sale_3.getRefersToFormula());
  473. assertEquals("sale_4", sale_4.getNameName());
  474. assertEquals("'To be renamed'!$A$3", sale_4.getRefersToFormula());
  475. FormulaEvaluator evaluator = wb.getCreationHelper().createFormulaEvaluator();
  476. Cell cell0 = sh1.getRow(0).getCell(0);
  477. Cell cell1 = sh1.getRow(1).getCell(0);
  478. Cell cell2 = sh1.getRow(2).getCell(0);
  479. assertEquals("SUM('Testing 47100'!A1:C1)", cell0.getCellFormula());
  480. assertEquals("SUM('Testing 47100'!A1:C1,'To be renamed'!A1:A5)", cell1.getCellFormula());
  481. assertEquals("sale_2+sale_3+'Testing 47100'!C1", cell2.getCellFormula());
  482. assertEquals(6.0, evaluator.evaluate(cell0).getNumberValue(), 0);
  483. assertEquals(21.0, evaluator.evaluate(cell1).getNumberValue(), 0);
  484. assertEquals(6.0, evaluator.evaluate(cell2).getNumberValue(), 0);
  485. wb.setSheetName(1, "47100 - First");
  486. wb.setSheetName(2, "47100 - Second");
  487. assertEquals("sale_2", sale_2.getNameName());
  488. assertEquals("'47100 - First'!$A$1", sale_2.getRefersToFormula());
  489. assertEquals("sale_3", sale_3.getNameName());
  490. assertEquals("'47100 - First'!$B$1", sale_3.getRefersToFormula());
  491. assertEquals("sale_4", sale_4.getNameName());
  492. assertEquals("'47100 - Second'!$A$3", sale_4.getRefersToFormula());
  493. assertEquals("SUM('47100 - First'!A1:C1)", cell0.getCellFormula());
  494. assertEquals("SUM('47100 - First'!A1:C1,'47100 - Second'!A1:A5)", cell1.getCellFormula());
  495. assertEquals("sale_2+sale_3+'47100 - First'!C1", cell2.getCellFormula());
  496. evaluator.clearAllCachedResultValues();
  497. assertEquals(6.0, evaluator.evaluate(cell0).getNumberValue(), 0);
  498. assertEquals(21.0, evaluator.evaluate(cell1).getNumberValue(), 0);
  499. assertEquals(6.0, evaluator.evaluate(cell2).getNumberValue(), 0);
  500. wb = _testDataProvider.writeOutAndReadBack(wb);
  501. sh1 = wb.getSheetAt(0);
  502. sale_2 = wb.getNameAt(1);
  503. sale_3 = wb.getNameAt(2);
  504. sale_4 = wb.getNameAt(3);
  505. cell0 = sh1.getRow(0).getCell(0);
  506. cell1 = sh1.getRow(1).getCell(0);
  507. cell2 = sh1.getRow(2).getCell(0);
  508. assertEquals("sale_2", sale_2.getNameName());
  509. assertEquals("'47100 - First'!$A$1", sale_2.getRefersToFormula());
  510. assertEquals("sale_3", sale_3.getNameName());
  511. assertEquals("'47100 - First'!$B$1", sale_3.getRefersToFormula());
  512. assertEquals("sale_4", sale_4.getNameName());
  513. assertEquals("'47100 - Second'!$A$3", sale_4.getRefersToFormula());
  514. assertEquals("SUM('47100 - First'!A1:C1)", cell0.getCellFormula());
  515. assertEquals("SUM('47100 - First'!A1:C1,'47100 - Second'!A1:A5)", cell1.getCellFormula());
  516. assertEquals("sale_2+sale_3+'47100 - First'!C1", cell2.getCellFormula());
  517. evaluator = wb.getCreationHelper().createFormulaEvaluator();
  518. assertEquals(6.0, evaluator.evaluate(cell0).getNumberValue(), 0);
  519. assertEquals(21.0, evaluator.evaluate(cell1).getNumberValue(), 0);
  520. assertEquals(6.0, evaluator.evaluate(cell2).getNumberValue(), 0);
  521. }
  522. public void changeSheetNameWithSharedFormulas(String sampleFile){
  523. Workbook wb = _testDataProvider.openSampleWorkbook(sampleFile);
  524. FormulaEvaluator evaluator = wb.getCreationHelper().createFormulaEvaluator();
  525. Sheet sheet = wb.getSheetAt(0);
  526. for (int rownum = 1; rownum <= 40; rownum++) {
  527. Cell cellA = sheet.getRow(1).getCell(0);
  528. Cell cellB = sheet.getRow(1).getCell(1);
  529. assertEquals(cellB.getStringCellValue(), evaluator.evaluate(cellA).getStringValue());
  530. }
  531. wb.setSheetName(0, "Renamed by POI");
  532. evaluator.clearAllCachedResultValues();
  533. for (int rownum = 1; rownum <= 40; rownum++) {
  534. Cell cellA = sheet.getRow(1).getCell(0);
  535. Cell cellB = sheet.getRow(1).getCell(1);
  536. assertEquals(cellB.getStringCellValue(), evaluator.evaluate(cellA).getStringValue());
  537. }
  538. }
  539. protected void assertSheetOrder(Workbook wb, String... sheets) {
  540. StringBuilder sheetNames = new StringBuilder();
  541. for(int i = 0;i < wb.getNumberOfSheets();i++) {
  542. sheetNames.append(wb.getSheetAt(i).getSheetName()).append(",");
  543. }
  544. assertEquals("Had: " + sheetNames.toString(),
  545. sheets.length, wb.getNumberOfSheets());
  546. for(int i = 0;i < wb.getNumberOfSheets();i++) {
  547. assertEquals("Had: " + sheetNames.toString(),
  548. sheets[i], wb.getSheetAt(i).getSheetName());
  549. }
  550. }
  551. }