fix code and add sh

This commit is contained in:
Looly 2020-03-31 11:06:39 +08:00
parent 174d80e865
commit ccccbf67aa
8 changed files with 101 additions and 90 deletions

View File

@ -3,12 +3,13 @@
------------------------------------------------------------------------------------------------------------- -------------------------------------------------------------------------------------------------------------
## 5.2.6 (2020-03-26) ## 5.2.6 (2020-04-01)
### 新特性 ### 新特性
* 【extra 】 JschUtil增加execByShell方法(issue#I1CYES@Gitee) * 【extra 】 JschUtil增加execByShell方法(issue#I1CYES@Gitee)
* 【core 】 StrUtil增加subBetweenAll方法Console增加where和lineNumber方法(issue#812@Github) * 【core 】 StrUtil增加subBetweenAll方法Console增加where和lineNumber方法(issue#812@Github)
* 【core 】 TableMap增加getKeys和getValues方法 * 【core 】 TableMap增加getKeys和getValues方法
* 【json 】 JSONObject和JSONArray增加set方法标识put弃用
### Bug修复 ### Bug修复
* 【extra 】 修复SpringUtil使用devtools重启报错问题 * 【extra 】 修复SpringUtil使用devtools重启报错问题

3
bin/cobertura.sh Normal file
View File

@ -0,0 +1,3 @@
#!/bin/bash
exec mvn -T 1 cobertura:cobertura

3
bin/simple_install.sh Normal file
View File

@ -0,0 +1,3 @@
#!/bin/bash
exec mvn -T 1C clean install -Dmaven.test.skip=true -Dmaven.javadoc.skip=true

View File

@ -252,8 +252,21 @@ public class JSONArray implements JSON, JSONGetter<Integer>, List<Object>, Rando
* *
* @param value 可以是 Boolean, Double, Integer, JSONArray, JSONObject, Long, or String, or the JSONNull.NULL * @param value 可以是 Boolean, Double, Integer, JSONArray, JSONObject, Long, or String, or the JSONNull.NULL
* @return this. * @return this.
* @see #set(Object)
*/ */
public JSONArray put(Object value) { public JSONArray put(Object value) {
return set(value);
}
/**
* Append an object value. This increases the array's length by one. <br>
* 加入元素数组长度+1等同于 {@link JSONArray#add(Object)}
*
* @param value 可以是 Boolean, Double, Integer, JSONArray, JSONObject, Long, or String, or the JSONNull.NULL
* @return this.
* @since 5.2.5
*/
public JSONArray set(Object value) {
this.add(value); this.add(value);
return this; return this;
} }
@ -284,7 +297,7 @@ public class JSONArray implements JSON, JSONGetter<Integer>, List<Object>, Rando
} }
JSONObject jo = new JSONObject(); JSONObject jo = new JSONObject();
for (int i = 0; i < names.size(); i += 1) { for (int i = 0; i < names.size(); i += 1) {
jo.put(names.getStr(i), this.getObj(i)); jo.set(names.getStr(i), this.getObj(i));
} }
return jo; return jo;
} }
@ -440,7 +453,7 @@ public class JSONArray implements JSON, JSONGetter<Integer>, List<Object>, Rando
while (index != this.size()) { while (index != this.size()) {
this.add(JSONNull.NULL); this.add(JSONNull.NULL);
} }
this.put(element); this.set(element);
} }
} }

View File

@ -279,7 +279,7 @@ public class JSONObject implements JSON, JSONGetter<String>, Map<String, Object>
for (String name : names) { for (String name : names) {
value = this.get(name); value = this.get(name);
if (null != value) { if (null != value) {
ja.put(value); ja.set(value);
} }
} }
return ja; return ja;
@ -332,14 +332,16 @@ public class JSONObject implements JSON, JSONGetter<String>, Map<String, Object>
} }
/** /**
* PUT 键值对到JSONObject中如果值为<code>null</code>将此键移除 * PUT 键值对到JSONObject中在忽略null模式下如果值为<code>null</code>将此键移除
* *
* @param key * @param key
* @param value 值对象. 可以是以下类型: Boolean, Double, Integer, JSONArray, JSONObject, Long, String, or the JSONNull.NULL. * @param value 值对象. 可以是以下类型: Boolean, Double, Integer, JSONArray, JSONObject, Long, String, or the JSONNull.NULL.
* @return this. * @return this.
* @throws JSONException 值是无穷数字抛出此异常 * @throws JSONException 值是无穷数字抛出此异常
* @deprecated 此方法存在歧义原Map接口返回的是之前的值重写后返回this了未来版本此方法会修改请使用{@link #set(String, Object)}
*/ */
@Override @Override
@Deprecated
public JSONObject put(String key, Object value) throws JSONException { public JSONObject put(String key, Object value) throws JSONException {
if (null == key) { if (null == key) {
return this; return this;
@ -356,6 +358,19 @@ public class JSONObject implements JSON, JSONGetter<String>, Map<String, Object>
return this; return this;
} }
/**
* 设置键值对到JSONObject中在忽略null模式下如果值为<code>null</code>将此键移除
*
* @param key
* @param value 值对象. 可以是以下类型: Boolean, Double, Integer, JSONArray, JSONObject, Long, String, or the JSONNull.NULL.
* @return this.
* @throws JSONException 值是无穷数字抛出此异常
*/
public JSONObject set(String key, Object value) throws JSONException {
put(key, value);
return this;
}
/** /**
* 一次性Put 键值对如果key已经存在抛出异常如果键值中有null值忽略 * 一次性Put 键值对如果key已经存在抛出异常如果键值中有null值忽略
* *
@ -365,7 +380,7 @@ public class JSONObject implements JSON, JSONGetter<String>, Map<String, Object>
* @throws JSONException 值是无穷数字键重复抛出异常 * @throws JSONException 值是无穷数字键重复抛出异常
*/ */
public JSONObject putOnce(String key, Object value) throws JSONException { public JSONObject putOnce(String key, Object value) throws JSONException {
if (key != null && value != null) { if (key != null) {
if (rawHashMap.containsKey(key)) { if (rawHashMap.containsKey(key)) {
throw new JSONException("Duplicate key \"{}\"", key); throw new JSONException("Duplicate key \"{}\"", key);
} }
@ -409,11 +424,11 @@ public class JSONObject implements JSON, JSONGetter<String>, Map<String, Object>
InternalJSONUtil.testValidity(value); InternalJSONUtil.testValidity(value);
Object object = this.getObj(key); Object object = this.getObj(key);
if (object == null) { if (object == null) {
this.put(key, value instanceof JSONArray ? new JSONArray().put(value) : value); this.put(key, value instanceof JSONArray ? new JSONArray().set(value) : value);
} else if (object instanceof JSONArray) { } else if (object instanceof JSONArray) {
((JSONArray) object).put(value); ((JSONArray) object).set(value);
} else { } else {
this.put(key, new JSONArray().put(object).put(value)); this.set(key, new JSONArray().set(object).set(value));
} }
return this; return this;
} }
@ -430,9 +445,9 @@ public class JSONObject implements JSON, JSONGetter<String>, Map<String, Object>
InternalJSONUtil.testValidity(value); InternalJSONUtil.testValidity(value);
Object object = this.getObj(key); Object object = this.getObj(key);
if (object == null) { if (object == null) {
this.put(key, new JSONArray().put(value)); this.set(key, new JSONArray().set(value));
} else if (object instanceof JSONArray) { } else if (object instanceof JSONArray) {
this.put(key, ((JSONArray) object).put(value)); this.set(key, ((JSONArray) object).set(value));
} else { } else {
throw new JSONException("JSONObject [" + key + "] is not a JSONArray."); throw new JSONException("JSONObject [" + key + "] is not a JSONArray.");
} }

View File

@ -10,10 +10,10 @@ import java.util.Iterator;
*/ */
public class JSONObjectIter implements Iterable<JSONObject> { public class JSONObjectIter implements Iterable<JSONObject> {
Iterator<Object> iter; Iterator<Object> iterator;
public JSONObjectIter(Iterator<Object> iter) { public JSONObjectIter(Iterator<Object> iterator) {
this.iter = iter; this.iterator = iterator;
} }
@Override @Override
@ -22,17 +22,17 @@ public class JSONObjectIter implements Iterable<JSONObject> {
@Override @Override
public boolean hasNext() { public boolean hasNext() {
return iter.hasNext(); return iterator.hasNext();
} }
@Override @Override
public JSONObject next() { public JSONObject next() {
return (JSONObject) iter.next(); return (JSONObject) iterator.next();
} }
@Override @Override
public void remove() { public void remove() {
iter.remove(); iterator.remove();
} }
}; };
} }

View File

@ -1,17 +1,7 @@
package cn.hutool.json; package cn.hutool.json;
import java.math.BigDecimal;
import java.util.Date;
import java.util.List;
import java.util.Objects;
import cn.hutool.core.annotation.Alias; import cn.hutool.core.annotation.Alias;
import cn.hutool.core.collection.CollUtil; import cn.hutool.core.collection.CollUtil;
import lombok.Data;
import org.junit.Assert;
import org.junit.Ignore;
import org.junit.Test;
import cn.hutool.core.collection.CollectionUtil; import cn.hutool.core.collection.CollectionUtil;
import cn.hutool.core.date.DatePattern; import cn.hutool.core.date.DatePattern;
import cn.hutool.core.date.DateUtil; import cn.hutool.core.date.DateUtil;
@ -30,6 +20,15 @@ import cn.hutool.json.test.bean.UserWithMap;
import cn.hutool.json.test.bean.report.CaseReport; import cn.hutool.json.test.bean.report.CaseReport;
import cn.hutool.json.test.bean.report.StepReport; import cn.hutool.json.test.bean.report.StepReport;
import cn.hutool.json.test.bean.report.SuiteReport; import cn.hutool.json.test.bean.report.SuiteReport;
import lombok.Data;
import org.junit.Assert;
import org.junit.Ignore;
import org.junit.Test;
import java.math.BigDecimal;
import java.util.Date;
import java.util.List;
import java.util.Objects;
/** /**
* JSONObject单元测试 * JSONObject单元测试
@ -61,32 +60,33 @@ public class JSONObjectTest {
@Test @Test
public void toStringTest3() { public void toStringTest3() {
JSONObject json = Objects.requireNonNull(JSONUtil.createObj()// JSONObject json = Objects.requireNonNull(JSONUtil.createObj()//
.put("dateTime", DateUtil.parse("2019-05-02 22:12:01")))// .set("dateTime", DateUtil.parse("2019-05-02 22:12:01")))//
.setDateFormat(DatePattern.NORM_DATE_PATTERN); .setDateFormat(DatePattern.NORM_DATE_PATTERN);
Assert.assertEquals("{\"dateTime\":\"2019-05-02\"}", json.toString()); Assert.assertEquals("{\"dateTime\":\"2019-05-02\"}", json.toString());
} }
@Test @Test
public void toStringWithDateTest() { public void toStringWithDateTest() {
JSONObject json = JSONUtil.createObj().put("date", DateUtil.parse("2019-05-08 19:18:21")); JSONObject json = JSONUtil.createObj().set("date", DateUtil.parse("2019-05-08 19:18:21"));
assert json != null; assert json != null;
Assert.assertEquals("{\"date\":1557314301000}", json.toString()); Assert.assertEquals("{\"date\":1557314301000}", json.toString());
json = Objects.requireNonNull(JSONUtil.createObj().put("date", DateUtil.parse("2019-05-08 19:18:21"))).setDateFormat(DatePattern.NORM_DATE_PATTERN); json = Objects.requireNonNull(JSONUtil.createObj().set("date", DateUtil.parse("2019-05-08 19:18:21"))).setDateFormat(DatePattern.NORM_DATE_PATTERN);
Assert.assertEquals("{\"date\":\"2019-05-08\"}", json.toString()); Assert.assertEquals("{\"date\":\"2019-05-08\"}", json.toString());
} }
@Test @Test
public void putAllTest() { public void putAllTest() {
JSONObject json1 = JSONUtil.createObj(); JSONObject json1 = JSONUtil.createObj()
json1.put("a", "value1"); .set("a", "value1")
json1.put("b", "value2"); .set("b", "value2")
json1.put("c", "value3"); .set("c", "value3")
json1.put("d", true); .set("d", true);
JSONObject json2 = JSONUtil.createObj(); JSONObject json2 = JSONUtil.createObj()
json2.put("a", "value21"); .set("a", "value21")
json2.put("b", "value22"); .set("b", "value22");
// putAll操作会覆盖相同key的值因此a,b两个key的值改变c的值不变 // putAll操作会覆盖相同key的值因此a,b两个key的值改变c的值不变
json1.putAll(json2); json1.putAll(json2);
@ -134,13 +134,14 @@ public class JSONObjectTest {
Console.log(json2); Console.log(json2);
} }
@SuppressWarnings("ConstantConditions")
@Test @Test
public void toBeanTest() { public void toBeanTest() {
JSONObject subJson = JSONUtil.createObj().put("value1", "strValue1").put("value2", "234"); JSONObject subJson = JSONUtil.createObj().set("value1", "strValue1").set("value2", "234");
JSONObject json = JSONUtil.createObj().put("strValue", "strTest").put("intValue", 123) JSONObject json = JSONUtil.createObj().set("strValue", "strTest").set("intValue", 123)
// 测试空字符串转对象 // 测试空字符串转对象
.put("doubleValue", "").put("beanValue", subJson).put("list", JSONUtil.createArray().put("a").put("b")).put("testEnum", "TYPE_A"); .set("doubleValue", "")
.set("beanValue", subJson)
.set("list", JSONUtil.createArray().set("a").set("b")).set("testEnum", "TYPE_A");
TestBean bean = json.toBean(TestBean.class); TestBean bean = json.toBean(TestBean.class);
Assert.assertEquals("a", bean.getList().get(0)); Assert.assertEquals("a", bean.getList().get(0));
@ -153,14 +154,13 @@ public class JSONObjectTest {
Assert.assertEquals(TestEnum.TYPE_A, bean.getTestEnum()); Assert.assertEquals(TestEnum.TYPE_A, bean.getTestEnum());
} }
@SuppressWarnings("ConstantConditions")
@Test @Test
public void toBeanNullStrTest() { public void toBeanNullStrTest() {
JSONObject json = JSONUtil.createObj()// JSONObject json = JSONUtil.createObj()//
.put("strValue", "null")// .set("strValue", "null")//
.put("intValue", 123)// .set("intValue", 123)//
.put("beanValue", "null")// .set("beanValue", "null")//
.put("list", JSONUtil.createArray().put("a").put("b")); .set("list", JSONUtil.createArray().set("a").set("b"));
TestBean bean = json.toBean(TestBean.class); TestBean bean = json.toBean(TestBean.class);
// 当JSON中为字符串"null"时应被当作字符串处理 // 当JSON中为字符串"null"时应被当作字符串处理
@ -222,15 +222,14 @@ public class JSONObjectTest {
/** /**
* 在JSON转Bean过程中Bean中字段如果为父类定义的泛型类型则应正确转换此方法用于测试这类情况 * 在JSON转Bean过程中Bean中字段如果为父类定义的泛型类型则应正确转换此方法用于测试这类情况
*/ */
@SuppressWarnings("ConstantConditions")
@Test @Test
public void toBeanTest6() { public void toBeanTest6() {
JSONObject json = JSONUtil.createObj() JSONObject json = JSONUtil.createObj()
.put("targetUrl", "http://test.com") .set("targetUrl", "http://test.com")
.put("success", "true") .set("success", "true")
.put("result", JSONUtil.createObj() .set("result", JSONUtil.createObj()
.put("token", "tokenTest") .set("token", "tokenTest")
.put("userId", "测试用户1")); .set("userId", "测试用户1"));
TokenAuthWarp2 bean = json.toBean(TokenAuthWarp2.class); TokenAuthWarp2 bean = json.toBean(TokenAuthWarp2.class);
Assert.assertEquals("http://test.com", bean.getTargetUrl()); Assert.assertEquals("http://test.com", bean.getTargetUrl());
@ -260,7 +259,8 @@ public class JSONObjectTest {
userA.setDate(new Date()); userA.setDate(new Date());
userA.setSqs(CollectionUtil.newArrayList(new Seq(null), new Seq("seq2"))); userA.setSqs(CollectionUtil.newArrayList(new Seq(null), new Seq("seq2")));
JSONObject json = JSONUtil.parseObj(userA, false); JSONObject json = JSONUtil.parseObj(userA, false, true);
Assert.assertTrue(json.containsKey("a")); Assert.assertTrue(json.containsKey("a"));
Assert.assertTrue(json.getJSONArray("sqs").getJSONObject(0).containsKey("seq")); Assert.assertTrue(json.getJSONArray("sqs").getJSONObject(0).containsKey("seq"));
} }
@ -282,10 +282,11 @@ public class JSONObjectTest {
Assert.assertEquals(bean.toString(), bean2.toString()); Assert.assertEquals(bean.toString(), bean2.toString());
} }
@SuppressWarnings("ConstantConditions")
@Test @Test
public void parseBeanTest3() { public void parseBeanTest3() {
JSONObject json = JSONUtil.createObj().put("code", 22).put("data", "{\"jobId\": \"abc\", \"videoUrl\": \"http://a.com/a.mp4\"}"); JSONObject json = JSONUtil.createObj()
.set("code", 22)
.set("data", "{\"jobId\": \"abc\", \"videoUrl\": \"http://a.com/a.mp4\"}");
JSONBean bean = json.toBean(JSONBean.class); JSONBean bean = json.toBean(JSONBean.class);
Assert.assertEquals(22, bean.getCode()); Assert.assertEquals(22, bean.getCode());
@ -322,10 +323,12 @@ public class JSONObjectTest {
Assert.assertEquals(DateUtil.parse("2018-10-25"), bean.getDate()); Assert.assertEquals(DateUtil.parse("2018-10-25"), bean.getDate());
} }
@SuppressWarnings("ConstantConditions")
@Test @Test
public void beanTransTest3() { public void beanTransTest3() {
JSONObject userAJson = JSONUtil.createObj().put("a", "AValue").put("name", "nameValue").put("date", "08:00:00"); JSONObject userAJson = JSONUtil.createObj()
.set("a", "AValue")
.set("name", "nameValue")
.set("date", "08:00:00");
UserA bean = JSONUtil.toBean(userAJson.toString(), UserA.class); UserA bean = JSONUtil.toBean(userAJson.toString(), UserA.class);
Assert.assertEquals(DateUtil.today() + " 08:00:00", DateUtil.date(bean.getDate()).toString()); Assert.assertEquals(DateUtil.today() + " 08:00:00", DateUtil.date(bean.getDate()).toString());
} }
@ -377,10 +380,9 @@ public class JSONObjectTest {
Assert.assertEquals("张三", jsonObject.getStr("name")); Assert.assertEquals("张三", jsonObject.getStr("name"));
Assert.assertEquals(new Integer(35), jsonObject.getInt("age")); Assert.assertEquals(new Integer(35), jsonObject.getInt("age"));
@SuppressWarnings("ConstantConditions")
JSONObject json = JSONUtil.createObj() JSONObject json = JSONUtil.createObj()
.put("name", "张三") .set("name", "张三")
.put("age", 35); .set("age", 35);
final BeanWithAlias bean = JSONUtil.toBean(Objects.requireNonNull(json).toString(), BeanWithAlias.class); final BeanWithAlias bean = JSONUtil.toBean(Objects.requireNonNull(json).toString(), BeanWithAlias.class);
Assert.assertEquals("张三", bean.getValue1()); Assert.assertEquals("张三", bean.getValue1());
Assert.assertEquals(new Integer(35), bean.getValue2()); Assert.assertEquals(new Integer(35), bean.getValue2());

View File

@ -1,40 +1,14 @@
package cn.hutool.json.test.bean; package cn.hutool.json.test.bean;
import lombok.Data;
import java.util.Date; import java.util.Date;
import java.util.List; import java.util.List;
@Data
public class UserA { public class UserA {
private String name; private String name;
private String a; private String a;
private Date date; private Date date;
private List<Seq> sqs; private List<Seq> sqs;
public String getName() {
return name;
}
public void setName(String name) {
this.name = name;
}
public String getA() {
return a;
}
public void setA(String a) {
this.a = a;
}
public Date getDate() {
return date;
}
public void setDate(Date date) {
this.date = date;
}
public List<Seq> getSqs() {
return sqs;
}
public void setSqs(List<Seq> sqs) {
this.sqs = sqs;
}
@Override
public String toString() {
return "UserA [name=" + name + ", a=" + a + ", date=" + date + ", sqs=" + sqs + "]";
}
} }