为测试框架model类自动生成xml结果集

简介: 问题:有大量类似于theProductId这样名字的字符串需要转换成the_product_id这种数据库column名的形式。 思路:见到(见)大写字母(缝)就插入(插)一个“_”字符(针)进去,最后把所有字母都转换为小写。

问题:有大量类似于theProductId这样名字的字符串需要转换成the_product_id这种数据库column名的形式。

思路:见到()大写字母()就插入()一个“_”字符()进去,最后把所有字母都转换为小写。

解决办法:递归,字符串操作——见缝插针。

方法如下:

public static String toDbFormat(String theString, String insertString, int i) {
    StringBuilder sb = new StringBuilder(theString);
    String result = theString;
    if (i < sb.length()) {
        if (Character.isUpperCase(sb.charAt(i))) {
            sb.insert(i, insertString);
            i = i + 2;
        } else {
            i++;
        }
        result = toDbFormat(sb.toString(), insertString, i);
    }
    return result.toLowerCase();
}

实际应用——在接口自动化测试框架中根据model类为mybatis文件夹中的xml文件自动生成result部分:

public static void createXmlOut(Object object) throws IOException{
    //生成mybatis文件夹中xml文件的result部分
    FileWriter writer= new FileWriter("D:\\xmlOut.txt");
    @SuppressWarnings("rawtypes")
    Class clz = object.getClass();
    for (java.lang.reflect.Field field : clz.getDeclaredFields()) {
        String target = "<result property=\""+field.getName()+"\" column=\""+toDbFormat(field.getName(), "_", 0)+"\" />";
        writer.append(target+"\r\n");
    }
    writer.flush();
    writer.close();
}

测试方法(这里SomeModel替换为测试框架中实际的model类):

public static void main(String[] args) throws IOException {
    SomeModel someModel = new SomeModel();
    createXmlOut(someModel);
}

执行测试方法后就可以在你的D盘xmlOut.txt文件中看到生成的结果了。完整测试代码如下:

package com.netease.lede.qa.util;

import java.io.FileWriter;
import java.io.IOException;

import com.netease.lede.qa.model.duobao.TbDuobaoCoinDetail;

public class CreateResultXMLUtil {
    public static String toDbFormat(String theString, String insertString, int i) {
        // 将变量名转成数据库列名形式
        StringBuilder sb = new StringBuilder(theString);
        String result = theString;
        if (i < sb.length()) {
            if (Character.isUpperCase(sb.charAt(i))) {
                sb.insert(i, insertString);
                i = i + 2;
            } else {
                i++;
            }
            result = toDbFormat(sb.toString(), insertString, i);
        }
        return result.toLowerCase();
    }

    public static void createXmlOut(Object object) throws IOException {
        // 生成mybatis文件夹中xml文件的result部分
        FileWriter writer = new FileWriter("D:\\xmlOut.txt");
        @SuppressWarnings("rawtypes")
        Class clz = object.getClass();
        for (java.lang.reflect.Field field : clz.getDeclaredFields()) {
            String target = "<result property=\"" + field.getName() + "\" column=\""
                    + toDbFormat(field.getName(), "_", 0) + "\" />";
            TylanStringUtil.log(target);
            writer.append(target + "\r\n");
        }
        writer.flush();
        writer.close();
    }

    public static void main(String[] args) throws IOException {
        TbDuobaoCoinDetail tbDuobaoCoinDetail = new TbDuobaoCoinDetail();
        createXmlOut(tbDuobaoCoinDetail);
    }
}
View Code

 

相关文章
|
测试技术 开发者
vertx的学习总结6之动态代理类和测试
本文是Vert.x学习系列的第六部分,介绍了如何使用动态代理在事件总线上公开服务,以及如何进行Vert.x组件的异步测试,包括动态代理的创建和使用,以及JUnit 5和Vert.x测试工具的结合使用。
204 3
vertx的学习总结6之动态代理类和测试
|
Java 程序员 测试技术
Java|让 JUnit4 测试类自动注入 logger 和被测 Service
本文介绍如何通过自定义 IDEA 的 JUnit4 Test Class 模板,实现生成测试类时自动注入 logger 和被测 Service。
299 5
|
设计模式 SQL 安全
PHP中的设计模式:单例模式的深入探索与实践在PHP的编程实践中,设计模式是解决常见软件设计问题的最佳实践。单例模式作为设计模式中的一种,确保一个类只有一个实例,并提供全局访问点,广泛应用于配置管理、日志记录和测试框架等场景。本文将深入探讨单例模式的原理、实现方式及其在PHP中的应用,帮助开发者更好地理解和运用这一设计模式。
在PHP开发中,单例模式通过确保类仅有一个实例并提供一个全局访问点,有效管理和访问共享资源。本文详细介绍了单例模式的概念、PHP实现方式及应用场景,并通过具体代码示例展示如何在PHP中实现单例模式以及如何在实际项目中正确使用它来优化代码结构和性能。
284 2
|
JSON 测试技术 数据格式
单元测试问题之使用JCode5插件生成测试类如何解决
单元测试问题之使用JCode5插件生成测试类如何解决
634 3
|
Java 测试技术 Spring
单元测试问题之在 JCode5 类中使用 testService如何解决
单元测试问题之在 JCode5 类中使用 testService如何解决
139 2
|
测试技术
详解单元测试问题之MockHandlerImpl类的handle方法中VerificationMode不为空如何解决
详解单元测试问题之MockHandlerImpl类的handle方法中VerificationMode不为空如何解决
257 3
|
JavaScript Java 测试技术
《手把手教你》系列技巧篇(七十一)-java+ selenium自动化测试-自定义类解决元素同步问题(详解教程)
【6月更文挑战第12天】本文介绍了如何创建一个自定义类库来解决自动化测试中的元素同步问题。作者指出,大部分错误源于元素因时间不同步而引发,为此提供了一种解决方案。在项目实践中,首先在`library`包下创建名为`MyWait`的类,包含一个方法`isElementPresent`,该方法通过循环尝试并等待指定元素出现,避免了直接使用时间等待可能导致的不准确性。之后,在测试类中调用此自定义方法,成功实现了元素同步。代码示例展示了如何在Java+Selenium自动化测试中应用这个自定义类。
183 2
|
Java 数据库 Spring
Java编程问题之在测试中使用CGLIB创建代理类如何解决
Java编程问题之在测试中使用CGLIB创建代理类如何解决
245 0
|
XML 关系型数据库 数据库
使用mybatis-generator插件生成postgresql数据库model、mapper、xml
使用mybatis-generator插件生成postgresql数据库model、mapper、xml
1443 0
|
Java
springboot Test 测试类中如何排除一个bean类
springboot Test 测试类中如何排除一个bean类
693 0