请问 java -cp “.\\bin;.\\libs\\*;” org.testng.TestNG .\\testng.xml 这是什么意思?
——先解释整体命令的意思,拆成三部分解释:
首先 cp 是设置classpath(如果不知道这是啥 把他暂时理解为java搜索类文件的路径就行)的缩写方式,是java的参数;
后面的org.testng.TestNG是包含main方法类的全名,同样是java参数
最后的.\\testng.xml是程序参数,或者说是main方法里的参数
——–之后解释\与\\的问题
\是windows系统代表文件路径级别的方式,点(.)则代表着当前目录,.\bin表示的是当前目录下的bin文件夹;libs同样如此;
让后就是这个双杠了,在编程的字符串中,\代表着转义字符,例如\n,\t分别对应于换行和TAB,而在字符串里表示windows路径时,我们本意需要的就是\本身,故而使用\\,做为\的转义字符;
上述情况是在编码中的字符串常量里表达的,这里我大胆的猜一下,可能写这个命令的人理解错了一些东西,作为参数,\是不需要转义的;而操作系统有这样一个默认,即输入多个杠表示的是同一级路径,比如C:\与C:\\\\\\\\都可以代表C盘根目录,所以即使写了多个杠也一样能正常使用。
————最后说引号
这个是命令的问题,一般来讲,执行命令时会把空格后的东西当成参数,但有时,参数本身就带有空格,比如“C:\Program Files”这个路径,用引号引起来,是为了告诉命令的执行者C:\Program Files是一个不可分割的整体,不要把Files单独的当成参数了。
一般而言,出现此类情况都是文件夹名称的问题,所以在打命令时,习惯了将表达路径的参数用引号引起来,使程序不会因为路径中带有空格而出问题。
————其它的一些建议
1.classpath是个比较重要的概念,需要好好了解一下。
2.编码里最好少用\\,这是windows的表达方式,当你需要java的跨平台特性时,可能会遇到麻烦(比如linux就不认);你可以使用/来表示路径结构,例如/C:/windows/
基于Appium的Android自动化测试(二)——TestNG
TestNG介绍
TestNG意为test next generation,是Java中的一个测试框架,Java中已经有一个JUnit的测试框架,类似于JUnit和NUnit,但TestNG比JUnit功能更加强大,使用也更方便,测试人员一般用TestNG来写自动化测试。
TestNG最简单的测试
下面是TestNG的一个例子
packageTankLearn2.Learn;
importorg.junit.AfterClass;
importorg.junit.BeforeClass;
importorg.testng.annotations.Test;
publicclassTestNGLearn1{
@BeforeClass
publicvoidbeforeClass(){
System.out.println(“this is before class”);
}
@Test
publicvoidTestNgLearn(){
System.out.println(“this is TestNG test case”);
}
@AfterClass
publicvoidafterClass(){
System.out.println(“this is after class”);
}
}
TestNG的基本注解
注解 描述
@BeforeSuite 注解的方法将只运行一次,运行所有测试前此套件中。
@AfterSuite 注解的方法将只运行一次,此套件中的所有测试都运行之后。
@BeforeClass 注解的方法将只运行一次先行先试在当前类中的方法调用。
@AfterClass 注解的方法将只运行一次后已经运行在当前类中的所有测试方法。
@BeforeTest 注解的方法将被运行之前的任何测试方法属于内部类的标签的运行。
@AfterTest 注解的方法将被运行后,所有的测试方法,属于内部类的标签的运行。
@BeforeGroups 组的列表,这种配置方法将之前运行。此方法是保证在运行属于任何这些组第一个测试方法,该方法被调用。
@AfterGroups 组的名单,这种配置方法后,将运行。此方法是保证运行后不久,最后的测试方法,该方法属于任何这些组被调用。
@BeforeMethod 注解的方法将每个测试方法之前运行。
@AfterMethod 被注释的方法将被运行后,每个测试方法。
@DataProvider 标志着一个方法,提供数据的一个测试方法。注解的方法必须返回一个Object[] [],其中每个对象[]的测试方法的参数列表中可以分配。
该@Test方法,希望从这个DataProvider的接收数据,需要使用一个dataProvider名称等于这个注解的名字。
@Listeners 定义一个测试类的监听器。
@Parameters 介绍如何将参数传递给@Test方法。
@Test 标记一个类或方法作为测试的一部分。
TestNG组测试
在编写测试的过程中,经常遇到只想执行个别或者某一部分/某一类型的测试用例,TestNG提供了分组测试方法,可以按组来执行测试用例。
packageTankLearn2.Learn;
importorg.testng.annotations.Test;
publicclassGroupTest{
@Test(groups = {“systemtest”})
publicvoidtestLogin(){
System.out.println(“this is test login”);
}
@Test(groups = {“functiontest”})
publicvoidtestOpenPage(){
System.out.println(“this is test Open Page”);
}
}
TestNG依赖测试
有时,我们需要按顺序来调用测试用例,测试用例之间存在依赖关系,TestNG支持测试用例之间的依赖。
importorg.openqa.selenium.WebElement;
importorg.testng.Assert;
importorg.testng.annotations.Test;
importpage.*;
importutil.AppiumTest;
importjava.util.List;
importstaticutil.Helpers.*;
@Test
publicvoidmethod1()
{
BookMarkEditPage bookMarkPageEdit =newBookMarkEditPage();
bookMarkPageEdit.addPoiToBookMark(“清华东路西口”);
Assert.assertTrue(bookMarkPageEdit.verifyAddPoiToBookMark(“清华东路西口”),”添加poi点失败”);
System.out.println(“This is method 1”);
}
@Test(dependsOnMethods = {“method1”})
publicvoidmethod2(){
BookMarkCommonPage bookMarkCommonPage =newBookMarkCommonPage();
bookMarkCommonPage.deleteAllItems();
Assert.assertTrue(bookMarkCommonPage.isDisplayed(“你还没有添加收藏”),”删除失败!”);
System.out.println(“This is method 2”);
}
TestNG忽略测试
当测试用例还没准备好时,可以给测试用例加上@Test(enable = false), 来禁用此测试用例。
packageTestng;
importorg.junit.AfterClass;
importorg.junit.BeforeClass;
importorg.testng.annotations.AfterMethod;
importorg.testng.annotations.BeforeMethod;
importorg.testng.annotations.Test;
publicclassLtg{
@BeforeMethod
publicvoidbeforeMethod(){
System.out.println(“this is before method”);
}
@Test(enabled =false)
publicvoidTestNgLearn1(){
System.out.println(“this is TestNG test case 1”);
}
@Test
publicvoidTestNgLearn2(){
System.out.println(“this is TestNG test case 2”); }
@AfterMethod
publicvoidafterMethod(){
System.out.println(“this is after method”);
}
}
TestNg执行顺序
BeforeMethod/AfterMethod会在每个方法中调用一次,这种适用场所,比如执行完第一个用例之后要重置数据才能执行第二条用例时,可以用这种方式,BeforeMethod 就放重置数据的方法,让每个方法执行之前都去调用这个方法
TestNG具体生命周期
TestNg特点
1、annotations注释,如@test @BeforeMethod ;
2、支持多线程执行case ;
3、支持数据驱动dataProvider ;
4、支持参参数 ;
5、能够作为eclipse的插件 ;
6、能够(配合reportng)生产客观的测试报告 ;
7、可通过testng.xml管理执行case和suite;
TestNG suite
testng.xml文档中最上层的元素
说明:一个xml文件只能有一个,是一个xml文件的根级
由和组成
suite定义一个测试套件,可以设置是否使用多线程,可包含多个测试用例或者测试group。
testng.xml 配置详解
简单的大概结构如下:
以下详细XML规则
-结-构-树
suite
–tests
—-parameters
—-groups
——definitions
——runs
—-classes
–parameters
比较详细的结构如下:
使用idea+testNG搭建自动化测试框架
一、所需环境
1、JDK
2、Maven
3、intellij idea
二、创建工程
三、导入相关依赖包和插件
1)导入testNG依赖包
在pom.xml中添加
2)添加编译插件和执行测试插件
在pom.xml中添加
四、创建测试类
1)在Java文件夹下创建
2)编写testNG.xml
xml文件用于按照需要批量执行用例,右键选择运行可独立执行
?xml version=”1.0″ encoding=”utf-8″ ?
suite name=”testproj” parallel=”false”
test name=”testDemo1″
classes
class name=”TestDemo”/class
/classes
/test
/suite
五、运行testNG.xml
testng运行提示引用不存在的项目
可在配置testng的环境变量设置。
新建一个TESTNG目录,用来存放依赖jar包,如放置C盘,配置系统变量:计算机-属性-高级系统设置-高级-环境变量-系统变量,变量名:TESTNG_HOME,变量值:C:\TESTNG,ClASSPAT与前面配置用;隔开H加入,cmd执行testng.xml文件,进入testng.xml文件目录执行命令java org.testng.TestNG testng.xml,最后重启就可以了。
TestNG简单的学习类和方法级别@Test的区别
使用TestNG类执行测试用例。这个类的主入口点在TestNG的框架运行测试。用户可以创建自己的TestNG的对象,并调用它以许多不同的方式:
在现有的testng.xml
合成testng.xml,完全从Java创建
直接设定测试类
您还可以定义哪些群体包括或排除,分配参数,命令行参数:
-d outputdir: 指定输出目录
-testclass class_name: 指定了一个或多个类名
-testjar jar_name: 指定的jar包含测试
-sourcedir src1;src2: ; 分隔源目录列表(只有当使用的javadoc注释)
-target
-groups
-testrunfactory
-listener
testng.xml现有在下面的例子中,我们将创建TestNG的对象。
创建一个类
创建一个Java类进行测试为 MessageUtil.java 在 C:\ TestNG_WORKSPACE
/*
* This class prints the given message on console.
*/
public class MessageUtil {
private String message;
//Constructor
//@param message to be printed
public MessageUtil(String message){
this.message = message;
}
// prints the message
public String printMessage(){
System.out.println(message);
return message;
}
}
创建测试例类
创建一个Java测试类 SampleTest.java
您的测试类添加一个的测试方法testPrintMessage()
添加注释@Test 到方法 testPrintMessage()
实现测试条件和使用的assertEquals API TestNG的检查条件
创建一个Java类文件名 SampleTest.java在 C:\ TestNG_WORKSPACE
import org.testng.Assert;
import org.testng.annotations.Test;
public class SampleTest {
String message = “Hello World”;
MessageUtil messageUtil = new MessageUtil(message);
@Test
public void testPrintMessage() {
Assert.assertEquals(message, messageUtil.printMessage());
}
}
创建 testng.xml
接下来,让我们创建testng.xml文件在 C:\ TestNG_WORKSPACE 执行测试用例,此文件捕获整个测试XML。这个文件可以很容易地描述所有的测试套件和它们的参数在一个文件中,你可以检查你的代码库或e-mail给同事。这也使得它容易提取测试或分裂的几个运行时配置的子集(例如,TestNG的database.xml 只能运行测试,行使数据库)。
?xml version=”1.0″ encoding=”UTF-8″?
suite name=”Sample test Suite”
test name=”Sample test”
classes
class name=”SampleTest” /
/classes
/test
/suite
情况下使用javac编译测试
C:\TestNG_WORKSPACEjavac MessageUtil.java SampleTest.java
现在,运行这个 testng.xml,将运行中定义的测试用例 test 标签
C:\TestNG_WORKSPACEjava -cp “C:\TestNG_WORKSPACE” org.testng.TestNG testng.xml
验证输出。
Hello World
===============================================
Sample test Suite
Total tests run: 1, Failures: 0, Skips: 0
===============================================
TestNG.xml配置,同一个方法同一个参数,传递多个不同的值,该如何写代码?
象pagg定义没定义用 说面写javaType前面命名用需要另配置文件定义图:我另mybatis配置文件定义studentpage