Native Driver的搭建及使用

1.在被测程序中加入server-standalone.jar包

2.在被测程序的AndroidManifest中加入代码:

 <instrumentation
        android:name="com.google.android.testing.nativedriver.server.ServerInstrumentation"
        android:targetPackage="com.console" />

    <uses-permission android:name="android.permission.WAKE_LOCK" />
    <uses-permission android:name="android.permission.DISABLE_KEYGUARD" />
    <uses-permission android:name="android.permission.INTERNET" />
    <uses-permission android:name="android.permission.WRITE_EXTERNAL_STORAGE" />

3.创建本地测试程序

4.在本地测试程序中加入client-standalone.jar包

5.在本地测试程序中加入testng6.8.jar包

6.在BeforeClass中加入如下代码:

@BeforeClass
	public void beforeClass() {
		// 这里把之前的adb命令放入到beforeclass中,如果有beforesuite的话也可以放到beforesuite中
		try {
			String cmd = "cmd.exe /k start adb shell am instrument "
					+ "com.console/com.google.android.testing.nativedriver.server.ServerInstrumentation";
			Runtime.getRuntime().exec(cmd);
			Thread.sleep(10000);
			String cmd2 = "cmd.exe /k start "
					+ "adb forward tcp:54129 tcp:54129";
			Runtime.getRuntime().exec(cmd2);
			Thread.sleep(2000);
			driver = getDriver();
		} catch (IOException e) {
			e.printStackTrace();
		} catch (InterruptedException e) {
			e.printStackTrace();
		}
		// 统一设置通过find方法查找元素等待超时的时间,这里有时候发现等待超时的时间远远大于这个设置的,原因还未知
		driver.manage().timeouts().implicitlyWait(20, TimeUnit.SECONDS);
	}

7.使用AndroidNativeDriver driver对象去获取对象WebElement:

@Test
	public void login() {
		startLoginActivity();
		WebElement et = driver.findElementById("et_input");
		et.sendKeys("ps");

		WebElement btn = driver.findElementById("btn_ok");
		btn.click();
	}


  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
1. 下载Mycat2 从Mycat2官网http://www.mycat.io/下载最新版本的Mycat2,解压缩到指定的目录。 2. 安装Java Mycat2需要Java环境,可以从官网下载并安装Java。 3. 配置Mycat2 在Mycat2的conf目录下,有三个配置文件需要修改: ① server.xml:主要配置服务器的IP和端口。 ② schema.xml:配置数据库信息和数据分片。 ③ rule.xml:配置数据读写分离策略。 4. 启动Mycat2 在Mycat2的bin目录下,执行./mycat start命令,启动Mycat2服务。 5. 测试Mycat2 在Mycat2的bin目录下,执行./mycat console命令,进入Mycat2的控制台,输入show @@datasources命令,可以查看已经配置好的数据源信息。 6. 配置MySQL数据库 在Mycat2中配置MySQL数据库,需要在schema.xml文件中添加数据源信息。 例如: ```xml <dataHost name="db1" maxCon="1000" minCon="10" balance="0" writeType="0" dbType="mysql" dbDriver="native" switchType="1" slaveThreshold="100"> <heartbeat>select user()</heartbeat> <writeHost host="host1" url="jdbc:mysql://host1:3306/test" user="root" password="123456"> </writeHost> <readHost host="host2" url="jdbc:mysql://host2:3306/test" user="root" password="123456"/> <readHost host="host3" url="jdbc:mysql://host3:3306/test" user="root" password="123456"/> </dataHost> ``` 上面的配置中,定义了一个名为db1的数据源,包含一个写节点和两个读节点,分别连接到host1、host2和host3上的3306端口。 7. 配置数据分片 在schema.xml文件中,可以通过配置数据分片来实现数据的水平扩展。 例如: ```xml <schema name="TESTDB" checkSQLschema="false" sqlMaxLimit="100"> <table name="order" primaryKey="id" dataNode="dn1,dn2" rule="mod-long"> </table> </schema> ``` 上面的配置中,定义了一个名为TESTDB的数据库,其中order表被分片到dn1和dn2两个数据节点上,分片规则为mod-long。 8. 配置数据读写分离 在rule.xml文件中,可以配置数据读写分离策略。 例如: ```xml <rule name="user_rule"> <columns>id</columns> <tables>user</tables> <algorithm>mod-long</algorithm> <shardRules> <rule> <dataSourceName>db1</dataSourceName> <tableName>user</tableName> <columnValue>0-2</columnValue> </rule> <rule> <dataSourceName>db2</dataSourceName> <tableName>user</tableName> <columnValue>3-5</columnValue> </rule> <rule> <dataSourceName>db3</dataSourceName> <tableName>user</tableName> <columnValue>6-9</columnValue> </rule> </shardRules> </rule> ``` 上面的配置中,定义了一个名为user_rule的规则,对user表进行分片,根据id字段的值进行分片,分三片,分别连接到db1、db2和db3上。 9. 总结 通过以上步骤,我们成功搭建了一个Mycat2分布式数据库集群。Mycat2具有分布式、高可用、高并发、分片、读写分离等特点,是一个非常优秀的分布式数据库中间件。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值