Mock Object - Reasons For Use

Reasons For Use

In a unit test, mock objects can simulate the behavior of complex, real (non-mock) objects and are therefore useful when a real object is impractical or impossible to incorporate into a unit test. If an object has any of the following characteristics, it may be useful to use a mock object in its place:

  • supplies non-deterministic results (e.g., the current time or the current temperature);
  • has states that are difficult to create or reproduce (e.g., a network error);
  • is slow (e.g., a complete database, which would have to be initialized before the test);
  • does not yet exist or may change behavior;
  • would have to include information and methods exclusively for testing purposes (and not for its actual task).

For example, an alarm clock program which causes a bell to ring at a certain time might get the current time from the outside world. To test this, the test must wait until the alarm time to know whether it has rung the bell correctly. If a mock object is used in place of the real object, it can be programmed to provide the bell-ringing time (whether it is actually that time or not) so that the alarm clock program can be tested in isolation.

Read more about this topic:  Mock Object

Famous quotes containing the word reasons:

    Science is the knowledge of many, orderly and methodically
    digested and arranged, so as to become attainable by one. The
    knowledge of reasons and their conclusions constitutes abstract, that of causes and their effects, and of the laws of nature, natural science.
    John Frederick William Herschel (1792–1871)