Modularization of Feature Methods

classic Classic list List threaded Threaded
8 messages Options
Reply | Threaded
Open this post in threaded view
|  
Report Content as Inappropriate

Modularization of Feature Methods

Fredy
Hi all!

We have some testscenario, collection of some given when then things.
In the moment, we define one testcase == one feature method. now we want to reuse some blocks or some sequences of blocks.
That should be possible with the Stepwise Extension! But does it work with inheritance? and if, how?

I hope the following pseudo code will explain my thoughts:

@Stepwise
class MySpec extends Specification{
    def "process task A"(){
      
        given: "a task of type a"
            a = new task()
       
        when: "task is processed"
            systemATaskProcessor.process()
           
        then: "task is completed"
            a.isComplete()
    }
   
    def "process task B"(){
       
        given: "a task of type b"
            b = new bTask()
       
        when: "task is processed"
            systemBTaskProcessor.process()
           
        then: "task is completed"
            b.isComplete()
    }
}

@Stepwise
class MyOtherSpec extends MySpec{

    def "process task A"(){
       
        given: "a task of type a"
            a = new task()
       
        when: "task is processed"
            systemATaskProcessor.process()
           
        then: "task is completed"
            a.isComplete()
    }
   
   
    def "process task A1"(){
       
    .......
    }
   
   
    def "process task B"(){
       
        given: "a task of type b"
            b = new bTask()
       
        when: "task is processed"
            systemBTaskProcessor.process()
           
        then: "task is completed"
            b.isComplete()

    }
}

@Stepwise
class My2ndOtherSpec extends MySpec{

    def "process task A"(){
       
        given: "a task of type a"
            a = new task()
       
        when: "task is processed"
            systemATaskProcessor.process()
           
        then: "task is completed"
            a.isComplete()
    }
   
   
    def "process task A2"(){
       
    .......
    }
   
   
    def "process task B"(){
       
        given: "a task of type b"
            b = new bTask()
       
        when: "task is processed"
            systemBTaskProcessor.process()
           
        then: "task is completed"
            b.isComplete()

    }
}


Any idea ??
Thanks!

--
You received this message because you are subscribed to the Google Groups "Spock Framework - User" group.
To unsubscribe from this group and stop receiving emails from it, send an email to [hidden email].
To post to this group, send email to [hidden email].
Visit this group at http://groups.google.com/group/spockframework.
For more options, visit https://groups.google.com/d/optout.
Reply | Threaded
Open this post in threaded view
|  
Report Content as Inappropriate

Re: Modularization of Feature Methods

Kostis Kapelonis
Hello

I am not sure that your pseudocode is clear. You say that you "want to
reuse some blocks or some sequences of blocks" but I see that both
MyOtherSpec and My2ndOtherSpec redefine "process task A" and "process
task B". So where is the code re-use? Am I missing something?
Your example would work correctly without the class MySpec. With the
StepWize annotation you could verify correctly the sequence A-A1-B and
A-A2-B using just the two other classes (if that is what you are
after)

Perhaps you can explain a bit more on your real world case and what
you are trying to accomplish.

If A and B are just two tasks that need to run always at the beginning
and the end of every test method, then just put the code directly at
setup()/cleanup methods.
No need to test them every time.

Inheritance among test cases is usually employed in order to share
setup and verification code, not to run the same test methods again
and again.

Kostis


On Mon, Jun 22, 2015 at 2:15 PM, Fredy <[hidden email]> wrote:

> Hi all!
>
> We have some testscenario, collection of some given when then things.
> In the moment, we define one testcase == one feature method. now we want to
> reuse some blocks or some sequences of blocks.
> That should be possible with the Stepwise Extension! But does it work with
> inheritance? and if, how?
>
> I hope the following pseudo code will explain my thoughts:
>
> @Stepwise
> class MySpec extends Specification{
>     def "process task A"(){
>
>         given: "a task of type a"
>             a = new task()
>
>         when: "task is processed"
>             systemATaskProcessor.process()
>
>         then: "task is completed"
>             a.isComplete()
>     }
>
>     def "process task B"(){
>
>         given: "a task of type b"
>             b = new bTask()
>
>         when: "task is processed"
>             systemBTaskProcessor.process()
>
>         then: "task is completed"
>             b.isComplete()
>     }
> }
>
> @Stepwise
> class MyOtherSpec extends MySpec{
>
>     def "process task A"(){
>
>         given: "a task of type a"
>             a = new task()
>
>         when: "task is processed"
>             systemATaskProcessor.process()
>
>         then: "task is completed"
>             a.isComplete()
>     }
>
>
>     def "process task A1"(){
>
>     .......
>     }
>
>
>     def "process task B"(){
>
>         given: "a task of type b"
>             b = new bTask()
>
>         when: "task is processed"
>             systemBTaskProcessor.process()
>
>         then: "task is completed"
>             b.isComplete()
>
>     }
> }
>
> @Stepwise
> class My2ndOtherSpec extends MySpec{
>
>     def "process task A"(){
>
>         given: "a task of type a"
>             a = new task()
>
>         when: "task is processed"
>             systemATaskProcessor.process()
>
>         then: "task is completed"
>             a.isComplete()
>     }
>
>
>     def "process task A2"(){
>
>     .......
>     }
>
>
>     def "process task B"(){
>
>         given: "a task of type b"
>             b = new bTask()
>
>         when: "task is processed"
>             systemBTaskProcessor.process()
>
>         then: "task is completed"
>             b.isComplete()
>
>     }
> }
>
> Any idea ??
> Thanks!
>
> --
> You received this message because you are subscribed to the Google Groups
> "Spock Framework - User" group.
> To unsubscribe from this group and stop receiving emails from it, send an
> email to [hidden email].
> To post to this group, send email to [hidden email].
> Visit this group at http://groups.google.com/group/spockframework.
> For more options, visit https://groups.google.com/d/optout.

--
You received this message because you are subscribed to the Google Groups "Spock Framework - User" group.
To unsubscribe from this group and stop receiving emails from it, send an email to [hidden email].
To post to this group, send email to [hidden email].
Visit this group at http://groups.google.com/group/spockframework.
For more options, visit https://groups.google.com/d/optout.
Reply | Threaded
Open this post in threaded view
|  
Report Content as Inappropriate

Re: Modularization of Feature Methods

Fredy
Hi Kostis,
you are right, the pseudo code is ambiguous.
I won't duplicate the codeblocks "process task A" and "process task B" ! That was a try to clearify my problem -> failed ;-)

So the solution should look like:

@Stepwise
class MyOtherSpec extends MySpec{

    "process task A"()
     
    def "process task A1"(){
    .......
    }
  
    "process task B"()
}

@Stepwise
class My2ndOtherSpec extends MySpec{

    "process task A"()

    def "process task A2"(){
    .......
    }
  
    "process task B"()
}


"Perhaps you can explain a bit more on your real world case and what you are trying to accomplish. "
-> That is not always so easy if you should not talk about the business of your employer.

We want to do integration tests for complex useCases that run over 3 to 4 systems. There are batch jobs and webservice calls included.
Some scenarios when/then, when/then, ... are included in more than one useCase or we do different testcases for the same useCase and have to
include this scenarios in all the testcases. (on different positions, so setup/cleanup is not possible).
Put the reusable scenarios in Helper Classes is not possible, because we want to use the spock blocks for reporting.

"not to run the same test methods again and again." You are right, that is redundant, but the generated reports have to include these redundant things. In our own reports we want to generate a kind of user story with dynamic variables. So we have to rerun the same scenario again and again. Depending on the situation after the "same test methods" has been called the system acts different and we have to go on with a testcase specific scenario. That are the reasons for reusing blocks/scenarios.

sample report:



<img style="" src="" alt="">
Thanks a lot for your fast answer
Fredy

Am Montag, 22. Juni 2015 21:55:35 UTC+2 schrieb Kostis Kapelonis:
Hello

I am not sure that your pseudocode is clear. You say that you "want to
reuse some blocks or some sequences of blocks" but I see that both
MyOtherSpec and My2ndOtherSpec redefine "process task A" and "process
task B". So where is the code re-use? Am I missing something?
Your example would work correctly without the class MySpec. With the
StepWize annotation you could verify correctly the sequence A-A1-B and
A-A2-B using just the two other classes (if that is what you are
after)

Perhaps you can explain a bit more on your real world case and what
you are trying to accomplish.

If A and B are just two tasks that need to run always at the beginning
and the end of every test method, then just put the code directly at
setup()/cleanup methods.
No need to test them every time.

Inheritance among test cases is usually employed in order to share
setup and verification code, not to run the same test methods again
and again.

Kostis


On Mon, Jun 22, 2015 at 2:15 PM, Fredy <<a href="javascript:" target="_blank" gdf-obfuscated-mailto="0dSNZjsfC5MJ" rel="nofollow" onmousedown="this.href='javascript:';return true;" onclick="this.href='javascript:';return true;">haus...@...> wrote:

> Hi all!
>
> We have some testscenario, collection of some given when then things.
> In the moment, we define one testcase == one feature method. now we want to
> reuse some blocks or some sequences of blocks.
> That should be possible with the Stepwise Extension! But does it work with
> inheritance? and if, how?
>
> I hope the following pseudo code will explain my thoughts:
>
> @Stepwise
> class MySpec extends Specification{
>     def "process task A"(){
>
>         given: "a task of type a"
>             a = new task()
>
>         when: "task is processed"
>             systemATaskProcessor.process()
>
>         then: "task is completed"
>             a.isComplete()
>     }
>
>     def "process task B"(){
>
>         given: "a task of type b"
>             b = new bTask()
>
>         when: "task is processed"
>             systemBTaskProcessor.process()
>
>         then: "task is completed"
>             b.isComplete()
>     }
> }
>
> @Stepwise
> class MyOtherSpec extends MySpec{
>
>     def "process task A"(){
>
>         given: "a task of type a"
>             a = new task()
>
>         when: "task is processed"
>             systemATaskProcessor.process()
>
>         then: "task is completed"
>             a.isComplete()
>     }
>
>
>     def "process task A1"(){
>
>     .......
>     }
>
>
>     def "process task B"(){
>
>         given: "a task of type b"
>             b = new bTask()
>
>         when: "task is processed"
>             systemBTaskProcessor.process()
>
>         then: "task is completed"
>             b.isComplete()
>
>     }
> }
>
> @Stepwise
> class My2ndOtherSpec extends MySpec{
>
>     def "process task A"(){
>
>         given: "a task of type a"
>             a = new task()
>
>         when: "task is processed"
>             systemATaskProcessor.process()
>
>         then: "task is completed"
>             a.isComplete()
>     }
>
>
>     def "process task A2"(){
>
>     .......
>     }
>
>
>     def "process task B"(){
>
>         given: "a task of type b"
>             b = new bTask()
>
>         when: "task is processed"
>             systemBTaskProcessor.process()
>
>         then: "task is completed"
>             b.isComplete()
>
>     }
> }
>
> Any idea ??
> Thanks!
>
> --
> You received this message because you are subscribed to the Google Groups
> "Spock Framework - User" group.
> To unsubscribe from this group and stop receiving emails from it, send an
> email to <a href="javascript:" target="_blank" gdf-obfuscated-mailto="0dSNZjsfC5MJ" rel="nofollow" onmousedown="this.href='javascript:';return true;" onclick="this.href='javascript:';return true;">spockframewor...@googlegroups.com.
> To post to this group, send email to <a href="javascript:" target="_blank" gdf-obfuscated-mailto="0dSNZjsfC5MJ" rel="nofollow" onmousedown="this.href='javascript:';return true;" onclick="this.href='javascript:';return true;">spockfr...@googlegroups.com.
> Visit this group at <a href="http://groups.google.com/group/spockframework" target="_blank" rel="nofollow" onmousedown="this.href='http://groups.google.com/group/spockframework';return true;" onclick="this.href='http://groups.google.com/group/spockframework';return true;">http://groups.google.com/group/spockframework.
> For more options, visit <a href="https://groups.google.com/d/optout" target="_blank" rel="nofollow" onmousedown="this.href='https://groups.google.com/d/optout';return true;" onclick="this.href='https://groups.google.com/d/optout';return true;">https://groups.google.com/d/optout.

--
You received this message because you are subscribed to the Google Groups "Spock Framework - User" group.
To unsubscribe from this group and stop receiving emails from it, send an email to [hidden email].
To post to this group, send email to [hidden email].
Visit this group at http://groups.google.com/group/spockframework.
For more options, visit https://groups.google.com/d/optout.
Reply | Threaded
Open this post in threaded view
|  
Report Content as Inappropriate

Re: Modularization of Feature Methods

Fredy

Next try with the screenshot:

<img style="" src="" alt="">

--
You received this message because you are subscribed to the Google Groups "Spock Framework - User" group.
To unsubscribe from this group and stop receiving emails from it, send an email to [hidden email].
To post to this group, send email to [hidden email].
Visit this group at http://groups.google.com/group/spockframework.
For more options, visit https://groups.google.com/d/optout.
Reply | Threaded
Open this post in threaded view
|  
Report Content as Inappropriate

Re: Modularization of Feature Methods

Fredy
In reply to this post by Kostis Kapelonis
Hi Kostis,
you are right, the pseudo code is ambiguous.
I won't duplicate the codeblocks "process task A" and "process task B" ! That was a try to clearify my problem -> failed ;-)

So the solution should look like:

@Stepwise
class MyOtherSpec extends MySpec{

    "process task A"()
     
    def "process task A1"(){
    .......
    }
 
    "process task B"()
}

@Stepwise
class My2ndOtherSpec extends MySpec{

    "process task A"()

    def "process task A2"(){
    .......
    }
 
    "process task B"()
}


"Perhaps you can explain a bit more on your real world case and what you are trying to accomplish. "
-> That is not always so easy if you should not talk about the business of your employer.

We want to do integration tests for complex useCases that run over 3 to 4 systems. There are batch jobs and webservice calls included.
Some scenarios when/then, when/then, ... are included in more than one useCase or we do different testcases for the same useCase and have to
include this scenarios in all the testcases. (on different positions, so setup/cleanup is not possible).
Put the reusable scenarios in Helper Classes is not possible, because we want to use the spock blocks for reporting.

"not to run the same test methods again and again." You are right, that is redundant, but the generated reports have to include these redundant things. In our own reports we want to generate a kind of user story with dynamic variables. So we have to rerun the same scenario again and again. Depending on the situation after the "same test methods" has been called the system acts different and we have to go on with a testcase specific scenario. That are the reasons for reusing blocks/scenarios.

sample report:

    <h1>MyTestCase</h1>
    <table>       
        <tr>
            <td><b>SETUP</b> New Customer with xyz Contract</br>
                  <p>
                    Customer 0815 was created with workorder 678.<br />
                    Contract 0816 was created with workorder 679.<br />
                    Contract has ...... with id 654<br/>
                  </p>
            </td>
        </tr>
        <tr>
            <td><br/><b>WHEN</b> The EventCreator was called,</br>
                  <p>
                    The <a href="someLink">Service</a> has created a xyz-Event (2274) for accountnumber: 0815,<br /> and contractWorkorderNumber: 687.<br />
                  </p>
            </td>
        </tr>   
        <tr>
            <td><br/><b>THEN</b> ....</br>
                  <p>
                ...
                  </p>
              </td>
          </tr>
          <tr>
            <td><br/><b>WHEN</b> ...</br>
                  <p>
                    .... and so on
                  </p>
            </td>
        </tr>   
        <tr>
            <td><br/><b>THEN</b> ....</br>
                  <p>
                ...
                  </p>
              </td>
          </tr>
    </table>




Thanks a lot for your fast answer
Fredy

--
You received this message because you are subscribed to the Google Groups "Spock Framework - User" group.
To unsubscribe from this group and stop receiving emails from it, send an email to [hidden email].
To post to this group, send email to [hidden email].
Visit this group at http://groups.google.com/group/spockframework.
For more options, visit https://groups.google.com/d/optout.
Reply | Threaded
Open this post in threaded view
|  
Report Content as Inappropriate

Re: Modularization of Feature Methods

Fredy
In reply to this post by Kostis Kapelonis
Hi Kostis,
you are right, the pseudo code is ambiguous.
I won't duplicate the codeblocks "process task A" and "process task B" ! That was a try to clearify my problem -> failed ;-)

So the solution should look like:

@Stepwise
class MyOtherSpec extends MySpec{

    "process task A"()
    
    def "process task A1"(){
    .......
    }
 
    "process task B"()
}

@Stepwise
class My2ndOtherSpec extends MySpec{

    "process task A"()

    def "process task A2"(){
    .......
    }
 
    "process task B"()
}


"Perhaps you can explain a bit more on your real world case and what you are trying to accomplish. "
-> That is not always so easy if you should not talk about the business of your employer.

We want to do integration tests for complex useCases that run over 3 to 4 systems. There are batch jobs and webservice calls included.
Some scenarios when/then, when/then, ... are included in more than one useCase or we do different testcases for the same useCase and have to
include this scenarios in all the testcases. (on different positions, so setup/cleanup is not possible).
Put the reusable scenarios in Helper Classes is not possible, because we want to use the spock blocks for reporting.

"not to run the same test methods again and again." You are right, that is redundant, but the generated reports have to include these redundant things. In our own reports we want to generate a kind of user story with dynamic variables. So we have to rerun the same scenario again and again. Depending on the situation after the "same test methods" has been called the system acts different and we have to go on with a testcase specific scenario. That are the reasons for reusing blocks/scenarios.

sample report:

MyTestCase

SETUP New Customer with xyz Contract

Customer 0815 was created with workorder 678.
 Contract 0816 was created with workorder 679.
 Contract has ...... with id 654

WHEN The EventCreator was called,
 calling service xyz

THEN
The Service has created a xyz-Event (2274) for accountnumber: 0815,
 and contractWorkorderNumber: 687.

WHEN The Event Processor was called
Start Batch Jon xyz with executionid 67

THEN Event is in PROGRESS
The xyz-Event (2274) is in state PROGRESS

THEN and the system A was called
The xyz in systemn A for accountnumber: 0815 has changed like....

WHEN ...
...

THEN ...
...

and so on



Thanks a lot for your fast answer
Fredy

--
You received this message because you are subscribed to the Google Groups "Spock Framework - User" group.
To unsubscribe from this group and stop receiving emails from it, send an email to [hidden email].
To post to this group, send email to [hidden email].
Visit this group at http://groups.google.com/group/spockframework.
For more options, visit https://groups.google.com/d/optout.
Reply | Threaded
Open this post in threaded view
|  
Report Content as Inappropriate

Re: Modularization of Feature Methods

Fredy
In reply to this post by Kostis Kapelonis
Hi Kostis,
no more reply ? Did you understand my situation? What do you think about it?

Fredy

--
You received this message because you are subscribed to the Google Groups "Spock Framework - User" group.
To unsubscribe from this group and stop receiving emails from it, send an email to [hidden email].
To post to this group, send email to [hidden email].
Visit this group at http://groups.google.com/group/spockframework.
For more options, visit https://groups.google.com/d/optout.
Reply | Threaded
Open this post in threaded view
|  
Report Content as Inappropriate

Re: Modularization of Feature Methods

Kostis Kapelonis
Hello

As far as I know what you ask in not possible. The Stepwize annotation
is not that smart to understand class hierarchy and automatically nest
inherited methods to their "effective" order.

The only workaround I can think is to put into helper classes the
common code. But just the common code, not the whole Spock blocks (so
that reporting works correctly as you say)

Kostis

On Thu, Jun 25, 2015 at 9:50 AM, Fredy <[hidden email]> wrote:

> Hi Kostis,
> no more reply ? Did you understand my situation? What do you think about it?
>
> Fredy
>
> --
> You received this message because you are subscribed to the Google Groups
> "Spock Framework - User" group.
> To unsubscribe from this group and stop receiving emails from it, send an
> email to [hidden email].
> To post to this group, send email to [hidden email].
> Visit this group at http://groups.google.com/group/spockframework.
> For more options, visit https://groups.google.com/d/optout.

--
You received this message because you are subscribed to the Google Groups "Spock Framework - User" group.
To unsubscribe from this group and stop receiving emails from it, send an email to [hidden email].
To post to this group, send email to [hidden email].
Visit this group at http://groups.google.com/group/spockframework.
For more options, visit https://groups.google.com/d/optout.
Loading...