Skip to content

Commit

Permalink
Fix URLEncode to be backwards compatible (metafacture-fix#273)
Browse files Browse the repository at this point in the history
Complements c093da1.
  • Loading branch information
dr0i committed Nov 14, 2023
1 parent 4bfe2d0 commit d66b2f6
Show file tree
Hide file tree
Showing 2 changed files with 25 additions and 2 deletions.
Original file line number Diff line number Diff line change
Expand Up @@ -25,16 +25,19 @@
* Default is to convert a whitespace " "to a plus sign "+". This can be set so that a whitespace " " is escaped to
* "%20".
* Safe characters for this escaper are the ranges 0..9, a..z and A..Z. These are always safe and should not be
* specified.
* specified. Default safe characters are also ".", "-", "*", and "_", following URLEncoder.
*
* @see java.net.URLEncoder
*
* @author Markus Michael Geipel
* @author Pascal Christoph (dr0i)
*/
public final class URLEncode extends AbstractSimpleStatelessFunction {
private String safeChars = "";
private String safeChars =".-*_";
private Boolean plusForSpace = true;
private PercentEscaper percentEscaper = new PercentEscaper(safeChars, plusForSpace);


/**
* Creates an instance of {@link URLEncode}.
*/
Expand All @@ -50,6 +53,8 @@ public String process(final String value) {
* Sets a URI escaper with the specified safe characters. The ranges 0..9, a..z and A..Z are always safe
* and should not be specified.
*
* Default is also ".", "-", "*", and "_" , mimicking {@link java.net.URLEncoder}.
*
* @param safeChars the chars which will not be escaped
*/
public void setSafeChars(final String safeChars) {
Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -16,6 +16,9 @@

package org.metafacture.metamorph.functions;

import java.io.UnsupportedEncodingException;
import java.net.URLEncoder;

import static org.junit.Assert.*;
import org.junit.Test;

Expand All @@ -31,10 +34,15 @@ public final class URLEncodeTest {
private static final String CAFE_ENCODED = "caf%C3%A9";
private static final String SOME_CHARS = "/&%\\+";
private static final String SOME_CHARS_ENCODED = "%2F%26%25%5C%2B";
private static final String SPECIAL_CHARACTERS = ".-*_";
private static final String URL =
"http://lobid.org/resources/search?q=hasItem.hasItem.heldBy.id:\"http://lobid" +
".org/organisations/DE-290#!\"&format=json";
private static final String WHITESPACE = " ";
private static final String WHITESPACE_AS_PLUS_ENCODED = "+";
private static final String WHITESPACE_PERCENT_ENCODED = "%20";

URLEncoder urlEncoder;
@Test
public void testUtf8(){
final URLEncode urlEncode = new URLEncode();
Expand Down Expand Up @@ -64,5 +72,15 @@ public void testSafeChars(){
urlEncode.setSafeChars(SOME_CHARS);
assertEquals(SOME_CHARS, urlEncode.process(SOME_CHARS));
}
@Test
public void testSpecialChars(){
final URLEncode urlEncode = new URLEncode();
assertEquals(SPECIAL_CHARACTERS, urlEncode.process(SPECIAL_CHARACTERS));
}
@Test
public void testBackwardsCompatibility() throws UnsupportedEncodingException {
final URLEncode urlEncode = new URLEncode();
assertEquals(urlEncode.process(URL), URLEncoder.encode(URL, "UTF-8"));
}

}

0 comments on commit d66b2f6

Please sign in to comment.