Vous ne pouvez pas sélectionner plus de 25 sujets Les noms de sujets doivent commencer par une lettre ou un nombre, peuvent contenir des tirets ('-') et peuvent comporter jusqu'à 35 caractères.

TestXSSFRichTextString.java 22KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426427428429430431432433434435436437438439440441442443444445446447448449450451452453454455456457458459460461462463464465466467468469470471472473474475476477478479480481482483484485486487488489490491492493494495496497498499500501502503504505506507508509510511512513514515516517518519520521522523524525526527528529530531532533534535536537538539540541542543544545546547548549550551552553554555556557558559560561562
  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.xssf.usermodel;
  16. import static org.junit.jupiter.api.Assertions.assertEquals;
  17. import static org.junit.jupiter.api.Assertions.assertFalse;
  18. import static org.junit.jupiter.api.Assertions.assertNotNull;
  19. import static org.junit.jupiter.api.Assertions.assertNull;
  20. import static org.junit.jupiter.api.Assertions.assertSame;
  21. import static org.junit.jupiter.api.Assertions.assertThrows;
  22. import static org.junit.jupiter.api.Assertions.assertTrue;
  23. import java.io.IOException;
  24. import java.util.Objects;
  25. import java.util.Spliterator;
  26. import java.util.TreeMap;
  27. import java.util.stream.IntStream;
  28. import java.util.stream.StreamSupport;
  29. import org.apache.poi.ss.usermodel.Cell;
  30. import org.apache.poi.ss.usermodel.Row;
  31. import org.apache.poi.ss.usermodel.Sheet;
  32. import org.apache.poi.xssf.XSSFTestDataSamples;
  33. import org.apache.poi.xssf.model.StylesTable;
  34. import org.junit.jupiter.api.Test;
  35. import org.openxmlformats.schemas.officeDocument.x2006.sharedTypes.STXstring;
  36. import org.openxmlformats.schemas.spreadsheetml.x2006.main.CTFont;
  37. import org.openxmlformats.schemas.spreadsheetml.x2006.main.CTRPrElt;
  38. import org.openxmlformats.schemas.spreadsheetml.x2006.main.CTRst;
  39. /**
  40. * Tests functionality of the XSSFRichTextRun object
  41. */
  42. public final class TestXSSFRichTextString {
  43. @Test
  44. void testCreate() {
  45. XSSFRichTextString rt = new XSSFRichTextString("Apache POI");
  46. assertEquals("Apache POI", rt.getString());
  47. assertFalse(rt.hasFormatting());
  48. CTRst st = rt.getCTRst();
  49. assertTrue(st.isSetT());
  50. assertEquals("Apache POI", st.getT());
  51. assertFalse(rt.hasFormatting());
  52. rt.append(" is cool stuff");
  53. assertEquals(2, st.sizeOfRArray());
  54. assertFalse(st.isSetT());
  55. assertEquals("Apache POI is cool stuff", rt.getString());
  56. assertFalse(rt.hasFormatting());
  57. }
  58. @Test
  59. void testEmpty() {
  60. XSSFRichTextString rt = new XSSFRichTextString();
  61. assertEquals(0, rt.getIndexOfFormattingRun(9999));
  62. assertEquals(-1, rt.getLengthOfFormattingRun(9999));
  63. assertNull(rt.getFontAtIndex(9999));
  64. }
  65. @Test
  66. void testApplyFont() {
  67. XSSFRichTextString rt = new XSSFRichTextString();
  68. rt.append("123");
  69. rt.append("4567");
  70. rt.append("89");
  71. assertEquals("123456789", rt.getString());
  72. assertFalse(rt.hasFormatting());
  73. XSSFFont font1 = new XSSFFont();
  74. font1.setBold(true);
  75. rt.applyFont(2, 5, font1);
  76. assertTrue(rt.hasFormatting());
  77. assertEquals(4, rt.numFormattingRuns());
  78. assertEquals(0, rt.getIndexOfFormattingRun(0));
  79. assertEquals("12", rt.getCTRst().getRArray(0).getT());
  80. assertEquals(2, rt.getIndexOfFormattingRun(1));
  81. assertEquals("345", rt.getCTRst().getRArray(1).getT());
  82. assertEquals(5, rt.getIndexOfFormattingRun(2));
  83. assertEquals(2, rt.getLengthOfFormattingRun(2));
  84. assertEquals("67", rt.getCTRst().getRArray(2).getT());
  85. assertEquals(7, rt.getIndexOfFormattingRun(3));
  86. assertEquals(2, rt.getLengthOfFormattingRun(3));
  87. assertEquals("89", rt.getCTRst().getRArray(3).getT());
  88. assertEquals(-1, rt.getIndexOfFormattingRun(9999));
  89. assertEquals(-1, rt.getLengthOfFormattingRun(9999));
  90. assertNull(rt.getFontAtIndex(9999));
  91. }
  92. @Test
  93. void testApplyFontIndex() {
  94. XSSFRichTextString rt = new XSSFRichTextString("Apache POI");
  95. rt.applyFont(0, 10, (short)1);
  96. rt.applyFont((short)1);
  97. assertNotNull(rt.getFontAtIndex(0));
  98. }
  99. @Test
  100. void testApplyFontWithStyles() {
  101. XSSFRichTextString rt = new XSSFRichTextString("Apache POI");
  102. StylesTable tbl = new StylesTable();
  103. rt.setStylesTableReference(tbl);
  104. assertThrows(IndexOutOfBoundsException.class, () -> rt.applyFont(0, 10, (short)1), "Fails without styles in the table");
  105. tbl.putFont(new XSSFFont());
  106. rt.applyFont(0, 10, (short)1);
  107. rt.applyFont((short)1);
  108. }
  109. @Test
  110. void testApplyFontException() {
  111. XSSFRichTextString rt = new XSSFRichTextString("Apache POI");
  112. rt.applyFont(0, 0, (short)1);
  113. IllegalArgumentException e;
  114. e = assertThrows(IllegalArgumentException.class, () -> rt.applyFont(11, 10, (short)1));
  115. assertTrue(e.getMessage().contains("11"));
  116. e = assertThrows(IllegalArgumentException.class, () -> rt.applyFont(-1, 10, (short)1));
  117. assertTrue(e.getMessage().contains("-1"));
  118. e = assertThrows(IllegalArgumentException.class, () -> rt.applyFont(0, 555, (short)1));
  119. assertTrue(e.getMessage().contains("555"));
  120. }
  121. @Test
  122. void testClearFormatting() {
  123. XSSFRichTextString rt = new XSSFRichTextString("Apache POI");
  124. assertEquals("Apache POI", rt.getString());
  125. assertFalse(rt.hasFormatting());
  126. rt.clearFormatting();
  127. CTRst st = rt.getCTRst();
  128. assertTrue(st.isSetT());
  129. assertEquals("Apache POI", rt.getString());
  130. assertEquals(0, rt.numFormattingRuns());
  131. assertFalse(rt.hasFormatting());
  132. XSSFFont font = new XSSFFont();
  133. font.setBold(true);
  134. rt.applyFont(7, 10, font);
  135. assertEquals(2, rt.numFormattingRuns());
  136. assertTrue(rt.hasFormatting());
  137. rt.clearFormatting();
  138. assertEquals("Apache POI", rt.getString());
  139. assertEquals(0, rt.numFormattingRuns());
  140. assertFalse(rt.hasFormatting());
  141. }
  142. @Test
  143. void testGetFonts() {
  144. XSSFRichTextString rt = new XSSFRichTextString();
  145. XSSFFont font1 = new XSSFFont();
  146. font1.setFontName("Arial");
  147. font1.setItalic(true);
  148. rt.append("The quick", font1);
  149. XSSFFont font1$ = rt.getFontOfFormattingRun(0);
  150. assertEquals(font1.getItalic(), font1$.getItalic());
  151. assertEquals(font1.getFontName(), font1$.getFontName());
  152. XSSFFont font2 = new XSSFFont();
  153. font2.setFontName("Courier");
  154. font2.setBold(true);
  155. rt.append(" brown fox", font2);
  156. XSSFFont font2$ = rt.getFontOfFormattingRun(1);
  157. assertEquals(font2.getBold(), font2$.getBold());
  158. assertEquals(font2.getFontName(), font2$.getFontName());
  159. }
  160. /**
  161. * make sure we insert xml:space="preserve" attribute
  162. * if a string has leading or trailing white spaces
  163. */
  164. @Test
  165. void testPreserveSpaces() {
  166. XSSFRichTextString rt = new XSSFRichTextString("Apache");
  167. CTRst ct = rt.getCTRst();
  168. STXstring xs = ct.xgetT();
  169. assertEquals("<xml-fragment>Apache</xml-fragment>", xs.xmlText());
  170. rt.setString(" Apache");
  171. assertEquals("<xml-fragment xml:space=\"preserve\"> Apache</xml-fragment>", xs.xmlText());
  172. rt.append(" POI");
  173. rt.append(" ");
  174. assertEquals(" Apache POI ", rt.getString());
  175. assertEquals("<xml-fragment xml:space=\"preserve\"> Apache</xml-fragment>", rt.getCTRst().getRArray(0).xgetT().xmlText());
  176. assertEquals("<xml-fragment xml:space=\"preserve\"> POI</xml-fragment>", rt.getCTRst().getRArray(1).xgetT().xmlText());
  177. assertEquals("<xml-fragment xml:space=\"preserve\"> </xml-fragment>", rt.getCTRst().getRArray(2).xgetT().xmlText());
  178. }
  179. /**
  180. * test that unicode representation_ xHHHH_ is properly processed
  181. */
  182. @Test
  183. void testUtfDecode() {
  184. CTRst st = CTRst.Factory.newInstance();
  185. st.setT("abc_x000D_2ef_x000D_");
  186. XSSFRichTextString rt = new XSSFRichTextString(st);
  187. //_x000D_ is converted into carriage return
  188. assertEquals("abc\r2ef\r", rt.getString());
  189. // Test Lowercase case
  190. CTRst st2 = CTRst.Factory.newInstance();
  191. st2.setT("abc_x000d_2ef_x000d_");
  192. XSSFRichTextString rt2 = new XSSFRichTextString(st2);
  193. assertEquals("abc\r2ef\r", rt2.getString());
  194. }
  195. @Test
  196. void testApplyFont_lowlevel(){
  197. CTRst st = CTRst.Factory.newInstance();
  198. String text = "Apache Software Foundation";
  199. XSSFRichTextString str = new XSSFRichTextString(text);
  200. assertEquals(26, text.length());
  201. st.addNewR().setT(text);
  202. TreeMap<Integer, CTRPrElt> formats = str.getFormatMap(st);
  203. assertEquals(1, formats.size());
  204. assertEquals(26, (int)formats.firstKey());
  205. assertNull(formats.get( formats.firstKey() ));
  206. CTRPrElt fmt1 = CTRPrElt.Factory.newInstance();
  207. str.applyFont(formats, 0, 6, fmt1);
  208. assertEquals(2, formats.size());
  209. assertEquals("[6, 26]", formats.keySet().toString());
  210. Object[] runs1 = formats.values().toArray();
  211. assertSame(fmt1, runs1[0]);
  212. assertSame(null, runs1[1]);
  213. CTRPrElt fmt2 = CTRPrElt.Factory.newInstance();
  214. str.applyFont(formats, 7, 15, fmt2);
  215. assertEquals(4, formats.size());
  216. assertEquals("[6, 7, 15, 26]", formats.keySet().toString());
  217. Object[] runs2 = formats.values().toArray();
  218. assertSame(fmt1, runs2[0]);
  219. assertSame(null, runs2[1]);
  220. assertSame(fmt2, runs2[2]);
  221. assertSame(null, runs2[3]);
  222. CTRPrElt fmt3 = CTRPrElt.Factory.newInstance();
  223. str.applyFont(formats, 6, 7, fmt3);
  224. assertEquals(4, formats.size());
  225. assertEquals("[6, 7, 15, 26]", formats.keySet().toString());
  226. Object[] runs3 = formats.values().toArray();
  227. assertSame(fmt1, runs3[0]);
  228. assertSame(fmt3, runs3[1]);
  229. assertSame(fmt2, runs3[2]);
  230. assertSame(null, runs3[3]);
  231. CTRPrElt fmt4 = CTRPrElt.Factory.newInstance();
  232. str.applyFont(formats, 0, 7, fmt4);
  233. assertEquals(3, formats.size());
  234. assertEquals("[7, 15, 26]", formats.keySet().toString());
  235. Object[] runs4 = formats.values().toArray();
  236. assertSame(fmt4, runs4[0]);
  237. assertSame(fmt2, runs4[1]);
  238. assertSame(null, runs4[2]);
  239. CTRPrElt fmt5 = CTRPrElt.Factory.newInstance();
  240. str.applyFont(formats, 0, 26, fmt5);
  241. assertEquals(1, formats.size());
  242. assertEquals("[26]", formats.keySet().toString());
  243. Object[] runs5 = formats.values().toArray();
  244. assertSame(fmt5, runs5[0]);
  245. CTRPrElt fmt6 = CTRPrElt.Factory.newInstance();
  246. str.applyFont(formats, 15, 26, fmt6);
  247. assertEquals(2, formats.size());
  248. assertEquals("[15, 26]", formats.keySet().toString());
  249. Object[] runs6 = formats.values().toArray();
  250. assertSame(fmt5, runs6[0]);
  251. assertSame(fmt6, runs6[1]);
  252. str.applyFont(formats, 0, 26, null);
  253. assertEquals(1, formats.size());
  254. assertEquals("[26]", formats.keySet().toString());
  255. Object[] runs7 = formats.values().toArray();
  256. assertSame(null, runs7[0]);
  257. str.applyFont(formats, 15, 26, fmt6);
  258. assertEquals(2, formats.size());
  259. assertEquals("[15, 26]", formats.keySet().toString());
  260. Object[] runs8 = formats.values().toArray();
  261. assertSame(null, runs8[0]);
  262. assertSame(fmt6, runs8[1]);
  263. str.applyFont(formats, 15, 26, fmt5);
  264. assertEquals(2, formats.size());
  265. assertEquals("[15, 26]", formats.keySet().toString());
  266. Object[] runs9 = formats.values().toArray();
  267. assertSame(null, runs9[0]);
  268. assertSame(fmt5, runs9[1]);
  269. str.applyFont(formats, 2, 20, fmt6);
  270. assertEquals(3, formats.size());
  271. assertEquals("[2, 20, 26]", formats.keySet().toString());
  272. Object[] runs10 = formats.values().toArray();
  273. assertSame(null, runs10[0]);
  274. assertSame(fmt6, runs10[1]);
  275. assertSame(fmt5, runs10[2]);
  276. str.applyFont(formats, 22, 24, fmt4);
  277. assertEquals(5, formats.size());
  278. assertEquals("[2, 20, 22, 24, 26]", formats.keySet().toString());
  279. Object[] runs11 = formats.values().toArray();
  280. assertSame(null, runs11[0]);
  281. assertSame(fmt6, runs11[1]);
  282. assertSame(fmt5, runs11[2]);
  283. assertSame(fmt4, runs11[3]);
  284. assertSame(fmt5, runs11[4]);
  285. str.applyFont(formats, 0, 10, fmt1);
  286. assertEquals(5, formats.size());
  287. assertEquals("[10, 20, 22, 24, 26]", formats.keySet().toString());
  288. Object[] runs12 = formats.values().toArray();
  289. assertSame(fmt1, runs12[0]);
  290. assertSame(fmt6, runs12[1]);
  291. assertSame(fmt5, runs12[2]);
  292. assertSame(fmt4, runs12[3]);
  293. assertSame(fmt5, runs12[4]);
  294. }
  295. @Test
  296. void testApplyFont_usermodel(){
  297. String text = "Apache Software Foundation";
  298. XSSFRichTextString str = new XSSFRichTextString(text);
  299. XSSFFont font1 = new XSSFFont();
  300. XSSFFont font2 = new XSSFFont();
  301. XSSFFont font3 = new XSSFFont();
  302. str.applyFont(font1);
  303. assertEquals(1, str.numFormattingRuns());
  304. str.applyFont(0, 6, font1);
  305. str.applyFont(6, text.length(), font2);
  306. assertEquals(2, str.numFormattingRuns());
  307. assertEquals("Apache", str.getCTRst().getRArray(0).getT());
  308. assertEquals(" Software Foundation", str.getCTRst().getRArray(1).getT());
  309. str.applyFont(15, 26, font3);
  310. assertEquals(3, str.numFormattingRuns());
  311. assertEquals("Apache", str.getCTRst().getRArray(0).getT());
  312. assertEquals(" Software", str.getCTRst().getRArray(1).getT());
  313. assertEquals(" Foundation", str.getCTRst().getRArray(2).getT());
  314. str.applyFont(6, text.length(), font2);
  315. assertEquals(2, str.numFormattingRuns());
  316. assertEquals("Apache", str.getCTRst().getRArray(0).getT());
  317. assertEquals(" Software Foundation", str.getCTRst().getRArray(1).getT());
  318. }
  319. @Test
  320. void testLineBreaks_bug48877() {
  321. XSSFFont font = new XSSFFont();
  322. font.setBold(true);
  323. font.setFontHeightInPoints((short) 14);
  324. XSSFRichTextString str;
  325. STXstring t1, t2, t3;
  326. str = new XSSFRichTextString("Incorrect\nLine-Breaking");
  327. str.applyFont(0, 8, font);
  328. t1 = str.getCTRst().getRArray(0).xgetT();
  329. t2 = str.getCTRst().getRArray(1).xgetT();
  330. assertEquals("<xml-fragment>Incorrec</xml-fragment>", t1.xmlText());
  331. assertEquals("<xml-fragment>t\nLine-Breaking</xml-fragment>", t2.xmlText());
  332. str = new XSSFRichTextString("Incorrect\nLine-Breaking");
  333. str.applyFont(0, 9, font);
  334. t1 = str.getCTRst().getRArray(0).xgetT();
  335. t2 = str.getCTRst().getRArray(1).xgetT();
  336. assertEquals("<xml-fragment>Incorrect</xml-fragment>", t1.xmlText());
  337. assertEquals("<xml-fragment xml:space=\"preserve\">\nLine-Breaking</xml-fragment>", t2.xmlText());
  338. str = new XSSFRichTextString("Incorrect\n Line-Breaking");
  339. str.applyFont(0, 9, font);
  340. t1 = str.getCTRst().getRArray(0).xgetT();
  341. t2 = str.getCTRst().getRArray(1).xgetT();
  342. assertEquals("<xml-fragment>Incorrect</xml-fragment>", t1.xmlText());
  343. assertEquals("<xml-fragment xml:space=\"preserve\">\n Line-Breaking</xml-fragment>", t2.xmlText());
  344. str = new XSSFRichTextString("Tab\tseparated\n");
  345. t1 = str.getCTRst().xgetT();
  346. // trailing \n causes must be preserved
  347. assertEquals("<xml-fragment xml:space=\"preserve\">Tab\tseparated\n</xml-fragment>", t1.xmlText());
  348. str.applyFont(0, 3, font);
  349. t1 = str.getCTRst().getRArray(0).xgetT();
  350. t2 = str.getCTRst().getRArray(1).xgetT();
  351. assertEquals("<xml-fragment>Tab</xml-fragment>", t1.xmlText());
  352. assertEquals("<xml-fragment xml:space=\"preserve\">\tseparated\n</xml-fragment>", t2.xmlText());
  353. str = new XSSFRichTextString("Tab\tseparated\n");
  354. str.applyFont(0, 4, font);
  355. t1 = str.getCTRst().getRArray(0).xgetT();
  356. t2 = str.getCTRst().getRArray(1).xgetT();
  357. assertEquals("<xml-fragment xml:space=\"preserve\">Tab\t</xml-fragment>", t1.xmlText());
  358. assertEquals("<xml-fragment xml:space=\"preserve\">separated\n</xml-fragment>", t2.xmlText());
  359. str = new XSSFRichTextString("\n\n\nNew Line\n\n");
  360. str.applyFont(0, 3, font);
  361. str.applyFont(11, 13, font);
  362. t1 = str.getCTRst().getRArray(0).xgetT();
  363. t2 = str.getCTRst().getRArray(1).xgetT();
  364. t3 = str.getCTRst().getRArray(2).xgetT();
  365. // YK: don't know why, but XmlBeans converts leading tab characters to spaces
  366. assertEquals("<xml-fragment xml:space=\"preserve\">\n\n\n</xml-fragment>", t1.xmlText());
  367. assertEquals("<xml-fragment>New Line</xml-fragment>", t2.xmlText());
  368. assertEquals("<xml-fragment xml:space=\"preserve\">\n\n</xml-fragment>", t3.xmlText());
  369. }
  370. @Test
  371. void testBug56511() throws IOException {
  372. try (XSSFWorkbook wb = XSSFTestDataSamples.openSampleWorkbook("56511.xlsx")) {
  373. int[] idx = { 0 };
  374. StreamSupport.stream(wb::spliterator, Spliterator.IMMUTABLE, false)
  375. .flatMap(sheet -> StreamSupport.stream(sheet::spliterator, Spliterator.IMMUTABLE, false))
  376. .filter(Objects::nonNull)
  377. .flatMap(row -> StreamSupport.stream(row::spliterator, Spliterator.IMMUTABLE, false))
  378. .filter(Objects::nonNull)
  379. .map(Cell::getRichStringCellValue)
  380. .map(XSSFRichTextString.class::cast)
  381. .flatMap(x -> IntStream.range(0, x.numFormattingRuns()).mapToObj(x::getFontOfFormattingRun))
  382. .forEach(f -> { if (idx[0]++ == 2) { assertNull(f); } else { assertNotNull(f); }} );
  383. }
  384. }
  385. @Test
  386. void testBug56511_values() throws IOException {
  387. try (XSSFWorkbook wb = XSSFTestDataSamples.openSampleWorkbook("56511.xlsx")) {
  388. Sheet sheet = wb.getSheetAt(0);
  389. Row row = sheet.getRow(0);
  390. // verify the values to ensure future changes keep the returned information equal
  391. XSSFRichTextString rt = (XSSFRichTextString) row.getCell(0).getRichStringCellValue();
  392. assertEquals(0, rt.numFormattingRuns());
  393. assertNull(rt.getFontOfFormattingRun(0));
  394. assertEquals(-1, rt.getLengthOfFormattingRun(0));
  395. rt = (XSSFRichTextString) row.getCell(1).getRichStringCellValue();
  396. assertEquals(0, row.getCell(1).getRichStringCellValue().numFormattingRuns());
  397. assertNull(rt.getFontOfFormattingRun(1));
  398. assertEquals(-1, rt.getLengthOfFormattingRun(1));
  399. rt = (XSSFRichTextString) row.getCell(2).getRichStringCellValue();
  400. assertEquals(2, rt.numFormattingRuns());
  401. assertNotNull(rt.getFontOfFormattingRun(0));
  402. assertEquals(4, rt.getLengthOfFormattingRun(0));
  403. assertNotNull(rt.getFontOfFormattingRun(1));
  404. assertEquals(9, rt.getLengthOfFormattingRun(1));
  405. assertNull(rt.getFontOfFormattingRun(2));
  406. rt = (XSSFRichTextString) row.getCell(3).getRichStringCellValue();
  407. assertEquals(3, rt.numFormattingRuns());
  408. assertNull(rt.getFontOfFormattingRun(0));
  409. assertEquals(1, rt.getLengthOfFormattingRun(0));
  410. assertNotNull(rt.getFontOfFormattingRun(1));
  411. assertEquals(3, rt.getLengthOfFormattingRun(1));
  412. assertNotNull(rt.getFontOfFormattingRun(2));
  413. assertEquals(9, rt.getLengthOfFormattingRun(2));
  414. }
  415. }
  416. @Test
  417. void testToString() {
  418. XSSFRichTextString rt = new XSSFRichTextString("Apache POI");
  419. assertNotNull(rt.toString());
  420. rt = new XSSFRichTextString();
  421. assertEquals("", rt.toString());
  422. }
  423. @Test
  424. void test59008Font() {
  425. XSSFFont font = new XSSFFont(CTFont.Factory.newInstance());
  426. XSSFRichTextString rts = new XSSFRichTextString();
  427. rts.append("This is correct ");
  428. int s1 = rts.length();
  429. rts.append("This is Bold Red", font);
  430. int s2 = rts.length();
  431. rts.append(" This uses the default font rather than the cell style font");
  432. int s3 = rts.length();
  433. assertEquals("<xml-fragment/>", rts.getFontAtIndex(s1-1).toString());
  434. assertEquals(font, rts.getFontAtIndex(s2-1));
  435. assertEquals("<xml-fragment/>", rts.getFontAtIndex(s3-1).toString());
  436. }
  437. @Test
  438. void test60289UtfDecode() throws IOException {
  439. XSSFWorkbook wb = XSSFTestDataSamples.openSampleWorkbook("60289.xlsx");
  440. assertEquals("Rich Text\r\nTest", wb.getSheetAt(0).getRow(1).getCell(1).getRichStringCellValue().getString());
  441. wb.close();
  442. }
  443. @Test
  444. void testUtfDecode_withApplyFont() {
  445. XSSFFont font = new XSSFFont();
  446. font.setBold(true);
  447. font.setFontHeightInPoints((short) 14);
  448. CTRst st = CTRst.Factory.newInstance();
  449. st.setT("abc_x000D_2ef_x000D_");
  450. XSSFRichTextString rt = new XSSFRichTextString(st);
  451. rt.applyFont(font);
  452. assertEquals("abc\r2ef\r", rt.getString());
  453. }
  454. @Test
  455. void testUtfLength() {
  456. assertEquals(0, XSSFRichTextString.utfLength(null));
  457. assertEquals(0, XSSFRichTextString.utfLength(""));
  458. assertEquals(3, XSSFRichTextString.utfLength("abc"));
  459. assertEquals(3, XSSFRichTextString.utfLength("ab_x0032_"));
  460. assertEquals(3, XSSFRichTextString.utfLength("a_x0032__x0032_"));
  461. assertEquals(3, XSSFRichTextString.utfLength("_x0032_a_x0032_"));
  462. assertEquals(3, XSSFRichTextString.utfLength("_x0032__x0032_a"));
  463. }
  464. }