码迷,mamicode.com
首页 > 移动开发 > 详细

AppiumDriverLocalService 启动appium控制台不显示日志以及把日志保存到本地

时间:2018-05-12 19:22:07      阅读:582      评论:0      收藏:0      [点我收藏+]

标签:catch   dex   ace   gpo   ring   txt   manage   except   exception   

import java.io.File;
import java.io.OutputStream;
import java.lang.reflect.Field;
import java.util.ArrayList;

import org.openqa.selenium.WebElement;
import org.openqa.selenium.remote.DesiredCapabilities;
import org.testng.annotations.AfterClass;
import org.testng.annotations.BeforeClass;
import org.testng.annotations.Test;

import cn.lebo.appium.base.AndroidCapabilityType;
import io.appium.java_client.android.AndroidDriver;
import io.appium.java_client.service.local.AppiumDriverLocalService;
import io.appium.java_client.service.local.AppiumServiceBuilder;

public class NewTest {

    AppiumDriverLocalService service = null;
    AndroidDriver<WebElement> driver = null;

    @SuppressWarnings("unchecked")
    @BeforeClass
    public void beforClass() {
        Field streamField = null;
        Field streamsField = null;
        

        service = AppiumDriverLocalService
                .buildService(new AppiumServiceBuilder().usingPort(4723).withLogFile(new File("d:\\44555554.txt")));
        try {
            streamField = AppiumDriverLocalService.class.getDeclaredField("stream");
            streamField.setAccessible(true);
            streamsField = Class.forName("io.appium.java_client.service.local.ListOutputStream")
                    .getDeclaredField("streams");
            streamsField.setAccessible(true);
        } catch (ClassNotFoundException | NoSuchFieldException e) {
            e.printStackTrace();
        }
        try {
            ((ArrayList<OutputStream>) streamsField.get(streamField.get(service))).clear(); // remove System.out logging
        } catch (IllegalAccessException e) {
            e.printStackTrace();
        }
        
        service.start();

        DesiredCapabilities capabilities = new DesiredCapabilities();
        capabilities.setCapability(AndroidCapabilityType.DEVICE_NAME, "android");
        capabilities.setCapability(AndroidCapabilityType.APP_PACKAGE, "com.hpplay.sdk.source.test");
        capabilities.setCapability(AndroidCapabilityType.APP_ACTIVITY, "com.hpplay.sdk.source.test.MainActivity");
        driver = new AndroidDriver<>(service, capabilities);

    }

    @Test
    public void demo1() {
        System.out.println("执行test");
        driver.openNotifications();
        System.out.println("执行" + driver.toString());
        // driver.manage().logs().get("logcat");

    }

    @AfterClass
    public void AfterClass() {
        service.stop();
        System.out.println("停止test");
    }

}

 

AppiumDriverLocalService 启动appium控制台不显示日志以及把日志保存到本地

标签:catch   dex   ace   gpo   ring   txt   manage   except   exception   

原文地址:https://www.cnblogs.com/dengnapianhuahai/p/9029413.html

(0)
(0)
   
举报
评论 一句话评论(0
登录后才能评论!
© 2014 mamicode.com 版权所有  联系我们:gaon5@hotmail.com
迷上了代码!