~slub.team/goobi-indexserver/3.x

« back to all changes in this revision

Viewing changes to solr/solrj/src/test/org/apache/solr/common/util/TestXMLEscaping.java

  • Committer: Sebastian Meyer
  • Date: 2012-08-03 09:12:40 UTC
  • Revision ID: sebastian.meyer@slub-dresden.de-20120803091240-x6861b0vabq1xror
Remove Lucene and Solr source code and add patches instead
Fix Bug #985487: Auto-suggestion for the search interface

Show diffs side-by-side

added added

removed removed

Lines of Context:
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
 
 *
9
 
 *     http://www.apache.org/licenses/LICENSE-2.0
10
 
 *
11
 
 * Unless required by applicable law or agreed to in writing, software
12
 
 * distributed under the License is distributed on an "AS IS" BASIS,
13
 
 * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
14
 
 * See the License for the specific language governing permissions and
15
 
 * limitations under the License.
16
 
 */
17
 
 
18
 
package org.apache.solr.common.util;
19
 
 
20
 
import java.io.IOException;
21
 
import java.io.StringWriter;
22
 
import org.apache.lucene.util.LuceneTestCase;
23
 
import org.apache.solr.common.util.XML;
24
 
 
25
 
/** Test (some of the) character escaping functions of the XML class
26
 
 *  $Id$
27
 
 */
28
 
 
29
 
public class TestXMLEscaping extends LuceneTestCase {
30
 
  private void doSimpleTest(String input,String expectedOutput) throws IOException {
31
 
    final StringWriter sw = new StringWriter();
32
 
    XML.escapeCharData(input, sw);
33
 
    final String result = sw.toString();
34
 
    assertEquals("Escaped output matches '" + expectedOutput + "'",result,expectedOutput);
35
 
  }
36
 
  
37
 
  public void testNoEscape() throws IOException {
38
 
    doSimpleTest("Bonnie","Bonnie");
39
 
  }
40
 
  
41
 
  public void testAmpAscii() throws IOException {
42
 
    doSimpleTest("Bonnie & Clyde","Bonnie & Clyde");
43
 
  }
44
 
 
45
 
  public void testAmpAndTagAscii() throws IOException {
46
 
    doSimpleTest("Bonnie & Cl<em>y</em>de","Bonnie &amp; Cl&lt;em&gt;y&lt;/em&gt;de");
47
 
  }
48
 
 
49
 
  public void testAmpWithAccents() throws IOException {
50
 
    // 00e9 is unicode eacute
51
 
    doSimpleTest("Les \u00e9v\u00e9nements chez Bonnie & Clyde","Les \u00e9v\u00e9nements chez Bonnie &amp; Clyde");
52
 
  }
53
 
 
54
 
  public void testAmpDotWithAccents() throws IOException {
55
 
    // 00e9 is unicode eacute
56
 
    doSimpleTest("Les \u00e9v\u00e9nements chez Bonnie & Clyde.","Les \u00e9v\u00e9nements chez Bonnie &amp; Clyde.");
57
 
  }
58
 
 
59
 
  public void testAmpAndTagWithAccents() throws IOException {
60
 
    // 00e9 is unicode eacute
61
 
    doSimpleTest("Les \u00e9v\u00e9nements <chez/> Bonnie & Clyde","Les \u00e9v\u00e9nements &lt;chez/&gt; Bonnie &amp; Clyde");
62
 
  }
63
 
 
64
 
  public void testGt() throws IOException {
65
 
    doSimpleTest("a ]]> b","a ]]&gt; b");
66
 
  }
67
 
}
68
 
 
69
 
 
70