kuangshuai
4 years ago
21 changed files with 169 additions and 1064 deletions
@ -1,253 +0,0 @@
|
||||
package com.fr.design.mainframe.template.info; |
||||
|
||||
import com.fr.config.MarketConfig; |
||||
import com.fr.design.DesignerEnvManager; |
||||
import com.fr.design.mainframe.burying.point.AbstractPointInfo; |
||||
import com.fr.general.CloudCenter; |
||||
import com.fr.json.JSON; |
||||
import com.fr.json.JSONFactory; |
||||
import com.fr.json.JSONObject; |
||||
import com.fr.stable.StringUtils; |
||||
import com.fr.stable.xml.XMLPrintWriter; |
||||
import com.fr.stable.xml.XMLableReader; |
||||
import com.fr.third.joda.time.DateTime; |
||||
|
||||
import java.util.HashMap; |
||||
import java.util.Map; |
||||
|
||||
/** |
||||
* 对应一张模版的记录 |
||||
* Created by plough on 2019/4/18. |
||||
*/ |
||||
public class TemplateInfo extends AbstractPointInfo { |
||||
static final String XML_TAG = "TemplateInfo"; |
||||
private static final String SIMPLE_DATE_PATTRN = "yyyy-MM-dd HH:mm"; |
||||
|
||||
private static final String CONSUMING_URL = CloudCenter.getInstance().acquireUrlByKind("tempinfo.consuming") + "/single"; |
||||
private static final String PROCESS_URL = CloudCenter.getInstance().acquireUrlByKind("tempinfo.process") + "/single"; |
||||
|
||||
private static final String XML_PROCESS_MAP = "processMap"; |
||||
private static final String XML_CONSUMING_MAP = "consumingMap"; |
||||
private static final String ATTR_DAY_COUNT = "day_count"; |
||||
private static final String ATTR_TEMPLATE_ID = "templateID"; |
||||
private static final String ATTR_ORIGIN_ID = "originID"; |
||||
private static final String ATTR_PROCESS = "process"; |
||||
private static final String ATTR_FLOAT_COUNT = "float_count"; |
||||
private static final String ATTR_WIDGET_COUNT = "widget_count"; |
||||
private static final String ATTR_CELL_COUNT = "cell_count"; |
||||
private static final String ATTR_BLOCK_COUNT = "block_count"; |
||||
private static final String ATTR_REPORT_TYPE = "report_type"; |
||||
private static final String ATTR_CREATE_TIME = "create_time"; |
||||
private static final String ATTR_UUID = "uuid"; |
||||
private static final String ATTR_UID = "uid"; |
||||
private static final String ATTR_SAVE_RECORD = "saveRecord"; |
||||
private static final String ATTR_PARA_APPLY = "paraApply"; |
||||
private static final String ATTR_COMPONENTS_INFO = "components_info"; |
||||
private static final String ATTR_REUSE_CMP_LIST = "reuseCmptList"; |
||||
|
||||
|
||||
private static final String TEST_TEMPLATE_FLAG = "test_template"; |
||||
private static final int VALID_CELL_COUNT = 5; // 有效报表模板的格子数
|
||||
private static final int VALID_WIDGET_COUNT = 5; // 有效报表模板的控件数
|
||||
|
||||
private String templateID = StringUtils.EMPTY; |
||||
private String originID = StringUtils.EMPTY; |
||||
// todo: processMap 和 consumingMap 还可以再拆解为小类,以后继续重构
|
||||
private Map<String, Object> processMap = new HashMap<>(); |
||||
private Map<String, Object> consumingMap = new HashMap<>(); |
||||
|
||||
private TemplateInfo() { |
||||
} |
||||
|
||||
private TemplateInfo(String templateID, String originID) { |
||||
this.templateID = templateID; |
||||
this.originID = originID; |
||||
} |
||||
|
||||
@Override |
||||
protected String key() { |
||||
return templateID; |
||||
} |
||||
|
||||
public static TemplateInfo newInstanceByRead(XMLableReader reader) { |
||||
TemplateInfo templateInfo = new TemplateInfo(); |
||||
reader.readXMLObject(templateInfo); |
||||
return templateInfo; |
||||
} |
||||
|
||||
public static TemplateInfo newInstance(String templateID) { |
||||
return newInstance(templateID, StringUtils.EMPTY, StringUtils.EMPTY, StringUtils.EMPTY); |
||||
} |
||||
|
||||
public static TemplateInfo newInstance(String templateID, String originID, String saveRecord) { |
||||
String createTime = DateTime.now().toString(SIMPLE_DATE_PATTRN); |
||||
return newInstance(templateID, originID, saveRecord, createTime); |
||||
} |
||||
|
||||
public static TemplateInfo newInstance(String templateID, String originID, String saveRecord, String createTime) { |
||||
HashMap<String, Object> consumingMap = new HashMap<>(); |
||||
|
||||
String uuid = DesignerEnvManager.getEnvManager().getUUID(); |
||||
MarketConfig config = MarketConfig.getInstance(); |
||||
consumingMap.put(ATTR_UUID, uuid); |
||||
consumingMap.put(ATTR_TEMPLATE_ID, templateID); |
||||
consumingMap.put(ATTR_ORIGIN_ID, originID); |
||||
consumingMap.put(ATTR_CREATE_TIME, createTime); |
||||
consumingMap.put(ATTR_UID, config.getBBSAttr().getBbsUid()); |
||||
consumingMap.put(ATTR_SAVE_RECORD, saveRecord); |
||||
|
||||
TemplateInfo templateInfo = new TemplateInfo(templateID, originID); |
||||
templateInfo.consumingMap = consumingMap; |
||||
|
||||
return templateInfo; |
||||
} |
||||
|
||||
String getTemplateID() { |
||||
return templateID; |
||||
} |
||||
|
||||
public String getTemplateInfoID() { |
||||
return templateID + "_" + getSaveTime(); |
||||
} |
||||
|
||||
public long getSaveTime() { |
||||
String saveRecord = (String) consumingMap.get(ATTR_SAVE_RECORD); |
||||
JSONObject jo = JSONFactory.createJSON(JSON.OBJECT, saveRecord); |
||||
return jo.getLong("time"); |
||||
} |
||||
|
||||
public String getTemplateCreateTime() { |
||||
return (String) consumingMap.get(ATTR_CREATE_TIME); |
||||
} |
||||
|
||||
|
||||
@Override |
||||
public void writeXML(XMLPrintWriter writer) { |
||||
writer.startTAG(XML_TAG); |
||||
if (StringUtils.isNotEmpty(templateID)) { |
||||
writer.attr(ATTR_TEMPLATE_ID, this.templateID); |
||||
} |
||||
if (StringUtils.isNotEmpty(originID)) { |
||||
writer.attr(ATTR_ORIGIN_ID, this.originID); |
||||
} |
||||
if (idleDayCount >= 0) { |
||||
writer.attr(ATTR_DAY_COUNT, this.idleDayCount); |
||||
} |
||||
writer.attr(TEST_TEMPLATE_FLAG, this.testTemplate); |
||||
writeProcessMap(writer); |
||||
writeConsumingMap(writer); |
||||
|
||||
writer.end(); |
||||
} |
||||
|
||||
private void writeProcessMap(XMLPrintWriter writer) { |
||||
writer.startTAG(XML_PROCESS_MAP); |
||||
writer.attr(ATTR_PROCESS, (String) processMap.get(ATTR_PROCESS)); |
||||
writer.attr(ATTR_FLOAT_COUNT, (int) processMap.get(ATTR_FLOAT_COUNT)); |
||||
writer.attr(ATTR_WIDGET_COUNT, (int) processMap.get(ATTR_WIDGET_COUNT)); |
||||
writer.attr(ATTR_CELL_COUNT, (int) processMap.get(ATTR_CELL_COUNT)); |
||||
writer.attr(ATTR_BLOCK_COUNT, (int) processMap.get(ATTR_BLOCK_COUNT)); |
||||
writer.attr(ATTR_REPORT_TYPE, (int) processMap.get(ATTR_REPORT_TYPE)); |
||||
writer.attr(ATTR_PARA_APPLY, (int) processMap.get(ATTR_PARA_APPLY)); |
||||
writer.attr(ATTR_COMPONENTS_INFO, (String) processMap.get(ATTR_COMPONENTS_INFO)); |
||||
writer.attr(ATTR_REUSE_CMP_LIST, (String) processMap.get(ATTR_REUSE_CMP_LIST)); |
||||
writer.end(); |
||||
} |
||||
|
||||
private void writeConsumingMap(XMLPrintWriter writer) { |
||||
writer.startTAG(XML_CONSUMING_MAP); |
||||
writer.attr(ATTR_CREATE_TIME, (String) consumingMap.get(ATTR_CREATE_TIME)); |
||||
writer.attr(ATTR_UUID, (String) consumingMap.get(ATTR_UUID)); |
||||
writer.attr(ATTR_UID, (int) consumingMap.get(ATTR_UID)); |
||||
writer.attr(ATTR_SAVE_RECORD, (String) consumingMap.get(ATTR_SAVE_RECORD)); |
||||
writer.end(); |
||||
} |
||||
|
||||
@Override |
||||
public void readXML(XMLableReader reader) { |
||||
if (!reader.isChildNode()) { |
||||
idleDayCount = reader.getAttrAsInt(ATTR_DAY_COUNT, 0); |
||||
testTemplate = reader.getAttrAsBoolean(TEST_TEMPLATE_FLAG, false); |
||||
templateID = reader.getAttrAsString(ATTR_TEMPLATE_ID, StringUtils.EMPTY); |
||||
originID = reader.getAttrAsString(ATTR_ORIGIN_ID, StringUtils.EMPTY); |
||||
} else { |
||||
try { |
||||
String name = reader.getTagName(); |
||||
if (XML_PROCESS_MAP.equals(name)) { |
||||
processMap.put(ATTR_PROCESS, reader.getAttrAsString(ATTR_PROCESS, StringUtils.EMPTY)); |
||||
processMap.put(ATTR_FLOAT_COUNT, reader.getAttrAsInt(ATTR_FLOAT_COUNT, 0)); |
||||
processMap.put(ATTR_WIDGET_COUNT, reader.getAttrAsInt(ATTR_WIDGET_COUNT, 0)); |
||||
processMap.put(ATTR_CELL_COUNT, reader.getAttrAsInt(ATTR_CELL_COUNT, 0)); |
||||
processMap.put(ATTR_BLOCK_COUNT, reader.getAttrAsInt(ATTR_BLOCK_COUNT, 0)); |
||||
processMap.put(ATTR_REPORT_TYPE, reader.getAttrAsInt(ATTR_REPORT_TYPE, 0)); |
||||
processMap.put(ATTR_PARA_APPLY, reader.getAttrAsInt(ATTR_PARA_APPLY, 0)); |
||||
processMap.put(ATTR_COMPONENTS_INFO, reader.getAttrAsString(ATTR_COMPONENTS_INFO, StringUtils.EMPTY)); |
||||
processMap.put(ATTR_REUSE_CMP_LIST, reader.getAttrAsString(ATTR_REUSE_CMP_LIST, StringUtils.EMPTY)); |
||||
processMap.put(ATTR_TEMPLATE_ID, templateID); |
||||
} else if (XML_CONSUMING_MAP.equals(name)) { |
||||
consumingMap.put(ATTR_CREATE_TIME, reader.getAttrAsString(ATTR_CREATE_TIME, StringUtils.EMPTY)); |
||||
consumingMap.put(ATTR_TEMPLATE_ID, templateID); |
||||
consumingMap.put(ATTR_ORIGIN_ID, originID); |
||||
consumingMap.put(ATTR_UUID, reader.getAttrAsString(ATTR_UUID, StringUtils.EMPTY)); |
||||
consumingMap.put(ATTR_UID, reader.getAttrAsInt(ATTR_UID, 0)); |
||||
consumingMap.put(ATTR_SAVE_RECORD, reader.getAttrAsString(ATTR_SAVE_RECORD, StringUtils.EMPTY)); |
||||
} |
||||
} catch (Exception ex) { |
||||
// 什么也不做,使用默认值
|
||||
} |
||||
} |
||||
} |
||||
|
||||
@Override |
||||
public boolean isTestTemplate() { |
||||
return testTemplate; |
||||
} |
||||
|
||||
public static boolean isTestTemplate(int reportType, int cellCount, int floatCount, int blockCount, int widgetCount) { |
||||
boolean isTestTemplate; |
||||
if (reportType == 0) { // 普通报表
|
||||
isTestTemplate = cellCount <= VALID_CELL_COUNT && floatCount <= 1 && widgetCount <= VALID_WIDGET_COUNT; |
||||
} else if (reportType == 1) { // 聚合报表
|
||||
isTestTemplate = blockCount <= 1 && widgetCount <= VALID_WIDGET_COUNT; |
||||
} else { // 表单(reportType == 2)
|
||||
isTestTemplate = widgetCount <= 1; |
||||
} |
||||
return isTestTemplate; |
||||
} |
||||
|
||||
@Override |
||||
protected boolean isComplete() { |
||||
return true; |
||||
} |
||||
|
||||
@Override |
||||
public Map<String, String> getSendInfo() { |
||||
Map<String, String> sendMap = new HashMap<>(); |
||||
sendMap.put(CONSUMING_URL, JSONFactory.createJSON(JSON.OBJECT, consumingMap).toString()); |
||||
sendMap.put(PROCESS_URL, JSONFactory.createJSON(JSON.OBJECT, processMap).toString()); |
||||
return sendMap; |
||||
} |
||||
|
||||
|
||||
void updateProcessMap(TemplateProcessInfo processInfo) { |
||||
HashMap<String, Object> processMap = new HashMap<>(); |
||||
|
||||
// 暂不支持模版制作过程的收集
|
||||
processMap.put(ATTR_PROCESS, StringUtils.EMPTY); |
||||
|
||||
processMap.put(ATTR_REPORT_TYPE, processInfo.getReportType()); |
||||
processMap.put(ATTR_CELL_COUNT, processInfo.getCellCount()); |
||||
processMap.put(ATTR_FLOAT_COUNT, processInfo.getFloatCount()); |
||||
processMap.put(ATTR_BLOCK_COUNT, processInfo.getBlockCount()); |
||||
processMap.put(ATTR_WIDGET_COUNT, processInfo.getWidgetCount()); |
||||
processMap.put(ATTR_PARA_APPLY, processInfo.useParaPane() ? 1 : 0); |
||||
processMap.put(ATTR_COMPONENTS_INFO, processInfo.getComponentsInfo().toString()); |
||||
processMap.put(ATTR_REUSE_CMP_LIST, processInfo.getReuseCmpList().toString()); |
||||
this.processMap = processMap; |
||||
} |
||||
|
||||
|
||||
int getIdleDayCount() { |
||||
return this.idleDayCount; |
||||
} |
||||
} |
@ -1,210 +0,0 @@
|
||||
package com.fr.design.mainframe.template.info; |
||||
|
||||
import com.fr.design.mainframe.burying.point.AbstractPointCollector; |
||||
import com.fr.design.mainframe.burying.point.AbstractPointInfo; |
||||
import com.fr.json.JSON; |
||||
import com.fr.json.JSONFactory; |
||||
import com.fr.json.JSONObject; |
||||
import com.fr.stable.StringUtils; |
||||
import com.fr.stable.xml.XMLPrintWriter; |
||||
import com.fr.stable.xml.XMLableReader; |
||||
|
||||
import java.util.ArrayList; |
||||
import java.util.List; |
||||
import java.util.Map; |
||||
import java.util.concurrent.ConcurrentHashMap; |
||||
|
||||
/** |
||||
* 做模板的过程和耗时收集,辅助类 |
||||
* Created by plough on 2017/2/21. |
||||
*/ |
||||
public class TemplateInfoCollector extends AbstractPointCollector<TemplateInfo> { |
||||
private static final String XML_TAG = "TplInfo"; |
||||
private static final String XML_TEMPLATE_INFO_LIST = "TemplateInfoList"; |
||||
private static final String XML_FILE_NAME = "tpl.info"; |
||||
private static TemplateInfoCollector instance; |
||||
private DesignerOpenHistory designerOpenHistory = DesignerOpenHistory.getInstance(); |
||||
//记录指定模板最新的模板耗时信息ID
|
||||
private Map<String, Long> latestTemplateInfo; |
||||
|
||||
private TemplateInfoCollector() { |
||||
super(); |
||||
} |
||||
|
||||
public static TemplateInfoCollector getInstance() { |
||||
if (instance == null) { |
||||
instance = new TemplateInfoCollector(); |
||||
} |
||||
return instance; |
||||
} |
||||
|
||||
/** |
||||
* 根据模板ID是否在收集列表中,判断是否需要收集当前模板的信息 |
||||
*/ |
||||
public boolean contains(String templateID) { |
||||
return StringUtils.isNotEmpty(templateID) && latestTemplateInfo.containsKey(templateID); |
||||
} |
||||
|
||||
/** |
||||
* 收集模板信息。如果之前没有记录,则新增;如果已有记录,则更新。 |
||||
* 同时将最新数据保存到文件中。 |
||||
* |
||||
* @param templateID 模版id |
||||
* @param originID 模版的原始id,仅对另存为的模版有效,对于非另存为的模版,值总是为空 |
||||
* @param processInfo 包含模版的一些基本信息(如模版类型、包含控件数量等) |
||||
* @param timeConsume 本次制作耗时,单位为 s |
||||
*/ |
||||
@Override |
||||
public void collectInfo(String templateID, String originID, TemplateProcessInfo processInfo, int timeConsume) { |
||||
if (!shouldCollectInfo()) { |
||||
return; |
||||
} |
||||
long saveTime = System.currentTimeMillis(); |
||||
|
||||
TemplateInfo templateInfo = createTemplateInfo(templateID, originID, saveTime, timeConsume); |
||||
|
||||
pointInfoMap.put(templateInfo.getTemplateInfoID(), templateInfo); |
||||
|
||||
//更新下此模板最新保存记录
|
||||
updateLatestTemplateInfo(templateID, saveTime); |
||||
|
||||
// 收集模版基本信息
|
||||
templateInfo.updateProcessMap(processInfo); |
||||
//设置是否是测试模板
|
||||
templateInfo.setTestTemplate(processInfo.isTestTemplate()); |
||||
// 刷新闲置日计数器
|
||||
templateInfo.resetIdleDayCount(); |
||||
|
||||
|
||||
// 每次更新之后,都同步到暂存文件中
|
||||
saveInfo(); |
||||
} |
||||
|
||||
private TemplateInfo createTemplateInfo(String templateID, String originID, long saveTime, int timeConsume){ |
||||
JSONObject saveRecord = JSONFactory.createJSON(JSON.OBJECT); |
||||
saveRecord.put("time", saveTime); |
||||
saveRecord.put("consume", timeConsume); |
||||
if (this.contains(templateID)){ |
||||
return TemplateInfo.newInstance(templateID, originID, saveRecord.toString(), getTemplateCreateTime(templateID)); |
||||
} |
||||
return TemplateInfo.newInstance(templateID, originID, saveRecord.toString()); |
||||
} |
||||
|
||||
private String getTemplateCreateTime(String templateID) { |
||||
long latestSaveTime = latestTemplateInfo.get(templateID); |
||||
TemplateInfo latestTemplateInfo = pointInfoMap.get(templateID + "_" + latestSaveTime); |
||||
return latestTemplateInfo.getTemplateCreateTime(); |
||||
} |
||||
|
||||
/** |
||||
* 更新 day_count:打开设计器却未编辑模板的连续日子 |
||||
*/ |
||||
@Override |
||||
protected void addIdleDayCount() { |
||||
// 判断今天是否第一次打开设计器,为了防止同一天内,多次 addIdleDayCount
|
||||
if (designerOpenHistory.hasOpenedToday()) { |
||||
return; |
||||
} |
||||
for (TemplateInfo templateInfo : pointInfoMap.values()) { |
||||
templateInfo.addIdleDayCountByOne(); |
||||
} |
||||
designerOpenHistory.update(); |
||||
} |
||||
|
||||
private void updateLatestTemplateInfo(TemplateInfo templateInfo) { |
||||
String templateID = templateInfo.getTemplateID(); |
||||
if (latestTemplateInfo.containsKey(templateID)) { |
||||
long latestSaveTime = latestTemplateInfo.get(templateID); |
||||
updateLatestTemplateInfo(templateID, Math.max(latestSaveTime, templateInfo.getSaveTime())); |
||||
} else { |
||||
updateLatestTemplateInfo(templateID, templateInfo.getSaveTime()); |
||||
} |
||||
} |
||||
|
||||
private void updateLatestTemplateInfo(String templateID, long saveTime) { |
||||
latestTemplateInfo.put(templateID, saveTime); |
||||
} |
||||
|
||||
@Override |
||||
public void readXML(XMLableReader reader) { |
||||
if (reader.isChildNode()) { |
||||
try { |
||||
String name = reader.getTagName(); |
||||
if (DesignerOpenHistory.XML_TAG.equals(name)) { |
||||
if (designerOpenHistory == null) { |
||||
designerOpenHistory = DesignerOpenHistory.getInstance(); |
||||
} |
||||
reader.readXMLObject(designerOpenHistory); |
||||
} else if (TemplateInfo.XML_TAG.equals(name)) { |
||||
TemplateInfo templateInfo = TemplateInfo.newInstanceByRead(reader); |
||||
updateLatestTemplateInfo(templateInfo); |
||||
pointInfoMap.put(templateInfo.getTemplateInfoID(), templateInfo); |
||||
} |
||||
} catch (Exception ex) { |
||||
// 什么也不做,使用默认值
|
||||
} |
||||
} |
||||
} |
||||
|
||||
@Override |
||||
public void writeXML(XMLPrintWriter writer) { |
||||
writer.startTAG(XML_TAG); |
||||
|
||||
designerOpenHistory.writeXML(writer); |
||||
|
||||
writer.startTAG(XML_TEMPLATE_INFO_LIST); |
||||
for (TemplateInfo templateInfo : pointInfoMap.values()) { |
||||
templateInfo.writeXML(writer); |
||||
} |
||||
writer.end(); |
||||
|
||||
writer.end(); |
||||
} |
||||
|
||||
/** |
||||
* 获取缓存文件存放路径 |
||||
*/ |
||||
@Override |
||||
protected String getInfoFilePath() { |
||||
return XML_FILE_NAME; |
||||
} |
||||
|
||||
@Override |
||||
public void sendPointInfo() { |
||||
addIdleDayCount(); |
||||
List<String> removeList = new ArrayList<>(); |
||||
List<String> sendList = new ArrayList<>(); |
||||
for (String latestTemplateInfokey : latestTemplateInfo.keySet()) { |
||||
AbstractPointInfo pointInfo = pointInfoMap.get(latestTemplateInfokey + "_" + latestTemplateInfo.get(latestTemplateInfokey)); |
||||
if (pointInfo.isTestTemplate()) { |
||||
continue; |
||||
} |
||||
for (String key : pointInfoMap.keySet()) { |
||||
if (key.startsWith(latestTemplateInfokey)) { |
||||
sendList.add(key); |
||||
} |
||||
} |
||||
} |
||||
// 发送记录
|
||||
for (String key : sendList) { |
||||
if (SendHelper.sendPointInfo(pointInfoMap.get(key))) { |
||||
removeList.add(key); |
||||
} |
||||
} |
||||
|
||||
// 清空记录
|
||||
for (String key : removeList) { |
||||
pointInfoMap.remove(key); |
||||
} |
||||
|
||||
saveInfo(); |
||||
} |
||||
|
||||
|
||||
@Override |
||||
protected void loadFromFile() { |
||||
latestTemplateInfo = new ConcurrentHashMap<>(); |
||||
super.loadFromFile(); |
||||
} |
||||
|
||||
} |
@ -1,38 +1,7 @@
|
||||
package com.fr.design.mainframe.template.info; |
||||
|
||||
import com.fr.invoke.Reflect; |
||||
import com.fr.json.JSONObject; |
||||
import com.fr.stable.xml.XMLableReader; |
||||
import com.fr.third.javax.xml.stream.XMLStreamException; |
||||
|
||||
import java.io.StringReader; |
||||
import java.util.Map; |
||||
|
||||
import static org.junit.Assert.assertTrue; |
||||
|
||||
/** |
||||
* Created by plough on 2019/4/25. |
||||
*/ |
||||
public class SendHelperTest { |
||||
private static final String CONSUMING_URL = "http://cloud.fanruan.com/api/monitor/record_of_reports_consuming/single"; |
||||
private static final String PROCESS_URL = "http://cloud.fanruan.com/api/monitor/record_of_reports_process/single"; |
||||
|
||||
private static final String NORMAL_INFO = "<TemplateInfo templateID=\"16a988ce-8529-42f5-b17c-2ee849355071\" day_count=\"9\">\n" + |
||||
"<processMap process=\"\" float_count=\"0\" widget_count=\"0\" cell_count=\"1\" block_count=\"0\" report_type=\"0\"/>\n" + |
||||
"<consumingMap activitykey=\"2e0ea413-fa9c241e0-9723-4354fce51e81\" jar_time=\"不是安装版本\" create_time=\"2019-03-26 16:13\" uuid=\"476ca2cc-f789-4c5d-8e89-ef146580775c\" time_consume=\"129\" version=\"10.0\" username=\"plough\"/>\n" + |
||||
"</TemplateInfo>"; |
||||
|
||||
// 只在调试的时候运行,不需要每次都自动运行
|
||||
public static void main(String[] args) throws XMLStreamException { |
||||
StringReader sr = new StringReader(NORMAL_INFO); |
||||
XMLableReader xmlReader = XMLableReader.createXMLableReader(sr); |
||||
TemplateInfo templateInfo = TemplateInfo.newInstanceByRead(xmlReader); |
||||
Map consumingMap = Reflect.on(templateInfo).field("consumingMap").get(); |
||||
Map processMap = Reflect.on(templateInfo).field("processMap").get(); |
||||
boolean res = Reflect.on(SendHelper.class).call("sendSinglePointInfo", CONSUMING_URL, new JSONObject(consumingMap).toString()).get(); |
||||
assertTrue(res); |
||||
|
||||
boolean res2 = Reflect.on(SendHelper.class).call("sendSinglePointInfo", PROCESS_URL, new JSONObject(processMap).toString()).get(); |
||||
assertTrue(res2); |
||||
} |
||||
} |
||||
|
@ -1,252 +0,0 @@
|
||||
package com.fr.design.mainframe.template.info; |
||||
|
||||
import com.fr.config.MarketConfig; |
||||
import com.fr.design.DesignerEnvManager; |
||||
import com.fr.invoke.Reflect; |
||||
import com.fr.json.JSON; |
||||
import com.fr.json.JSONArray; |
||||
import com.fr.json.JSONFactory; |
||||
import com.fr.stable.ProductConstants; |
||||
import com.fr.stable.StringUtils; |
||||
import com.fr.third.org.apache.commons.io.FileUtils; |
||||
import org.easymock.EasyMock; |
||||
import org.junit.After; |
||||
import org.junit.Assert; |
||||
import org.junit.Before; |
||||
import org.junit.Test; |
||||
import org.junit.runner.RunWith; |
||||
import org.powermock.api.easymock.PowerMock; |
||||
import org.powermock.core.classloader.annotations.PrepareForTest; |
||||
import org.powermock.core.classloader.annotations.SuppressStaticInitializationFor; |
||||
import org.powermock.modules.junit4.PowerMockRunner; |
||||
|
||||
import java.io.File; |
||||
import java.io.IOException; |
||||
import java.util.Map; |
||||
|
||||
import static com.fr.design.mainframe.template.info.TemplateInfoTestHelper.assertJsonStringEquals; |
||||
import static com.fr.design.mainframe.template.info.TemplateInfoTestHelper.setUpMockForNewInstance; |
||||
import static org.junit.Assert.assertEquals; |
||||
import static org.junit.Assert.assertTrue; |
||||
|
||||
/** |
||||
* Created by plough on 2019/4/18. |
||||
*/ |
||||
@RunWith(PowerMockRunner.class) |
||||
@PrepareForTest({ProductConstants.class, MarketConfig.class, DesignerEnvManager.class}) |
||||
@SuppressStaticInitializationFor({"com.fr.jvm.assist.FineAssist"}) |
||||
public class TemplateInfoCollectorTest { |
||||
private String filePath; |
||||
private String initialFileContent; |
||||
private TemplateProcessInfo mockProcessInfo; |
||||
|
||||
@Before |
||||
public void setUp() throws IOException { |
||||
PowerMock.mockStatic(ProductConstants.class); |
||||
|
||||
filePath = getClass().getResource("tpl.info").getPath(); |
||||
String dirPath = filePath.substring(0, filePath.indexOf("tpl.info")); |
||||
EasyMock.expect(ProductConstants.getEnvHome()).andReturn(dirPath).anyTimes(); |
||||
EasyMock.replay(); |
||||
PowerMock.replayAll(); |
||||
|
||||
mockProcessInfo = EasyMock.mock(TemplateProcessInfo.class); |
||||
EasyMock.expect(mockProcessInfo.getBlockCount()).andReturn(3).anyTimes(); |
||||
EasyMock.expect(mockProcessInfo.getCellCount()).andReturn(13).anyTimes(); |
||||
EasyMock.expect(mockProcessInfo.getFloatCount()).andReturn(1).anyTimes(); |
||||
EasyMock.expect(mockProcessInfo.getReportType()).andReturn(0).anyTimes(); |
||||
EasyMock.expect(mockProcessInfo.getWidgetCount()).andReturn(0).anyTimes(); |
||||
EasyMock.expect(mockProcessInfo.useParaPane()).andReturn(false).anyTimes(); |
||||
EasyMock.expect(mockProcessInfo.getComponentsInfo()).andReturn(new JSONArray()).anyTimes(); |
||||
EasyMock.expect(mockProcessInfo.isTestTemplate()).andReturn(true).anyTimes(); |
||||
EasyMock.expect(mockProcessInfo.getReuseCmpList()).andReturn(JSONArray.create().add("reuse-id-1")).anyTimes(); |
||||
EasyMock.replay(mockProcessInfo); |
||||
|
||||
// 缓存 tpl.info
|
||||
initialFileContent = FileUtils.readFileToString(new File(filePath), "utf-8"); |
||||
|
||||
Reflect.on(TemplateInfoCollector.class).set("instance", null); |
||||
// 后执行 testReadXML 用例时,之前保留的单例会造成影响
|
||||
Reflect.on(DesignerOpenHistory.class).set("singleton", null); |
||||
} |
||||
|
||||
@After |
||||
public void tearDown() throws IOException { |
||||
// 恢复 tpl.info
|
||||
FileUtils.writeStringToFile(new File(filePath), initialFileContent, "utf-8"); |
||||
} |
||||
|
||||
@Test |
||||
public void testReadXML() { |
||||
assertEquals(",,", DesignerOpenHistory.getInstance().toString()); |
||||
|
||||
TemplateInfoCollector collector = TemplateInfoCollector.getInstance(); |
||||
|
||||
assertEquals("2020-05-07,2020-05-06,2020-04-30", DesignerOpenHistory.getInstance().toString()); |
||||
} |
||||
|
||||
@Test |
||||
public void testCollectInfo() throws Exception { |
||||
setUpMockForNewInstance(); |
||||
TemplateInfoCollector collector = TemplateInfoCollector.getInstance(); |
||||
|
||||
String templateID = "e5d7dbb2-d1df-43d4-b974-67acb5ecbffa"; |
||||
int timeConsume = 200; |
||||
|
||||
collector.collectInfo(templateID, StringUtils.EMPTY, mockProcessInfo, timeConsume); |
||||
|
||||
// 检查是否写入成功
|
||||
Reflect.on(collector).call("loadFromFile"); |
||||
TemplateInfo templateInfo = getTemplateInfoByID(templateID); |
||||
|
||||
Map consumingMap = Reflect.on(templateInfo).field("consumingMap").get(); |
||||
Map processMap = Reflect.on(templateInfo).field("processMap").get(); |
||||
|
||||
assertJsonStringEquals("{\"process\":\"\",\"float_count\":1,\"widget_count\":0," + |
||||
"\"cell_count\":13,\"paraApply\":0,\"block_count\":3,\"report_type\":0,\"components_info\":\"[]\"," + |
||||
"\"templateID\":\"e5d7dbb2-d1df-43d4-b974-67acb5ecbffa\",\"reuseCmptList\":\"[\\\"reuse-id-1\\\"]\"" + |
||||
"}", |
||||
JSONFactory.createJSON(JSON.OBJECT, processMap).toString()); |
||||
|
||||
Assert.assertEquals(71113, consumingMap.get("uid")); |
||||
Assert.assertEquals("2020-05-07 17:25", consumingMap.get("create_time")); |
||||
Assert.assertEquals("e5d7dbb2-d1df-43d4-b974-67acb5ecbffa", consumingMap.get("templateID")); |
||||
Assert.assertEquals("6b6699ff-ec63-43b0-9deb-b580a5f10411", consumingMap.get("uuid")); |
||||
} |
||||
|
||||
@Test |
||||
public void testCollectInfoForNewTemplate() throws Exception { |
||||
setUpMockForNewInstance(); |
||||
|
||||
TemplateInfoCollector collector = TemplateInfoCollector.getInstance(); |
||||
|
||||
String templateID = "e5d7dbb2-d1df-43d4-b974-67acb5ecbffa"; |
||||
int timeConsume = 200; |
||||
|
||||
collector.collectInfo(templateID, StringUtils.EMPTY, mockProcessInfo, timeConsume); |
||||
|
||||
// 检查是否写入成功
|
||||
Reflect.on(collector).call("loadFromFile"); |
||||
assertTrue(collector.contains(templateID)); |
||||
|
||||
TemplateInfo templateInfo = getTemplateInfoByID(templateID); |
||||
Map processMap = Reflect.on(templateInfo).field("processMap").get(); |
||||
|
||||
assertEquals(templateID, templateInfo.getTemplateID()); |
||||
|
||||
assertJsonStringEquals("{\"process\":\"\",\"float_count\":1,\"widget_count\":0," + |
||||
"\"cell_count\":13,\"paraApply\":0,\"block_count\":3,\"report_type\":0,\"components_info\":\"[]\"," + |
||||
"\"templateID\":\"e5d7dbb2-d1df-43d4-b974-67acb5ecbffa\",\"reuseCmptList\":\"[\\\"reuse-id-1\\\"]\"" + |
||||
"}", JSONFactory.createJSON(JSON.OBJECT, processMap).toString()); |
||||
|
||||
Map<String, Object> consumingMap = Reflect.on(templateInfo).field("consumingMap").get(); |
||||
Assert.assertEquals(71113, consumingMap.get("uid")); |
||||
Assert.assertEquals("2020-05-07 17:25", consumingMap.get("create_time")); |
||||
Assert.assertEquals("e5d7dbb2-d1df-43d4-b974-67acb5ecbffa", consumingMap.get("templateID")); |
||||
Assert.assertEquals("6b6699ff-ec63-43b0-9deb-b580a5f10411", consumingMap.get("uuid")); |
||||
} |
||||
|
||||
@Test |
||||
public void testCollectInfoWhenSaveAs() throws Exception { |
||||
setUpMockForNewInstance(); |
||||
|
||||
TemplateInfoCollector collector = TemplateInfoCollector.getInstance(); |
||||
|
||||
String templateID = "e5d7dbb2-d1df-43d4-b974-67acb5ecbffa"; |
||||
String originID = "16a988ce-8529-42f5-b17c-2ee849355071"; |
||||
int timeConsume = 200; |
||||
|
||||
collector.collectInfo(templateID, originID, mockProcessInfo, timeConsume); |
||||
|
||||
// 检查是否写入成功
|
||||
Reflect.on(collector).call("loadFromFile"); |
||||
TemplateInfo templateInfo = getTemplateInfoByID(templateID); |
||||
Map processMap = Reflect.on(templateInfo).field("processMap").get(); |
||||
|
||||
assertJsonStringEquals("{\"process\":\"\",\"float_count\":1,\"widget_count\":0," + |
||||
"\"cell_count\":13,\"paraApply\":0,\"block_count\":3,\"report_type\":0,\"components_info\":\"[]\"," + |
||||
"\"templateID\":\"e5d7dbb2-d1df-43d4-b974-67acb5ecbffa\",\"reuseCmptList\":\"[\\\"reuse-id-1\\\"]\"" + |
||||
"}", JSONFactory.createJSON(JSON.OBJECT, processMap).toString()); |
||||
|
||||
Map<String, Object> consumingMap = Reflect.on(templateInfo).field("consumingMap").get(); |
||||
Assert.assertEquals(71113, consumingMap.get("uid")); |
||||
Assert.assertEquals("2020-05-07 17:25", consumingMap.get("create_time")); |
||||
Assert.assertEquals("e5d7dbb2-d1df-43d4-b974-67acb5ecbffa", consumingMap.get("templateID")); |
||||
Assert.assertEquals("6b6699ff-ec63-43b0-9deb-b580a5f10411", consumingMap.get("uuid")); |
||||
Assert.assertEquals("16a988ce-8529-42f5-b17c-2ee849355071", consumingMap.get("originID")); |
||||
} |
||||
|
||||
@Test |
||||
public void testCollectInfoWhenSaveAsWithNoTrackOriginID() throws Exception { |
||||
setUpMockForNewInstance(); |
||||
|
||||
TemplateInfoCollector collector = TemplateInfoCollector.getInstance(); |
||||
|
||||
String templateID = "e5d7dbb2-d1df-43d4-b974-67acb5ecbffa"; |
||||
String originID = "3kha8jcs-31xw-42f5-h2ww-2ee84935312z"; |
||||
int timeConsume = 200; |
||||
|
||||
collector.collectInfo(templateID, originID, mockProcessInfo, timeConsume); |
||||
|
||||
TemplateInfo templateInfo = getTemplateInfoByID(templateID); |
||||
assertEquals(templateID, templateInfo.getTemplateID()); |
||||
|
||||
Map<String, Object> consumingMap = Reflect.on(templateInfo).field("consumingMap").get(); |
||||
Assert.assertEquals(71113, consumingMap.get("uid")); |
||||
Assert.assertEquals("2020-05-07 17:25", consumingMap.get("create_time")); |
||||
Assert.assertEquals("e5d7dbb2-d1df-43d4-b974-67acb5ecbffa", consumingMap.get("templateID")); |
||||
Assert.assertEquals("6b6699ff-ec63-43b0-9deb-b580a5f10411", consumingMap.get("uuid")); |
||||
Assert.assertEquals("3kha8jcs-31xw-42f5-h2ww-2ee84935312z", consumingMap.get("originID")); |
||||
} |
||||
|
||||
@Test |
||||
public void testAddIdleDateCount() { |
||||
String templateID = "e5d7dbb2-d1df-43d4-b974-67acb5ecbffa"; |
||||
TemplateInfoCollector collecter = TemplateInfoCollector.getInstance(); |
||||
TemplateInfo templateInfo = getTemplateInfoByID(templateID); |
||||
|
||||
assertEquals(0, templateInfo.getIdleDayCount()); |
||||
|
||||
Reflect.on(collecter).call("addIdleDayCount"); |
||||
assertEquals(1, templateInfo.getIdleDayCount()); |
||||
|
||||
// 同一天内多次调用无效
|
||||
Reflect.on(collecter).call("addIdleDayCount"); |
||||
assertEquals(1, templateInfo.getIdleDayCount()); |
||||
} |
||||
|
||||
@Test |
||||
public void testContains() { |
||||
TemplateInfoCollector collector = TemplateInfoCollector.getInstance(); |
||||
String templateID1 = "e5d7dbb2-d1df-43d4-b974-67acb5ecbffa"; |
||||
Assert.assertTrue(collector.contains(templateID1)); |
||||
String templateID2 = "e5d7dbb2-d1df-43d4-b974-67acb5ecbffb"; |
||||
Assert.assertFalse(collector.contains(templateID2)); |
||||
} |
||||
|
||||
@Test |
||||
public void testGetTemplateCreateTime() throws Exception { |
||||
setUpMockForNewInstance(); |
||||
TemplateInfoCollector collector = TemplateInfoCollector.getInstance(); |
||||
String templateID = "e5d7dbb2-d1df-43d4-b974-67acb5ecbffa"; |
||||
String createTime = Reflect.on(collector).call("getTemplateCreateTime", templateID).get(); |
||||
Assert.assertEquals("2020-05-07 17:25", createTime); |
||||
|
||||
templateID = "2521d03c-b238-41a5-9a1d-2498efff3a97"; |
||||
createTime = Reflect.on(collector).call("getTemplateCreateTime", templateID).get(); |
||||
Assert.assertEquals("2020-05-07 17:45", createTime); |
||||
} |
||||
|
||||
|
||||
private TemplateInfo getTemplateInfoByID(String templateID) { |
||||
TemplateInfoCollector collector = TemplateInfoCollector.getInstance(); |
||||
Map<String, Long> latestTemplateInfo = Reflect.on(collector).field("latestTemplateInfo").get(); |
||||
Map<String, TemplateInfo> pointInfoMap = Reflect.on(collector).field("pointInfoMap").get(); |
||||
if (latestTemplateInfo.containsKey(templateID)) { |
||||
long latestSaveTime = latestTemplateInfo.get(templateID); |
||||
return pointInfoMap.get(templateID + "_" + latestSaveTime); |
||||
} else { |
||||
return TemplateInfo.newInstance(templateID); |
||||
} |
||||
} |
||||
} |
@ -1,143 +0,0 @@
|
||||
package com.fr.design.mainframe.template.info; |
||||
|
||||
import com.fr.config.MarketConfig; |
||||
import com.fr.design.DesignerEnvManager; |
||||
import com.fr.invoke.Reflect; |
||||
import com.fr.json.JSON; |
||||
import com.fr.json.JSONFactory; |
||||
import com.fr.json.JSONObject; |
||||
import com.fr.stable.StringUtils; |
||||
import com.fr.stable.xml.XMLableReader; |
||||
import com.fr.third.javax.xml.stream.XMLStreamException; |
||||
import org.junit.Assert; |
||||
import org.junit.Before; |
||||
import org.junit.Test; |
||||
import org.junit.runner.RunWith; |
||||
import org.powermock.core.classloader.annotations.PrepareForTest; |
||||
import org.powermock.modules.junit4.PowerMockRunner; |
||||
|
||||
import java.io.StringReader; |
||||
import java.util.Map; |
||||
|
||||
import static com.fr.design.mainframe.template.info.TemplateInfoTestHelper.assertJsonStringEquals; |
||||
import static com.fr.design.mainframe.template.info.TemplateInfoTestHelper.setUpMockForNewInstance; |
||||
import static org.junit.Assert.assertEquals; |
||||
|
||||
/** |
||||
* Created by plough on 2019/4/19. |
||||
*/ |
||||
@RunWith(PowerMockRunner.class) |
||||
@PrepareForTest({MarketConfig.class, DesignerEnvManager.class}) |
||||
public class TemplateInfoTest { |
||||
|
||||
private static final String NORMAL_INFO = "<TemplateInfo templateID=\"aac1139e-018b-4481-867a-a18fc6d6f3e6\" day_count=\"0\" test_template=\"true\">\n" + |
||||
"<processMap process=\"\" float_count=\"0\" widget_count=\"0\" cell_count=\"3\" block_count=\"0\" report_type=\"0\" paraApply=\"0\" components_info=\"[]\"/>\n" + |
||||
"<consumingMap create_time=\"2020-05-07 17:28\" uuid=\"6b6699ff-ec63-43b0-9deb-b580a5f10411\" uid=\"71113\" saveRecord=\"{"time":1588843693000,"consume":4}\"/>\n" + |
||||
"</TemplateInfo>"; |
||||
|
||||
private static final String SAVE_AS_INFO = "<TemplateInfo templateID=\"2521d03c-b238-41a5-9a1d-2498efff3a97\" originID=\"aac1139e-018b-4481-867a-a18fc6d6f3e6\" day_count=\"0\" test_template=\"true\">\n" + |
||||
"<processMap process=\"\" float_count=\"0\" widget_count=\"0\" cell_count=\"3\" block_count=\"0\" report_type=\"0\" paraApply=\"0\" components_info=\"[]\"/>\n" + |
||||
"<consumingMap create_time=\"2020-05-07 17:45\" uuid=\"6b6699ff-ec63-43b0-9deb-b580a5f10411\" uid=\"71113\" saveRecord=\"{"time":1588844751000,"consume":1058}\"/>\n" + |
||||
"</TemplateInfo>"; |
||||
|
||||
private TemplateInfo templateInfo; |
||||
private TemplateInfo templateInfoSaveAs; // 另存为的模版记录
|
||||
|
||||
@Before |
||||
public void setUp() throws XMLStreamException { |
||||
templateInfo = createTemplateInfo(NORMAL_INFO); |
||||
templateInfoSaveAs = createTemplateInfo(SAVE_AS_INFO); |
||||
} |
||||
|
||||
@Test |
||||
public void testNewInstance() throws Exception { |
||||
setUpMockForNewInstance(); |
||||
|
||||
String templateID = "24avc8n2-1iq8-iuj2-wx24-8yy0i8132302"; |
||||
TemplateInfo templateInfo = TemplateInfo.newInstance(templateID); |
||||
assertEquals(templateID, templateInfo.getTemplateID()); |
||||
assertEquals(StringUtils.EMPTY, Reflect.on(templateInfo).field("originID").get()); |
||||
assertEquals(0, (int) Reflect.on(templateInfo).field("idleDayCount").get()); |
||||
assertEquals(false, templateInfo.isTestTemplate()); |
||||
|
||||
Map<String, Object> consumingMap = Reflect.on(templateInfo).field("consumingMap").get(); |
||||
assertEquals(templateID, consumingMap.get("templateID")); |
||||
assertEquals(StringUtils.EMPTY, consumingMap.get("originID")); |
||||
assertEquals("6b6699ff-ec63-43b0-9deb-b580a5f10411", consumingMap.get("uuid")); |
||||
assertEquals(71113, consumingMap.get("uid")); |
||||
assertEquals(StringUtils.EMPTY, consumingMap.get("saveRecord")); |
||||
} |
||||
|
||||
@Test |
||||
public void testNewInstanceWithMoreArgs() throws Exception { |
||||
setUpMockForNewInstance(); |
||||
|
||||
String templateID = "24121212-u2c8-ncd2-82nx-8ud0i8138888"; |
||||
String originID = "24avc8n2-1iq8-iuj2-wx24-8yy0i8132302"; |
||||
String saveRecord = "{\"time\";:1588843629000,\"consume\":81}"; |
||||
String createTime = "2020-05-07 17:25"; |
||||
TemplateInfo templateInfo = TemplateInfo.newInstance(templateID, originID, saveRecord, createTime); |
||||
assertEquals(templateID, templateInfo.getTemplateID()); |
||||
assertEquals(originID, Reflect.on(templateInfo).field("originID").get()); |
||||
assertEquals(0, (int) Reflect.on(templateInfo).field("idleDayCount").get()); |
||||
assertEquals(false, templateInfo.isTestTemplate()); |
||||
|
||||
Map<String, Object> consumingMap = Reflect.on(templateInfo).field("consumingMap").get(); |
||||
assertEquals(templateID, consumingMap.get("templateID")); |
||||
assertEquals(originID, consumingMap.get("originID")); |
||||
assertEquals("6b6699ff-ec63-43b0-9deb-b580a5f10411", consumingMap.get("uuid")); |
||||
assertEquals(71113, consumingMap.get("uid")); |
||||
assertEquals(saveRecord, consumingMap.get("saveRecord")); |
||||
assertEquals(createTime, consumingMap.get("create_time")); |
||||
} |
||||
|
||||
@Test |
||||
public void testGetTemplateID() { |
||||
assertEquals("aac1139e-018b-4481-867a-a18fc6d6f3e6", templateInfo.getTemplateID()); |
||||
assertEquals("2521d03c-b238-41a5-9a1d-2498efff3a97", templateInfoSaveAs.getTemplateID()); |
||||
} |
||||
|
||||
@Test |
||||
public void testGetSendInfo() { |
||||
|
||||
Map consumingMap = Reflect.on(templateInfo).field("consumingMap").get(); |
||||
Map processMap = Reflect.on(templateInfo).field("processMap").get(); |
||||
Map consumingMap1 = Reflect.on(templateInfoSaveAs).field("consumingMap").get(); |
||||
Map processMap1 = Reflect.on(templateInfoSaveAs).field("processMap").get(); |
||||
assertJsonStringEquals("{\"uid\":71113,\"originID\":\"\",\"create_time\":\"2020-05-07 17:28\"," + |
||||
"\"saveRecord\":\"{\\\"time\\\":1588843693000,\\\"consume\\\":4}\"," + |
||||
"\"templateID\":\"aac1139e-018b-4481-867a-a18fc6d6f3e6\"," + |
||||
"\"uuid\":\"6b6699ff-ec63-43b0-9deb-b580a5f10411\"}", JSONFactory.createJSON(JSON.OBJECT, consumingMap).toString()); |
||||
|
||||
assertJsonStringEquals("{\"uid\":71113,\"originID\":\"aac1139e-018b-4481-867a-a18fc6d6f3e6\"," + |
||||
"\"create_time\":\"2020-05-07 17:45\",\"saveRecord\":\"{\\\"time\\\":1588844751000,\\\"consume\\\":1058}\"," + |
||||
"\"templateID\":\"2521d03c-b238-41a5-9a1d-2498efff3a97\"," + |
||||
"\"uuid\":\"6b6699ff-ec63-43b0-9deb-b580a5f10411\"}", JSONFactory.createJSON(JSON.OBJECT, consumingMap1).toString()); |
||||
assertJsonStringEquals("{\"process\":\"\",\"float_count\":0,\"widget_count\":0,\"cell_count\":3," + |
||||
"\"paraApply\":0,\"block_count\":0,\"report_type\":0,\"components_info\":\"[]\"," + |
||||
"\"templateID\":\"aac1139e-018b-4481-867a-a18fc6d6f3e6\"}", JSONFactory.createJSON(JSON.OBJECT, processMap).toString()); |
||||
assertJsonStringEquals("{\"process\":\"\",\"float_count\":0,\"widget_count\":0,\"cell_count\":3," + |
||||
"\"paraApply\":0,\"block_count\":0,\"report_type\":0,\"components_info\":\"[]\"," + |
||||
"\"templateID\":\"2521d03c-b238-41a5-9a1d-2498efff3a97\"}", JSONFactory.createJSON(JSON.OBJECT, processMap1).toString()); |
||||
} |
||||
|
||||
private TemplateInfo createTemplateInfo(String xmlContent) throws XMLStreamException { |
||||
StringReader sr = new StringReader(xmlContent); |
||||
XMLableReader xmlReader = XMLableReader.createXMLableReader(sr); |
||||
return TemplateInfo.newInstanceByRead(xmlReader); |
||||
} |
||||
|
||||
@Test |
||||
public void testGetSaveTime() { |
||||
Map consumingMap = Reflect.on(templateInfo).field("consumingMap").get(); |
||||
String saveRecord = (String) consumingMap.get("saveRecord"); |
||||
JSONObject object = JSONFactory.createJSON(JSON.OBJECT, saveRecord); |
||||
Assert.assertEquals(1588843693000L, object.optLong("time")); |
||||
} |
||||
|
||||
@Test |
||||
public void testGetTemplateCreateTime() { |
||||
Map consumingMap = Reflect.on(templateInfo).field("consumingMap").get(); |
||||
Assert.assertEquals("2020-05-07 17:28", (String) consumingMap.get("create_time")); |
||||
} |
||||
} |
Loading…
Reference in new issue