由于 bash 没有一流的函数,我通过将字符串传递给函数来模拟匿名函数,然后由eval.
it() {
    echo "$1" # prints the description of the spec
    beforeEach # a setup function
    eval "$2"
    if (($? == 0)); then
        # do something
    fi
    afterEach  # a cleanup function
}
it "should echo something" '{
  echo "something"
}'
这允许编写非常简洁的测试(它定义了规范)。现在我想知道这是否是 eval 的有效用法。
编辑
我知道匿名函数字符串中不需要开头 { 和结尾 } ,它就像 Jasmine 这样的东西。
编辑
这pseudo anonymous function实际上是一个测试,这意味着在测试结束时,有类似的东西
[[ var == 'foo' ]]
或者
((i > 10))
即某种测试(或断言,在 XUnit 术语中)。除了然后被评估的返回码之外,它永远不需要返回任何东西,如果返回码为 0(成功),则描述以绿色打印,否则为红色(测试失败)。
对于一次性使用的“匿名”函数,我使用以下约定在函数作用域中执行 bash 脚本:
#!/usr/bin/env bash
_() {
  #...
} && _ "$@"
unset -f _
虽然不是真正的匿名,但这类似于JavaScript 中的IIFE(立即调用函数表达式)习惯用法。
Bash 函数必须有一个名称。您可以使用任何您喜欢的名称(main这是一个流行的选择。)我更喜欢单个下划线_,因为 a) 它很短 b) 它通常在许多语言中用于指示一次性值。
如果它能完成工作,并且您(最好是其他人)完全了解它是如何工作的。
我已经不止一次或两次为测试用例自动化编写类似的代码,但我承认它可能会变得非常复杂,特别是如果你从简单开始,然后让它有机增长。
不管怎样,我想建议在风格上进行改进;
if eval "$2"; then
  # something
或者如果“某事”是一个简单的命令,普通的旧命令
eval "$2" && # something
话虽如此,如果您可以完全避免这种情况可能会更好eval,但这取决于您的测试用例。
$2 && # something
| 归档时间: | 
 | 
| 查看次数: | 1173 次 | 
| 最近记录: |