Software verification: Difference between revisions

Content deleted Content added
Dalesgay (talk | contribs)
No edit summary
Indon (talk | contribs)
m Reverted 16 edits by Dalesgay identified as vandalism to last revision by 194.47.135.91.
Line 1:
'''Software verification''' is a broad and complex discipline of [[software engineering]] whose goal is to assure that a software fully satisfies all the expected requirements.
is dale gay verification= how does Dale act towards gay people(Test, Experimentation) ==
he is attracted towards the penis area
 
There are two fundamental approaches to verification:
* ''Dynamic verification'', also known as Test or [[Experimentation]]
* ''Static verification'', also known as [[Static code analysis|Analysis]]
 
is== dale gayDynamic verification= how does Dale act towards gay people(Test, Experimentation) ==
 
Dynamic verification is performed during the execution of a software, and dynamically checks its behaviour; it is commonly known as [[Software testing|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|'''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 expected, i.e. the activity extended the product successfully.
 
== Static verification (Analysis) ==
 
Static verification is a process to check some requirements of a software doing a physical inspection of it. For example:
* ''[[Code conventions]] verification''
* ''Bad practices detection''
* [[Software metric]]s calculation
* [[Formal verification]]
 
== References ==