用 Xcode Configuration 和 Scheme 配置项目环境

Landing

想象一个场景,我们正在开发一款支付系统,这个支付系统同时支持有Web版和原生的iOS APP版本。
这个支付系统有三个环境:

  • dev: 调用支付的开发环境接口,并不会真的扣钱。
  • qa: 调用支付的测试环境接口,假的测试账户中的余额会发生变化。
  • production: 调用产品环境中的支付接口,账户余额和钱会真实发生变化。

对于 Web 版的系统,我可以在浏览器中打开三个窗口,然后依次输入不同环境下的域名: www.dev.pay-example.comwww.qa.pay-example.comwww.prod.pay-example.com 来分别进行测试。

对于 iOS APP 呢?我们想要的其实是类似的,打开一台手机,我们可以同时安装三个APP:PayExampleDevPayExampleQAPayExample 然后可以切换APP来使用它们。

那么怎样通过一个 iOS 工程打包出三个不同的 APP 呢?方法很多,本文我们就来介绍通过 Xcode ConfigurationScheme 的配置方式来实现。

添加 Xcode Configuration

  • 新建 Group,命名为:Configuration
  • 在 Configuration 中新建不同环境下的 Configuration Settings file

具体步骤如下图:

配置项目的 Configuration

  • 在不同的 Configuration file 中,配置需要的键值对,用于在项目中引用,具体配置,请参考 Demo源码
  • Project -> Info -> Configurations
  • 将 Configurations 配置为 Dev、QA、Prod,并配置对应的 Configuration File

具体步骤如下图:

创建 scheme

  • 创建 scheme (PayExampleDev、PayExampleQA、PayExampleProd),供不同环境使用
  • Edit Scheme -> Step -> Info -> Build Configuration,配置对应的 Build Configuration 为 Dev、QA、Prod

在项目配置中引用 xcconfig 中定义的变量

  • PayExample target -> General -> Display Name
  • 配置 Display Name 为 $(PE_BUNDLE_NAME)

具体步骤如下图:

在某一个 Scheme 上执行某操作时,在此 Scheme 的此步骤上定义的 BuildConfig 就会生效。

比如:
用于打包 QA 环境的scheme PayExampleQA,其 Build 配置的 Build ConfigurationQA
QAConfiguration 中配置的 config 文件为:qa.xcconfig
项目中,APP 的 Display Name 的值为:$(PE_BUNDLE_NAME)
qa.xcconfigPE_BUNDLE_NAME 的值为 PayExampleQA

如此 PayExampleQA scheme 在打包后,显示的APP名称为 PayExampleQA

Setup bundle identifier

iOS 中是通过 bundle identifier 来标识不同的应用的。也就是说,想要通过一份代码同时编译出三个应用安装到设备中,我们需要在 dev.xcconfig, qa.xcconfig, prod.xcconfig 中分别定义 BUNDLE_IDENTIFIER ,并在项目配置中引用它。

当我们直接在配置中定义 PE_BUNDLE_ID ,并在项目配置中引用它时(Xcode10.1 (10B61)),会发现配置无效(如下图)

当查看 info.plist 时,可以发现 Bundle identifier 的 value 是 $(PRODUCT_BUNDLE_IDENTIFIER)。 我们可以在 Project -> Build Settings -> Product Bundle Identifier 中配置它的值为 $(PE_BUNDLE_ID)。具体操作如下图:

最终效果

完成上述配置以后,我们可以在不同 Scheme 下执行 run 命令将 APP 安装到模拟器中,查看效果:

What’s More

如果你需要在 Jenkins 或者 Travis 中搭建 pipeline,此配置同样适用。

当我们用脚本来打包 APP 时,会执行如下命令:

1
2
3
4
5
xcodebuild archive -workspace 项目名称.xcworkspace 
-scheme scheme名称
-archivePath archive包存储路径
CODE_SIGN_IDENTITY=证书
PROVISIONING_PROFILE=描述文件UUID

通过指定不同的 scheme 即可管理不同环境下的项目配置。

构建 pipeline 将会在后续文章中详细介绍,敬请期待!