Appium APPIUM+IOS 真机+java 测试 (完结)

匿名 · 2015年03月17日 · 最后由 恒温 回复于 2015年03月17日 · 1526 次阅读

@all
appium 上的 IOS setting

java 测试代码
public class AppLoginTest {

private WebDriver driver;

@Before
public void setUp() throws Exception {
// set up appium
File classpathRoot = new File(System.getProperty("user.dir"));
System.out.println(System.getProperty("user.dir"));
File appDir = new File(classpathRoot, "apps");
File app = new File(appDir, "reliao.ipa");
DesiredCapabilities capabilities = new DesiredCapabilities();
//capabilities.setCapability("device","multiMedia");
capabilities.setCapability(MobileCapabilityType.VERSION, "7.1");
//capabilities.setCapability(MobileCapabilityType.ACCEPT_SSL_CERTS,true);
capabilities.setCapability(MobileCapabilityType.PLATFORM, "Mac");
capabilities.setCapability("deviceName","iphone");
capabilities.setCapability("platformName", "ios");
//capabilities.setCapability("app", app.getAbsolutePath());
//System.out.println(app.getAbsolutePath());
//capabilities.setCapability(MobileCapabilityType.APP,"com.iqiyi.reliao");
driver = new RemoteWebDriver(new URL("http://127.0.0.1:4723/wd/hub"), capabilities);
}

最后贴出 appium 报错信息
Launching Appium with command: '/Volumes/Appium 1/Appium.app/Contents/Resources/node/bin/node' lib/server/main.js --address "127.0.0.1" --command-timeout "7200" --platform-version "7.1" --platform-name "iOS" --app "/Users/a/git_zcr/reliao-automation/hotchat-test/apps/reliao.ipa" --udid "446f94713d060f49faa03fe14d5044e549e484cd" --show-sim-log --default-device

info: Welcome to Appium v1.3.4 (REV c8c79a85fbd6870cd6fc3d66d038a115ebe22efe)

info: Appium REST http interface listener started on 127.0.0.1:4723
info: [debug] Non-default server args: {"app":"/Users/a/git_zcr/reliao-automation/hotchat-test/apps/reliao.ipa","udid":"446f94713d060f49faa03fe14d5044e549e484cd","address":"127.0.0.1","platformName":"iOS","platformVersion":"7.1","defaultDevice":true,"showSimulatorLog":true,"defaultCommandTimeout":7200}
warn: Deprecated server args: {"--show-sim-log":"use instead: --show-ios-log"}
info: Console LogLevel: debug

info: --> GET /wd/hub/status {}
info: [debug] Responding to client with success: {"status":0,"value":{"build":{"version":"1.3.4","revision":"c8c79a85fbd6870cd6fc3d66d038a115ebe22efe"}}}

info: <-- GET /wd/hub/status 200 8.219 ms - 104 {"status":0,"value":{"build":{"version":"1.3.4","revision":"c8c79a85fbd6870cd6fc3d66d038a115ebe22efe"}}}

info: --> POST /wd/hub/session {"desiredCapabilities":{"platformName":"IOS","version":"7.1","deviceName":"iphone","platform":"MAC"}}

info: Client User-Agent string: Apache-HttpClient/4.3.3 (java 1.5)

info: [debug] The following desired capabilities were provided, but not recognized by appium. They will be passed on to any other services running on this server. : version, platform
info: [debug] Using local .ipa from command line: /Users/a/git_zcr/reliao-automation/hotchat-test/apps/reliao.ipa
info: [debug] Copying local zip to tmp dir

info: [debug] /Users/a/git_zcr/reliao-automation/hotchat-test/apps/reliao.ipa copied to /var/folders/7f/bdnt2lkj3_lb26xzz7c9wj5m0000gn/T/115217-52035-r09wzz/appium-app.zip
info: [debug] Unzipping /var/folders/7f/bdnt2lkj3_lb26xzz7c9wj5m0000gn/T/115217-52035-r09wzz/appium-app.zip
info: [debug] Testing zip archive: /var/folders/7f/bdnt2lkj3_lb26xzz7c9wj5m0000gn/T/115217-52035-r09wzz/appium-app.zip

info: [debug] Zip archive tested clean

info: [debug] Unzip successful

info: [debug] Using locally extracted app: /var/folders/7f/bdnt2lkj3_lb26xzz7c9wj5m0000gn/T/115217-52035-r09wzz/Payload/reliao.app

info: [debug] Creating new appium session 3e619947-5d84-4a6e-af78-87c51b57e12c
info: [debug] Removing any remaining instruments sockets
info: [debug] Cleaned up instruments socket /tmp/instruments_sock
info: [debug] Setting Xcode folder
info: [debug] Setting Xcode version

info: [debug] Setting iOS SDK Version

info: [debug] Getting sdk version from xcrun with a timeout

info: [debug] iOS SDK Version set to 8.1

parseFileSync() is deprecated. Use parseStringSync() instead.

info: [debug] Not checking whether simulator is available since we're on a real device
info: [debug] Detecting automation tracetemplate
info: [debug] Not auto-detecting udid, running on sim
info: [debug] Could not parse plist file (as binary) at /var/folders/7f/bdnt2lkj3_lb26xzz7c9wj5m0000gn/T/115217-52035-r09wzz/Payload/reliao.app/en.lproj/Localizable.strings
info: Will try to parse the plist file as XML
info: [debug] Could not parse plist file (as XML) at /var/folders/7f/bdnt2lkj3_lb26xzz7c9wj5m0000gn/T/115217-52035-r09wzz/Payload/reliao.app/en.lproj/Localizable.strings
warn: Could not parse app Localizable.strings; assuming it doesn't exist
info: [debug] Getting bundle ID from app
info: [debug] Parsed app Info.plist (as binary)
info: [debug] Creating instruments
info: On some xcode 6 platforms, instruments-without-delay does not work. If you experience this, you will need to re-run appium with the --native-instruments-lib flag
info: [debug] Preparing uiauto bootstrap
info: [debug] Dynamic bootstrap dir: /Users/a/Library/Application Support/appium/bootstrap
info: [debug] Dynamic env: {"nodePath":"/Volumes/Appium 1/Appium.app/Contents/Resources/node/bin/node","commandProxyClientPath":"/Volumes/Appium 1/Appium.app/Contents/Resources/node_modules/appium/node_modules/appium-uiauto/bin/command-proxy-client.js","instrumentsSock":"/tmp/instruments_sock","interKeyDelay":null,"justLoopInfinitely":false,"autoAcceptAlerts":false,"sendKeyStrategy":"grouped"}
info: [debug] Dynamic bootstrap code: // This file is automatically generated. Do not manually modify!
...
info: [debug] Dynamic bootstrap path: /Users/a/Library/Application Support/appium/bootstrap/bootstrap-b68f81badbd951b6.js
info: [debug] Reusing dynamic bootstrap: /Users/a/Library/Application Support/appium/bootstrap/bootstrap-b68f81badbd951b6.js
info: [debug] Getting device string from opts: {"forceIphone":false,"forceIpad":false,"xcodeVersion":"6.1","iOSSDKVersion":"8.1","deviceName":"iphone","platformVersion":"7.1"}
info: [debug] fixDevice is on
info: [debug] Final device string is: 'iphone (7.1 Simulator)'
info: [debug] Not setting device type since we're on a real device
info: [debug] Checking whether we need to set app preferences
info: [debug] Not setting iOS and app preferences since we're on a real device
info: [debug] Running ios sim reset flow
info: [debug] Killing the simulator process
info: [debug] Killall iOS Simulator
info: [debug] Killing any other simulator daemons

info: [debug] On a real device; cannot clean device state
info: [debug] Not setting locale because we're using a real device
info: [debug] No iOS / app preferences to set
info: [debug] Starting iOS device log capture via deviceconsole

info: [debug] Not pre-launching simulator

info: [debug] Creating iDevice object with udid 446f94713d060f49faa03fe14d5044e549e484cd

error: Failed to start an Appium session, err was: Error: Command failed: /bin/sh: /Volumes/Appium: is a directory

info: [debug] Couldn't find ideviceinstaller, trying built-in at /Volumes/Appium 1/Appium.app/Contents/Resources/node_modules/appium/build/libimobiledevice-macosx/ideviceinstaller
info: [debug] Checking app install status using: /Volumes/Appium 1/Appium.app/Contents/Resources/node_modules/appium/build/fruitstrap/fruitstrap isInstalled --id 446f94713d060f49faa03fe14d5044e549e484cd --bundle com.iqiyi.reliao
info: [debug] App is not installed. Will try to install the app.
info: [debug] Installing ipa found at /Users/a/git_zcr/reliao-automation/hotchat-test/apps/reliao.ipa
info: [debug] Creating iDevice object with udid 446f94713d060f49faa03fe14d5044e549e484cd
info: [debug] Couldn't find ideviceinstaller, trying built-in at /Volumes/Appium 1/Appium.app/Contents/Resources/node_modules/appium/build/libimobiledevice-macosx/ideviceinstaller
info: [debug] Cleaning up appium session
info: [debug] Error: Command failed: /bin/sh: /Volumes/Appium: is a directory

at ChildProcess.exithandler (child_process.js:658:15)
at ChildProcess.emit (events.js:98:17)
at maybeClose (child_process.js:766:16)
at Socket. (child_process.js:979:11)
at Socket.emit (events.js:95:17)
at Pipe.close (net.js:466:12)
info: [debug] Responding to client with error: {"status":33,"value":{"message":"A new session could not be created. (Original error: Command failed: /bin/sh: /Volumes/Appium: is a directory\n)","killed":false,"code":126,"signal":null,"origValue":"Command failed: /bin/sh: /Volumes/Appium: is a directory\n"},"sessionId":null}
info: <-- POST /wd/hub/session 500 2307.131 ms - 278

info: --> GET /wd/hub/status {}

麻烦各位大侠们给看看,这 ideviceinstaller 我要怎么重新再 build?THANKS!!

此问题已经解决:ANDROID 环境配置的问题。用 appium-doctor 验证后发现没有配置好。

共收到 13 条回复 时间 点赞

代码请贴代码并使用代码块!
日志请贴日志并使用代码块!
提问,指明问题信息,请像一个职业测试一样报问题
支持 Markdown 格式, 粗体删除线单行代码
支持表情,见 Emoji cheat sheet
按 “M” 键查看更多 帮助。

代码请贴代码并使用代码块!
日志请贴日志并使用代码块!
提问,指明问题信息,请像一个职业测试一样报问题
支持 Markdown 格式, 粗体、删除线、单行代码
支持表情,见 Emoji cheat sheet
按 “M” 键查看更多 帮助。

另外真机测试有帖子很详细的说明了。请善待论坛的搜索。

那个 错误已经告诉你了
error: Failed to start an Appium session, err was: Error: Command failed: /bin/sh: /Volumes/Appium: is a directory

目录问题

你就先试试录制工具能不能打开!如果录制工具都没法启动,你的环境变量参数就有问题

你是不是没有把 appium.app 从 dmg 拷到 application 文件夹……
/Volumes/Appium明显是挂载的 dmg 镜像地址……
如果后面还有Couldn't find ideviceinstaller错误,请看官方 issue:https://github.com/appium/appium/issues/2276

匿名 #6 · 2015年03月17日

@monkey @lihuazhang 好的,努力学习中。

#6 楼 @myf_1127 帖子用代码块啊。

#6 楼 @myf_1127 你可以先修改下帖子

匿名 #9 · 2015年03月17日

@chenhengjie123 谢谢提醒,是有这个原因

匿名 #10 · 2015年03月17日

@testly 是环境没有配置好。但是后来环境配置好了,那个 inspector 也打不开,定位元素很费劲的说。

#9 楼 @myf_1127 inspector 能正常打开的前提是被测应用已经被 appium 打开了。
对应文档:https://github.com/appium/appium-dot-app#inspector--recorder

看这标题还以为是分享自己的踩坑总结。。。。。

#10 楼 @myf_1127 inspector 打不开 你勾上 Bid 试试

需要 登录 後方可回應,如果你還沒有帳號按這裡 注册