Skip to content

Latest commit

 

History

History
44 lines (30 loc) · 2.09 KB

RecordingIO.md

File metadata and controls

44 lines (30 loc) · 2.09 KB

Recording Input and Output

Before discussing how IO could be captured with Testrecorder, let us have a look on typical IO, to understand why IO cannot be captured in the same way as common variable state.

Typical sources of input are:

  • reading from console
  • reading from a file
  • reading system date/time
  • user interactions with a gui
  • computing a random number (using system time as seed)

Typical outputs are

  • writing to console
  • writing to a file
  • displaying data in the gui

From these examples we derive:

  • input is almost never part of the state before a method call, it is received while executing the method
  • output is almost never part of the state after a method call, it is generated while executing the method

And further:

  • input is originating from outside the java program, from a source that is not reproducible programmatically
  • output is only verifiable outside the java program, consumed from an entity that is not reproducible

Testrecorder follows a well known paradigm to simulate output/input - verifying and mocking. In the following sections we will show how we can mock input and capture output. However mocking/verifying with Testrecorder is not always applicable without modification of the code under test. The last section will give some hints how to change the code such that mocking is applicable.

Input

To capture the input, for mocking it in the later test cases, there are two variants:

  • Mark the method that produces input with the @Input annotation
  • Use a SerializationProfile implementing the method getInputs() and return the method that produces input

Whatever variant you choose, the result and the arguments of the method will be interpreted as input data.

Output

To capture output, for verifying it in the later test cases, there are two variants:

  • Mark the method that produces input with the @Output annotation
  • Use a SerializationProfile implementing the method getOutputs() and return the method that transfers output

Whatever variant you choose, the result and the arguments of the method will be interpreted as output data.