- iOS/Objective-C 元类和类别
- objective-c - -1001 错误,当 NSURLSession 通过 httpproxy 和/etc/hosts
- java - 使用网络类获取 url 地址
- ios - 推送通知中不播放声音
我想在 CI (Jenkins Pipeline) 中的项目上运行 UI 测试和单元测试。 UI 测试要求图像和视频位于测试设备/模拟器上。在 UI 测试中,我请求存储读/写访问权限,以便我可以将一些 Assets 转储到下载文件夹中,然后在测试套件结束时删除它们。
当我在 Jenkins (mac) 上运行我的测试时,没有授予权限,没有媒体传输,我的所有测试都失败了。
该项目包含一个应用程序模块和两个内部库模块。
构建
sh "./gradlew clean assembleRelease"
单元测试
sh "./gradlew testReleaseUnitTest"
界面测试
sh "$ANDROID_HOME/emulator/emulator @my_sweet_emulator_name -no-boot-anim & $ANDROID_HOME/platform-tools/adb wait-for-device"
sh './gradlew connectedAndroidTest'
1) CI 构建卡在隐式 assembleDebugAndroidTest
任务上
2) 如果我在我的计算机上的命令行上运行该任务,测试将安装,但是未授予读/写存储的权限,因此所有测试都会失败,因为设备上没有任何预期的内容。
testBuildType "release"
我如何授予权限
@RunWith(AndroidJUnit4::class)
class MyMediaClassTest {
@Rule
@JvmField
val activityRule = ActivityTestRule(MainActivity::class.java)
@Rule
@JvmField
val grantPermissionRule: GrantPermissionRule = GrantPermissionRule
.grant(android.Manifest.permission.READ_EXTERNAL_STORAGE,
android.Manifest.permission.WRITE_EXTERNAL_STORAGE)
// tests and stuff
}
我看到了一个短期解决方案,可以手动将我所有的媒体 Assets 复制到模拟器中。但这似乎不对,这应该可以自动化。
最佳答案
它与我合作的方式是按照以下步骤操作:
在我的 app
模块的 AndroidManifest.xml
文件中添加了权限。
<uses-permission android:name="android.permission.READ_EXTERNAL_STORAGE"/>
<uses-permission android:name="android.permission.WRITE_EXTERNAL_STORAGE"/>
并尝试执行以下插桩测试用例/类:
@RunWith(AndroidJUnit4::class)
class ExampleInstrumentedTest {
@Rule
@JvmField
val grantPermissionRule: GrantPermissionRule = GrantPermissionRule
.grant(android.Manifest.permission.READ_EXTERNAL_STORAGE,
android.Manifest.permission.WRITE_EXTERNAL_STORAGE)
val rootDir = "/sdcard/"
@Test
fun testTargetContextPermission() {
val targetContext = InstrumentationRegistry.getTargetContext()
assertTrue("Not the target package",
!targetContext.packageName.endsWith(".test"))
assertTrue("Permissions not Granted", targetContext.checkSelfPermission(
android.Manifest.permission.READ_EXTERNAL_STORAGE) == PackageManager.PERMISSION_GRANTED &&
targetContext.checkSelfPermission(
android.Manifest.permission.WRITE_EXTERNAL_STORAGE) == PackageManager.PERMISSION_GRANTED)
val file = File(rootDir + "targetTest.txt")
if (file.exists()) {
file.delete()
}
assertTrue("File was not created", file.createNewFile())
val sdcard = File(rootDir)
assertTrue("sdcard is empty or file not found", sdcard.list().size != 0 &&
Arrays.asList<String>(*sdcard.list()).contains("targetTest.txt"))
}
@Test
fun testInstrumentationPermission() {
val instrumentationContext = InstrumentationRegistry.getContext()
assertTrue("Not the instrumentation package",
instrumentationContext.packageName.endsWith(".test"))
assertTrue("Permissions not Granted", instrumentationContext.checkSelfPermission(
android.Manifest.permission.READ_EXTERNAL_STORAGE) == PackageManager.PERMISSION_GRANTED &&
instrumentationContext.checkSelfPermission(
android.Manifest.permission.WRITE_EXTERNAL_STORAGE) == PackageManager.PERMISSION_GRANTED)
val file = File(rootDir + "instrumentationTest.txt")
if (file.exists()) {
file.delete()
}
assertTrue("File was not created", file.createNewFile())
val sdcard = File(rootDir)
assertTrue("sdcard is empty or file not found", sdcard.list().size != 0 &&
Arrays.asList<String>(*sdcard.list()).contains("instrumentationTest.txt"))
}
}
两个测试用例都成功返回。将 rootDir
更改为 "/"
后,测试失败,因为 /
目录是只读的,这是预期的。
拥有两个测试用例背后的想法是测试测试可以在运行时检索的不同 Context
。 testTargetContextPermission
使用 Context
应用程序,它没有其包名称或应用程序 ID 以 .test
结尾。 testInstrumentationPermission
使用检测应用程序 Context
,它 的包名称或应用程序 ID 以 .test
结尾。我认为需要在他们的每个 AndroidManifest
中定义权限,但事实证明,为您的 app
AndroidManifest
定义权限只会自动提供对 Instrumentation 包也有相同的权限。
关于在 CI 中使用存储权限进行 Android UI 测试,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/52976714/
我们都知道ci" ci' ci( ci[ ... 做。在日常编辑中非常方便。我发现了一些奇怪的东西,并查看了帮助,没有找出原因。 说,我有一个文件: foo "target" foo 'target'
关闭。这个问题不符合Stack Overflow guidelines .它目前不接受答案。 想改进这个问题?将问题更新为 on-topic对于堆栈溢出。 6年前关闭。 Improve this qu
我的本地 gitlab 安装中有许多存储库。我正在从 Jenkins 迁移到 gitlab 以进行 CI,并且毫无问题地切换了我的第一个 repo。当我添加 .gitlab-ci.yml 时,第二个
我在一个github项目中有几个文件夹,每个文件夹都有一个不同的.travis.yml文件。 设置travis-ci的正确方法是什么,以便我可以指定要构建的文件夹/子项目? 我可以添加before_s
Gitlab 文档说明了以下关于 GIT_STRATEGY: none 的内容: none also re-uses the project workspace, but skips all Git
我想用以下条件配置我的 CI: 当我创建合并请求时 而这个目标分支是 develop 我的工作运行。 我没有找到这个特定工作的文档。 谢谢 最佳答案 在 Gitlab CI 文档中几个小时后,我找到了
我有一个带有子目录 ( test ) 的 gem,其中包含用于测试项目的 Rails 3.1.1 应用程序。我正在尝试设置 Travis-CI 以进行持续集成,但是我不知道如何设置我的 .travis
如何指定:语言:.travis.yml 中的无? 我不指定语言,默认使用 Ruby。 我没有 ruby 。我正在使用 C、C++、Ocaml、Python 和 Felix。 构建脚本只是“制作”。 最
我正在使用 gitlab pages部署作业的输出。我有 3 个不同的工作产生 html输出。一项工作总是在运行。其他 2 个作业是可选的,因此它们是手动运行的。 如何将手 Action 业的输出部署
我在 gitlab.com 上有一个使用 CI 功能的私有(private)存储库。一些 CI 作业会创建存储的工件文件。我刚刚通过将其添加到 CI 配置中实现了一天后自动删除工件: expire_i
假设我为一个项目配置了多个作业,如下所示: build_win32: script: ... build_ios: script: ... unit_tests: script: ...
如何创建跨越多个阶段的 CI 作业以提高并行性? 如下图所示: 这个想法是slow_build应该最早开始build ,但是 test不依赖它,所以 test应该可以尽快启动build已经完成了。 (
我有一个 CI 管道,它可能正在做一些半变态的事情。我们不要争论这部分。 作为 CI 的一部分,我将生成一个工件 ( README.md ),我希望将其提交并推回同一存储库。只需使用 git push
我的项目同时使用nodejs和java 我尝试从 node_js 构建开始,然后安装 java(因为这是一个 npm 模块) 但是安装java的脚本失败了,而且我认为当已经存在java构建时就没有必要
我不想为了运行构建而将每一个小的更改都推送到 .travis.yml 以及对源代码所做的每一个小的更改。使用jenkins,您可以下载jenkins并在本地运行。特拉维斯提供这样的东西吗? Note:
主题。 这是否意味着在免费帐户中我的 api 请求数量有限? 响应部分示例: { "@type": "pending", "remaining_requests": 9, "reposit
有什么办法可以按顺序从舞台运行作业吗?我尝试过使用依赖项来做到这一点 job1: stage:deploy ... job2: stage:deploy dependencies:
我正在努力为多个项目设置 gitlab 运行程序,我们希望能够为所有项目设置环境变量。我尝试在 .bashrc 中为 gitlab-runner 和 root 用户设置全局变量,但在 CI 脚本过程中
Travis 有一种针对不同 PHP 版本测试项目的简单方法。 现在我想为插件运行测试。为此,我编写了一个在 .travis.yml 的安装阶段调用的脚本,它检查主项目并将我的插件源移动到正确的目录中
关闭。这个问题是not reproducible or was caused by typos .它目前不接受答案。 想改善这个问题吗?更新问题,使其成为 on-topic对于堆栈溢出。 5年前关闭。
我是一名优秀的程序员,十分优秀!