该类代码详见git:https://github.com/AppiumTestDistribution/AppiumTestDistribution/tree/master/src/main/java/com/appium/capabilities

我只知道他是用来做caps/capacities.json的json解析,但是具体怎么解析的不是很清楚,对jsonObject的类使用不清楚,看得很吃力,也没个注释。

部分代码如下:

/**
* 初始化caps/capabilities.json的设备配置文件,getAllATDOverrideEnvVars方法可以从系统变量中获取atd开头的key -value键值对
*/
public class CapabilityManager { private static CapabilityManager instance;
private JSONObject capabilities; /**
* 初始化配置文件:从caps/capabilities.json中读取设备信息
*/
private CapabilityManager() {
//设备配置路径
String capabilitiesFilePath = getCapabilityLocation();
// 解析json
JsonParser jsonParser = new JsonParser(capabilitiesFilePath);
StringBuilder varParsing = new StringBuilder(200);
varParsing.append("atd").append("_");
capabilities = loadAndOverrideFromEnvVars(jsonParser.getObjectFromJSON(),
new JSONObject(),
getAllATDOverrideEnvVars(),
varParsing);
} /**
* 单例模式
* @return 返回设备配置文件信息
*/
public static CapabilityManager getInstance() {
if (instance == null) {
instance = new CapabilityManager();
}
return instance;
} /**
* 返回当前系统的keyValue映射关系,找到atd开头的参数
* @return atd开头的key的键值对
*/
private Map<String, Object> getAllATDOverrideEnvVars() {
Map<String, Object> atdOverrideEnv = new HashMap<>();
System.getenv().forEach((key, value) -> {
if (key.startsWith("atd")) {
atdOverrideEnv.put(key, value);
}
});
return atdOverrideEnv;
} ………………
}

  

这里我不知道从哪里可以找到atd得配置,,,,在代码中找了很多地方,包括配置文件,都没有找到atd,这个来源不是很懂,要去读一下System.getenv()的API文档。

另两个方法看的很疑惑,这里只po部分代码,这两个方法来回的调用,看得我一脸懵逼。。。。今天看了个设计模式叫代理模式,不知道这个方法的设计和代理模式有没有什么关联。还要找时间研究一下。

/**
* 加载并重写系统变量,遍历所有的json的最小单位,
* @param originalObject 旧json
* @param objectToUpdate 新json
* @param allATDOverrideEnvVars 含有atd的键值对
* @param currentPath 当前的String串
* @return jsonObject
*/
private JSONObject loadAndOverrideFromEnvVars(JSONObject originalObject,
JSONObject objectToUpdate,
Map<String, Object> allATDOverrideEnvVars,
StringBuilder currentPath) {
Set<String> keys = originalObject.keySet();
keys.forEach(keyStr -> {
Object keyvalue = originalObject.get(keyStr);
if (keyvalue instanceof JSONObject) {
processJSONObject(objectToUpdate,
allATDOverrideEnvVars,
currentPath,
//当前的json的key值
keyStr,
//当前key的value
(JSONObject) keyvalue);
} else if (keyvalue instanceof JSONArray) {
processJSONArray(objectToUpdate,
allATDOverrideEnvVars,
currentPath,
keyStr,
(JSONArray) keyvalue);
} else {
processJSONObject(objectToUpdate,
currentPath,
keyStr,
keyvalue);
}
});
return objectToUpdate;
}

  

processJSONArray/JsonObject 的截取代码如下:

private void processJSONObject(JSONObject objectToUpdate,
StringBuilder currentPath,
String keyStr,
Object keyvalue) {
currentPath.append(keyStr);
String getFromEnv = System.getenv(currentPath.toString());
Object updatedValue = (null == getFromEnv) ? keyvalue : getFromEnv;
objectToUpdate.put(keyStr, updatedValue);
currentPath.delete(currentPath.lastIndexOf("_") + 1, currentPath.length());
} private void processJSONArray(JSONObject objectToUpdate,
Map<String, Object> allATDOverrideEnvVars,
StringBuilder currentPath,
String keyStr,
JSONArray keyvalue) {
JSONArray jsonArray = new JSONArray();
objectToUpdate.put(keyStr, jsonArray);
currentPath.append(keyStr).append("_");
JSONArray arrayValues = keyvalue;
for (int arrIndex = 0; arrIndex < arrayValues.length(); arrIndex++) {
processJSONArrayItem(allATDOverrideEnvVars,
currentPath,
jsonArray,
arrayValues,
arrIndex);
}
currentPath.delete(currentPath.lastIndexOf(keyStr), currentPath.length());
} private void processJSONArrayItem(Map<String, Object> allATDOverrideEnvVars,
StringBuilder currentPath,
JSONArray jsonArray,
JSONArray arrayValues,
int arrIndex) {
JSONObject arrayItem = (JSONObject) arrayValues.get(arrIndex);
JSONObject jsonObject = new JSONObject();
jsonArray.put(jsonObject);
currentPath.append(arrIndex).append("_");
loadAndOverrideFromEnvVars((JSONObject) arrayItem,
jsonObject,
allATDOverrideEnvVars,
currentPath);
currentPath.delete(currentPath.lastIndexOf(String.valueOf(arrIndex)), currentPath.length());
} /**
*
* @param objectToUpdate 要修改的jsonObject
* @param allATDOverrideEnvVars 含有atd的键值对
* @param currentPath 当前的string串
* @param keyStr key值
* @param keyvalue value值
*/
private void processJSONObject(JSONObject objectToUpdate,
Map<String, Object> allATDOverrideEnvVars,
StringBuilder currentPath,
String keyStr,
JSONObject keyvalue) {
JSONObject jsonObject = new JSONObject();
//增加一层json的嵌套,key保留,value为新增的空的value
objectToUpdate.put(keyStr, jsonObject);
//string 增加_
currentPath.append(keyStr).append("_");
loadAndOverrideFromEnvVars(keyvalue, jsonObject, allATDOverrideEnvVars, currentPath);
currentPath.delete(currentPath.lastIndexOf(keyStr), currentPath.length());
}

  

TODO:AppiumTestDistribution--CapabilityManager 类的更多相关文章

  1. 【Todo】Java类面试题分析

    Java 面试中的重要话题 多线程,并发及线程基础数据类型转换的基本原则垃圾回收(GC)Java 集合框架数组字符串GOF 设计模式SOLID (单一功能.开闭原则.里氏替换.接口隔离以及依赖反转)设 ...

  2. 【Todo】C++类 & 通用面试题分析记录 & 最难的bug

    1. the most difficult bug u fixed and how u solved this problem.. 解决过很多疑难bug.最困难的分为两类.一类是并发.多线程类的,因为 ...

  3. C# 使用IComparer自定义List类的排序方案

    List类中不带参数的Sort函数可以用来为List类中的元素排序,但如果List类中的元素类型本身不能直接进行比较(如自定义的struct和很多class),或是希望采用更加灵活的自定义比较方式,可 ...

  4. 使用SQLiteOpenHelper类对数据库简单操作

    实现数据库基本操作       数据库创建的问题解决了,接下来就该使用数据库实现应用程序功能的时候了.基本的操作包括创建.读取.更新.删除,即我们通常说的CRUD(Create, Read, Upda ...

  5. jeecg中的一个上下文工具类获取request,session

    通过调用其中的方法可以获取到request和session,调用方式如下: HttpServletRequest request = ContextHolderUtils.getRequest();H ...

  6. C#学习笔记(14)——C# 使用IComparer自定义List类的排序方案

    说明(2017-7-17 21:34:59): 原文:https://my.oschina.net/Tsybius2014/blog/298702?p=1 另一篇比较好的:https://wenku. ...

  7. json 工具处理类

    package com.js.ai.modules.pointwall.util; import java.lang.reflect.Type; import java.net.URLDecoder; ...

  8. Scala类和对象(二)

    1. 类和属性 1.1 如何控制构造函数字段的可见性 在Scala中: 如果一个字段被声明为var, Scala会为该字段生成getter和setter方法. 如果字段是val, Scala只生成ge ...

  9. Collections集合工具类常用的方法

    java.utils.Collections //是集合工具类,用来对集合进行操作.部分方法如下: public static <T> boolean addAll(Collection& ...

  10. Java类的继承与多态特性-入门笔记

    相信对于继承和多态的概念性我就不在怎么解释啦!不管你是.Net还是Java面向对象编程都是比不缺少一堂课~~Net如此Java亦也有同样的思想成分包含其中. 继承,多态,封装是Java面向对象的3大特 ...

随机推荐

  1. css实现可伸缩的搜索框

    效果图: 代码: <!DOCTYPE html> <html> <head> <meta http-equiv="Content-Type" ...

  2. Java面试 - PATH与CLASSPATH 的区别?

    PATH:操作系统提供的路径配置,用于定义所有可执行程序的路径. CLASSPATH:由JRE提供的,用于定义Java 程序解释时类加载路径.

  3. websocket抓包

    https://www.cnblogs.com/xiaoniuzai/p/7588739.html http://blog.sina.com.cn/s/blog_12df1b9e60102vyeq.h ...

  4. 分布式架构下,session共享有什么方案么?

    分布式架构下,session共享有什么方案么? 会点代码的大叔 科技领域创作者 分布式架构下的session共享,也可以称作分布式session一致性:关于这个问题,和大家说一说解决方案(如果有其他的 ...

  5. 2019ICPC南昌网络赛总结

    打的很崩的一场比赛.上来签到题我就wa了一发,感觉在梦游.然后我开了H题,队友开B题,f(n)=3f(n-1)+2f(n)傻子都知道矩阵快速幂,但是1e7的强制在线必须把logn优化,然后试图打表寻找 ...

  6. Python class and object

    # Python继承 class Person(object): """人""" def __init__(self, name, age) ...

  7. jenkinsFile harbor docker优化版

    node { //study-center def mvnHome = tool name: 'maven', type: 'maven' REGISTRY = "192.168.22.27 ...

  8. python学习-39 生成器总结

    总结 1.语法上和函数类似:生成器函数和常规函数几乎是一样的.它们都是使用def语句进行定义,差别在于,生成器使用yield语句返回一个值,常规函数使用return语句返回一个值. 2.自动实现迭代器 ...

  9. Java非常好用的反射框架Reflections

    MAVEN 坐标 <dependency> <groupId>org.reflections</groupId> <artifactId>reflect ...

  10. 情感交流篇:HTML页面如何与后端联系

    通过ajax get方法: 基本格式:$.get("后台一般处理程序文件路径",{传值,格式为  KEY:VULES},function(后台返回值){接到后台数据后处理}); $ ...