当前位置:首页 > 技术 > 正文内容

Mac环境下Appium 2.X安装与配置(支持Android/iOS及Python)

访客 技术 2026年6月18日 1

前置条件

以下是为macOS环境搭建Appium 2.X的详细步骤,支持Android和iOS自动化测试。

通用安装步骤

  1. 确保已安装Python(建议版本小于3.10,尤其是PyCharm 2019版用户)。
  2. 安装Java JDK(推荐版本11)。
  3. 通过Homebrew安装Git:brew install git
  4. 根据macOS版本安装Xcode。
  5. 安装Node.js和npm:brew install nodebrew install npm
  6. 安装Selenium和ChromeDriver:
    
    pip3 install selenium
            
    确保ChromeDriver版本与Chrome浏览器匹配,并验证驱动是否正常运行:
    
    from selenium import webdriver
    browser = webdriver.Chrome()
    browser.get('https://www.baidu.com')
            

Android相关配置

  1. 下载并解压Android SDK,执行以下命令安装必要组件:
    
    cd [android-sdk路径]
    tools/bin/sdkmanager "platform-tools" "platforms;[版本号]"
            
  2. 配置环境变量,编辑.bash_profile.zshrc文件:
    
    export ANDROID_HOME='/Users/[用户名]/Documents/android-sdk'
    export PATH=${PATH}:$ANDROID_HOME/platform-tools:$ANDROID_HOME/tools
            
    保存后执行:source ~/.bash_profilesource ~/.zshrc
  3. 安装UiAutomator2驱动:npm install appium-uiautomator2-driver

iOS相关配置

  1. 安装libimobiledevice:brew install libimobiledevice --HEAD
  2. 安装ideviceinstaller:brew install ideviceinstaller
  3. 安装Carthage:brew install carthage
  4. 安装ios-deploy:brew install ios-deploy
  5. 可选:安装ios_webkit_debug_proxy:brew install ios-webkit-debug-proxy
  6. 验证Command Line Tools是否安装成功:xcodebuild -version

Appium安装与配置

  1. 全局安装Appium:npm install -g appium@next
  2. 安装驱动程序:
    
    appium driver install uiautomator2
    appium driver install xcuitest
            
  3. 安装Appium Doctor以检查环境:npm install -g appium-doctor
  4. 验证环境:appium-doctor --ios

WebDriverAgent配置

  1. 进入Appium WebDriverAgent目录,重新下载最新版本替换原有版本。
  2. 打开WebDriverAgent.xcodeproj文件,配置Team和Bundle Identifier。
  3. 构建并运行WebDriverAgentRunner项目。
  4. 使用iproxy映射端口:iproxy 8100 8100
  5. 检查设备连接状态:http://127.0.0.1:8100/status

示例代码


import unittest
from appium.options.ios import XCUITestOptions
from appium import webdriver

class IosTest(unittest.TestCase):
    def setUp(self):
        options = XCUITestOptions()
        options.load_capabilities({
            'platformName': 'iOS',
            'deviceName': 'iPhone 14',
            'platformVersion': '16.0',
            'bundleId': 'com.example.app',
            'udid': 'your_device_udid',
            'xcodeOrgId': 'your_xcode_org_id',
            'xcodeSigningId': 'iPhone Developer',
            'noReset': True,
        })
        self.driver = webdriver.Remote(
            'http://127.0.0.1:4723', 
            options=options
        )

    def tearDown(self):
        self.driver.quit()

    def test_sample(self):
        print("Running test...")

常见命令

  • 查看设备列表(Android):adb devices
  • 查看设备列表(iOS):xcrun simctl list
标签: AppiummacOS

相关文章

Linux crontab 详解

1) crontab 是什么cron 是 Linux 的定时任务守护进程;crontab 是用来编辑/查看“按时间周期执行命令”的表(cron table)。常见两类:用户 crontab:每个用户一份(crontab -e 编辑)系统级 crontab / cron.d:可指定执行用户(/etc/crontab、/etc/cron.d/*)2) crontab 时间...

富文本里可以允许的 HTML 属性

一、所有标签默认允许的安全属性(极少)class        (可选)id           (通常建议禁用)title️ 注意:id 容易被滥用做锚点注入,很多系统直接禁用class 允许的话最好只允许固定前缀(如 editor-*)二、a 标签允许属性<a href="" t...

Mac 安装 Node.js 指南

方法一:通过官网安装包(最简单,适合初学者)如果你只是想快速安装并开始使用,这是最直接的方法。访问 Node.js 官网。页面会显示两个版本:LTS (Recommended For Most Users):长期支持版,最稳定。建议选这个。Current:最新特性版,包含最新功能但可能不够稳定。下载 .pkg 安装包并运行。按照安装向导点击“下一步”即可完成。方法二:使用 Homebrew 安装(...

Dom\HTML_NO_DEFAULT_NS 的副作用:自动加闭合标签

在使用Dom\HTMLDocument时,Dom\HTML_NO_DEFAULT_NS 将禁止在解析过程中设置元素的命名空间, 此设置是为了与DOMDocument向后兼容而存在的。当使用它时,已知的一个副作用就是:自动加闭合标签例如 </img> 为什么会这样?当你使用:Dom\HTML_NO_DEFAULT_NS文档会变成 无命名空间模式,此时内部更接近 XML...

Laravel 事件和监听器创建

在 Laravel 中,使用 Artisan 命令创建 Events(事件) 和 Listeners(监听器) 是非常高效的。你可以通过以下几种方式来实现:1. 手动创建单个 Event如果你只想创建一个事件类,可以使用 make:event 命令:Bashphp artisan make:event UserRegistered执行后,文件将生成在 app/Even...

自定义域名解析神器 dnsmasq

什么是 dnsmasq?dnsmasq 是一个轻量级、功能强大的网络服务工具,专为小型和中等规模网络设计。它是一个综合的网络基础设施解决方案[1]。dnsmasq 能做什么?功能说明应用场景DNS 转发与缓存将 DNS 查询转发到上游服务器(ISP、Google DNS 等),并在本地缓存结果加快 DNS 查询速度,减少外部 DNS 流量本地 DNS解析本地网络设备的主机名,无需编辑&n...

发表评论

访客

◎欢迎参与讨论,请在这里发表您的看法和观点。