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.

StyliserStylesTest.java 7.8KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197
  1. /*
  2. * Copyright (c) 2006-2014 DMDirc Developers
  3. *
  4. * Permission is hereby granted, free of charge, to any person obtaining a copy
  5. * of this software and associated documentation files (the "Software"), to deal
  6. * in the Software without restriction, including without limitation the rights
  7. * to use, copy, modify, merge, publish, distribute, sublicense, and/or sell
  8. * copies of the Software, and to permit persons to whom the Software is
  9. * furnished to do so, subject to the following conditions:
  10. *
  11. * The above copyright notice and this permission notice shall be included in
  12. * all copies or substantial portions of the Software.
  13. *
  14. * THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR
  15. * IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY,
  16. * FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE
  17. * AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER
  18. * LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM,
  19. * OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE
  20. * SOFTWARE.
  21. */
  22. package com.dmdirc.ui.messages;
  23. import com.dmdirc.interfaces.config.AggregateConfigProvider;
  24. import com.dmdirc.ui.core.util.Utils;
  25. import java.awt.Color;
  26. import java.awt.font.TextAttribute;
  27. import java.text.AttributedCharacterIterator;
  28. import java.util.Arrays;
  29. import java.util.List;
  30. import java.util.Map;
  31. import javax.swing.text.DefaultStyledDocument;
  32. import org.junit.Ignore;
  33. import org.junit.Test;
  34. import org.junit.runner.RunWith;
  35. import org.junit.runners.Parameterized;
  36. import static org.junit.Assert.*;
  37. import static org.mockito.Mockito.*;
  38. @RunWith(Parameterized.class)
  39. @Ignore("Doesn't work in a headless environment (initialises an IRCDocument)")
  40. public class StyliserStylesTest {
  41. protected String input, output;
  42. public StyliserStylesTest(String input, String output) {
  43. this.input = input;
  44. this.output = output;
  45. }
  46. @Test
  47. public void testStyle() {
  48. assertEquals(output, style(input));
  49. }
  50. protected static String style(final String input) {
  51. final DefaultStyledDocument doc = new DefaultStyledDocument();
  52. final StringBuilder builder = new StringBuilder();
  53. final AggregateConfigProvider manager = mock(AggregateConfigProvider.class);
  54. final Styliser styliser = new Styliser(null, manager);
  55. styliser.addStyledString(doc, new String[]{input});
  56. final AttributedCharacterIterator aci = Utils.getAttributedString(styliser,
  57. new String[]{input, }, "dialog", 12).
  58. getAttributedString().getIterator();
  59. Map<AttributedCharacterIterator.Attribute, Object> map = null;
  60. char chr = aci.current();
  61. while (aci.getIndex() < aci.getEndIndex()) {
  62. if (!aci.getAttributes().equals(map)) {
  63. style(aci.getAttributes(), builder);
  64. map = aci.getAttributes();
  65. }
  66. builder.append(chr);
  67. chr = aci.next();
  68. }
  69. return builder.toString();
  70. }
  71. protected static void style(final Map<AttributedCharacterIterator.Attribute, Object> map,
  72. final StringBuilder builder) {
  73. builder.append('<');
  74. String[] entries = new String[9];
  75. for (Map.Entry<AttributedCharacterIterator.Attribute, Object> entry : map.entrySet()) {
  76. if (entry.getKey().equals(TextAttribute.FOREGROUND)) {
  77. entries[0] = "color=" + toColour(entry.getValue());
  78. } else if (entry.getKey().equals(TextAttribute.BACKGROUND)) {
  79. entries[1] = "background=" + toColour(entry.getValue());
  80. } else if (entry.getKey().equals(TextAttribute.WEIGHT)) {
  81. entries[2] = "bold";
  82. } else if (entry.getKey().equals(TextAttribute.FAMILY)
  83. && entry.getValue().equals("monospaced")) {
  84. entries[3] = "monospace";
  85. } else if (entry.getKey().equals(TextAttribute.POSTURE)) {
  86. entries[4] = "italic";
  87. } else if (entry.getKey().equals(TextAttribute.UNDERLINE)) {
  88. entries[5] = "underline";
  89. } else if (entry.getKey().equals(IRCTextAttribute.HYPERLINK)) {
  90. entries[6] = "hyperlink";
  91. } else if (entry.getKey().equals(IRCTextAttribute.CHANNEL)) {
  92. entries[7] = "channel";
  93. } else if (entry.getKey().equals(IRCTextAttribute.NICKNAME)) {
  94. entries[8] = "nickname";
  95. }
  96. }
  97. int count = 0;
  98. for (String entry : entries) {
  99. if (entry != null) {
  100. builder.append(entry);
  101. builder.append(',');
  102. count++;
  103. }
  104. }
  105. if (count > 0) {
  106. builder.deleteCharAt(builder.length() - 1);
  107. }
  108. builder.append('>');
  109. }
  110. protected static String toColour(final Object object) {
  111. final Color colour = (Color) object;
  112. return colour.getRed() + "," + colour.getGreen() + ","
  113. + colour.getBlue();
  114. }
  115. @Parameterized.Parameters
  116. public static List<String[]> data() {
  117. final String[][] tests = {
  118. // No style
  119. {"Blah blah blah", "<>Blah blah blah"},
  120. // Bold
  121. {"Blahblah", "<>Blah<bold>blah"},
  122. {"Blahblah", "<>Blah<bold>b<>lah"},
  123. {"Blahblah", "<>Blah<bold>b<>lah"},
  124. // Bold + Underline
  125. {"Blahblah", "<>B<underline>lah<bold,underline>b<underline>lah"},
  126. {"Blahblah", "<>B<underline>lahb<bold>lah"},
  127. {"Blahblah", "<>B<underline>lahb<bold>l<>ah"},
  128. {"Blahblah", "<>B<underline>l<>ahb<bold,underline>l<>ah"},
  129. // IRC colours
  130. {"4moo", "<color=255,0,0>moo"},
  131. {"4moo", "<color=255,0,0>m<>oo"},
  132. {"4moo", "<color=255,0,0>m<>oo"},
  133. {"20moo", "<color=255,0,0>m<>oo"}, // Colours wrap around
  134. {"4,4moo", "<color=255,0,0,background=255,0,0>m<>oo"},
  135. {"4,4m4,4oo", "<color=255,0,0,background=255,0,0>moo"},
  136. // Persistant irc colours
  137. {"4m0oo", "<color=255,0,0>m<color=255,255,255>o<color=255,0,0>o"},
  138. {"4moo", "<color=255,0,0>moo"},
  139. {"4,0moo", "<color=255,0,0,background=255,255,255>moo"},
  140. // Hex colours
  141. {"FF0000moo", "<color=255,0,0>moo"},
  142. {"FF0000moo", "<color=255,0,0>m<>oo"},
  143. {"FF0000moo", "<color=255,0,0>m<>oo"},
  144. {"QUXmoo", "<>QUXmoo"},
  145. {"FFFFFQUXmoo", "<>FFFFFQUXmoo"},
  146. {"FF0000,FF0000moo", "<color=255,0,0,background=255,0,0>m<>oo"},
  147. {"xFF0000", "<>x"}, // Issue 3248
  148. // Persistant hex colours
  149. {"FF0000mFFFFFFoo", "<color=255,0,0>m<color=255,255,255>o<color=255,0,0>o"},
  150. {"FF0000moo", "<color=255,0,0>moo"},
  151. {"FF0000,FFFFFFmoo", "<color=255,0,0,background=255,255,255>moo"},
  152. // Fixed width
  153. {"Blahblah", "<>Blah<monospace>b<>lah"},
  154. {"Blahblah", "<>Blah<monospace>b<>lah"}, // Issue 1413
  155. // Italics
  156. {"Blahblah", "<>Blah<italic>b<>lah"},
  157. {"Blahblah", "<>Blah<italic>b<>lah"},
  158. // Nesting
  159. {"Blahblahblahblah", "<>Blah<italic>b<bold,italic>lahblah<bold>b<>lah"},
  160. // Negation
  161. {"\u0012Blah4FF0000moo", "<>Blahmoo"},
  162. {"\u0012Blah4FF0000moo\u0012foo", "<>Blahmoo<bold>foo"},
  163. {"Blah 4\u0012BlahBlah", "<>Blah <color=255,0,0>BlahBlah"}, // Stop
  164. {"Blah 4\u0012BlahBlah", "<>Blah <color=255,0,0>BlahBlah"}, // Empty colour
  165. {"Blah 4\u0012BlahBlah", "<>Blah <color=255,0,0>BlahBlah"}, // Empty hex colour
  166. };
  167. return Arrays.asList(tests);
  168. }
  169. }