CXYVIP官网源码交易平台_网站源码_商城源码_小程序源码平台-丞旭猿论坛
CXYVIP官网源码交易平台_网站源码_商城源码_小程序源码平台-丞旭猿论坛
CXYVIP官网源码交易平台_网站源码_商城源码_小程序源码平台-丞旭猿论坛

利用均匀水流导致水位变化来显示时间是什么原因(不看后悔)利用均匀水流导致的水位变化来显示时间是什么的原则,利用 BATS 测试 Bash 脚本和库,丞旭猿免费源码交易平台,

1.均匀水流导致的水位变化来显示时间是什么

Bash 自动测试系统可以使 Bash 代码也通过 Java、Ruby 和 Python 开发人员所使用的同类测试过程。

2.利用均匀水流导致的水位变化来显示时间是什么原

用 Java、Ruby 和 Python 等语言编写应用程序的软件开发人员拥有复杂的库,可以帮助他们随着时间的推移保持软件的完整性他们可以创建测试,以在结构化环境中通过执行一系列动作来运行应用程序,以确保其软件所有的方面均按预期工作。

3.均匀水流导致水位变化显示时间是什么原理

当这些测试在持续集成(CI)系统中自动进行时,它们的功能就更加强大了,每次推送到源代码库都会触发测试,并且在测试失败时会立即通知开发人员这种快速反馈提高了开发人员对其应用程序功能完整性的信心Bash 自动测试系统Bash Automated Testing System(BATS)使编写 Bash 脚本和库的开发人员能够将 Java、Ruby、Python 和其他开发人员所使用的相同惯例应用于其 Bash 代码中。

4.利用均匀水流导致水位变化显示时间是什么原理

安装 BATSBATS GitHub 页面包含了安装指令有两个 BATS 辅助库提供更强大的断言或允许覆写 BATS 使用的 Test Anything Protocol(TAP)输出格式这些库可以安装在一个标准位置,并被所有的脚本引用。

5.用均匀水流导致的水位变化来显示时间是什么的基本

更方便的做法是,将 BATS 及其辅助库的完整版本包含在 Git 仓库中,用于要测试的每组脚本或库这可以通过git 子模块系统来完成以下命令会将 BATS 及其辅助库安装到 Git 知识库中的 test

6.用均匀水流导致的水位变化来显示时间是什么原理

目录中git submodule init git submodule add https://github.com/sstephenson/bats test/libs/bats git submodule 。

7.均匀水流导致的水位变化显示时间是什么的基本原理

add https://github.com/ztombol/bats-assert test/libs/bats-assert git submodule add https://github.com/ztombol/bats-support test/libs/bats-support

8.利用均匀水流导致水位变化显示时间是什么的原理

git add . git commit -m installed bats要克隆 Git 仓库并同时安装其子模块,请在 git clone时使用–recurse-submodules标记每个 BATS 测试脚本必须由 。

9.利用均匀水流导致的水位变化显示时间是什么原理

bats可执行文件执行如果你将 BATS 安装到源代码仓库的test/libs目录中,则可以使用以下命令调用测试:./test/libs/bats/bin/bats 或者,将以下内容添加到每个 BATS 测试脚本的开头:。

10.利用均匀水流导致水位变化来显示时间是什么原理

#!/usr/bin/env ./test/libs/bats/bin/batsloadlibs/bats-support/loadloadlibs/bats-assert/load并且执行命令 chmod +x

这将 a、使它们可与安装在./test/libs/bats中的 BATS 一同执行,并且 b、包含这些辅助库BATS 测试脚本通常存储在test目录中,并以要测试的脚本命名,扩展名为.bats例如,一个测试。

bin/build的 BATS 脚本应称为test/build.bats你还可以通过向 BATS 传递正则表达式来运行一整套 BATS 测试文件,例如 ./test/lib/bats/bin/bats test/*.bats。

为 BATS 覆盖率而组织库和脚本Bash 脚本和库必须以一种有效地方式将其内部工作原理暴露给 BATS 进行组织通常,在调用或执行时库函数和运行诸多命令的 Shell 脚本不适合进行有效的 BATS 测试。

例如,build.sh是许多人都会编写的典型脚本本质上是一大堆代码有些人甚至可能将这堆代码放入库中的函数中但是,在 BATS 测试中运行一大堆代码,并在单独的测试用例中覆盖它可能遇到的所有故障类型是不可能的。

测试这堆代码并有足够的覆盖率的唯一方法就是把它分解成许多小的、可重用的、最重要的是可独立测试的函数向库添加更多的函数很简单额外的好处是其中一些函数本身可以变得出奇的有用将库函数分解为许多较小的函数后,你可以在 BATS 测试中援引source这些库,并像测试任何其他命令一样运行这些函数。

Bash 脚本也必须分解为多个函数,执行脚本时,脚本的主要部分应调用这些函数此外,还有一个非常有用的技巧,可以让你更容易地用 BATS 测试 Bash 脚本:将脚本主要部分中执行的所有代码都移到一个函数中,称为 。

run_main然后,将以下内容添加到脚本的末尾:if [[ “${BASH_SOURCE[0]}” == “${0}” ]] then run_main fi这段额外的代码做了一些特别的事情它使脚本在作为脚本执行时与使用援引source进入环境时的行为有所不同。

通过援引并测试单个函数,这个技巧使得脚本的测试方式和库的测试方式变得一样例如,这是重构的 build.sh,以获得更好的 BATS 可测试性编写和运行测试如上所述,BATS 是一个 TAP 兼容的测试框架,其语法和输出对于使用过其他 TAP 兼容测试套件(例如 JUnit、RSpec 或 Jest)的用户来说将是熟悉的。

它的测试被组织成单个测试脚本测试脚本被组织成一个或多个描述性 @test块中,它们描述了被测试应用程序的单元每个@test块将运行一系列命令,这些命令准备测试环境、运行要测试的命令,并对被测试命令的退出和输出进行断言。

许多断言函数是通过bats、bats-assert和bats-support库导入的,这些库在 BATS 测试脚本的开头加载到环境中下面是一个典型的 BATS 测试块:@test”requires CI_COMMIT_REF_SLUG environment variable”。

{ unset CI_COMMIT_REF_SLUG assert_empty “${CI_COMMIT_REF_SLUG}” run some_command assert_failure assert_output –partial

“CI_COMMIT_REF_SLUG” } 如果 BATS 脚本包含 setup(安装)和/或teardown(拆卸) 函数,则 BATS 将在每个测试块运行之前和之后自动执行它们这样就可以创建环境变量、测试文件以及执行一个或所有测试所需的其他操作,然后在每次测试运行后将其拆卸。

Build.bats是对我们新格式化的build.sh脚本的完整 BATS 测试(此测试中的mock_docker命令将在以下关于模拟/打标的部分中进行说明)当测试脚本运行时,BATS 使用 exec(执行)来将每个

@test块作为单独的子进程运行这样就可以在一个@test中导出环境变量甚至函数,而不会影响其他@test或污染你当前的 Shell 会话测试运行的输出是一种标准格式,可以被人理解,并且可以由 TAP 使用端以编程方式进行解析或操作。

下面是CI_COMMIT_REF_SLUG测试块失败时的输出示例: ✗ requires CI_COMMIT_REF_SLUG environment variable (from function

`assert_outputinfiletest/libs/bats-assert/src/assert.bash, line 231, intestfiletest/ci_deploy.bats

, line 26) `assert_output –partial “CI_COMMIT_REF_SLUG” failed– output does not contain substring —

substring (1lines): CI_COMMIT_REF_SLUG output (3lines): ./bin/deploy.sh: join_string_by: command

not found oc error Could not login — ** Did not delete , as test failed ** 1 test,

1 failure 下面是成功测试的输出:✓ requires CI_COMMIT_REF_SLUG environment variable 辅助库像任何 Shell 脚本或库一样,BATS 测试脚本可以包括辅助库,以在测试之间共享通用代码或增强其性能。

这些辅助库,例如 bats-assert和bats-support甚至可以使用 BATS 进行测试库可以和 BATS 脚本放在同一个测试目录下,如果测试目录下的文件数量过多,也可以放在 test/libs。

目录下BATS 提供了load函数,该函数接受一个相对于要测试的脚本的 Bash 文件的路径(例如,在我们的示例中的test),并援引该文件文件必须以后缀.bash结尾,但是传递给load函数的文件路径不能包含后缀。

build.bats加载bats-assert和bats-support库、一个小型helpers.bash库以及docker_mock.bash库(如下所述),以下代码位于测试脚本的开头,解释器魔力行下方:

loadlibs/bats-support/loadloadlibs/bats-assert/loadloadhelpersloaddocker_mock打标测试输入和模拟外部调用大多数 Bash 脚本和库运行时都会执行函数和/或可执行文件。

通常,它们被编程为基于这些函数或可执行文件的输出状态或输出(stdout、stderr)以特定方式运行为了正确地测试这些脚本,通常需要制作这些命令的伪版本,这些命令被设计成在特定测试过程中以特定方式运行,称为“打标stubbing”。

可能还需要监视正在测试的程序,以确保其调用了特定命令,或者使用特定参数调用了特定命令,此过程称为“模拟mocking”有关更多信息,请查看在 Ruby RSpec 中有关模拟和打标的讨论,它适用于任何测试系统。

Bash shell 提供了一些技巧,可以在你的 BATS 测试脚本中使用这些技巧进行模拟和打标所有这些都需要使用带有 -f标志的 Bashexport命令来导出一个覆盖了原始函数或可执行文件的函数必须在测试程序执行之前完成此操作。

下面是重写可执行命令cat的简单示例:function cat { echo”THIS WOULD CAT ${*}” } export -f cat 此方法以相同的方式覆盖了函数如果一个测试需要覆盖要测试的脚本或库中的函数,则在对函数进行打标或模拟之前,必须先声明已测试脚本或库,这一点很重要。

否则,在声明脚本时,打标/模拟将被原函数替代另外,在运行即将进行的测试命令之前确认打标/模拟下面是build.bats的示例,该示例模拟build.sh中描述的raise函数,以确保登录函数会引发特定的错误消息:

@test”.login raises on oc error” { source${profile_script}function raise { echo”${1} raised”; } export

-f raise run login assert_failure assert_output -p “Could not login raised” } 一般情况下,没有必要在测试后复原打标/模拟的函数,因为

export(输出)仅在当前@test块的exec(执行)期间影响当前子进程但是,可以模拟/打标 BATSassert函数在内部使用的命令(例如cat、sed等)是可能的在运行这些断言命令之前,必须对这些模拟/打标函数进行。

unset(复原),否则它们将无法正常工作下面是build.bats中的一个示例,该示例模拟sed,运行build_deployable函数并在运行任何断言之前复原sed:@test”.build_deployable prints information, runs docker build on a modified Dockerfile.production and publish_image when its not a dry_run”。

{ local expected_dockerfile=Dockerfile.productionlocal application=applicationlocal environment=environment

local expected_original_base_image=”${application}”local expected_candidate_image=”${application}-candidate{environment}”

local expected_deployable_image=”${application}{environment}”source${profile_script} mock_docker build –build-arg OAUTH_CLIENT_ID –build-arg OAUTH_REDIRECT –build-arg DDS_API_BASE_URL -t

“${expected_deployable_image}” – function publish_image { echo”publish_image ${*}”; } export -f publish_image

function sed { echo”sed ${*}” >&2; echo”FROM application-candidate:environment”; } export -f sed run build_deployable

“${application}””${environment}” assert_success unset sed assert_output –regexp “sed.*${expected_dockerfile}

” assert_output -p “Building ${expected_original_base_image} deployable ${expected_deployable_image} FROM

${expected_candidate_image}” assert_output -p “FROM ${expected_candidate_image} piped” assert_output -p

“build –build-arg OAUTH_CLIENT_ID –build-arg OAUTH_REDIRECT –build-arg DDS_API_BASE_URL -t ${expected_deployable_image}

-” assert_output -p “publish_image ${expected_deployable_image}” }有的时候相同的命令,例如 foo,将在被测试的同一函数中使用不同的参数多次调用。

这些情况需要创建一组函数:mock_foo:将期望的参数作为输入,并将其持久化到 TMP 文件中foo:命令的模拟版本,该命令使用持久化的预期参数列表处理每个调用必须使用export -f将其导出cleanup_foo

:删除 TMP 文件,用于拆卸函数这可以进行测试以确保在删除之前成功完成@test块由于此功能通常在不同的测试中重复使用,因此创建一个可以像其他库一样加载的辅助库会变得有意义docker_mock.bash是一个很棒的例子。

它被加载到build.bats中,并在任何测试调用 Docker 可执行文件的函数的测试块中使用使用docker_mock典型的测试块如下所示:@test”.publish_image fails if docker push fails”。

{ setup_publish local expected_image=”image”local expected_publishable_image=”${CI_REGISTRY_IMAGE}

/${expected_image}”source${profile_script} mock_docker tag “${expected_image}””${expected_publishable_image}

” mock_docker push “${expected_publishable_image}” and_fail run publish_image “${expected_image}”

assert_failure assert_output -p “tagging ${expected_image} as ${expected_publishable_image}” assert_output -p

“tag ${expected_image}${expected_publishable_image}” assert_output -p “pushing image to gitlab registry”

assert_output -p “push ${expected_publishable_image}” } 该测试建立了一个使用不同的参数两次调用 Docker 的预期在对Docker 的第二次调用失败时,它会运行测试命令,然后测试退出状态和对 Docker 调用的预期。

一方面 BATS 利用 mock_docker.bash引入${BATS_TMPDIR}环境变量,BATS 在测试开始的位置对其进行了设置,以允许测试和辅助程序在标准位置创建和销毁 TMP 文件如果测试失败,。

mock_docker.bash库不会删除其持久化的模拟文件,但会打印出其所在位置,以便可以查看和删除它你可能需要定期从该目录中清除旧的模拟文件关于模拟/打标的一个注意事项:build.bats测试有意识地违反了关于测试声明的规定:不要模拟没有拥有的!该规定要求调用开发人员没有编写代码的测试命令,例如。

docker、cat、sed等,应封装在自己的库中,应在使用它们脚本的测试中对其进行模拟然后应该在不模拟外部命令的情况下测试封装库这是一个很好的建议,而忽略它是有代价的如果 Docker CLI API 发生变化,则测试脚本不会检测到此变化,从而导致错误内容直到经过测试的 。

build.sh脚本在使用新版本 Docker 的生产环境中运行后才显示出来测试开发人员必须确定要严格遵守此标准的程度,但是他们应该了解其所涉及的权衡总结在任何软件开发项目中引入测试制度,都会在以下两方面产生权衡: a、增加开发和维护代码及测试所需的时间和组织,b、增加开发人员在对应用程序整个生命周期中完整性的信心。

测试制度可能不适用于所有脚本和库通常,满足以下一个或多个条件的脚本和库才可以使用 BATS 测试:值得存储在源代码管理中用于关键流程中,并依靠它们长期稳定运行需要定期对其进行修改以添加/删除/修改其功能

可以被其他人使用一旦决定将测试规则应用于一个或多个 Bash 脚本或库,BATS 就提供其他软件开发环境中可用的全面测试功能致谢:感谢 Darrin Mann向我引荐了 BATS 测试via: https://opensource.com/article/19/2/testing-bash-bats。

作者:Darin London选题:lujun9972译者:stevenzdg988校对:wxy本文由 LCTT原创编译,Linux中国荣誉推出

© 版权声明
THE END
喜欢就支持一下吧
点赞0赞赏 分享
相关推荐
评论 抢沙发
头像
欢迎您留下宝贵的见解!
提交
头像

昵称

取消
昵称表情代码图片

    暂无评论内容