Changes for page Testing Principles
Last modified by chrisby on 2024/04/01 12:52
Summary
-
Page properties (1 modified, 0 added, 0 removed)
Details
- Page properties
-
- Content
-
... ... @@ -5,7 +5,9 @@ 5 5 ** **Meaningful Tests:** Don't add tests that don't add value or test something that has already been tested. 6 6 7 7 * **Strictness**: If at least one test fails, it requires the developer's attention. He is not allowed to proceed with other work until that problem is fixed, and all tests must pass without exception. 8 -* **Falsifiability** = The ability to fail. Wrongfully failing tests are easy to detect, because a good developer will pay attention to all failing tests and fix the problem before moving on. Wrongfully passing tests are hard to detect because everything seems fine, which is why it is so important to focus on preventing them. They do damage by appearing to validate functionality that they do not. Use TDD, and get into the habit of mutating the critical section of production code to trigger the test failure, see [[TDD article>>doc:Tutorials and Guides.Test-Driven Development Workflow with Git.WebHome]]. A test should fail before production code is written. Tests without assertions always pass, which is why the assertion should be the first thing written in a test to prevent forgetting it. 8 +* **Falsifiability** = The ability to fail. 9 +** Wrongfully failing tests are easy to detect, because a good developer will pay attention to all failing tests and fix the problems before moving on. 10 +** Wrongfully passing tests are hard to detect because everything seems fine, which is why it is so important to focus on preventing them. They do damage by appearing to validate functionality that they do not. Use TDD, and get into the habit of mutating the critical section of production code to trigger the test failure, see [[TDD article>>doc:Tutorials and Guides.Test-Driven Development Workflow with Git.WebHome]]. A test should fail before production code is written. Tests without assertions always pass, which is why the assertion should be the first thing written in a test to prevent forgetting it. 9 9 * **Determinism**: Repeated tests should always produce the same result. The success of tests should never depend on anything other than the production code. Avoid sources of randomness that could cause the test to fail only some of the time. These include random number generators, threads, host-specific infrastructure (operating system, absolute paths, hardware: I/O speed or CPU load), networking over the local network or Internet, time/timestamps, pre-existing values in the database or files on the host system that are not in the source code. 10 10 * **Single Action Execution**: The entire setup and testing process should require a single click or shell command. Otherwise, they will not be used regularly, which reduces the quality assurance of the production code. 11 11 * **Independence**: Tests should be independent and not influenced by other tests; the order in which tests are executed should not matter. ... ... @@ -14,3 +14,4 @@ 14 14 * **Test behavior, not implementation.** Always run tests against interfaces from production code to test the implementation behind them. The developer should be free to modify the code as long as it produces the correct results. This also reduces the coupling between test and production code, resulting in less work to adapt tests when the implementation changes. Avoid reflection and weakening encapsulation by making private things public. However, weakening encapsulation is a lesser evil than not testing at all. 15 15 * **'Program testing can be used to show the presence of bugs, but never show their absence!' **(Edsger W. Dijkstra). 16 16 ** Follow good testing practices to avoid a large number of bugs, but be aware that bugs may still occur and be prepared for them. 19 +* **Requirement fulfillment over specific solutions:** Don't limit tests to a specific solution when multiple valid solutions exist. Test for compliance with solution requirements, not the specific output. This provides flexibility by accepting any valid solution. For example, in pathfinding problems, minimum travel costs validate a solution, not the particular path chosen.