<divid="siteSub">From Wikipedia, the free encyclopedia</div>
<divid="contentSub"></div>
<divid="jump-to-nav"class="mw-jump">
Jump to: <ahref="#mw-head">navigation</a>, <ahref="#p-search">search</a>
</div>
<divid="mw-content-text"lang="en"dir="ltr"class="mw-content-ltr"><script>functionmfTempOpenSection(id){varblock=document.getElementById("mf-section-"+id);block.className+=" open-block";block.previousSibling.className+=" open-block";}</script><p><b>Regression testing</b> is a type of <ahref="/wiki/Software_testing"title="Software testing">software testing</a> that verifies that software previously developed and tested still performs correctly even after it was changed or interfaced with other software. Changes may include software enhancements, <ahref="/wiki/Patch_(computing)"title="Patch (computing)">patches</a>, <ahref="/wiki/Configuration_file"title="Configuration file">configuration</a> changes, etc. During regression testing, new <ahref="/wiki/Software_bug"title="Software bug">software bugs</a> or <i><ahref="/wiki/Software_regression"title="Software regression">regressions</a></i> may be uncovered. Sometimes a software change impact analysis is performed to determine what areas could be affected by the proposed changes. These areas may include <ahref="/wiki/Functional_testing"title="Functional testing">functional</a> and <ahref="/wiki/Non-functional_testing"title="Non-functional testing">non-functional</a> areas of the system.</p>
<p>The purpose of regression testing is to ensure that changes such as those mentioned above have not introduced new faults.<supid="cite_ref-1"class="reference"><ahref="#cite_note-1">[1]</a></sup> One of the main reasons for regression testing is to determine whether a change in one part of the software affects other parts of the software.<supid="cite_ref-2"class="reference"><ahref="#cite_note-2">[2]</a></sup></p>
<p>Common methods of regression testing include re-running previously completed tests and checking whether program behavior has changed and whether previously fixed faults have re-emerged. Regression testing can be performed to test a system efficiently by systematically selecting the appropriate minimum set of tests needed to adequately cover a particular change.</p>
<p>Contrast with <ahref="/wiki/Non-regression_testing"title="Non-regression testing">non-regression testing</a> (usually validation-test for a new issue), which aims to verify whether, after introducing or updating a given software application, the change has had the intended effect.</p>
<liclass="toclevel-2 tocsection-4"><ahref="#Regression_test_selection"><spanclass="tocnumber">2.2</span><spanclass="toctext">Regression test selection</span></a></li>
<liclass="toclevel-2 tocsection-5"><ahref="#Test_case_prioritization"><spanclass="tocnumber">2.3</span><spanclass="toctext">Test case prioritization</span></a>
<ul>
<liclass="toclevel-3 tocsection-6"><ahref="#Types_of_test_case_prioritization"><spanclass="tocnumber">2.3.1</span><spanclass="toctext">Types of test case prioritization</span></a></li>
<liclass="toclevel-1 tocsection-8"><ahref="#Benefits_and_drawbacks"><spanclass="tocnumber">3</span><spanclass="toctext">Benefits and drawbacks</span></a></li>
<p>As software is fixed or changed, emergence of new faults and/or re-emergence of old faults is quite common. Sometimes re-emergence occurs because a fix gets lost through poor <ahref="/wiki/Revision_control"class="mw-redirect"title="Revision control">revision control</a> practices (or simple human error in revision control). Often, a fix for a problem will be "<ahref="/wiki/Software_brittleness"title="Software brittleness">fragile</a>" in that it fixes the problem in the narrow case where it was first observed but not in more general cases which may arise over the lifetime of the software. Frequently, a fix for a problem in one area inadvertently causes a <ahref="/wiki/Software_bug"title="Software bug">software bug</a> in another area. Finally, it may happen that, when some feature is redesigned, some of the same mistakes that were made in the original implementation of the feature are made in the redesign.</p>
<p>Therefore, in most software development situations, it is considered <ahref="/wiki/Best_Coding_Practices"class="mw-redirect"title="Best Coding Practices">good coding practice</a>, when a bug is located and fixed, to record a test that exposes the bug and re-run that test regularly after subsequent changes to the program.<supid="cite_ref-kolawa_3-0"class="reference"><ahref="#cite_note-kolawa-3">[3]</a></sup> Although this may be done through <ahref="/wiki/Manual_testing"title="Manual testing">manual testing</a> procedures using programming techniques, it is often done using <ahref="/wiki/Automated_testing"class="mw-redirect"title="Automated testing">automated testing</a> tools.<supid="cite_ref-4"class="reference"><ahref="#cite_note-4">[4]</a></sup> Such a <ahref="/wiki/Test_suite"title="Test suite">test suite</a> contains software tools that allow the testing environment to execute all the regression <ahref="/wiki/Test_case"title="Test case">test cases</a> automatically; some projects even set up automated systems to re-run all regression tests at specified intervals and report any failures (which could imply a regression or an out-of-date test).<supid="cite_ref-5"class="reference"><ahref="#cite_note-5">[5]</a></sup> Common strategies are to run such a system after every successful compile (for small projects), every night, or once a week. Those strategies can be automated by an external tool.</p>
<p>Regression testing is an integral part of the <ahref="/wiki/Extreme_programming"title="Extreme programming">extreme programming</a> software development method. In this method, design documents are replaced by extensive, repeatable, and automated testing of the entire software package throughout each stage of the <ahref="/wiki/Software_development_process"title="Software development process">software development process</a>. Regression testing is done after functional testing has concluded, to verify that the other functionalities are working.</p>
<p>In the corporate world, regression testing has traditionally been performed by a <ahref="/wiki/Software_quality_assurance"title="Software quality assurance">software quality assurance</a> team after the development team has completed work. However, defects found at this stage are the most costly to fix. This problem is being addressed by the rise of <ahref="/wiki/Unit_testing"title="Unit testing">unit testing</a>. Although developers have always written test cases as part of the development cycle, these test cases have generally been either <ahref="/wiki/Functional_testing"title="Functional testing">functional tests</a> or <ahref="/wiki/Unit_testing"title="Unit testing">unit tests</a> that verify only intended outcomes. Developer testing compels a developer to focus on unit testing and to include both positive and negative test cases.<supid="cite_ref-6"class="reference"><ahref="#cite_note-6">[6]</a></sup></p>
<p>This technique checks all the test cases on the current program to check its integrity. Though it is expensive as it needs to re-run all the cases, it ensures that there are no errors because of the modified code.<supid="cite_ref-:0_7-0"class="reference"><ahref="#cite_note-:0-7">[7]</a></sup></p>
<h3><spanclass="mw-headline"id="Regression_test_selection">Regression test selection</span><spanclass="mw-editsection"><spanclass="mw-editsection-bracket">[</span><ahref="/w/index.php?title=Regression_testing&action=edit&section=4"title="Edit section: Regression test selection">edit</a><spanclass="mw-editsection-bracket">]</span></span></h3>
<p>Unlike Retest all, This technique runs a part of the <ahref="/wiki/Test_suite"title="Test suite">test suite</a> (owing to the cost of retest all) if cost of selecting the part of test suite is less than retest all technique.<supid="cite_ref-:0_7-1"class="reference"><ahref="#cite_note-:0-7">[7]</a></sup></p>
<h3><spanclass="mw-headline"id="Test_case_prioritization">Test case prioritization</span><spanclass="mw-editsection"><spanclass="mw-editsection-bracket">[</span><ahref="/w/index.php?title=Regression_testing&action=edit&section=5"title="Edit section: Test case prioritization">edit</a><spanclass="mw-editsection-bracket">]</span></span></h3>
<p>Prioritize the test cases so as to increase a test suite's rate of fault detection. Test case prioritization techniques schedule test cases so that the test cases that are higher in priority are executed before the test cases that have a lesser priority.<supid="cite_ref-:0_7-2"class="reference"><ahref="#cite_note-:0-7">[7]</a></sup></p>
<h4><spanclass="mw-headline"id="Types_of_test_case_prioritization">Types of test case prioritization</span><spanclass="mw-editsection"><spanclass="mw-editsection-bracket">[</span><ahref="/w/index.php?title=Regression_testing&action=edit&section=6"title="Edit section: Types of test case prioritization">edit</a><spanclass="mw-editsection-bracket">]</span></span></h4>
<ul>
<li>General prioritization - Prioritize test cases that will be beneficial on subsequent versions</li>
</ul>
<ul>
<li>Version-specific prioritization - Prioritize test cases with respect to a particular version of the software.</li>
<p>This technique is a Hybrid Approach of both Regression Test Selection and Test Case Prioritization. Algorithms for the approach that have been proposed are test selection algorithm and hybrid technique proposed<supid="cite_ref-:0_7-3"class="reference"><ahref="#cite_note-:0-7">[7]</a></sup></p>
<h2><spanclass="mw-headline"id="Benefits_and_drawbacks">Benefits and drawbacks</span><spanclass="mw-editsection"><spanclass="mw-editsection-bracket">[</span><ahref="/w/index.php?title=Regression_testing&action=edit&section=8"title="Edit section: Benefits and drawbacks">edit</a><spanclass="mw-editsection-bracket">]</span></span></h2>
<p>Regression testing is performed when changes are made to the existing functionality of the software or if there is a bug fix in the software. Regression testing can be achieved through multiple approaches, if a <i>test all</i> approach is followed it provides certainty that the changes made to the software have not affected the existing functionalities, which are unaltered, in any way.<supid="cite_ref-:1_8-0"class="reference"><ahref="#cite_note-:1-8">[8]</a></sup></p>
<p>In an agile project management process, where the software development life cycles are very short, resources are scarce and changes to the software are very frequent; Regression testing might introduce a lot of unnecessary overheads.<supid="cite_ref-:1_8-1"class="reference"><ahref="#cite_note-:1-8">[8]</a></sup></p>
<p>Typically, regression testing is carried out by automation tools, but the existing generation of regression testing tools is not equipped to handle <ahref="/wiki/Database"title="Database">database</a> application. For this reason, performing a regression test on a database application could prove to be taxing as it would require a great deal of manual effort.<supid="cite_ref-9"class="reference"><ahref="#cite_note-9">[9]</a></sup></p>
<p>Moreover, performing regression testing in a software development environment which tends to use black box components from a third party can get a bit tricky as any change in the third party component may interfere with the rest of the system and performing regression testing on a third party component is difficult because it is an unknown entity.<supid="cite_ref-:1_8-2"class="reference"><ahref="#cite_note-:1-8">[8]</a></sup></p>
<p>Regression testing can be used not only for testing the <i><ahref="/wiki/Correctness_(computer_science)"title="Correctness (computer science)">correctness</a></i> of a program, but often also for tracking the quality of its output.<supid="cite_ref-10"class="reference"><ahref="#cite_note-10">[10]</a></sup> For instance, in the design of a <ahref="/wiki/Compiler"title="Compiler">compiler</a>, regression testing could track the code size, and the time it takes to compile and execute the test suite cases.</p>
<blockquoteclass="templatequote">
<p>Also as a consequence of the introduction of new bugs, program maintenance requires far more system testing per statement written than any other programming. Theoretically, after each fix one must run the entire batch of test cases previously run against the system, to ensure that it has not been damaged in an obscure way. In practice, such <i>regression testing</i> must indeed approximate this theoretical idea, and it is very costly.</p>
<divclass="templatequotecite"><cite>— <ahref="/wiki/Fred_Brooks"title="Fred Brooks">Fred Brooks</a>, <i><ahref="/wiki/The_Mythical_Man_Month"class="mw-redirect"title="The Mythical Man Month">The Mythical Man Month</a></i>, p. 122</cite></div>
</blockquote>
<p>Regression tests can be broadly categorized as <ahref="/wiki/Functional_test"class="mw-redirect"title="Functional test">functional tests</a> or <ahref="/wiki/Unit_testing"title="Unit testing">unit tests</a>. Functional tests exercise the complete program with various inputs. Unit tests exercise individual functions, <ahref="/wiki/Subroutine"title="Subroutine">subroutines</a>, or object methods. Both functional testing tools and unit testing tools tend to be automated and a third-party product that are not part of the compiler suite. A functional test may be a scripted series of program inputs, possibly even involving an automated mechanism for controlling mouse movements and clicks. A unit test may be a set of separate functions within the code itself, or a driver layer that links to the code without altering the code being tested.</p>
<h2><spanclass="mw-headline"id="See_also">See also</span><spanclass="mw-editsection"><spanclass="mw-editsection-bracket">[</span><ahref="/w/index.php?title=Regression_testing&action=edit&section=10"title="Edit section: See also">edit</a><spanclass="mw-editsection-bracket">]</span></span></h2>
<liid="cite_note-1"><spanclass="mw-cite-backlink"><b><ahref="#cite_ref-1">^</a></b></span><spanclass="reference-text"><citeclass="citation book">Myers, Glenford (2004). <i>The Art of Software Testing</i>. Wiley. <ahref="/wiki/International_Standard_Book_Number"title="International Standard Book Number">ISBN</a> <ahref="/wiki/Special:BookSources/978-0-471-46912-4"title="Special:BookSources/978-0-471-46912-4">978-0-471-46912-4</a>.</cite><spantitle="ctx_ver=Z39.88-2004&rfr_id=info%3Asid%2Fen.wikipedia.org%3ARegression+testing&rft.aufirst=Glenford&rft.aulast=Myers&rft.btitle=The+Art+of+Software+Testing&rft.date=2004&rft.genre=book&rft.isbn=978-0-471-46912-4&rft.pub=Wiley&rft_val_fmt=info%3Aofi%2Ffmt%3Akev%3Amtx%3Abook"class="Z3988"><spanstyle="display:none;"> </span></span></span></li>
<liid="cite_note-2"><spanclass="mw-cite-backlink"><b><ahref="#cite_ref-2">^</a></b></span><spanclass="reference-text"><citeclass="citation book">Savenkov, Roman (2008). <i>How to Become a Software Tester</i>. Roman Savenkov Consulting. p. 386. <ahref="/wiki/International_Standard_Book_Number"title="International Standard Book Number">ISBN</a> <ahref="/wiki/Special:BookSources/978-0-615-23372-7"title="Special:BookSources/978-0-615-23372-7">978-0-615-23372-7</a>.</cite><spantitle="ctx_ver=Z39.88-2004&rfr_id=info%3Asid%2Fen.wikipedia.org%3ARegression+testing&rft.aufirst=Roman&rft.aulast=Savenkov&rft.btitle=How+to+Become+a+Software+Tester&rft.date=2008&rft.genre=book&rft.isbn=978-0-615-23372-7&rft.pages=386&rft.pub=Roman+Savenkov+Consulting&rft_val_fmt=info%3Aofi%2Ffmt%3Akev%3Amtx%3Abook"class="Z3988"><spanstyle="display:none;"> </span></span></span></li>
<liid="cite_note-kolawa-3"><spanclass="mw-cite-backlink"><b><ahref="#cite_ref-kolawa_3-0">^</a></b></span><spanclass="reference-text"><citeclass="citation book">Kolawa, Adam; Huizinga, Dorota (2007). <arel="nofollow"class="external text"href="http://www.wiley.com/WileyCDA/WileyTitle/productCd-0470042125.html"><i>Automated Defect Prevention: Best Practices in Software Management</i></a>. Wiley-IEEE Computer Society Press. p. 73. <ahref="/wiki/International_Standard_Book_Number"title="International Standard Book Number">ISBN</a> <ahref="/wiki/Special:BookSources/0-470-04212-5"title="Special:BookSources/0-470-04212-5">0-470-04212-5</a>.</cite><spantitle="ctx_ver=Z39.88-2004&rfr_id=info%3Asid%2Fen.wikipedia.org%3ARegression+testing&rft.aufirst=Adam&rft.au=Huizinga%2C+Dorota&rft.aulast=Kolawa&rft.btitle=Automated+Defect+Prevention%3A+Best+Practices+in+Software+Management&rft.date=2007&rft.genre=book&rft_id=http%3A%2F%2Fwww.wiley.com%2FWileyCDA%2FWileyTitle%2FproductCd-0470042125.html&rft.isbn=0-470-04212-5&rft.pages=73&rft.pub=Wiley-IEEE+Computer+Society+Press&rft_val_fmt=info%3Aofi%2Ffmt%3Akev%3Amtx%3Abook"class="Z3988"><spanstyle="display:none;"> </span></span></span></li>
<liid="cite_note-4"><spanclass="mw-cite-backlink"><b><ahref="#cite_ref-4">^</a></b></span><spanclass="reference-text"><arel="nofollow"class="external text"href="http://safari.oreilly.com/0201794292/ch08lev1sec4">Automate Regression Tests When Feasible</a>, Automated Testing: Selected Best Practices, Elfriede Dustin, Safari Books Online</span></li>
<liid="cite_note-5"><spanclass="mw-cite-backlink"><b><ahref="#cite_ref-5">^</a></b></span><spanclass="reference-text"><citeclass="citation web">daVeiga, Nada (February 2008). <arel="nofollow"class="external text"href="http://www.ddj.com/development-tools/206105233;jsessionid=2HN1TRYZ4JGVAQSNDLRSKH0CJUNN2JVN">"Change Code Without Fear: Utilize a Regression Safety Net"</a>. <i><ahref="/wiki/Dr._Dobb%27s_Journal"title="Dr. Dobb's Journal">Dr. Dobb's Journal</a></i>.</cite><spantitle="ctx_ver=Z39.88-2004&rfr_id=info%3Asid%2Fen.wikipedia.org%3ARegression+testing&rft.atitle=Change+Code+Without+Fear%3A+Utilize+a+Regression+Safety+Net&rft.aufirst=Nada&rft.aulast=daVeiga&rft.date=2008-02&rft.genre=unknown&rft_id=http%3A%2F%2Fwww.ddj.com%2Fdevelopment-tools%2F206105233%3Bjsessionid%3D2HN1TRYZ4JGVAQSNDLRSKH0CJUNN2JVN&rft.jtitle=Dr.+Dobb%27s+Journal&rft_val_fmt=info%3Aofi%2Ffmt%3Akev%3Amtx%3Ajournal"class="Z3988"><spanstyle="display:none;"> </span></span></span></li>
<liid="cite_note-6"><spanclass="mw-cite-backlink"><b><ahref="#cite_ref-6">^</a></b></span><spanclass="reference-text"><citeclass="citation web">Dudney, Bill (2004-12-08). <arel="nofollow"class="external text"href="http://www.sys-con.com/read/47359.htm">"Developer Testing Is 'In': An interview with Alberto Savoia and Kent Beck"</a><spanclass="reference-accessdate">. Retrieved <spanclass="nowrap">2007-11-29</span></span>.</cite><spantitle="ctx_ver=Z39.88-2004&rfr_id=info%3Asid%2Fen.wikipedia.org%3ARegression+testing&rft.aufirst=Bill&rft.aulast=Dudney&rft.btitle=Developer+Testing+Is+%27In%27%3A+An+interview+with+Alberto+Savoia+and+Kent+Beck&rft.date=2004-12-08&rft.genre=unknown&rft_id=http%3A%2F%2Fwww.sys-con.com%2Fread%2F47359.htm&rft_val_fmt=info%3Aofi%2Ffmt%3Akev%3Amtx%3Abook"class="Z3988"><spanstyle="display:none;"> </span></span></span></li>
<liid="cite_note-:1-8"><spanclass="mw-cite-backlink">^ <ahref="#cite_ref-:1_8-0"><sup><i><b>a</b></i></sup></a><ahref="#cite_ref-:1_8-1"><sup><i><b>b</b></i></sup></a><ahref="#cite_ref-:1_8-2"><sup><i><b>c</b></i></sup></a></span><spanclass="reference-text"><citeclass="citation journal">"Regression Testing Minimisation, Selection and Prioritisation: A Survey; S. Yoo, M. Harman". <i>Published online in Wiley InterScience</i>. 2007.</cite><spantitle="ctx_ver=Z39.88-2004&rfr_id=info%3Asid%2Fen.wikipedia.org%3ARegression+testing&rft.atitle=Regression+Testing+Minimisation%2C+Selection+and+Prioritisation%3A+A+Survey%3B+S.+Yoo%2C+M.+Harman&rft.date=2007&rft.genre=article&rft.jtitle=Published+online+in+Wiley+InterScience&rft_val_fmt=info%3Aofi%2Ffmt%3Akev%3Amtx%3Ajournal"class="Z3988"><spanstyle="display:none;"> </span></span></span></li>
<liid="cite_note-9"><spanclass="mw-cite-backlink"><b><ahref="#cite_ref-9">^</a></b></span><spanclass="reference-text"><citeclass="citation journal">"Efficient Regression Tests for Database Applications". <i>Springer Journal</i>. 2006.</cite><spantitle="ctx_ver=Z39.88-2004&rfr_id=info%3Asid%2Fen.wikipedia.org%3ARegression+testing&rft.atitle=Efficient+Regression+Tests+for+Database+Applications&rft.date=2006&rft.genre=article&rft.jtitle=Springer+Journal&rft_val_fmt=info%3Aofi%2Ffmt%3Akev%3Amtx%3Ajournal"class="Z3988"><spanstyle="display:none;"> </span></span></span></li>
<li><arel="nofollow"class="external text"href="http://smartbear.com/products/qa-tools/what-is-regression-testing/">What is Regression Testing</a> by Scott Barber and Tom Huston</li>
</ul>
</div>
<!--
NewPP limit report
Parsed by mw1173
Cached time: 20161201012247
Cache expiry: 2592000
Dynamic content: false
CPU time usage: 0.108 seconds
Real time usage: 0.134 seconds
Preprocessor visited node count: 569/1000000
Preprocessor generated node count: 0/1500000
Post‐expand include size: 14044/2097152 bytes
Template argument size: 569/2097152 bytes
Highest expansion depth: 7/40
Expensive parser function count: 0/500
Lua time usage: 0.046/10.000 seconds
Lua memory usage: 2.67 MB/50 MB
-->
<!--
Transclusion expansion time report (%,ms,calls,template)
Retrieved from "<adir="ltr"href="https://en.wikipedia.org/w/index.php?title=Regression_testing&oldid=748923973">https://en.wikipedia.org/w/index.php?title=Regression_testing&oldid=748923973</a>" </div>
<liid="pt-anonuserpage">Not logged in</li><liid="pt-anontalk"><ahref="/wiki/Special:MyTalk"title="Discussion about edits from this IP address [n]"accesskey="n">Talk</a></li><liid="pt-anoncontribs"><ahref="/wiki/Special:MyContributions"title="A list of edits made from this IP address [y]"accesskey="y">Contributions</a></li><liid="pt-createaccount"><ahref="/w/index.php?title=Special:CreateAccount&returnto=Regression+testing"title="You are encouraged to create an account and log in; however, it is not mandatory">Create account</a></li><liid="pt-login"><ahref="/w/index.php?title=Special:UserLogin&returnto=Regression+testing"title="You're encouraged to log in; however, it's not mandatory. [o]"accesskey="o">Log in</a></li></ul>
<liid="ca-nstab-main"class="selected"><span><ahref="/wiki/Regression_testing"title="View the content page [c]"accesskey="c">Article</a></span></li>
<liid="ca-talk"><span><ahref="/wiki/Talk:Regression_testing"title="Discussion about the content page [t]"accesskey="t"rel="discussion">Talk</a></span></li>
<liid="ca-edit"><span><ahref="/w/index.php?title=Regression_testing&action=edit"title="Edit this page [e]"accesskey="e">Edit</a></span></li>
<liid="ca-history"class="collapsible"><span><ahref="/w/index.php?title=Regression_testing&action=history"title="Past revisions of this page [h]"accesskey="h">View history</a></span></li>
<inputtype="search"name="search"placeholder="Search Wikipedia"title="Search Wikipedia [f]"accesskey="f"id="searchInput"/><inputtype="hidden"value="Special:Search"name="title"/><inputtype="submit"name="fulltext"value="Search"title="Search Wikipedia for this text"id="mw-searchButton"class="searchButton mw-fallbackSearchButton"/><inputtype="submit"name="go"value="Go"title="Go to a page with this exact name if it exists"id="searchButton"class="searchButton"/></div>
</form>
</div>
</div>
</div>
<divid="mw-panel">
<divid="p-logo"role="banner"><aclass="mw-wiki-logo"href="/wiki/Main_Page"title="Visit the main page"></a></div>
<liid="n-mainpage-description"><ahref="/wiki/Main_Page"title="Visit the main page [z]"accesskey="z">Main page</a></li><liid="n-contents"><ahref="/wiki/Portal:Contents"title="Guides to browsing Wikipedia">Contents</a></li><liid="n-featuredcontent"><ahref="/wiki/Portal:Featured_content"title="Featured content – the best of Wikipedia">Featured content</a></li><liid="n-currentevents"><ahref="/wiki/Portal:Current_events"title="Find background information on current events">Current events</a></li><liid="n-randompage"><ahref="/wiki/Special:Random"title="Load a random article [x]"accesskey="x">Random article</a></li><liid="n-sitesupport"><ahref="https://donate.wikimedia.org/wiki/Special:FundraiserRedirector?utm_source=donate&utm_medium=sidebar&utm_campaign=C13_en.wikipedia.org&uselang=en"title="Support us">Donate to Wikipedia</a></li><liid="n-shoplink"><ahref="//shop.wikimedia.org"title="Visit the Wikipedia store">Wikipedia store</a></li></ul>
<liid="n-help"><ahref="/wiki/Help:Contents"title="Guidance on how to use and edit Wikipedia">Help</a></li><liid="n-aboutsite"><ahref="/wiki/Wikipedia:About"title="Find out about Wikipedia">About Wikipedia</a></li><liid="n-portal"><ahref="/wiki/Wikipedia:Community_portal"title="About the project, what you can do, where to find things">Community portal</a></li><liid="n-recentchanges"><ahref="/wiki/Special:RecentChanges"title="A list of recent changes in the wiki [r]"accesskey="r">Recent changes</a></li><liid="n-contactpage"><ahref="//en.wikipedia.org/wiki/Wikipedia:Contact_us"title="How to contact Wikipedia">Contact page</a></li></ul>
<liid="t-whatlinkshere"><ahref="/wiki/Special:WhatLinksHere/Regression_testing"title="List of all English Wikipedia pages containing links to this page [j]"accesskey="j">What links here</a></li><liid="t-recentchangeslinked"><ahref="/wiki/Special:RecentChangesLinked/Regression_testing"rel="nofollow"title="Recent changes in pages linked from this page [k]"accesskey="k">Related changes</a></li><liid="t-upload"><ahref="/wiki/Wikipedia:File_Upload_Wizard"title="Upload files [u]"accesskey="u">Upload file</a></li><liid="t-specialpages"><ahref="/wiki/Special:SpecialPages"title="A list of all special pages [q]"accesskey="q">Special pages</a></li><liid="t-permalink"><ahref="/w/index.php?title=Regression_testing&oldid=748923973"title="Permanent link to this revision of the page">Permanent link</a></li><liid="t-info"><ahref="/w/index.php?title=Regression_testing&action=info"title="More information about this page">Page information</a></li><liid="t-wikibase"><ahref="https://www.wikidata.org/wiki/Q917415"title="Link to connected data repository item [g]"accesskey="g">Wikidata item</a></li><liid="t-cite"><ahref="/w/index.php?title=Special:CiteThisPage&page=Regression_testing&id=748923973"title="Information on how to cite this page">Cite this page</a></li></ul>
<liid="coll-create_a_book"><ahref="/w/index.php?title=Special:Book&bookcmd=book_creator&referer=Regression+testing">Create a book</a></li><liid="coll-download-as-rdf2latex"><ahref="/w/index.php?title=Special:Book&bookcmd=render_article&arttitle=Regression+testing&returnto=Regression+testing&oldid=748923973&writer=rdf2latex">Download as PDF</a></li><liid="t-print"><ahref="/w/index.php?title=Regression_testing&printable=yes"title="Printable version of this page [p]"accesskey="p">Printable version</a></li></ul>
<liid="footer-info-lastmod"> This page was last modified on 11 November 2016, at 05:56.</li>
<liid="footer-info-copyright">Text is available under the <arel="license"href="//en.wikipedia.org/wiki/Wikipedia:Text_of_Creative_Commons_Attribution-ShareAlike_3.0_Unported_License">Creative Commons Attribution-ShareAlike License</a><arel="license"href="//creativecommons.org/licenses/by-sa/3.0/"style="display:none;"></a>;
additional terms may apply. By using this site, you agree to the <ahref="//wikimediafoundation.org/wiki/Terms_of_Use">Terms of Use</a> and <ahref="//wikimediafoundation.org/wiki/Privacy_policy">Privacy Policy</a>. Wikipedia® is a registered trademark of the <ahref="//www.wikimediafoundation.org/">Wikimedia Foundation, Inc.</a>, a non-profit organization.</li>
"exact":"Therefore, in most software development situations, it is considered good coding practice, when a bug is located and fixed, to record a test that exposes the bug and re-run that test regularly after subsequent changes to the program",
"exact":"Also as a consequence of the introduction of new bugs, program maintenance requires far more system testing per statement written than any other programming",