使用Spock在多个返回结果中抛出IOException

Mat*_*Bro 5 groovy spock

我正在测试错误处理。我希望第一次调用mockedObject.foo()抛出一个新的 IOException,第二次调用返回 bar。我尝试了以下代码,

mockedObject.foo() >>> [{throw new IOException()}, bar]
Run Code Online (Sandbox Code Playgroud)

但是,当我运行测试时,我收到一条错误,指出无法将闭包强制转换为 Bar,

FooSpec$_$spock_feature_0_1_closure2 无法转换为 Bar

我如何用 Spock 来嘲笑这种行为?

编辑:看到 tim_yates 引用的文档后,我只是将测试更改为,

mockedObject.foo() >>> firstBar >> {throw new IOException()} >> secondBar
Run Code Online (Sandbox Code Playgroud)

这足以测试我需要测试的内容。下面的代码抛出了相同的异常,所以我猜测 Spock 正在根据第一个对象返回设置模拟方法的返回类型。

mockedObject.foo() >>> {throw new IOException()} >> secondBar
Run Code Online (Sandbox Code Playgroud)

tim*_*tes 6

您应该能够执行以下操作:

mockedObject.foo() >>> {throw new IOException()} >> bar
Run Code Online (Sandbox Code Playgroud)

请参阅文档中的此处


Opa*_*pal 1

这是一个完整的工作示例:

@Grab('org.spockframework:spock-core:0.7-groovy-2.0')
@Grab('cglib:cglib:3.1') 
@Grab('org.ow2.asm:asm-all:5.0.3') 

import spock.lang.*

class MyTestSpec extends Specification {    
   def 'spec'() {
      given:
      def a = new A()
      a.b = Mock(B) {
         foob() >> { throw new Exception('aaa') } >> 1
      }

      when:
      a.fooa()

      then:
      def e = thrown(Exception)        
      e.message == 'aaa'

      when:
      def r = a.fooa()

      then:
      r == 1
   }
}

class A {

    B b = new B()

    Integer fooa() {
        b.foob()
    }
}

class B {
    Integer foob() {
        2
    }
}
Run Code Online (Sandbox Code Playgroud)