You are viewing a plain text version of this content. The canonical link for it is here.
Posted to commits@juneau.apache.org by ja...@apache.org on 2016/08/09 17:15:31 UTC
[10/44] incubator-juneau git commit: Rename CT_* testcases.
http://git-wip-us.apache.org/repos/asf/incubator-juneau/blob/df0f8689/org.apache.juneau/src/test/java/org/apache/juneau/urlencoding/CT_UonSerializer.java
----------------------------------------------------------------------
diff --git a/org.apache.juneau/src/test/java/org/apache/juneau/urlencoding/CT_UonSerializer.java b/org.apache.juneau/src/test/java/org/apache/juneau/urlencoding/CT_UonSerializer.java
deleted file mode 100755
index 69c9bec..0000000
--- a/org.apache.juneau/src/test/java/org/apache/juneau/urlencoding/CT_UonSerializer.java
+++ /dev/null
@@ -1,460 +0,0 @@
-/***************************************************************************************************************************
- * Licensed to the Apache Software Foundation (ASF) under one or more contributor license agreements. See the NOTICE file
- * distributed with this work for additional information regarding copyright ownership. The ASF licenses this file
- * to you under the Apache License, Version 2.0 (the "License"); you may not use this file except in compliance
- * with the License. You may obtain a copy of the License at
- *
- * http://www.apache.org/licenses/LICENSE-2.0
- *
- * Unless required by applicable law or agreed to in writing, software distributed under the License is distributed on an
- * "AS IS" BASIS, WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. See the License for the
- * specific language governing permissions and limitations under the License.
- ***************************************************************************************************************************/
-package org.apache.juneau.urlencoding;
-
-import static org.junit.Assert.*;
-
-import org.apache.juneau.*;
-import org.junit.*;
-
-public class CT_UonSerializer {
-
- static UonSerializer s = UonSerializer.DEFAULT_ENCODING;
- static UonSerializer ss = UonSerializer.DEFAULT_SIMPLE_ENCODING;
- static UonSerializer su = UonSerializer.DEFAULT;
- static UonSerializer ssu = UonSerializer.DEFAULT_SIMPLE;
- static UonSerializer sr = UonSerializer.DEFAULT_READABLE;
-
-
- //====================================================================================================
- // Basic test
- //====================================================================================================
- @Test
- public void testBasic() throws Exception {
-
- Object t;
-
- // Simple string
- // Top level
- t = "a";
- assertEquals("a", s.serialize(t));
- assertEquals("a", ss.serialize(t));
- assertEquals("a", su.serialize(t));
- assertEquals("a", ssu.serialize(t));
- assertEquals("a", sr.serialize(t));
-
- // 2nd level
- t = new ObjectMap("{a:'a'}");
- assertEquals("$o(a=a)", s.serialize(t));
- assertEquals("(a=a)", ss.serialize(t));
- assertEquals("$o(a=a)", su.serialize(t));
- assertEquals("(a=a)", ssu.serialize(t));
- assertEquals("$o(\n\ta=a\n)", sr.serialize(t));
-
- // Simple map
- // Top level
- t = new ObjectMap("{a:'b',c:123,d:false,e:true,f:null}");
- assertEquals("$o(a=b,c=$n(123),d=$b(false),e=$b(true),f=%00)", s.serialize(t));
- assertEquals("(a=b,c=123,d=false,e=true,f=%00)", ss.serialize(t));
- assertEquals("$o(a=b,c=$n(123),d=$b(false),e=$b(true),f=\u0000)", su.serialize(t));
- assertEquals("(a=b,c=123,d=false,e=true,f=\u0000)", ssu.serialize(t));
- assertEquals("$o(\n\ta=b,\n\tc=$n(123),\n\td=$b(false),\n\te=$b(true),\n\tf=\u0000\n)", sr.serialize(t));
-
- // 2nd level
- t = new ObjectMap("{a:{a:'b',c:123,d:false,e:true,f:null}}");
- assertEquals("$o(a=$o(a=b,c=$n(123),d=$b(false),e=$b(true),f=%00))", s.serialize(t));
- assertEquals("(a=(a=b,c=123,d=false,e=true,f=%00))", ss.serialize(t));
- assertEquals("$o(a=$o(a=b,c=$n(123),d=$b(false),e=$b(true),f=\u0000))", su.serialize(t));
- assertEquals("(a=(a=b,c=123,d=false,e=true,f=\u0000))", ssu.serialize(t));
- assertEquals("$o(\n\ta=$o(\n\t\ta=b,\n\t\tc=$n(123),\n\t\td=$b(false),\n\t\te=$b(true),\n\t\tf=\u0000\n\t)\n)", sr.serialize(t));
-
- // Simple map with primitives as literals
- t = new ObjectMap("{a:'b',c:'123',d:'false',e:'true',f:'null'}");
- assertEquals("$o(a=b,c=123,d=false,e=true,f=null)", s.serialize(t));
- assertEquals("(a=b,c=123,d=false,e=true,f=null)", ss.serialize(t));
- assertEquals("$o(a=b,c=123,d=false,e=true,f=null)", su.serialize(t));
- assertEquals("(a=b,c=123,d=false,e=true,f=null)", ssu.serialize(t));
- assertEquals("$o(\n\ta=b,\n\tc=123,\n\td=false,\n\te=true,\n\tf=null\n)", sr.serialize(t));
-
- // null
- // Note that serializeParams is always encoded.
- // Top level
- t = null;
- assertEquals("%00", s.serialize(t));
- assertEquals("%00", ss.serialize(t));
- assertEquals("\u0000", su.serialize(t));
- assertEquals("\u0000", ssu.serialize(t));
- assertEquals("\u0000", sr.serialize(t));
-
- // 2nd level
- t = new ObjectMap("{null:null}");
- assertEquals("$o(%00=%00)", s.serialize(t));
- assertEquals("(%00=%00)", ss.serialize(t));
- assertEquals("$o(\u0000=\u0000)", su.serialize(t));
- assertEquals("(\u0000=\u0000)", ssu.serialize(t));
- assertEquals("$o(\n\t\u0000=\u0000\n)", sr.serialize(t));
-
- // 3rd level
- t = new ObjectMap("{null:{null:null}}");
- assertEquals("$o(%00=$o(%00=%00))", s.serialize(t));
- assertEquals("(%00=(%00=%00))", ss.serialize(t));
- assertEquals("$o(\u0000=$o(\u0000=\u0000))", su.serialize(t));
- assertEquals("(\u0000=(\u0000=\u0000))", ssu.serialize(t));
- assertEquals("$o(\n\t\u0000=$o(\n\t\t\u0000=\u0000\n\t)\n)", sr.serialize(t));
-
- // Empty array
- // Top level
- t = new String[0];
- assertEquals("$a()", s.serialize(t));
- assertEquals("()", ss.serialize(t));
- assertEquals("$a()", su.serialize(t));
- assertEquals("()", ssu.serialize(t));
- assertEquals("$a()", sr.serialize(t));
-
- // 2nd level in map
- t = new ObjectMap("{x:[]}");
- assertEquals("$o(x=$a())", s.serialize(t));
- assertEquals("(x=())", ss.serialize(t));
- assertEquals("$o(x=$a())", su.serialize(t));
- assertEquals("(x=())", ssu.serialize(t));
- assertEquals("$o(\n\tx=$a()\n)", sr.serialize(t));
-
- // Empty 2 dimensional array
- t = new String[1][0];
- assertEquals("$a($a())", s.serialize(t));
- assertEquals("(())", ss.serialize(t));
- assertEquals("$a($a())", su.serialize(t));
- assertEquals("(())", ssu.serialize(t));
- assertEquals("$a(\n\t$a()\n)", sr.serialize(t));
-
- // Array containing empty string
- // Top level
- t = new String[]{""};
- assertEquals("$a(())", s.serialize(t));
- assertEquals("(())", ss.serialize(t));
- assertEquals("$a(())", su.serialize(t));
- assertEquals("(())", ssu.serialize(t));
- assertEquals("$a(\n\t()\n)", sr.serialize(t));
-
- // 2nd level
- t = new ObjectMap("{x:['']}");
- assertEquals("$o(x=$a(()))", s.serialize(t));
- assertEquals("(x=(()))", ss.serialize(t));
- assertEquals("$o(x=$a(()))", su.serialize(t));
- assertEquals("(x=(()))", ssu.serialize(t));
- assertEquals("$o(\n\tx=$a(\n\t\t()\n\t)\n)", sr.serialize(t));
-
- // Array containing 3 empty strings
- t = new String[]{"","",""};
- assertEquals("$a(,,)", s.serialize(t));
- assertEquals("(,,)", ss.serialize(t));
- assertEquals("$a(,,)", su.serialize(t));
- assertEquals("(,,)", ssu.serialize(t));
- assertEquals("$a(\n\t(),\n\t(),\n\t()\n)", sr.serialize(t));
-
- // String containing \u0000
- // Top level
- t = "\u0000";
- assertEquals("(%00)", s.serialize(t));
- assertEquals("(%00)", ss.serialize(t));
- assertEquals("(\u0000)", su.serialize(t));
- assertEquals("(\u0000)", ssu.serialize(t));
- assertEquals("(\u0000)", sr.serialize(t));
-
- // 2nd level
- t = new ObjectMap("{'\u0000':'\u0000'}");
- assertEquals("$o((%00)=(%00))", s.serialize(t));
- assertEquals("((%00)=(%00))", ss.serialize(t));
- assertEquals("$o((\u0000)=(\u0000))", su.serialize(t));
- assertEquals("((\u0000)=(\u0000))", ssu.serialize(t));
- assertEquals("$o(\n\t(\u0000)=(\u0000)\n)", sr.serialize(t));
-
- // Boolean
- // Top level
- t = false;
- assertEquals("$b(false)", s.serialize(t));
- assertEquals("false", ss.serialize(t));
- assertEquals("$b(false)", su.serialize(t));
- assertEquals("false", ssu.serialize(t));
- assertEquals("$b(false)", sr.serialize(t));
-
- // 2nd level
- t = new ObjectMap("{x:false}");
- assertEquals("$o(x=$b(false))", s.serialize(t));
- assertEquals("(x=false)", ss.serialize(t));
- assertEquals("$o(x=$b(false))", su.serialize(t));
- assertEquals("(x=false)", ssu.serialize(t));
- assertEquals("$o(\n\tx=$b(false)\n)", sr.serialize(t));
-
- // Number
- // Top level
- t = 123;
- assertEquals("$n(123)", s.serialize(t));
- assertEquals("123", ss.serialize(t));
- assertEquals("$n(123)", su.serialize(t));
- assertEquals("123", ssu.serialize(t));
- assertEquals("$n(123)", sr.serialize(t));
-
- // 2nd level
- t = new ObjectMap("{x:123}");
- assertEquals("$o(x=$n(123))", s.serialize(t));
- assertEquals("(x=123)", ss.serialize(t));
- assertEquals("$o(x=$n(123))", su.serialize(t));
- assertEquals("(x=123)", ssu.serialize(t));
- assertEquals("$o(\n\tx=$n(123)\n)", sr.serialize(t));
-
- // Unencoded chars
- // Top level
- t = "x;/?:@-_.!*'";
- assertEquals("x;/?:@-_.!*'", s.serialize(t));
- assertEquals("x;/?:@-_.!*'", ss.serialize(t));
- assertEquals("x;/?:@-_.!*'", su.serialize(t));
- assertEquals("x;/?:@-_.!*'", ssu.serialize(t));
- assertEquals("x;/?:@-_.!*'", sr.serialize(t));
-
- // 2nd level
- t = new ObjectMap("{x:'x;/?:@-_.!*\\''}");
- assertEquals("$o(x=x;/?:@-_.!*')", s.serialize(t));
- assertEquals("(x=x;/?:@-_.!*')", ss.serialize(t));
- assertEquals("$o(x=x;/?:@-_.!*')", su.serialize(t));
- assertEquals("(x=x;/?:@-_.!*')", ssu.serialize(t));
- assertEquals("$o(\n\tx=x;/?:@-_.!*'\n)", sr.serialize(t));
-
- // Encoded chars
- // Top level
- t = "x{}|\\^[]`<>#%\"&+";
- assertEquals("x%7B%7D%7C%5C%5E%5B%5D%60%3C%3E%23%25%22%26%2B", s.serialize(t));
- assertEquals("x%7B%7D%7C%5C%5E%5B%5D%60%3C%3E%23%25%22%26%2B", ss.serialize(t));
- assertEquals("x{}|\\^[]`<>#%\"&+", su.serialize(t));
- assertEquals("x{}|\\^[]`<>#%\"&+", ssu.serialize(t));
- assertEquals("x{}|\\^[]`<>#%\"&+", sr.serialize(t));
-
- // 2nd level
- t = new ObjectMap("{'x{}|\\\\^[]`<>#%\"&+':'x{}|\\\\^[]`<>#%\"&+'}");
- assertEquals("$o(x%7B%7D%7C%5C%5E%5B%5D%60%3C%3E%23%25%22%26%2B=x%7B%7D%7C%5C%5E%5B%5D%60%3C%3E%23%25%22%26%2B)", s.serialize(t));
- assertEquals("(x%7B%7D%7C%5C%5E%5B%5D%60%3C%3E%23%25%22%26%2B=x%7B%7D%7C%5C%5E%5B%5D%60%3C%3E%23%25%22%26%2B)", ss.serialize(t));
- assertEquals("$o(x{}|\\^[]`<>#%\"&+=x{}|\\^[]`<>#%\"&+)", su.serialize(t));
- assertEquals("(x{}|\\^[]`<>#%\"&+=x{}|\\^[]`<>#%\"&+)", ssu.serialize(t));
- assertEquals("$o(\n\tx{}|\\^[]`<>#%\"&+=x{}|\\^[]`<>#%\"&+\n)", sr.serialize(t));
-
- // Escaped chars
- // Top level
- t = "x$,()~";
- assertEquals("x$,()~", s.serialize(t));
- assertEquals("x$,()~", ss.serialize(t));
- assertEquals("x$,()~", su.serialize(t));
- assertEquals("x$,()~", ssu.serialize(t));
- assertEquals("x$,()~", sr.serialize(t));
-
- // 2nd level
- // Note behavior on serializeParams() is different since 2nd-level is top level.
- t = new ObjectMap("{'x$,()~':'x$,()~'}");
- assertEquals("$o(x$~,~(~)~~=x$~,~(~)~~)", s.serialize(t));
- assertEquals("(x$~,~(~)~~=x$~,~(~)~~)", ss.serialize(t));
- assertEquals("$o(x$~,~(~)~~=x$~,~(~)~~)", su.serialize(t));
- assertEquals("(x$~,~(~)~~=x$~,~(~)~~)", ssu.serialize(t));
- assertEquals("$o(\n\tx$~,~(~)~~=x$~,~(~)~~\n)", sr.serialize(t));
-
- // 3rd level
- // Note behavior on serializeParams().
- t = new ObjectMap("{'x$,()~':{'x$,()~':'x$,()~'}}");
- assertEquals("$o(x$~,~(~)~~=$o(x$~,~(~)~~=x$~,~(~)~~))", s.serialize(t));
- assertEquals("(x$~,~(~)~~=(x$~,~(~)~~=x$~,~(~)~~))", ss.serialize(t));
- assertEquals("$o(x$~,~(~)~~=$o(x$~,~(~)~~=x$~,~(~)~~))", su.serialize(t));
- assertEquals("(x$~,~(~)~~=(x$~,~(~)~~=x$~,~(~)~~))", ssu.serialize(t));
- assertEquals("$o(\n\tx$~,~(~)~~=$o(\n\t\tx$~,~(~)~~=x$~,~(~)~~\n\t)\n)", sr.serialize(t));
-
- // Equals sign
- // Gets encoded at top level, and encoded+escaped at 2nd level.
- // Top level
- t = "x=";
- assertEquals("x=", s.serialize(t));
- assertEquals("x=", ss.serialize(t));
- assertEquals("x=", su.serialize(t));
- assertEquals("x=", ssu.serialize(t));
- assertEquals("x=", sr.serialize(t));
-
- // 2nd level
- t = new ObjectMap("{'x=':'x='}");
- assertEquals("$o(x~==x~=)", s.serialize(t));
- assertEquals("(x~==x~=)", ss.serialize(t));
- assertEquals("$o(x~==x~=)", su.serialize(t));
- assertEquals("(x~==x~=)", ssu.serialize(t));
- assertEquals("$o(\n\tx~==x~=\n)", sr.serialize(t));
-
- // 3rd level
- t = new ObjectMap("{'x=':{'x=':'x='}}");
- assertEquals("$o(x~==$o(x~==x~=))", s.serialize(t));
- assertEquals("(x~==(x~==x~=))", ss.serialize(t));
- assertEquals("$o(x~==$o(x~==x~=))", su.serialize(t));
- assertEquals("(x~==(x~==x~=))", ssu.serialize(t));
- assertEquals("$o(\n\tx~==$o(\n\t\tx~==x~=\n\t)\n)", sr.serialize(t));
-
- // String starting with parenthesis
- // Top level
- t = "()";
- assertEquals("(~(~))", s.serialize(t));
- assertEquals("(~(~))", ss.serialize(t));
- assertEquals("(~(~))", su.serialize(t));
- assertEquals("(~(~))", ssu.serialize(t));
- assertEquals("(~(~))", sr.serialize(t));
-
- // 2nd level
- t = new ObjectMap("{'()':'()'}");
- assertEquals("$o((~(~))=(~(~)))", s.serialize(t));
- assertEquals("((~(~))=(~(~)))", ss.serialize(t));
- assertEquals("$o((~(~))=(~(~)))", su.serialize(t));
- assertEquals("((~(~))=(~(~)))", ssu.serialize(t));
- assertEquals("$o(\n\t(~(~))=(~(~))\n)", sr.serialize(t));
-
- // String starting with $
- // Top level
- t = "$a";
- assertEquals("($a)", s.serialize(t));
- assertEquals("($a)", ss.serialize(t));
- assertEquals("($a)", su.serialize(t));
- assertEquals("($a)", ssu.serialize(t));
- assertEquals("($a)", sr.serialize(t));
-
- // 2nd level
- t = new ObjectMap("{$a:'$a'}");
- assertEquals("$o(($a)=($a))", s.serialize(t));
- assertEquals("(($a)=($a))", ss.serialize(t));
- assertEquals("$o(($a)=($a))", su.serialize(t));
- assertEquals("(($a)=($a))", ssu.serialize(t));
- assertEquals("$o(\n\t($a)=($a)\n)", sr.serialize(t));
-
- // Blank string
- // Top level
- t = "";
- assertEquals("", s.serialize(t));
- assertEquals("", ss.serialize(t));
- assertEquals("", su.serialize(t));
- assertEquals("", ssu.serialize(t));
- assertEquals("", sr.serialize(t));
-
- // 2nd level
- t = new ObjectMap("{'':''}");
- assertEquals("$o(=)", s.serialize(t));
- assertEquals("(=)", ss.serialize(t));
- assertEquals("$o(=)", su.serialize(t));
- assertEquals("(=)", ssu.serialize(t));
- assertEquals("$o(\n\t()=()\n)", sr.serialize(t));
-
- // 3rd level
- t = new ObjectMap("{'':{'':''}}");
- assertEquals("$o(=$o(=))", s.serialize(t));
- assertEquals("(=(=))", ss.serialize(t));
- assertEquals("$o(=$o(=))", su.serialize(t));
- assertEquals("(=(=))", ssu.serialize(t));
- assertEquals("$o(\n\t()=$o(\n\t\t()=()\n\t)\n)", sr.serialize(t));
-
- // Newline character
- // Top level
- t = "\n";
- assertEquals("%0A", s.serialize(t));
- assertEquals("%0A", ss.serialize(t));
- assertEquals("\n", su.serialize(t));
- assertEquals("\n", ssu.serialize(t));
- assertEquals("(\n)", sr.serialize(t));
-
- // 2nd level
- t = new ObjectMap("{'\n':'\n'}");
- assertEquals("$o(%0A=%0A)", s.serialize(t));
- assertEquals("(%0A=%0A)", ss.serialize(t));
- assertEquals("$o(\n=\n)", su.serialize(t));
- assertEquals("(\n=\n)", ssu.serialize(t));
- assertEquals("$o(\n\t(\n)=(\n)\n)", sr.serialize(t));
-
- // 3rd level
- t = new ObjectMap("{'\n':{'\n':'\n'}}");
- assertEquals("$o(%0A=$o(%0A=%0A))", s.serialize(t));
- assertEquals("(%0A=(%0A=%0A))", ss.serialize(t));
- assertEquals("$o(\n=$o(\n=\n))", su.serialize(t));
- assertEquals("(\n=(\n=\n))", ssu.serialize(t));
- assertEquals("$o(\n\t(\n)=$o(\n\t\t(\n)=(\n)\n\t)\n)", sr.serialize(t));
- }
-
- //====================================================================================================
- // Unicode characters test
- //====================================================================================================
- @Test
- public void testUnicodeChars() throws Exception {
- Object t;
-
- // 2-byte UTF-8 character
- // Top level
- t = "�";
- assertEquals("%C2%A2", s.serialize(t));
- assertEquals("%C2%A2", ss.serialize(t));
- assertEquals("�", su.serialize(t));
- assertEquals("�", ssu.serialize(t));
- assertEquals("�", sr.serialize(t));
-
- // 2nd level
- t = new ObjectMap("{'�':'�'}");
- assertEquals("$o(%C2%A2=%C2%A2)", s.serialize(t));
- assertEquals("(%C2%A2=%C2%A2)", ss.serialize(t));
- assertEquals("$o(�=�)", su.serialize(t));
- assertEquals("(�=�)", ssu.serialize(t));
- assertEquals("$o(\n\t�=�\n)", sr.serialize(t));
-
- // 3rd level
- t = new ObjectMap("{'�':{'�':'�'}}");
- assertEquals("$o(%C2%A2=$o(%C2%A2=%C2%A2))", s.serialize(t));
- assertEquals("(%C2%A2=(%C2%A2=%C2%A2))", ss.serialize(t));
- assertEquals("$o(�=$o(�=�))", su.serialize(t));
- assertEquals("(�=(�=�))", ssu.serialize(t));
- assertEquals("$o(\n\t�=$o(\n\t\t�=�\n\t)\n)", sr.serialize(t));
-
- // 3-byte UTF-8 character
- // Top level
- t = "\u20ac";
- assertEquals("%E2%82%AC", s.serialize(t));
- assertEquals("%E2%82%AC", ss.serialize(t));
- assertEquals("\u20ac", su.serialize(t));
- assertEquals("\u20ac", ssu.serialize(t));
- assertEquals("\u20ac", sr.serialize(t));
-
- // 2nd level
- t = new ObjectMap("{'\u20ac':'\u20ac'}");
- assertEquals("$o(%E2%82%AC=%E2%82%AC)", s.serialize(t));
- assertEquals("(%E2%82%AC=%E2%82%AC)", ss.serialize(t));
- assertEquals("$o(\u20ac=\u20ac)", su.serialize(t));
- assertEquals("(\u20ac=\u20ac)", ssu.serialize(t));
- assertEquals("$o(\n\t\u20ac=\u20ac\n)", sr.serialize(t));
-
- // 3rd level
- t = new ObjectMap("{'\u20ac':{'\u20ac':'\u20ac'}}");
- assertEquals("$o(%E2%82%AC=$o(%E2%82%AC=%E2%82%AC))", s.serialize(t));
- assertEquals("(%E2%82%AC=(%E2%82%AC=%E2%82%AC))", ss.serialize(t));
- assertEquals("$o(\u20ac=$o(\u20ac=\u20ac))", su.serialize(t));
- assertEquals("(\u20ac=(\u20ac=\u20ac))", ssu.serialize(t));
- assertEquals("$o(\n\t\u20ac=$o(\n\t\t\u20ac=\u20ac\n\t)\n)", sr.serialize(t));
-
- // 4-byte UTF-8 character
- // Top level
- t = "\U00024b62";
- assertEquals("%F0%A4%AD%A2", s.serialize(t));
- assertEquals("%F0%A4%AD%A2", ss.serialize(t));
- assertEquals("\U00024b62", su.serialize(t));
- assertEquals("\U00024b62", ssu.serialize(t));
- assertEquals("\U00024b62", sr.serialize(t));
-
- // 2nd level
- t = new ObjectMap("{'\U00024b62':'\U00024b62'}");
- assertEquals("$o(%F0%A4%AD%A2=%F0%A4%AD%A2)", s.serialize(t));
- assertEquals("(%F0%A4%AD%A2=%F0%A4%AD%A2)", ss.serialize(t));
- assertEquals("$o(\U00024b62=\U00024b62)", su.serialize(t));
- assertEquals("(\U00024b62=\U00024b62)", ssu.serialize(t));
- assertEquals("$o(\n\t\U00024b62=\U00024b62\n)", sr.serialize(t));
-
- // 3rd level
- t = new ObjectMap("{'\U00024b62':{'\U00024b62':'\U00024b62'}}");
- assertEquals("$o(%F0%A4%AD%A2=$o(%F0%A4%AD%A2=%F0%A4%AD%A2))", s.serialize(t));
- assertEquals("(%F0%A4%AD%A2=(%F0%A4%AD%A2=%F0%A4%AD%A2))", ss.serialize(t));
- assertEquals("$o(\U00024b62=$o(\U00024b62=\U00024b62))", su.serialize(t));
- assertEquals("(\U00024b62=(\U00024b62=\U00024b62))", ssu.serialize(t));
- assertEquals("$o(\n\t\U00024b62=$o(\n\t\t\U00024b62=\U00024b62\n\t)\n)", sr.serialize(t));
- }
-}
\ No newline at end of file
http://git-wip-us.apache.org/repos/asf/incubator-juneau/blob/df0f8689/org.apache.juneau/src/test/java/org/apache/juneau/urlencoding/CT_UrlEncodingParser.java
----------------------------------------------------------------------
diff --git a/org.apache.juneau/src/test/java/org/apache/juneau/urlencoding/CT_UrlEncodingParser.java b/org.apache.juneau/src/test/java/org/apache/juneau/urlencoding/CT_UrlEncodingParser.java
deleted file mode 100755
index c929bab..0000000
--- a/org.apache.juneau/src/test/java/org/apache/juneau/urlencoding/CT_UrlEncodingParser.java
+++ /dev/null
@@ -1,1000 +0,0 @@
-/***************************************************************************************************************************
- * Licensed to the Apache Software Foundation (ASF) under one or more contributor license agreements. See the NOTICE file
- * distributed with this work for additional information regarding copyright ownership. The ASF licenses this file
- * to you under the Apache License, Version 2.0 (the "License"); you may not use this file except in compliance
- * with the License. You may obtain a copy of the License at
- *
- * http://www.apache.org/licenses/LICENSE-2.0
- *
- * Unless required by applicable law or agreed to in writing, software distributed under the License is distributed on an
- * "AS IS" BASIS, WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. See the License for the
- * specific language governing permissions and limitations under the License.
- ***************************************************************************************************************************/
-package org.apache.juneau.urlencoding;
-
-import static org.apache.juneau.TestUtils.*;
-import static org.junit.Assert.*;
-
-import java.util.*;
-
-import org.apache.juneau.*;
-import org.apache.juneau.parser.*;
-import org.junit.*;
-
-@SuppressWarnings({"rawtypes","unchecked","hiding"})
-public class CT_UrlEncodingParser {
-
- static UrlEncodingParser p = UrlEncodingParser.DEFAULT;
-
- //====================================================================================================
- // Basic test
- //====================================================================================================
- @Test
- public void testBasic() throws Exception {
-
- String t;
- Map m;
- List l;
-
- // Simple string
- // Top level
- t = "_value=a";
- assertEquals("a", p.parse(t, Object.class));
- assertEquals("a", p.parse(t, String.class));
- t = "_value=(a)";
- assertEquals("a", p.parse(t, String.class));
- assertEquals("a", p.parse(t, Object.class));
- t = "_value=$s(a)";
- assertEquals("a", p.parse(t, String.class));
-
- t = "a";
- assertEquals("a", p.parseParameter(t, Object.class));
- assertEquals("a", p.parseParameter(t, String.class));
- t = "(a)";
- assertEquals("a", p.parseParameter(t, String.class));
- assertEquals("a", p.parseParameter(t, Object.class));
- t = "$s(a)";
- assertEquals("a", p.parseParameter(t, String.class));
-
- // 2nd level
- t = "?a=a";
- assertEquals("a", p.parse(t, Map.class).get("a"));
-
- // Simple map
- // Top level
- t = "?a=b&c=$n(123)&d=$b(false)&e=$b(true)&f=%00";
- m = p.parse(t, Map.class);
- assertEquals("b", m.get("a"));
- assertTrue(m.get("c") instanceof Number);
- assertEquals(123, m.get("c"));
- assertTrue(m.get("d") instanceof Boolean);
- assertEquals(Boolean.FALSE, m.get("d"));
- assertTrue(m.get("e") instanceof Boolean);
- assertEquals(Boolean.TRUE, m.get("e"));
- assertNull(m.get("f"));
-
- t = "$o(a=b,c=$n(123),d=$b(false),e=$b(true),f=%00)";
- m = p.parseParameter(t, Map.class);
- assertEquals("b", m.get("a"));
- assertTrue(m.get("c") instanceof Number);
- assertEquals(123, m.get("c"));
- assertTrue(m.get("d") instanceof Boolean);
- assertEquals(Boolean.FALSE, m.get("d"));
- assertTrue(m.get("e") instanceof Boolean);
- assertEquals(Boolean.TRUE, m.get("e"));
- assertEquals("%00", m.get("f"));
-
- t = "$o(a=b,c=$n(123),d=$b(false),e=$b(true),f=\u0000)";
- m = p.parseParameter(t, Map.class);
- assertTrue(m.containsKey("f"));
- assertNull(m.get("f"));
-
- t = "?a=true";
- m = p.parseMap(t, HashMap.class, String.class, Boolean.class);
- assertTrue(m.get("a") instanceof Boolean);
- assertEquals("true", m.get("a").toString());
-
- // null
- // Top level
- t = "_value=%00";
- assertNull(p.parse(t, Object.class));
- t = "\u0000";
- assertNull(p.parseParameter(t, Object.class));
- t = "%00";
- assertEquals("%00", p.parseParameter(t, Object.class));
-
- // 2nd level
- t = "?%00=%00";
- m = p.parse(t, Map.class);
- assertTrue(m.containsKey(null));
- assertNull(m.get(null));
-
- t = "?\u0000=\u0000";
- m = p.parse(t, Map.class);
- assertTrue(m.containsKey(null));
- assertNull(m.get(null));
-
- // 3rd level
- t = "?%00=$o(%00=%00)";
- m = p.parse(t, Map.class);
- assertTrue(((Map)m.get(null)).containsKey(null));
- assertNull(((Map)m.get(null)).get(null));
-
- // Empty array
- // Top level
- t = "_value=$a()";
- l = (List)p.parse(t, Object.class);
- assertTrue(l.isEmpty());
- t = "_value=()";
- l = p.parse(t, List.class);
- assertTrue(l.isEmpty());
- t = "$a()";
- l = (List)p.parseParameter(t, Object.class);
- assertTrue(l.isEmpty());
- t = "()";
- l = p.parseParameter(t, List.class);
- assertTrue(l.isEmpty());
-
- // 2nd level in map
- t = "?x=$a()";
- m = p.parseMap(t, HashMap.class, String.class, List.class);
- assertTrue(m.containsKey("x"));
- assertTrue(((List)m.get("x")).isEmpty());
- m = (Map)p.parse(t, Object.class);
- assertTrue(m.containsKey("x"));
- assertTrue(((List)m.get("x")).isEmpty());
- t = "?x=()";
- m = p.parseMap(t, HashMap.class, String.class, List.class);
- assertTrue(m.containsKey("x"));
- assertTrue(((List)m.get("x")).isEmpty());
-
- // Empty 2 dimensional array
- t = "_value=$a($a())";
- l = (List)p.parse(t, Object.class);
- assertTrue(l.size() == 1);
- l = (List)l.get(0);
- assertTrue(l.isEmpty());
- t = "0=()";
- l = p.parseCollection(t, LinkedList.class, List.class);
- assertTrue(l.size() == 1);
- l = (List)l.get(0);
- assertTrue(l.isEmpty());
- t = "$a($a())";
- l = (List)p.parseParameter(t, Object.class);
- assertTrue(l.size() == 1);
- l = (List)l.get(0);
- assertTrue(l.isEmpty());
- t = "(())";
- l = (List)p.parseParameter(t, p.getBeanContext().getCollectionClassMeta(LinkedList.class, List.class));
- assertTrue(l.size() == 1);
- l = (List)l.get(0);
- assertTrue(l.isEmpty());
-
- // Array containing empty string
- // Top level
- t = "_value=$a(())";
- l = (List)p.parse(t, Object.class);
- assertTrue(l.size() == 1);
- assertEquals("", l.get(0));
- t = "0=()";
- l = p.parseCollection(t, List.class, String.class);
- assertTrue(l.size() == 1);
- assertEquals("", l.get(0));
- t = "$a(())";
- l = (List)p.parseParameter(t, Object.class);
- assertTrue(l.size() == 1);
- assertEquals("", l.get(0));
- t = "(())";
- l = (List)p.parseParameter(t, p.getBeanContext().getCollectionClassMeta(List.class, String.class));
- assertTrue(l.size() == 1);
- assertEquals("", l.get(0));
-
- // 2nd level
- t = "?()=$a(())";
- m = (Map)p.parse(t, Object.class);
- assertEquals("", ((List)m.get("")).get(0));
- t = "?()=(())";
- m = p.parseMap(t, HashMap.class, String.class, List.class);
- assertEquals("", ((List)m.get("")).get(0));
-
- // Array containing 3 empty strings
- t = "_value=$a(,,)";
- l = (List)p.parse(t, Object.class);
- assertTrue(l.size() == 3);
- assertEquals("", l.get(0));
- assertEquals("", l.get(1));
- assertEquals("", l.get(2));
- t = "0=&1=&2=";
- l = p.parseCollection(t, List.class, Object.class);
- assertTrue(l.size() == 3);
- assertEquals("", l.get(0));
- assertEquals("", l.get(1));
- assertEquals("", l.get(2));
- t = "$a(,,)";
- l = (List)p.parseParameter(t, Object.class);
- assertTrue(l.size() == 3);
- assertEquals("", l.get(0));
- assertEquals("", l.get(1));
- assertEquals("", l.get(2));
- t = "(,,)";
- l = (List)p.parseParameter(t, p.getBeanContext().getCollectionClassMeta(List.class, Object.class));
- assertTrue(l.size() == 3);
- assertEquals("", l.get(0));
- assertEquals("", l.get(1));
- assertEquals("", l.get(2));
-
- // String containing \u0000
- // Top level
- t = "_value=$s(\u0000)";
- assertEquals("\u0000", p.parse(t, Object.class));
- t = "_value=(\u0000)";
- assertEquals("\u0000", p.parse(t, String.class));
- assertEquals("\u0000", p.parse(t, Object.class));
- t = "$s(\u0000)";
- assertEquals("\u0000", p.parseParameter(t, Object.class));
- t = "(\u0000)";
- assertEquals("\u0000", p.parseParameter(t, String.class));
- assertEquals("\u0000", p.parseParameter(t, Object.class));
-
- // 2nd level
- t = "?(\u0000)=(\u0000)";
- m = (Map)p.parse(t, Object.class);
- assertTrue(m.size() == 1);
- assertEquals("\u0000", m.get("\u0000"));
- m = p.parseMap(t, HashMap.class, String.class, Object.class);
- assertTrue(m.size() == 1);
- assertEquals("\u0000", m.get("\u0000"));
-
- // Boolean
- // Top level
- t = "_value=$b(false)";
- Boolean b = (Boolean)p.parse(t, Object.class);
- assertEquals(Boolean.FALSE, b);
- b = p.parse(t, Boolean.class);
- assertEquals(Boolean.FALSE, b);
- t = "_value=false";
- b = p.parse(t, Boolean.class);
- assertEquals(Boolean.FALSE, b);
- t = "$b(false)";
- b = (Boolean)p.parseParameter(t, Object.class);
- assertEquals(Boolean.FALSE, b);
- b = p.parseParameter(t, Boolean.class);
- assertEquals(Boolean.FALSE, b);
- t = "false";
- b = p.parseParameter(t, Boolean.class);
- assertEquals(Boolean.FALSE, b);
-
- // 2nd level
- t = "?x=$b(false)";
- m = (Map)p.parse(t, Object.class);
- assertEquals(Boolean.FALSE, m.get("x"));
- t = "?x=false";
- m = p.parseMap(t, HashMap.class, String.class, Boolean.class);
- assertEquals(Boolean.FALSE, m.get("x"));
-
- // Number
- // Top level
- t = "_value=$n(123)";
- Integer i = (Integer)p.parse(t, Object.class);
- assertEquals(123, i.intValue());
- i = p.parse(t, Integer.class);
- assertEquals(123, i.intValue());
- Double d = p.parse(t, Double.class);
- assertEquals(123, d.intValue());
- Float f = p.parse(t, Float.class);
- assertEquals(123, f.intValue());
- t = "_value=123";
- i = p.parse(t, Integer.class);
- assertEquals(123, i.intValue());
- t = "$n(123)";
- i = (Integer)p.parseParameter(t, Object.class);
- assertEquals(123, i.intValue());
- i = p.parseParameter(t, Integer.class);
- assertEquals(123, i.intValue());
- d = p.parseParameter(t, Double.class);
- assertEquals(123, d.intValue());
- f = p.parseParameter(t, Float.class);
- assertEquals(123, f.intValue());
- t = "123";
- i = p.parseParameter(t, Integer.class);
- assertEquals(123, i.intValue());
-
- // 2nd level
- t = "?x=$n(123)";
- m = (Map)p.parse(t, Object.class);
- assertEquals(123, ((Integer)m.get("x")).intValue());
- m = p.parseMap(t, HashMap.class, String.class, Double.class);
- assertEquals(123, ((Double)m.get("x")).intValue());
-
- // Unencoded chars
- // Top level
- t = "_value=x;/?:@-_.!*'";
- assertEquals("x;/?:@-_.!*'", p.parse(t, Object.class));
- t = "x;/?:@-_.!*'";
- assertEquals("x;/?:@-_.!*'", p.parseParameter(t, Object.class));
-
- // 2nd level
- t = "?x;/?:@-_.!*'=x;/?:@-_.!*'";
- m = (Map)p.parse(t, Object.class);
- assertEquals("x;/?:@-_.!*'", m.get("x;/?:@-_.!*'"));
- m = p.parseMap(t, HashMap.class, String.class, Object.class);
- assertEquals("x;/?:@-_.!*'", m.get("x;/?:@-_.!*'"));
- m = p.parseMap(t, HashMap.class, String.class, String.class);
- assertEquals("x;/?:@-_.!*'", m.get("x;/?:@-_.!*'"));
-
- // Encoded chars
- // Top level
- t = "_value=x{}|\\^[]`<>#%\"&+";
- try {
- assertEquals("x{}|\\^[]`<>#%\"&+", p.parse(t, Object.class));
- fail("Expected parse exception from invalid hex sequence.");
- } catch (ParseException e) {
- // Good.
- }
- t = "_value=x%7B%7D%7C%5C%5E%5B%5D%60%3C%3E%23%25%22%26%2B";
- assertEquals("x{}|\\^[]`<>#%\"&+", p.parse(t, Object.class));
- assertEquals("x{}|\\^[]`<>#%\"&+", p.parse(t, String.class));
- t = "x{}|\\^[]`<>#%\"&+";
- assertEquals("x{}|\\^[]`<>#%\"&+", p.parseParameter(t, Object.class));
- t = "x%7B%7D%7C%5C%5E%5B%5D%60%3C%3E%23%25%22%26%2B";
- assertEquals("x%7B%7D%7C%5C%5E%5B%5D%60%3C%3E%23%25%22%26%2B", p.parseParameter(t, Object.class));
- assertEquals("x%7B%7D%7C%5C%5E%5B%5D%60%3C%3E%23%25%22%26%2B", p.parseParameter(t, String.class));
-
- // 2nd level
- t = "?x{}|\\^[]`<>#%\"&+=x{}|\\^[]`<>#%\"&+";
- try {
- m = (Map)p.parse(t, Object.class);
- fail("Expected parse exception from invalid hex sequence.");
- } catch (ParseException e) {
- // Good.
- }
- t = "?x%7B%7D%7C%5C%5E%5B%5D%60%3C%3E%23%25%22%26%2B=x%7B%7D%7C%5C%5E%5B%5D%60%3C%3E%23%25%22%26%2B";
- m = (Map)p.parse(t, Object.class);
- assertEquals("x{}|\\^[]`<>#%\"&+", m.get("x{}|\\^[]`<>#%\"&+"));
-
- // Special chars
- // These characters are escaped and not encoded.
- // Top level
- t = "_value=x~$~,~(~)";
- assertEquals("x$,()", p.parse(t, Object.class));
- t = "x~$~,~(~)";
- assertEquals("x$,()", p.parseParameter(t, Object.class));
- t = "_value=x~~$~~,~~(~~)";
- assertEquals("x~$~,~(~)", p.parse(t, Object.class));
- t = "x~~$~~,~~(~~)";
- assertEquals("x~$~,~(~)", p.parseParameter(t, Object.class));
-
- // At secondary levels, these characters are escaped and not encoded.
- // 2nd level
- t = "?x~$~,~(~)=x~$~,~(~)";
- m = (Map)p.parse(t, Object.class);
- assertEquals("x$,()", m.get("x$,()"));
- t = "?x~~$~~,~~(~~)=x~~$~~,~~(~~)";
- m = (Map)p.parse(t, Object.class);
- assertEquals("x~$~,~(~)", m.get("x~$~,~(~)"));
-
- // Equals sign
- // Gets encoded at top level, and encoded+escaped at 2nd level.
- // Top level
- t = "_value=x=";
- assertEquals("x=", p.parse(t, Object.class));
- t = "_value=x%3D";
- assertEquals("x=", p.parse(t, Object.class));
- t = "x=";
- assertEquals("x=", p.parseParameter(t, Object.class));
- t = "x%3D";
- assertEquals("x%3D", p.parseParameter(t, Object.class));
-
- // 2nd level
- t = "?x~%3D=x~%3D";
- m = (Map)p.parse(t, Object.class);
- assertEquals("x=", m.get("x="));
- t = "?x~~%3D=x~~%3D";
- m = (Map)p.parse(t, Object.class);
- assertEquals("x~=", m.get("x~="));
-
- // String starting with parenthesis
- // Top level
- t = "_value=~(~)";
- assertEquals("()", p.parse(t, Object.class));
- assertEquals("()", p.parse(t, String.class));
- t = "_value=(~(~))";
- assertEquals("()", p.parse(t, Object.class));
- assertEquals("()", p.parse(t, String.class));
- t = "_value=(~(~))";
- assertEquals("()", p.parse(t, Object.class));
- assertEquals("()", p.parse(t, String.class));
- t = "~(~)";
- assertEquals("()", p.parseParameter(t, Object.class));
- assertEquals("()", p.parseParameter(t, String.class));
- t = "(~(~))";
- assertEquals("()", p.parseParameter(t, Object.class));
- assertEquals("()", p.parseParameter(t, String.class));
- t = "(~(~))";
- assertEquals("()", p.parseParameter(t, Object.class));
- assertEquals("()", p.parseParameter(t, String.class));
-
- // 2nd level
- t = "?(~(~))=(~(~))";
- m = (Map)p.parse(t, Object.class);
- assertEquals("()", m.get("()"));
- t = "?(~(~))=(~(~))";
- m = p.parseMap(t, HashMap.class, String.class, Object.class);
- assertEquals("()", m.get("()"));
-
- // String starting with $
- // Top level
- t = "_value=(~$a)";
- assertEquals("$a", p.parse(t, Object.class));
- t = "_value=(~$a)";
- assertEquals("$a", p.parse(t, Object.class));
- t = "(~$a)";
- assertEquals("$a", p.parseParameter(t, Object.class));
- t = "(~$a)";
- assertEquals("$a", p.parseParameter(t, Object.class));
-
- // 2nd level
- t = "?(~$a)=(~$a)";
- m = (Map)p.parse(t, Object.class);
- assertEquals("$a", m.get("$a"));
- m = p.parseMap(t, HashMap.class, String.class, Object.class);
- assertEquals("$a", m.get("$a"));
-
- // Blank string
- // Top level
- t = "_value=";
- assertEquals("", p.parse(t, Object.class));
- t = "";
- assertEquals("", p.parseParameter(t, Object.class));
-
- // 2nd level
- t = "?=";
- m = (Map)p.parse(t, Object.class);
- assertEquals("", m.get(""));
- m = p.parseMap(t, HashMap.class, String.class, Object.class);
- assertEquals("", m.get(""));
-
- // 3rd level
- t = "?=$o(=)";
- m = (Map)p.parse(t, Object.class);
- assertEquals("", ((Map)m.get("")).get(""));
- t = "?=(=)";
- m = p.parseMap(t, HashMap.class, String.class, HashMap.class);
- assertEquals("", ((Map)m.get("")).get(""));
-
- // Newline character
- // Top level
- t = "_value=(%0A)";
- assertEquals("\n", p.parse(t, Object.class));
- t = "(%0A)";
- assertEquals("%0A", p.parseParameter(t, Object.class));
- t = "(\n)";
- assertEquals("\n", p.parseParameter(t, Object.class));
-
- // 2nd level
- t = "?%0A=(%0A)";
- m = (Map)p.parse(t, Object.class);
- assertEquals("\n", m.get("\n"));
-
- // 3rd level
- t = "?%0A=$o((%0A)=(%0A))";
- m = (Map)p.parse(t, Object.class);
- assertEquals("\n", ((Map)m.get("\n")).get("\n"));
- }
-
- //====================================================================================================
- // Unicode character test
- //====================================================================================================
- @Test
- public void testUnicodeChars() throws Exception {
- String t;
- Map m;
-
- // 2-byte UTF-8 character
- // Top level
- t = "_value=�";
- assertEquals("�", p.parse(t, Object.class));
- assertEquals("�", p.parse(t, String.class));
- t = "_value=%C2%A2";
- assertEquals("�", p.parse(t, Object.class));
- assertEquals("�", p.parse(t, String.class));
- t = "�";
- assertEquals("�", p.parseParameter(t, Object.class));
- assertEquals("�", p.parseParameter(t, String.class));
- t = "%C2%A2";
- assertEquals("%C2%A2", p.parseParameter(t, Object.class));
- assertEquals("%C2%A2", p.parseParameter(t, String.class));
-
- // 2nd level
- t = "?%C2%A2=%C2%A2";
- m = (Map)p.parse(t, Object.class);
- assertEquals("�", m.get("�"));
-
- // 3rd level
- t = "?%C2%A2=$o(%C2%A2=%C2%A2)";
- m = (Map)p.parse(t, Object.class);
- assertEquals("�", ((Map)m.get("�")).get("�"));
-
- // 3-byte UTF-8 character
- // Top level
- t = "_value=\u20ac";
- assertEquals("\u20ac", p.parse(t, Object.class));
- assertEquals("\u20ac", p.parse(t, String.class));
- t = "_value=%E2%82%AC";
- assertEquals("\u20ac", p.parse(t, Object.class));
- assertEquals("\u20ac", p.parse(t, String.class));
- t = "\u20ac";
- assertEquals("\u20ac", p.parseParameter(t, Object.class));
- assertEquals("\u20ac", p.parseParameter(t, String.class));
- t = "%E2%82%AC";
- assertEquals("%E2%82%AC", p.parseParameter(t, Object.class));
- assertEquals("%E2%82%AC", p.parseParameter(t, String.class));
-
- // 2nd level
- t = "?%E2%82%AC=%E2%82%AC";
- m = (Map)p.parse(t, Object.class);
- assertEquals("\u20ac", m.get("\u20ac"));
-
- // 3rd level
- t = "?%E2%82%AC=$o(%E2%82%AC=%E2%82%AC)";
- m = (Map)p.parse(t, Object.class);
- assertEquals("\u20ac", ((Map)m.get("\u20ac")).get("\u20ac"));
-
- // 4-byte UTF-8 character
- // Top level
- t = "_value=\U00024b62";
- assertEquals("\U00024b62", p.parse(t, Object.class));
- assertEquals("\U00024b62", p.parse(t, String.class));
- t = "_value=%F0%A4%AD%A2";
- assertEquals("\U00024b62", p.parse(t, Object.class));
- assertEquals("\U00024b62", p.parse(t, String.class));
- t = "\U00024b62";
- assertEquals("\U00024b62", p.parseParameter(t, Object.class));
- assertEquals("\U00024b62", p.parseParameter(t, String.class));
- t = "%F0%A4%AD%A2";
- assertEquals("%F0%A4%AD%A2", p.parseParameter(t, Object.class));
- assertEquals("%F0%A4%AD%A2", p.parseParameter(t, String.class));
-
- // 2nd level
- t = "?%F0%A4%AD%A2=%F0%A4%AD%A2";
- m = (Map)p.parse(t, Object.class);
- assertEquals("\U00024b62", m.get("\U00024b62"));
-
- // 3rd level
- t = "?%F0%A4%AD%A2=$o(%F0%A4%AD%A2=%F0%A4%AD%A2)";
- m = (Map)p.parse(t, Object.class);
- assertEquals("\U00024b62", ((Map)m.get("\U00024b62")).get("\U00024b62"));
- }
-
- //====================================================================================================
- // Test simple bean
- //====================================================================================================
- @Test
- public void testSimpleBean() throws Exception {
- UrlEncodingParser p = UrlEncodingParser.DEFAULT;
- A t;
-
- String s = "?f1=foo&f2=123";
- t = p.parse(s, A.class);
- assertEquals("foo", t.f1);
- assertEquals(123, t.f2);
-
- s = "(f1=foo,f2=123)";
- t = p.parseParameter(s, A.class);
- assertEquals("foo", t.f1);
- assertEquals(123, t.f2);
-
- s = "$o(f1=foo,f2=123)";
- t = p.parseParameter(s, A.class);
- assertEquals("foo", t.f1);
- assertEquals(123, t.f2);
- }
-
- public static class A {
- public String f1;
- public int f2;
- }
-
- //====================================================================================================
- // Test URL-encoded strings with no-value parameters.
- //====================================================================================================
- @Test
- public void testNoValues() throws Exception {
- UrlEncodingParser p = UrlEncodingParser.DEFAULT;
- ObjectMap m;
-
- String s = "?f1";
- m = p.parse(s, ObjectMap.class);
- assertTrue(m.containsKey("f1"));
- assertNull(m.get("f1"));
- s = "?f1=f2&f3";
- m = p.parse(s, ObjectMap.class);
- assertEquals("f2", m.get("f1"));
- assertTrue(m.containsKey("f3"));
- assertNull(m.get("f3"));
- }
-
- //====================================================================================================
- // Test URL-encoded strings parsed into plain-text values using UrlEncodingParser.parseIntoSimpleMap().
- //====================================================================================================
- @Test
- public void testParseIntoSimpleMap() throws Exception {
- UrlEncodingParser p = UrlEncodingParser.DEFAULT;
- Map<String,String[]> m;
-
- String s = "?f1=,()=&f2a=$b(true)&f2b=true&f3a=$n(123)&f3b=123&f4=$s(foo)";
- m = p.parseIntoSimpleMap(s);
- assertEquals(",()=", m.get("f1")[0]);
- assertEquals("$b(true)", m.get("f2a")[0]);
- assertEquals("true", m.get("f2b")[0]);
- assertEquals("$n(123)", m.get("f3a")[0]);
- assertEquals("123", m.get("f3b")[0]);
- assertEquals("$s(foo)", m.get("f4")[0]);
-
- s = "f1=v1&=";
- m = p.parseIntoSimpleMap(s);
- assertEquals("v1", m.get("f1")[0]);
- assertEquals("", m.get("")[0]);
-
- s = "f1=v1&f2&f3";
- m = p.parseIntoSimpleMap(s);
- assertEquals("v1", m.get("f1")[0]);
- assertTrue(m.containsKey("f2"));
- assertTrue(m.containsKey("f3"));
- assertNull(m.get("f2"));
- assertNull(m.get("f3"));
- }
-
- //====================================================================================================
- // Test parsing URL-encoded strings with multiple values.
- //====================================================================================================
- @Test
- public void testParseIntoSimpleMapMultiValues() throws Exception {
- UrlEncodingParser p = UrlEncodingParser.DEFAULT;
- Map<String,String[]> m;
-
- String s = "?f1&f1&f2&f2=abc&f2=def&f2";
- m = p.parseIntoSimpleMap(s);
- assertObjectEquals("{f1:null,f2:['abc','def']}", m);
- }
-
- @Test
- public void testEmptyString() throws Exception {
- UrlEncodingParser p = UrlEncodingParser.DEFAULT;
-
- String s = "";
- B b = p.parse(s, B.class);
- assertEquals("f1", b.f1);
- }
-
- public static class B {
- public String f1 = "f1";
- }
-
- //====================================================================================================
- // Test comma-delimited list parameters.
- //====================================================================================================
- @Test
- public void testCommaDelimitedLists() throws Exception {
- UrlEncodingParser p = UrlEncodingParser.DEFAULT;
-
- String s = "?f1=1,2,3&f2=a,b,c&f3=true,false&f4=&f5";
- C c = p.parse(s, C.class);
- assertObjectEquals("{f1:[1,2,3],f2:['a','b','c'],f3:[true,false],f4:[]}", c);
- }
-
- public static class C {
- public int[] f1;
- public String[] f2;
- public boolean[] f3;
- public String[] f4;
- public String[] f5;
- }
-
- //====================================================================================================
- // Test comma-delimited list parameters with special characters.
- //====================================================================================================
- @Test
- public void testCommaDelimitedListsWithSpecialChars() throws Exception {
- UrlEncodingParser p = UrlEncodingParser.DEFAULT;
- String s;
- C1 c;
-
- // In the string below, the ~ character should not be interpreted as an escape.
- s = "?f1=a~b,a~b";
- c = p.parse(s, C1.class);
- assertObjectEquals("{f1:['a~b','a~b']}", c);
-
- s = "?f1=(a~b,a~b)";
- c = p.parse(s, C1.class);
- assertObjectEquals("{f1:['a~b','a~b']}", c);
-
- s = "?f1=((a~b),(a~b))";
- c = p.parse(s, C1.class);
- assertObjectEquals("{f1:['a~b','a~b']}", c);
-
- s = "?f1=($s(a~b),$s(a~b))";
- c = p.parse(s, C1.class);
- assertObjectEquals("{f1:['a~b','a~b']}", c);
-
- s = "?f1=$a($s(a~b),$s(a~b))";
- c = p.parse(s, C1.class);
- assertObjectEquals("{f1:['a~b','a~b']}", c);
-
- s = "?f1=~~,~~";
- c = p.parse(s, C1.class);
- assertObjectEquals("{f1:['~','~']}", c);
-
- s = "?f1=(~~,~~)";
- c = p.parse(s, C1.class);
- assertObjectEquals("{f1:['~','~']}", c);
-
- s = "?f1=(~~~~~~,~~~~~~)";
- c = p.parse(s, C1.class);
- assertObjectEquals("{f1:['~~~','~~~']}", c);
-
- s = "?f1=((~~~~~~),(~~~~~~))";
- c = p.parse(s, C1.class);
- assertObjectEquals("{f1:['~~~','~~~']}", c);
-
- // The ~ should be treated as an escape if followed by any of the following characters: ,()~=
- s = "?f1=~,~(~)~~~=~$,~,~(~)~~~=~$";
- c = p.parse(s, C1.class);
- assertObjectEquals("{f1:[',()~=$',',()~=$']}", c);
-
- s = "?f1=(~,~(~)~~~=~$,~,~(~)~~~=~$)";
- c = p.parse(s, C1.class);
- assertObjectEquals("{f1:[',()~=$',',()~=$']}", c);
-
- s = "?f1=((~,~(~)~~~=~$),(~,~(~)~~~=~$))";
- c = p.parse(s, C1.class);
- assertObjectEquals("{f1:[',()~=$',',()~=$']}", c);
-
- s = "?a~b=a~b";
- ObjectMap m = p.parse(s, ObjectMap.class);
- assertEquals("{'a~b':'a~b'}", m.toString());
-
- s = "?(a~b)=(a~b)";
- m = p.parse(s, ObjectMap.class);
- assertEquals("{'a~b':'a~b'}", m.toString());
-
- s = "?$s(a~b)=$s(a~b)";
- m = p.parse(s, ObjectMap.class);
- assertEquals("{'a~b':'a~b'}", m.toString());
-
- s = "?~~=~~";
- m = p.parse(s, ObjectMap.class);
- assertEquals("{'~':'~'}", m.toString());
-
- s = "?(~~)=(~~)";
- m = p.parse(s, ObjectMap.class);
- assertEquals("{'~':'~'}", m.toString());
-
- s = "?~~~~~~=~~~~~~";
- m = p.parse(s, ObjectMap.class);
- assertEquals("{'~~~':'~~~'}", m.toString());
-
- s = "?(~~~~~~)=(~~~~~~)";
- m = p.parse(s, ObjectMap.class);
- assertEquals("{'~~~':'~~~'}", m.toString());
-
- s = "?$s(~~~~~~)=$s(~~~~~~)";
- m = p.parse(s, ObjectMap.class);
- assertEquals("{'~~~':'~~~'}", m.toString());
-
- s = "?~,~(~)~~~=~$=~,~(~)~~~=~$";
- m = p.parse(s, ObjectMap.class);
- assertEquals("{',()~=$':',()~=$'}", m.toString());
-
- s = "?(~,~(~)~~~=~$)=(~,~(~)~~~=~$)";
- m = p.parse(s, ObjectMap.class);
- assertEquals("{',()~=$':',()~=$'}", m.toString());
-
- s = "?$s(~,~(~)~~~=~$)=$s(~,~(~)~~~=~$)";
- m = p.parse(s, ObjectMap.class);
- assertEquals("{',()~=$':',()~=$'}", m.toString());
-
- s = "?%7E%2C%7E%28%7E%29%7E%7E%7E%3D%7E%24=%7E%2C%7E%28%7E%29%7E%7E%7E%3D%7E%24";
- m = p.parse(s, ObjectMap.class);
- assertEquals("{',()~=$':',()~=$'}", m.toString());
-
- s = "?(%7E%2C%7E%28%7E%29%7E%7E%7E%3D%7E%24)=(%7E%2C%7E%28%7E%29%7E%7E%7E%3D%7E%24)";
- m = p.parse(s, ObjectMap.class);
- assertEquals("{',()~=$':',()~=$'}", m.toString());
-
- s = "?$s(%7E%2C%7E%28%7E%29%7E%7E%7E%3D%7E%24)=$s(%7E%2C%7E%28%7E%29%7E%7E%7E%3D%7E%24)";
- m = p.parse(s, ObjectMap.class);
- assertEquals("{',()~=$':',()~=$'}", m.toString());
- }
-
- public static class C1 {
- public String[] f1;
- }
-
- //====================================================================================================
- // Test comma-delimited list parameters.
- //====================================================================================================
- @Test
- public void testWhitespace() throws Exception {
- UrlEncodingParser p = UrlEncodingParser.DEFAULT_WS_AWARE;
- String s;
- ObjectMap m;
-
- s = "?f1=foo\n\t&f2=bar\n\t";
- m = p.parse(s, ObjectMap.class);
- assertEquals("{f1:'foo',f2:'bar'}", m.toString());
-
- s = "?f1=(\n\t)&f2=(\n\t)";
- m = p.parse(s, ObjectMap.class);
- assertEquals("\n\t", m.getString("f1"));
- assertEquals("\n\t", m.getString("f2"));
-
- s = "?f1=(\n\t)\n\t&f2=(\n\t)\n\t";
- m = p.parse(s, ObjectMap.class);
- assertEquals("\n\t", m.getString("f1"));
- assertEquals("\n\t", m.getString("f2"));
- assertEquals("{f1:'\\n\\t',f2:'\\n\\t'}", m.toString()); // Note that JsonSerializer escapes newlines and tabs.
-
- s = "?f1=$s(\n\t)\n\t&f2=$s(\n\t)\n\t";
- m = p.parse(s, ObjectMap.class);
- assertEquals("\n\t", m.getString("f1"));
- assertEquals("\n\t", m.getString("f2"));
- assertEquals("{f1:'\\n\\t',f2:'\\n\\t'}", m.toString()); // Note that JsonSerializer escapes newlines and tabs.
-
- s = "?f1=$o(\n\tf1a=a,\n\tf1b=b\n\t)\n\t&f2=$o(\n\tf2a=a,\n\tf2b=b\n\t)\n\t";
- m = p.parse(s, ObjectMap.class);
- assertEquals("{f1:{f1a:'a',f1b:'b'},f2:{f2a:'a',f2b:'b'}}", m.toString()); // Note that JsonSerializer escapes newlines and tabs.
- D d = p.parse(s, D.class);
- assertObjectEquals("{f1:{f1a:'a',f1b:'b'},f2:{f2a:'a',f2b:'b'}}", d); // Note that JsonSerializer escapes newlines and tabs.
-
- s = "?f1=$o(\n\tf1a=(\n\t),\n\tf1b=(\n\t)\n\t)\n\t&f2=$o(\n\tf2a=(\n\t),\n\tf2b=(\n\t)\n\t)\n\t";
- m = p.parse(s, ObjectMap.class);
- assertEquals("{f1:{f1a:'\\n\\t',f1b:'\\n\\t'},f2:{f2a:'\\n\\t',f2b:'\\n\\t'}}", m.toString()); // Note that JsonSerializer escapes newlines and tabs.
- d = p.parse(s, D.class);
- assertObjectEquals("{f1:{f1a:'\\n\\t',f1b:'\\n\\t'},f2:{f2a:'\\n\\t',f2b:'\\n\\t'}}", d); // Note that JsonSerializer escapes newlines and tabs.
-
- s = "?f1=$a(\n\tfoo,\n\tbar\n\t)\n\t&f2=$a(\n\tfoo,\n\tbar\n\t)\n\t";
- m = p.parse(s, ObjectMap.class);
- assertEquals("{f1:['foo','bar'],f2:['foo','bar']}", m.toString()); // Note that JsonSerializer escapes newlines and tabs.
-
- s = "f1=a,\n\tb,\n\tc\n\t&f2=1,\n\t2,\n\t3\n\t&f3=true,\n\tfalse\n\t";
- E e = p.parse(s, E.class);
- assertObjectEquals("{f1:['a','b','c'],f2:[1,2,3],f3:[true,false]}", e);
-
- s = "f1=a%2C%0D%0Ab%2C%0D%0Ac%0D%0A&f2=1%2C%0D%0A2%2C%0D%0A3%0D%0A&f3=true%2C%0D%0Afalse%0D%0A";
- e = p.parse(s, E.class);
- assertObjectEquals("{f1:['a','b','c'],f2:[1,2,3],f3:[true,false]}", e);
- }
-
- public static class D {
- public D1 f1;
- public D2 f2;
- }
-
- public static class D1 {
- public String f1a, f1b;
- }
-
- public static class D2 {
- public String f2a, f2b;
- }
-
- public static class E {
- public String[] f1;
- public int[] f2;
- public boolean[] f3;
- }
-
- //====================================================================================================
- // Multi-part parameters on beans via URLENC_expandedParams
- //====================================================================================================
- @Test
- public void testMultiPartParametersOnBeansViaProperty() throws Exception {
- UrlEncodingParser p;
- String in;
-
- p = UrlEncodingParser.DEFAULT.clone().setProperty(UrlEncodingContext.URLENC_expandedParams, true);
- in = ""
- + "f01=a&f01=b"
- + "&f02=c&f02=d"
- + "&f03=1&f03=2"
- + "&f04=3&f04=4"
- + "&f05=(e,f)&f05=(g,h)"
- + "&f06=(i,j)&f06=(k,l)"
- + "&f07=(a=a,b=1,c=true)&f07=(a=b,b=2,c=false)"
- + "&f08=(a=a,b=1,c=true)&f08=(a=b,b=2,c=false)"
- + "&f09=((a=a,b=1,c=true))&f09=((a=b,b=2,c=false))"
- + "&f10=((a=a,b=1,c=true))&f10=((a=b,b=2,c=false))"
- + "&f11=a&f11=b"
- + "&f12=c&f12=d"
- + "&f13=1&f13=2"
- + "&f14=3&f14=4"
- + "&f15=(e,f)&f15=(g,h)"
- + "&f16=(i,j)&f16=(k,l)"
- + "&f17=(a=a,b=1,c=true)&f17=(a=b,b=2,c=false)"
- + "&f18=(a=a,b=1,c=true)&f18=(a=b,b=2,c=false)"
- + "&f19=((a=a,b=1,c=true))&f19=((a=b,b=2,c=false))"
- + "&f20=((a=a,b=1,c=true))&f20=((a=b,b=2,c=false))";
-
- DTOs.B t = p.parse(in, DTOs.B.class);
- String e = "{"
- + "f01:['a','b'],"
- + "f02:['c','d'],"
- + "f03:[1,2],"
- + "f04:[3,4],"
- + "f05:[['e','f'],['g','h']],"
- + "f06:[['i','j'],['k','l']],"
- + "f07:[{a:'a',b:1,c:true},{a:'b',b:2,c:false}],"
- + "f08:[{a:'a',b:1,c:true},{a:'b',b:2,c:false}],"
- + "f09:[[{a:'a',b:1,c:true}],[{a:'b',b:2,c:false}]],"
- + "f10:[[{a:'a',b:1,c:true}],[{a:'b',b:2,c:false}]],"
- + "f11:['a','b'],"
- + "f12:['c','d'],"
- + "f13:[1,2],"
- + "f14:[3,4],"
- + "f15:[['e','f'],['g','h']],"
- + "f16:[['i','j'],['k','l']],"
- + "f17:[{a:'a',b:1,c:true},{a:'b',b:2,c:false}],"
- + "f18:[{a:'a',b:1,c:true},{a:'b',b:2,c:false}],"
- + "f19:[[{a:'a',b:1,c:true}],[{a:'b',b:2,c:false}]],"
- + "f20:[[{a:'a',b:1,c:true}],[{a:'b',b:2,c:false}]]"
- +"}";
- assertSortedObjectEquals(e, t);
- }
-
- //====================================================================================================
- // Multi-part parameters on beans via @UrlEncoding.expandedParams on class
- //====================================================================================================
- @Test
- public void testMultiPartParametersOnBeansViaAnnotationOnClass() throws Exception {
- UrlEncodingParser p;
- String in;
- p = UrlEncodingParser.DEFAULT;
- in = ""
- + "f01=a&f01=b"
- + "&f02=c&f02=d"
- + "&f03=1&f03=2"
- + "&f04=3&f04=4"
- + "&f05=(e,f)&f05=(g,h)"
- + "&f06=(i,j)&f06=(k,l)"
- + "&f07=(a=a,b=1,c=true)&f07=(a=b,b=2,c=false)"
- + "&f08=(a=a,b=1,c=true)&f08=(a=b,b=2,c=false)"
- + "&f09=((a=a,b=1,c=true))&f09=((a=b,b=2,c=false))"
- + "&f10=((a=a,b=1,c=true))&f10=((a=b,b=2,c=false))"
- + "&f11=a&f11=b"
- + "&f12=c&f12=d"
- + "&f13=1&f13=2"
- + "&f14=3&f14=4"
- + "&f15=(e,f)&f15=(g,h)"
- + "&f16=(i,j)&f16=(k,l)"
- + "&f17=(a=a,b=1,c=true)&f17=(a=b,b=2,c=false)"
- + "&f18=(a=a,b=1,c=true)&f18=(a=b,b=2,c=false)"
- + "&f19=((a=a,b=1,c=true))&f19=((a=b,b=2,c=false))"
- + "&f20=((a=a,b=1,c=true))&f20=((a=b,b=2,c=false))";
-
- DTOs.C t = p.parse(in, DTOs.C.class);
- String e = "{"
- + "f01:['a','b'],"
- + "f02:['c','d'],"
- + "f03:[1,2],"
- + "f04:[3,4],"
- + "f05:[['e','f'],['g','h']],"
- + "f06:[['i','j'],['k','l']],"
- + "f07:[{a:'a',b:1,c:true},{a:'b',b:2,c:false}],"
- + "f08:[{a:'a',b:1,c:true},{a:'b',b:2,c:false}],"
- + "f09:[[{a:'a',b:1,c:true}],[{a:'b',b:2,c:false}]],"
- + "f10:[[{a:'a',b:1,c:true}],[{a:'b',b:2,c:false}]],"
- + "f11:['a','b'],"
- + "f12:['c','d'],"
- + "f13:[1,2],"
- + "f14:[3,4],"
- + "f15:[['e','f'],['g','h']],"
- + "f16:[['i','j'],['k','l']],"
- + "f17:[{a:'a',b:1,c:true},{a:'b',b:2,c:false}],"
- + "f18:[{a:'a',b:1,c:true},{a:'b',b:2,c:false}],"
- + "f19:[[{a:'a',b:1,c:true}],[{a:'b',b:2,c:false}]],"
- + "f20:[[{a:'a',b:1,c:true}],[{a:'b',b:2,c:false}]]"
- +"}";
- assertSortedObjectEquals(e, t);
- }
-}
\ No newline at end of file
http://git-wip-us.apache.org/repos/asf/incubator-juneau/blob/df0f8689/org.apache.juneau/src/test/java/org/apache/juneau/urlencoding/CT_UrlEncodingSerializer.java
----------------------------------------------------------------------
diff --git a/org.apache.juneau/src/test/java/org/apache/juneau/urlencoding/CT_UrlEncodingSerializer.java b/org.apache.juneau/src/test/java/org/apache/juneau/urlencoding/CT_UrlEncodingSerializer.java
deleted file mode 100755
index 33d6ed1..0000000
--- a/org.apache.juneau/src/test/java/org/apache/juneau/urlencoding/CT_UrlEncodingSerializer.java
+++ /dev/null
@@ -1,497 +0,0 @@
-/***************************************************************************************************************************
- * Licensed to the Apache Software Foundation (ASF) under one or more contributor license agreements. See the NOTICE file
- * distributed with this work for additional information regarding copyright ownership. The ASF licenses this file
- * to you under the Apache License, Version 2.0 (the "License"); you may not use this file except in compliance
- * with the License. You may obtain a copy of the License at
- *
- * http://www.apache.org/licenses/LICENSE-2.0
- *
- * Unless required by applicable law or agreed to in writing, software distributed under the License is distributed on an
- * "AS IS" BASIS, WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. See the License for the
- * specific language governing permissions and limitations under the License.
- ***************************************************************************************************************************/
-package org.apache.juneau.urlencoding;
-
-import static org.junit.Assert.*;
-
-import java.util.*;
-
-import org.apache.juneau.*;
-import org.junit.*;
-
-public class CT_UrlEncodingSerializer {
-
- static UrlEncodingSerializer s = UrlEncodingSerializer.DEFAULT;
- static UrlEncodingSerializer ss = UrlEncodingSerializer.DEFAULT_SIMPLE;
- static UrlEncodingSerializer sr = UrlEncodingSerializer.DEFAULT_READABLE;
-
-
- //====================================================================================================
- // Basic test
- //====================================================================================================
- @Test
- public void testBasic() throws Exception {
-
- Object t;
-
- // Simple string
- // Top level
- t = "a";
- assertEquals("_value=a", s.serialize(t));
-
- // 2nd level
- t = new ObjectMap("{a:'a'}");
- assertEquals("a=a", s.serialize(t));
- assertEquals("a=a", ss.serialize(t));
- assertEquals("a=a", sr.serialize(t));
-
- // Simple map
- // Top level
- t = new ObjectMap("{a:'b',c:123,d:false,e:true,f:null}");
- assertEquals("a=b&c=$n(123)&d=$b(false)&e=$b(true)&f=%00", s.serialize(t));
- assertEquals("a=b&c=123&d=false&e=true&f=%00", ss.serialize(t));
- assertEquals("a=b\n&c=$n(123)\n&d=$b(false)\n&e=$b(true)\n&f=%00", sr.serialize(t));
-
- // 2nd level
- t = new ObjectMap("{a:{a:'b',c:123,d:false,e:true,f:null}}");
- assertEquals("a=$o(a=b,c=$n(123),d=$b(false),e=$b(true),f=%00)", s.serialize(t));
- assertEquals("a=(a=b,c=123,d=false,e=true,f=%00)", ss.serialize(t));
- assertEquals("a=$o(\n\ta=b,\n\tc=$n(123),\n\td=$b(false),\n\te=$b(true),\n\tf=%00\n)", sr.serialize(t));
-
- // Simple map with primitives as literals
- t = new ObjectMap("{a:'b',c:'123',d:'false',e:'true',f:'null'}");
- assertEquals("a=b&c=123&d=false&e=true&f=null", s.serialize(t));
- assertEquals("a=b&c=123&d=false&e=true&f=null", ss.serialize(t));
- assertEquals("a=b\n&c=123\n&d=false\n&e=true\n&f=null", sr.serialize(t));
-
- // null
- // Note that serializeParams is always encoded.
- // Top level
- t = null;
- assertEquals("_value=%00", s.serialize(t));
- assertEquals("_value=%00", ss.serialize(t));
- assertEquals("_value=%00", sr.serialize(t));
-
- // 2nd level
- t = new ObjectMap("{null:null}");
- assertEquals("%00=%00", s.serialize(t));
- assertEquals("%00=%00", ss.serialize(t));
- assertEquals("%00=%00", sr.serialize(t));
-
- // 3rd level
- t = new ObjectMap("{null:{null:null}}");
- assertEquals("%00=$o(%00=%00)", s.serialize(t));
- assertEquals("%00=(%00=%00)", ss.serialize(t));
- assertEquals("%00=$o(\n\t%00=%00\n)", sr.serialize(t));
-
- // Empty array
- // Top level
- t = new String[0];
- assertEquals("_value=$a()", s.serialize(t));
- assertEquals("_value=()", ss.serialize(t));
- assertEquals("_value=$a()", sr.serialize(t));
-
- // 2nd level in map
- t = new ObjectMap("{x:[]}");
- assertEquals("x=$a()", s.serialize(t));
- assertEquals("x=()", ss.serialize(t));
- assertEquals("x=$a()", sr.serialize(t));
-
- // Empty 2 dimensional array
- t = new String[1][0];
- assertEquals("_value=$a($a())", s.serialize(t));
- assertEquals("_value=(())", ss.serialize(t));
- assertEquals("_value=$a(\n\t$a()\n)", sr.serialize(t));
-
- // Array containing empty string
- // Top level
- t = new String[]{""};
- assertEquals("_value=$a(())", s.serialize(t));
- assertEquals("_value=(())", ss.serialize(t));
- assertEquals("_value=$a(\n\t()\n)", sr.serialize(t));
-
- // 2nd level
- t = new ObjectMap("{x:['']}");
- assertEquals("x=$a(())", s.serialize(t));
- assertEquals("x=(())", ss.serialize(t));
- assertEquals("x=$a(\n\t()\n)", sr.serialize(t));
-
- // Array containing 3 empty strings
- t = new String[]{"","",""};
- assertEquals("_value=$a(,,)", s.serialize(t));
- assertEquals("_value=(,,)", ss.serialize(t));
- assertEquals("_value=$a(\n\t(),\n\t(),\n\t()\n)", sr.serialize(t));
-
- // String containing \u0000
- // Top level
- t = "\u0000";
- assertEquals("_value=(%00)", s.serialize(t));
- assertEquals("_value=(%00)", ss.serialize(t));
- assertEquals("_value=(%00)", sr.serialize(t));
-
- // 2nd level
- t = new ObjectMap("{'\u0000':'\u0000'}");
- assertEquals("(%00)=(%00)", s.serialize(t));
- assertEquals("(%00)=(%00)", ss.serialize(t));
- assertEquals("(%00)=(%00)", sr.serialize(t));
-
- // Boolean
- // Top level
- t = false;
- assertEquals("_value=$b(false)", s.serialize(t));
- assertEquals("_value=false", ss.serialize(t));
- assertEquals("_value=$b(false)", sr.serialize(t));
-
- // 2nd level
- t = new ObjectMap("{x:false}");
- assertEquals("x=$b(false)", s.serialize(t));
- assertEquals("x=false", ss.serialize(t));
- assertEquals("x=$b(false)", sr.serialize(t));
-
- // Number
- // Top level
- t = 123;
- assertEquals("_value=$n(123)", s.serialize(t));
- assertEquals("_value=123", ss.serialize(t));
- assertEquals("_value=$n(123)", sr.serialize(t));
-
- // 2nd level
- t = new ObjectMap("{x:123}");
- assertEquals("x=$n(123)", s.serialize(t));
- assertEquals("x=123", ss.serialize(t));
- assertEquals("x=$n(123)", sr.serialize(t));
-
- // Unencoded chars
- // Top level
- t = "x;/?:@-_.!*'";
- assertEquals("_value=x;/?:@-_.!*'", s.serialize(t));
- assertEquals("_value=x;/?:@-_.!*'", ss.serialize(t));
- assertEquals("_value=x;/?:@-_.!*'", sr.serialize(t));
-
- // 2nd level
- t = new ObjectMap("{x:'x;/?:@-_.!*\\''}");
- assertEquals("x=x;/?:@-_.!*'", s.serialize(t));
- assertEquals("x=x;/?:@-_.!*'", ss.serialize(t));
- assertEquals("x=x;/?:@-_.!*'", sr.serialize(t));
-
- // Encoded chars
- // Top level
- t = "x{}|\\^[]`<>#%\"&+";
- assertEquals("_value=x%7B%7D%7C%5C%5E%5B%5D%60%3C%3E%23%25%22%26%2B", s.serialize(t));
- assertEquals("_value=x%7B%7D%7C%5C%5E%5B%5D%60%3C%3E%23%25%22%26%2B", ss.serialize(t));
- assertEquals("_value=x%7B%7D%7C%5C%5E%5B%5D%60%3C%3E%23%25%22%26%2B", sr.serialize(t));
-
- // 2nd level
- t = new ObjectMap("{'x{}|\\\\^[]`<>#%\"&+':'x{}|\\\\^[]`<>#%\"&+'}");
- assertEquals("x%7B%7D%7C%5C%5E%5B%5D%60%3C%3E%23%25%22%26%2B=x%7B%7D%7C%5C%5E%5B%5D%60%3C%3E%23%25%22%26%2B", s.serialize(t));
- assertEquals("x%7B%7D%7C%5C%5E%5B%5D%60%3C%3E%23%25%22%26%2B=x%7B%7D%7C%5C%5E%5B%5D%60%3C%3E%23%25%22%26%2B", ss.serialize(t));
- assertEquals("x%7B%7D%7C%5C%5E%5B%5D%60%3C%3E%23%25%22%26%2B=x%7B%7D%7C%5C%5E%5B%5D%60%3C%3E%23%25%22%26%2B", sr.serialize(t));
-
- // Escaped chars
- // Top level
- t = "x$,()~";
- assertEquals("_value=x$,()~", s.serialize(t));
- assertEquals("_value=x$,()~", ss.serialize(t));
- assertEquals("_value=x$,()~", sr.serialize(t));
-
- // 2nd level
- t = new ObjectMap("{'x$,()~':'x$,()~'}");
- assertEquals("x$,()~=x$,()~", s.serialize(t));
- assertEquals("x$,()~=x$,()~", ss.serialize(t));
- assertEquals("x$,()~=x$,()~", sr.serialize(t));
-
- // 3rd level
- t = new ObjectMap("{'x$,()~':{'x$,()~':'x$,()~'}}");
- assertEquals("x$,()~=$o(x$~,~(~)~~=x$~,~(~)~~)", s.serialize(t));
- assertEquals("x$,()~=(x$~,~(~)~~=x$~,~(~)~~)", ss.serialize(t));
- assertEquals("x$,()~=$o(\n\tx$~,~(~)~~=x$~,~(~)~~\n)", sr.serialize(t));
-
- // Equals sign
- // Gets encoded at top level, and encoded+escaped at 2nd level.
- // Top level
- t = "x=";
- assertEquals("_value=x=", s.serialize(t));
- assertEquals("_value=x=", ss.serialize(t));
- assertEquals("_value=x=", sr.serialize(t));
-
- // 2nd level
- t = new ObjectMap("{'x=':'x='}");
- assertEquals("x%3D=x=", s.serialize(t));
- assertEquals("x%3D=x=", ss.serialize(t));
- assertEquals("x%3D=x=", sr.serialize(t));
-
- // 3rd level
- t = new ObjectMap("{'x=':{'x=':'x='}}");
- assertEquals("x%3D=$o(x~==x~=)", s.serialize(t));
- assertEquals("x%3D=(x~==x~=)", ss.serialize(t));
- assertEquals("x%3D=$o(\n\tx~==x~=\n)", sr.serialize(t));
-
- // String starting with parenthesis
- // Top level
- t = "()";
- assertEquals("_value=(~(~))", s.serialize(t));
- assertEquals("_value=(~(~))", ss.serialize(t));
- assertEquals("_value=(~(~))", sr.serialize(t));
-
- // 2nd level
- t = new ObjectMap("{'()':'()'}");
- assertEquals("(~(~))=(~(~))", s.serialize(t));
- assertEquals("(~(~))=(~(~))", ss.serialize(t));
- assertEquals("(~(~))=(~(~))", sr.serialize(t));
-
- // String starting with $
- // Top level
- t = "$a";
- assertEquals("_value=($a)", s.serialize(t));
- assertEquals("_value=($a)", ss.serialize(t));
- assertEquals("_value=($a)", sr.serialize(t));
-
- // 2nd level
- t = new ObjectMap("{$a:'$a'}");
- assertEquals("($a)=($a)", s.serialize(t));
- assertEquals("($a)=($a)", ss.serialize(t));
- assertEquals("($a)=($a)", sr.serialize(t));
-
- // Blank string
- // Top level
- t = "";
- assertEquals("_value=", s.serialize(t));
- assertEquals("_value=", ss.serialize(t));
- assertEquals("_value=", sr.serialize(t));
-
- // 2nd level
- t = new ObjectMap("{'':''}");
- assertEquals("=", s.serialize(t));
- assertEquals("=", ss.serialize(t));
- assertEquals("=", sr.serialize(t));
-
- // 3rd level
- t = new ObjectMap("{'':{'':''}}");
- assertEquals("=$o(=)", s.serialize(t));
- assertEquals("=(=)", ss.serialize(t));
- assertEquals("=$o(\n\t()=()\n)", sr.serialize(t));
-
- // Newline character
- // Top level
- t = "\n";
- assertEquals("_value=%0A", s.serialize(t));
- assertEquals("_value=%0A", ss.serialize(t));
- assertEquals("_value=(%0A)", sr.serialize(t));
-
- // 2nd level
- t = new ObjectMap("{'\n':'\n'}");
- assertEquals("%0A=%0A", s.serialize(t));
- assertEquals("%0A=%0A", ss.serialize(t));
- assertEquals("(%0A)=(%0A)", sr.serialize(t));
-
- // 3rd level
- t = new ObjectMap("{'\n':{'\n':'\n'}}");
- assertEquals("%0A=$o(%0A=%0A)", s.serialize(t));
- assertEquals("%0A=(%0A=%0A)", ss.serialize(t));
- assertEquals("(%0A)=$o(\n\t(%0A)=(%0A)\n)", sr.serialize(t));
- }
-
- //====================================================================================================
- // Unicode characters test
- //====================================================================================================
- @Test
- public void testUnicodeChars() throws Exception {
- Object t;
-
- // 2-byte UTF-8 character
- // Top level
- t = "�";
- assertEquals("_value=%C2%A2", s.serialize(t));
- assertEquals("_value=%C2%A2", ss.serialize(t));
- assertEquals("_value=%C2%A2", sr.serialize(t));
-
- // 2nd level
- t = new ObjectMap("{'�':'�'}");
- assertEquals("%C2%A2=%C2%A2", s.serialize(t));
- assertEquals("%C2%A2=%C2%A2", ss.serialize(t));
- assertEquals("%C2%A2=%C2%A2", sr.serialize(t));
-
- // 3rd level
- t = new ObjectMap("{'�':{'�':'�'}}");
- assertEquals("%C2%A2=$o(%C2%A2=%C2%A2)", s.serialize(t));
- assertEquals("%C2%A2=(%C2%A2=%C2%A2)", ss.serialize(t));
- assertEquals("%C2%A2=$o(\n\t%C2%A2=%C2%A2\n)", sr.serialize(t));
-
- // 3-byte UTF-8 character
- // Top level
- t = "\u20ac";
- assertEquals("_value=%E2%82%AC", s.serialize(t));
- assertEquals("_value=%E2%82%AC", ss.serialize(t));
- assertEquals("_value=%E2%82%AC", sr.serialize(t));
-
- // 2nd level
- t = new ObjectMap("{'\u20ac':'\u20ac'}");
- assertEquals("%E2%82%AC=%E2%82%AC", s.serialize(t));
- assertEquals("%E2%82%AC=%E2%82%AC", ss.serialize(t));
- assertEquals("%E2%82%AC=%E2%82%AC", sr.serialize(t));
-
- // 3rd level
- t = new ObjectMap("{'\u20ac':{'\u20ac':'\u20ac'}}");
- assertEquals("%E2%82%AC=$o(%E2%82%AC=%E2%82%AC)", s.serialize(t));
- assertEquals("%E2%82%AC=(%E2%82%AC=%E2%82%AC)", ss.serialize(t));
- assertEquals("%E2%82%AC=$o(\n\t%E2%82%AC=%E2%82%AC\n)", sr.serialize(t));
-
- // 4-byte UTF-8 character
- // Top level
- t = "\U00024b62";
- assertEquals("_value=%F0%A4%AD%A2", s.serialize(t));
- assertEquals("_value=%F0%A4%AD%A2", ss.serialize(t));
- assertEquals("_value=%F0%A4%AD%A2", sr.serialize(t));
-
- // 2nd level
- t = new ObjectMap("{'\U00024b62':'\U00024b62'}");
- assertEquals("%F0%A4%AD%A2=%F0%A4%AD%A2", s.serialize(t));
- assertEquals("%F0%A4%AD%A2=%F0%A4%AD%A2", ss.serialize(t));
- assertEquals("%F0%A4%AD%A2=%F0%A4%AD%A2", sr.serialize(t));
-
- // 3rd level
- t = new ObjectMap("{'\U00024b62':{'\U00024b62':'\U00024b62'}}");
- assertEquals("%F0%A4%AD%A2=$o(%F0%A4%AD%A2=%F0%A4%AD%A2)", s.serialize(t));
- assertEquals("%F0%A4%AD%A2=(%F0%A4%AD%A2=%F0%A4%AD%A2)", ss.serialize(t));
- assertEquals("%F0%A4%AD%A2=$o(\n\t%F0%A4%AD%A2=%F0%A4%AD%A2\n)", sr.serialize(t));
- }
-
- //====================================================================================================
- // Multi-part parameters on beans via URLENC_expandedParams
- //====================================================================================================
- @Test
- @SuppressWarnings("hiding")
- public void testMultiPartParametersOnBeansViaProperty() throws Exception {
- UrlEncodingSerializer s;
- DTOs.B t = DTOs.B.create();
- String r;
-
- s = UrlEncodingSerializer.DEFAULT_SIMPLE;
- r = s.serialize(t);
- String e = ""
- + "f01=(a,b)"
- + "&f02=(c,d)"
- + "&f03=(1,2)"
- + "&f04=(3,4)"
- + "&f05=((e,f),(g,h))"
- + "&f06=((i,j),(k,l))"
- + "&f07=((a=a,b=1,c=true),(a=a,b=1,c=true))"
- + "&f08=((a=a,b=1,c=true),(a=a,b=1,c=true))"
- + "&f09=(((a=a,b=1,c=true)),((a=a,b=1,c=true)))"
- + "&f10=(((a=a,b=1,c=true)),((a=a,b=1,c=true)))"
- + "&f11=(a,b)"
- + "&f12=(c,d)"
- + "&f13=(1,2)"
- + "&f14=(3,4)"
- + "&f15=((e,f),(g,h))"
- + "&f16=((i,j),(k,l))"
- + "&f17=((a=a,b=1,c=true),(a=a,b=1,c=true))"
- + "&f18=((a=a,b=1,c=true),(a=a,b=1,c=true))"
- + "&f19=(((a=a,b=1,c=true)),((a=a,b=1,c=true)))"
- + "&f20=(((a=a,b=1,c=true)),((a=a,b=1,c=true)))";
- assertEquals(e, r);
-
- s = UrlEncodingSerializer.DEFAULT_SIMPLE.clone().setProperty(UrlEncodingContext.URLENC_expandedParams, true);
- r = s.serialize(t);
- e = ""
- + "f01=a&f01=b"
- + "&f02=c&f02=d"
- + "&f03=1&f03=2"
- + "&f04=3&f04=4"
- + "&f05=(e,f)&f05=(g,h)"
- + "&f06=(i,j)&f06=(k,l)"
- + "&f07=(a=a,b=1,c=true)&f07=(a=a,b=1,c=true)"
- + "&f08=(a=a,b=1,c=true)&f08=(a=a,b=1,c=true)"
- + "&f09=((a=a,b=1,c=true))&f09=((a=a,b=1,c=true))"
- + "&f10=((a=a,b=1,c=true))&f10=((a=a,b=1,c=true))"
- + "&f11=a&f11=b"
- + "&f12=c&f12=d"
- + "&f13=1&f13=2"
- + "&f14=3&f14=4"
- + "&f15=(e,f)&f15=(g,h)"
- + "&f16=(i,j)&f16=(k,l)"
- + "&f17=(a=a,b=1,c=true)&f17=(a=a,b=1,c=true)"
- + "&f18=(a=a,b=1,c=true)&f18=(a=a,b=1,c=true)"
- + "&f19=((a=a,b=1,c=true))&f19=((a=a,b=1,c=true))"
- + "&f20=((a=a,b=1,c=true))&f20=((a=a,b=1,c=true))";
- assertEquals(e, r);
- }
-
-
- //====================================================================================================
- // Multi-part parameters on beans via @UrlEncoding.expandedParams on class
- //====================================================================================================
- @Test
- @SuppressWarnings("hiding")
- public void testMultiPartParametersOnBeansViaAnnotationOnClass() throws Exception {
- UrlEncodingSerializer s;
- DTOs.C t = DTOs.C.create();
- String r;
-
- s = UrlEncodingSerializer.DEFAULT_SIMPLE;
- r = s.serialize(t);
- String e = ""
- + "f01=a&f01=b"
- + "&f02=c&f02=d"
- + "&f03=1&f03=2"
- + "&f04=3&f04=4"
- + "&f05=(e,f)&f05=(g,h)"
- + "&f06=(i,j)&f06=(k,l)"
- + "&f07=(a=a,b=1,c=true)&f07=(a=a,b=1,c=true)"
- + "&f08=(a=a,b=1,c=true)&f08=(a=a,b=1,c=true)"
- + "&f09=((a=a,b=1,c=true))&f09=((a=a,b=1,c=true))"
- + "&f10=((a=a,b=1,c=true))&f10=((a=a,b=1,c=true))"
- + "&f11=a&f11=b"
- + "&f12=c&f12=d"
- + "&f13=1&f13=2"
- + "&f14=3&f14=4"
- + "&f15=(e,f)&f15=(g,h)"
- + "&f16=(i,j)&f16=(k,l)"
- + "&f17=(a=a,b=1,c=true)&f17=(a=a,b=1,c=true)"
- + "&f18=(a=a,b=1,c=true)&f18=(a=a,b=1,c=true)"
- + "&f19=((a=a,b=1,c=true))&f19=((a=a,b=1,c=true))"
- + "&f20=((a=a,b=1,c=true))&f20=((a=a,b=1,c=true))";
- assertEquals(e, r);
-
- s = UrlEncodingSerializer.DEFAULT_SIMPLE.clone().setProperty(UrlEncodingContext.URLENC_expandedParams, true);
- r = s.serialize(t);
- e = ""
- + "f01=a&f01=b"
- + "&f02=c&f02=d"
- + "&f03=1&f03=2"
- + "&f04=3&f04=4"
- + "&f05=(e,f)&f05=(g,h)"
- + "&f06=(i,j)&f06=(k,l)"
- + "&f07=(a=a,b=1,c=true)&f07=(a=a,b=1,c=true)"
- + "&f08=(a=a,b=1,c=true)&f08=(a=a,b=1,c=true)"
- + "&f09=((a=a,b=1,c=true))&f09=((a=a,b=1,c=true))"
- + "&f10=((a=a,b=1,c=true))&f10=((a=a,b=1,c=true))"
- + "&f11=a&f11=b"
- + "&f12=c&f12=d"
- + "&f13=1&f13=2"
- + "&f14=3&f14=4"
- + "&f15=(e,f)&f15=(g,h)"
- + "&f16=(i,j)&f16=(k,l)"
- + "&f17=(a=a,b=1,c=true)&f17=(a=a,b=1,c=true)"
- + "&f18=(a=a,b=1,c=true)&f18=(a=a,b=1,c=true)"
- + "&f19=((a=a,b=1,c=true))&f19=((a=a,b=1,c=true))"
- + "&f20=((a=a,b=1,c=true))&f20=((a=a,b=1,c=true))";
- assertEquals(e, r);
- }
-
- @Test
- @SuppressWarnings("hiding")
- public void testMultiPartParametersOnMapOfStringArrays() throws Exception {
- UrlEncodingSerializer s;
- String r;
-
- Map<String,String[]> t = new LinkedHashMap<String,String[]>();
- t.put("f1", new String[]{"bar"});
- t.put("f2", new String[]{"bar","baz"});
- t.put("f3", new String[]{});
- s = UrlEncodingSerializer.DEFAULT_SIMPLE_EXPANDED;
- r = s.serialize(t);
- String e = "f1=bar&f2=bar&f2=baz";
- assertEquals(e, r);
- }
-}
\ No newline at end of file
http://git-wip-us.apache.org/repos/asf/incubator-juneau/blob/df0f8689/org.apache.juneau/src/test/java/org/apache/juneau/urlencoding/CommonParser_UonTest.java
----------------------------------------------------------------------
diff --git a/org.apache.juneau/src/test/java/org/apache/juneau/urlencoding/CommonParser_UonTest.java b/org.apache.juneau/src/test/java/org/apache/juneau/urlencoding/CommonParser_UonTest.java
new file mode 100755
index 0000000..b84aca9
--- /dev/null
+++ b/org.apache.juneau/src/test/java/org/apache/juneau/urlencoding/CommonParser_UonTest.java
@@ -0,0 +1,168 @@
+/***************************************************************************************************************************
+ * Licensed to the Apache Software Foundation (ASF) under one or more contributor license agreements. See the NOTICE file
+ * distributed with this work for additional information regarding copyright ownership. The ASF licenses this file
+ * to you under the Apache License, Version 2.0 (the "License"); you may not use this file except in compliance
+ * with the License. You may obtain a copy of the License at
+ *
+ * http://www.apache.org/licenses/LICENSE-2.0
+ *
+ * Unless required by applicable law or agreed to in writing, software distributed under the License is distributed on an
+ * "AS IS" BASIS, WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. See the License for the
+ * specific language governing permissions and limitations under the License.
+ ***************************************************************************************************************************/
+package org.apache.juneau.urlencoding;
+
+import static org.apache.juneau.BeanContext.*;
+import static org.apache.juneau.serializer.SerializerContext.*;
+import static org.junit.Assert.*;
+
+import java.util.*;
+
+import org.apache.juneau.*;
+import org.apache.juneau.parser.*;
+import org.junit.*;
+
+@SuppressWarnings({"rawtypes","hiding","serial"})
+public class CommonParser_UonTest {
+
+ ReaderParser p = UonParser.DEFAULT.clone().setClassLoader(getClass().getClassLoader());
+ ReaderParser pe = UonParser.DEFAULT_DECODING.clone().setClassLoader(getClass().getClassLoader());
+
+ //====================================================================================================
+ // testFromSerializer
+ //====================================================================================================
+ @Test
+ public void testFromSerializer() throws Exception {
+ Map m = null;
+ String in;
+
+ in = "$o(a=$n(1))";
+ m = (Map)p.parse(in, Object.class);
+ assertEquals(1, m.get("a"));
+
+ in = "$o(a=$n(1),b=foo+bar)";
+ m = (Map)p.parse(in, Object.class);
+ assertEquals(1, m.get("a"));
+ assertEquals("foo+bar", m.get("b"));
+ m = (Map)pe.parse(in, Object.class);
+ assertEquals(1, m.get("a"));
+ assertEquals("foo bar", m.get("b"));
+
+ in = "$o(a=$n(1),b=foo+bar,c=$b(false))";
+ m = (Map)pe.parse(in, Object.class);
+ assertEquals(1, m.get("a"));
+ assertEquals("foo bar", m.get("b"));
+ assertEquals(false, m.get("c"));
+
+ in = "$o(a=$n(1),b=foo%20bar,c=$b(false))";
+ m = (Map)pe.parse(in, Object.class);
+ assertEquals(1, m.get("a"));
+ assertEquals("foo bar", m.get("b"));
+ assertEquals(false, m.get("c"));
+
+ ObjectList jl = (ObjectList)p.parse("$a($o(attribute=value),$o(attribute='value'))", Object.class);
+ assertEquals("value", jl.getObjectMap(0).getString("attribute"));
+ assertEquals("'value'", jl.getObjectMap(1).getString("attribute"));
+
+ A1 b = new A1();
+ A2 tl = new A2();
+ tl.add(new A3("name0","value0"));
+ tl.add(new A3("name1","value1"));
+ b.list = tl;
+
+ in = new UonSerializer().setProperty(SERIALIZER_addClassAttrs, true).serialize(b);
+ b = (A1)p.parse(in, Object.class);
+ assertEquals("value1", b.list.get(1).value);
+
+ in = UonSerializer.DEFAULT.serialize(b);
+ b = p.parse(in, A1.class);
+ assertEquals("value1", b.list.get(1).value);
+ }
+
+ public static class A1 {
+ public A2 list;
+ }
+
+ public static class A2 extends LinkedList<A3> {
+ }
+
+ public static class A3 {
+ public String name, value;
+ public A3(){}
+ public A3(String name, String value) {
+ this.name = name;
+ this.value = value;
+ }
+ }
+
+ //====================================================================================================
+ // Correct handling of unknown properties.
+ //====================================================================================================
+ @Test
+ public void testCorrectHandlingOfUnknownProperties() throws Exception {
+ ReaderParser p = new UonParser().setProperty(BEAN_ignoreUnknownBeanProperties, true);
+ B t;
+
+ String in = "(a=1,unknown=3,b=2)";
+ t = p.parse(in, B.class);
+ assertEquals(t.a, 1);
+ assertEquals(t.b, 2);
+
+ try {
+ p = new UonParser();
+ p.parse(in, B.class);
+ fail("Exception expected");
+ } catch (ParseException e) {}
+ }
+
+ public static class B {
+ public int a, b;
+ }
+
+ //====================================================================================================
+ // Writing to Collection properties with no setters.
+ //====================================================================================================
+ @Test
+ public void testCollectionPropertiesWithNoSetters() throws Exception {
+
+ ReaderParser p = UonParser.DEFAULT;
+
+ String json = "(ints=(1,2,3),beans=((a=1,b=2)))";
+ C t = p.parse(json, C.class);
+ assertEquals(t.getInts().size(), 3);
+ assertEquals(t.getBeans().get(0).b, 2);
+ }
+
+ public static class C {
+ private Collection<Integer> ints = new LinkedList<Integer>();
+ private List<B> beans = new LinkedList<B>();
+ public Collection<Integer> getInts() {
+ return ints;
+ }
+ public List<B> getBeans() {
+ return beans;
+ }
+ }
+
+ //====================================================================================================
+ // Parser listeners.
+ //====================================================================================================
+ @Test
+ public void testParserListeners() throws Exception {
+ final List<String> events = new LinkedList<String>();
+ UonParser p = new UonParser().setProperty(BEAN_ignoreUnknownBeanProperties, true);
+ p.addListener(
+ new ParserListener() {
+ @Override /* ParserListener */
+ public <T> void onUnknownProperty(String propertyName, Class<T> beanClass, T bean, int line, int col) {
+ events.add(propertyName + "," + line + "," + col);
+ }
+ }
+ );
+
+ String in = "(a=1,unknownProperty=foo,b=2)";
+ p.parse(in, B.class);
+ assertEquals(1, events.size());
+ assertEquals("unknownProperty,1,5", events.get(0));
+ }
+}
http://git-wip-us.apache.org/repos/asf/incubator-juneau/blob/df0f8689/org.apache.juneau/src/test/java/org/apache/juneau/urlencoding/CommonParser_UrlEncodingTest.java
----------------------------------------------------------------------
diff --git a/org.apache.juneau/src/test/java/org/apache/juneau/urlencoding/CommonParser_UrlEncodingTest.java b/org.apache.juneau/src/test/java/org/apache/juneau/urlencoding/CommonParser_UrlEncodingTest.java
new file mode 100755
index 0000000..0efafa5
--- /dev/null
+++ b/org.apache.juneau/src/test/java/org/apache/juneau/urlencoding/CommonParser_UrlEncodingTest.java
@@ -0,0 +1,185 @@
+/***************************************************************************************************************************
+ * Licensed to the Apache Software Foundation (ASF) under one or more contributor license agreements. See the NOTICE file
+ * distributed with this work for additional information regarding copyright ownership. The ASF licenses this file
+ * to you under the Apache License, Version 2.0 (the "License"); you may not use this file except in compliance
+ * with the License. You may obtain a copy of the License at
+ *
+ * http://www.apache.org/licenses/LICENSE-2.0
+ *
+ * Unless required by applicable law or agreed to in writing, software distributed under the License is distributed on an
+ * "AS IS" BASIS, WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. See the License for the
+ * specific language governing permissions and limitations under the License.
+ ***************************************************************************************************************************/
+package org.apache.juneau.urlencoding;
+
+import static org.apache.juneau.BeanContext.*;
+import static org.apache.juneau.TestUtils.*;
+import static org.apache.juneau.serializer.SerializerContext.*;
+import static org.junit.Assert.*;
+
+import java.util.*;
+
+import org.apache.juneau.*;
+import org.apache.juneau.parser.*;
+import org.apache.juneau.serializer.*;
+import org.junit.*;
+
+@SuppressWarnings({"rawtypes","hiding","serial"})
+public class CommonParser_UrlEncodingTest {
+
+ ReaderParser p = UrlEncodingParser.DEFAULT.clone().setClassLoader(getClass().getClassLoader());
+
+ //====================================================================================================
+ // testFromSerializer
+ //====================================================================================================
+ @Test
+ public void testFromSerializer() throws Exception {
+ Map m = null;
+ String in;
+
+ in = "a=$n(1)";
+ m = (Map)p.parse(in, Object.class);
+ assertEquals(1, m.get("a"));
+
+ in = "a=$n(1)&b=foo+bar";
+ m = (Map)p.parse(in, Object.class);
+ assertEquals(1, m.get("a"));
+ assertEquals("foo bar", m.get("b"));
+
+ in = "a=$n(1)&b=foo+bar&c=$b(false)";
+ m = (Map)p.parse(in, Object.class);
+ assertEquals(1, m.get("a"));
+ assertEquals("foo bar", m.get("b"));
+ assertEquals(false, m.get("c"));
+
+ in = "a=$n(1)&b=foo%20bar&c=$b(false)";
+ m = (Map)p.parse(in, Object.class);
+ assertEquals(1, m.get("a"));
+ assertEquals("foo bar", m.get("b"));
+ assertEquals(false, m.get("c"));
+
+ ObjectMap jm = (ObjectMap)p.parse("x=$a($o(attribute=value),$o(attribute='value'))", Object.class);
+ assertEquals("value", jm.getObjectList("x").getObjectMap(0).getString("attribute"));
+ assertEquals("'value'", jm.getObjectList("x").getObjectMap(1).getString("attribute"));
+
+ ObjectList jl = (ObjectList)p.parse("_value=$a($o(attribute=value),$o(attribute='value'))", Object.class);
+ assertEquals("value", jl.getObjectMap(0).getString("attribute"));
+ assertEquals("'value'", jl.getObjectMap(1).getString("attribute"));
+
+ A1 b = new A1();
+ A2 tl = new A2();
+ tl.add(new A3("name0","value0"));
+ tl.add(new A3("name1","value1"));
+ b.list = tl;
+
+ in = new UrlEncodingSerializer().setProperty(SERIALIZER_addClassAttrs, true).serialize(b);
+ b = (A1)p.parse(in, Object.class);
+ assertEquals("value1", b.list.get(1).value);
+
+ in = UrlEncodingSerializer.DEFAULT.serialize(b);
+ b = p.parse(in, A1.class);
+ assertEquals("value1", b.list.get(1).value);
+ }
+
+ public static class A1 {
+ public A2 list;
+ }
+
+ public static class A2 extends LinkedList<A3> {
+ }
+
+ public static class A3 {
+ public String name, value;
+ public A3(){}
+ public A3(String name, String value) {
+ this.name = name;
+ this.value = value;
+ }
+ }
+
+ //====================================================================================================
+ // Correct handling of unknown properties.
+ //====================================================================================================
+ @Test
+ public void testCorrectHandlingOfUnknownProperties() throws Exception {
+ ReaderParser p = new UrlEncodingParser().setProperty(BEAN_ignoreUnknownBeanProperties, true);
+ B t;
+
+ String in = "a=1&unknown=3&b=2";
+ t = p.parse(in, B.class);
+ assertEquals(t.a, 1);
+ assertEquals(t.b, 2);
+
+ try {
+ p = new UrlEncodingParser();
+ p.parse(in, B.class);
+ fail("Exception expected");
+ } catch (ParseException e) {}
+ }
+
+ public static class B {
+ public int a, b;
+ }
+
+ //====================================================================================================
+ // Writing to Collection properties with no setters.
+ //====================================================================================================
+ @Test
+ public void testCollectionPropertiesWithNoSetters() throws Exception {
+
+ ReaderParser p = UrlEncodingParser.DEFAULT;
+
+ String json = "ints=(1,2,3)&beans=((a=1,b=2))";
+ C t = p.parse(json, C.class);
+ assertEquals(t.getInts().size(), 3);
+ assertEquals(t.getBeans().get(0).b, 2);
+ }
+
+ public static class C {
+ private Collection<Integer> ints = new LinkedList<Integer>();
+ private List<B> beans = new LinkedList<B>();
+ public Collection<Integer> getInts() {
+ return ints;
+ }
+ public List<B> getBeans() {
+ return beans;
+ }
+ }
+
+ //====================================================================================================
+ // Parser listeners.
+ //====================================================================================================
+ @Test
+ public void testParserListeners() throws Exception {
+ final List<String> events = new LinkedList<String>();
+ UonParser p = new UrlEncodingParser().setProperty(BEAN_ignoreUnknownBeanProperties, true);
+ p.addListener(
+ new ParserListener() {
+ @Override /* ParserListener */
+ public <T> void onUnknownProperty(String propertyName, Class<T> beanClass, T bean, int line, int col) {
+ events.add(propertyName + "," + line + "," + col);
+ }
+ }
+ );
+
+ String in = "a=1&unknownProperty=foo&b=2";
+ p.parse(in, B.class);
+ assertEquals(1, events.size());
+ assertEquals("unknownProperty,1,4", events.get(0));
+ }
+
+ @SuppressWarnings("unchecked")
+ @Test
+ public void testCollections() throws Exception {
+ WriterSerializer s = new UrlEncodingSerializer().setProperty(UonSerializerContext.UON_simpleMode, true);
+ ReaderParser p = new UrlEncodingParser();
+
+ List l = new ObjectList("foo","bar");
+ assertEquals("0=foo&1=bar", s.serialize(l));
+
+ String in = "0=foo&1=bar";
+ ClassMeta<LinkedList<String>> cm = p.getBeanContext().getCollectionClassMeta(LinkedList.class, String.class);
+ l = p.parse(in, cm);
+ assertObjectEquals("['foo','bar']",l);
+ }
+}