在bash中实现匿名函数是否可行(如果需要,甚至使用eval)?
发布时间:2020-12-15 21:32:02 所属栏目:安全 来源:网络整理
导读:由于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 cl
由于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这样的东西. 编辑 伪匿名函数实际上是一个测试,这意味着在测试结束时,有类似的东西 [[ var == 'foo' ]] 要么 ((i > 10)) 即某种测试(或以XUnit术语断言).它永远不需要返回任何东西,而不是返回代码然后被评估,如果返回代码是0(成功),描述将打印为绿色,否则为红色(测试失败). 解决方法
如果它完成了工作,你(以及理想的其他人)完全理解它是如何工作的.
我一直在为测试用例自动化编写类似的代码超过一次或两次,但我承认它可能变得非常毛茸茸,特别是如果你开始简单然后允许它有机增长. 对于它的价值,我想建议一种风格上的改进; if eval "$2"; then # something 或者如果“某事”是一个简单的命令,那么简单 eval "$2" && # something 话虽如此,如果你完全避免使用eval可能会更好,但这取决于你的测试用例. $2 && # something (编辑:李大同) 【声明】本站内容均来自网络,其相关言论仅代表作者个人观点,不代表本站立场。若无意侵犯到您的权利,请及时与联系站长删除相关内容! |