Test Oracles

Test Oracles:

  • An Oracle is a mechanism to determine whether the program passed or fail a test.
  • A test oracle is a source of expected results for a test case.
  • A test oracle is a method that verifies whether software executed correctly for a test case.
  • Test oracle is used to check the correctness of the output of the program for the test case.
  • Test oracle contain two essential parts:
    • Oracle information that represents expected output.
    • Oracle procedure that compares oracle information with the actual output.

How test oracle used:

Consider testing a process in which test cases are given to the test oracle and to the program under testing.
The output of the two is then compared to check if the program behaved correctly for test case.

Test Oracle would have following capabilities:

  • Generating the results from test cases.
  • Comparing the result from test cases.
  • Evaluating the result from test cases.

Examples of Test Oracles:

  • Checking keys before playing a game.

  • Test copy past in MS Word.

  • Test zoom in zoom out function in pain tool.

  • Test slide show in MS Power Point.
More topics from Software Engineering to read
Software Engineering

EasyExamNotes.com covered following topics in Software Engineering.
Python Programming ↓ 👆
Java Programming ↓ 👆
JAVA EasyExamNotes.com covered following topics in these notes.
JAVA Programs
Principles of Programming Languages ↓ 👆
Principles of Programming Languages
EasyExamNotes.com covered following topics in these notes.

Previous years solved papers:
A list of Video lectures References:
  1. Sebesta,”Concept of programming Language”, Pearson Edu 
  2. Louden, “Programming Languages: Principles & Practices” , Cengage Learning 
  3. Tucker, “Programming Languages: Principles and paradigms “, Tata McGraw –Hill. 
  4. E Horowitz, "Programming Languages", 2nd Edition, Addison Wesley

    Computer Organization and Architecture ↓ 👆

    Computer Organization and Architecture 

    EasyExamNotes.com covered following topics in these notes.

    1. Structure of desktop computers
    2. Logic gates
    3. Register organization
    4. Bus structure
    5. Addressing modes
    6. Register transfer language
    7. Direct mapping numericals
    8. Register in Assembly Language Programming
    9. Arrays in Assembly Language Programming


    1. William stalling ,“Computer Architecture and Organization” PHI
    2. Morris Mano , “Computer System Organization ”PHI

    Computer Network ↓ 👆
    Computer Network

    EasyExamNotes.com covered following topics in these notes.
    1. Data Link Layer
    2. Framing
    3. Byte count framing method
    4. Flag bytes with byte stuffing framing method
    5. Flag bits with bit stuffing framing method
    6. Physical layer coding violations framing method
    7. Error control in data link layer
    8. Stop and Wait scheme
    9. Sliding Window Protocol
    10. One bit sliding window protocol
    11. A protocol Using Go-Back-N
    12. Selective repeat protocol
    13. Application layer
    1. Andrew S. Tanenbaum, David J. Wetherall, “Computer Networks” Pearson Education.
    2. Douglas E Comer, “Internetworking with TCP/IP Principles, Protocols, And Architecture",Pearson Education
    3. KavehPahlavan, Prashant Krishnamurthy, “Networking Fundamentals”, Wiley Publication.
    4. Ying-Dar Lin, Ren-Hung Hwang, Fred Baker, “Computer Networks: An Open Source Approach”, McGraw Hill.