Skip to content
This repository has been archived by the owner on Oct 23, 2024. It is now read-only.

Commit

Permalink
Merge pull request #1008 from wuwen5/fixed#1005
Browse files Browse the repository at this point in the history
bug fixed for issue 1005.
  • Loading branch information
wenshao authored Jan 20, 2017
2 parents ac93f3a + 0292219 commit 9ce20b3
Show file tree
Hide file tree
Showing 2 changed files with 17 additions and 2 deletions.
Original file line number Diff line number Diff line change
Expand Up @@ -174,7 +174,7 @@ public <T> T deserialze(DefaultJSONParser parser, Type type, Object fieldName) {
componentType = componentClass = clazz.getComponentType();
}
JSONArray array = new JSONArray();
parser.parseArray(componentClass, array, fieldName);
parser.parseArray(componentType, array, fieldName);

return (T) toObjectArray(parser, componentClass, array);
}
Expand Down
17 changes: 16 additions & 1 deletion src/test/java/com/alibaba/json/bvt/bug/Issue1005.java
Original file line number Diff line number Diff line change
Expand Up @@ -10,7 +10,18 @@
*/
public class Issue1005 extends TestCase {
public void test_for_issue() throws Exception {
Model model = JSON.parseObject("{\"values\":[1,2,3]}", Model.class);
Model model = JSON.parseObject("{\"values\":[[1,2,3]]}", Model.class);

assertNotNull(model.values);
assertEquals(3, model.values[0].size());
assertEquals(Byte.class, model.values[0].get(0).getClass());
assertEquals(Byte.class, model.values[0].get(1).getClass());
assertEquals(Byte.class, model.values[0].get(2).getClass());
}

public void test_for_List() throws Exception {
Model2 model = JSON.parseObject("{\"values\":[1,2,3]}", Model2.class);

assertNotNull(model.values);
assertEquals(3, model.values.size());
assertEquals(Byte.class, model.values.get(0).getClass());
Expand All @@ -19,6 +30,10 @@ public void test_for_issue() throws Exception {
}

public static class Model {
public List<Byte>[] values;
}

public static class Model2 {
public List<Byte> values;
}
}

0 comments on commit 9ce20b3

Please sign in to comment.