Software verification

Software verification

Software verification is a broad and complex discipline of software engineering whose goal is to assure that software fully satisfies all the expected requirements.

There are two fundamental approaches to verification:
* "Dynamic verification", also known as Test or Experimentation
* "Static verification", also known as Analysis

Dynamic verification (Test,Experimentation)

Dynamic verification is performed during the execution of software, and dynamically checks its behaviour; it is commonly known as the Test phase.Verification is a Review Process.Depending on the scope of tests, we can categorize them in three families:
* "Test in the small": a test that checks a single function or class (Unit test)
* "Test in the large": a test that checks a group of classes, such as
** Module test (a single module)
** Integration test (more than one module)
** System test (the entire system)
* "Acceptance test": a formal test defined to check acceptance criteria for a software
** Functional test
** Non functional test (performance, stress test)

Software verification is often confused with software validation. The difference between verification" and validation"':
* Software "verification" asks the question, "Are we building the product right?"; that is, does the software conform to its specification.
* Software "validation" asks the question, "Are we building the right product?"; that is, is the software doing what the user really requires.The aim of software verification is to find the errors introduced by an activity, i.e. check if the product of the activity is as correct as it was at the beginning of the activity.

The aim of software validation is to declare whether the product of an activity is indeed what is expected, i.e. the activity extended the product successfully.

Static verification (Analysis)

Static verification is the process of checking that software meets requirements by doing a physical inspection of it. For example:
* "Code conventions verification"
* "Bad practices detection"
* Software metrics calculation
* Formal verification

References

* IEEE: "SWEBOK: Guide to the Software Engineering Body of Knowledge"
* Carlo Ghezzi, Mehdi Jazayeri, Dino Mandrioli: "Fundamentals of Software Engineering", Prentice Hall, ISBN 0-13-099183-X


Wikimedia Foundation. 2010.

Игры ⚽ Нужно сделать НИР?

Look at other dictionaries:

  • Independent software verification and validation — ISVV stands for Independent Software Verification and Validation. ISVV is targeted at safety critical software systems and aims to increase the quality of software products, thereby reducing risks and costs through the operational life of the… …   Wikipedia

  • Verification and Validation (software) — In software project management, software testing, and software engineering, Verification and Validation (V V) is the process of checking that a software system meets specifications and that it fulfils its intended purpose. It is normally part of… …   Wikipedia

  • Verification — The word Verify And Verification can refer to:* Verification and Validation: In engineering or a quality management system, verification is the act of reviewing, inspecting, testing, etc. to establish and document that a product, service, or… …   Wikipedia

  • Software testing — is an empirical investigation conducted to provide stakeholders with information about the quality of the product or service under test [ [http://www.kaner.com/pdfs/ETatQAI.pdf Exploratory Testing] , Cem Kaner, Florida Institute of Technology,… …   Wikipedia

  • Verification and Validation — Verification Validation is the process of checking that a product, service, or system meets specifications and that it fulfils its intended purpose. These are critical components of a quality management system such as ISO… …   Wikipedia

  • Software engineering — (SE) is the application of a systematic, disciplined, quantifiable approach to the development, operation, and maintenance of software, and the study of these approaches; that is, the application of engineering to software.[1] It is the… …   Wikipedia

  • Verification (spaceflight) — Verification in the field of space systems engineering covers two verification processes: Qualification and Acceptance Overview Verification standards are developed by organizations like the NASA and the ECSS to establishes the requirements for… …   Wikipedia

  • Software development process — Activities and steps Requirements Specification …   Wikipedia

  • Software Assurance — (SwA) is defined as “the level of confidence that software is free from vulnerabilities, either intentionally designed into the software or accidentally inserted at anytime during its lifecycle, and that the software functions in the intended… …   Wikipedia

  • Software Security Assurance — Software is itself a resource and thus must be afforded appropriate security. Software also contains and controls data and other resources. Therefore, it must be designed and implemented to protect those resources. Software Security Assurance is… …   Wikipedia

Share the article and excerpts

Direct link
Do a right-click on the link above
and select “Copy Link”