Preliminaries to a Software Testing Manifesto
I'm not quite ready for a manifesto. Still gathering my own thoughts, and trying to understand software testing terminology and methodologies. But - feels like there is a fair amount of confusion about how it's supposed to work even in the best case.
What is a Software Test
A software test is a repeatable process applied to a software product that yields a binary pass/fail result.
Why we Test
The value of a test lies in what it tells you when it runs. Depending on the kind of test, and whether it passes or fails, it could tell you:
- The application code is correct
- The application code has a bug
- The test code is correct
- The test code has a bug
- A dependent service has a bug
- Dependent services are working as expected
- Something is wrong on the internet which is interfering with the test
- The part of the internet the test relies on is working.
Testing Terminology
There is a bewildering variety of terms for various kinds of software tests and methodologies. Some of the distinctions are subtle and philosophical. With all that, the terminology seems incomplete - there are distinctions which seem worthy of distinction, where I've not yet been able to find a commonly used term. For these, I've invented a name.
Kinds/properties of tests
Primary Taxonomy
Different kinds of test are classified in a hierarchy or progression, where there are ones that are in some sense "lower level" that others. From lower to higher (vaguely):
- Unit Test, Component Test, Module Test - A test of a minimal part of a system that can be tested in isolation
- Solipsistic Unit Test - (personal terminology) A test that does not depend on other components, like for a function that accepts, and produces low-level dumb data.
- Solitary Unit Test - A test where the one and only concrete service is the service under test (all other dependencies, except for data/value types are mocked)
- Sociable Unit Test, Component Test - A test which uses concrete service dependencies to test the class currently under test.
- Integration Test - A test where individual units are combined and tested as a group.
- Functional Test - A test of the system against the functional requirements/specifications. These requirements are the technical ones intended for engineering.
- System Test - A test that focuses on verifying that a system as a whole meets specified requirements. These requirements are the high-level ones meaningful to end users (e.g. user documentationsx)
- End-to-End (E2E) Test, Chain Test - A test that validates the software system along with its integration with external interfaces. The purpose of end-to-end Test is to exercise a complete production-like scenario.
- Acceptance Test- A test of a system for acceptability. The purpose of this test is to evaluate the system’s compliance with the business requirements and assess whether it is acceptable for delivery.
Secondary Taxonomies
Various other terminology, variously applied:
- User Interface Test, UI Test. A test which starts at the User Interface level. Can be an E2E test, but could also mock services.
- Service Test - A hard to understand kind of test that is higher-level than a unit test, lower level than a UI test.
- Black Box Test, Behavioral Test - A test in which the internal structure/design/implementation of the item being tested is not known to the tester
- White Box Test, Clear Box Test, Glass Box Test, Transparent Box Test, Code-Based Test, Structural Test - A test in which the internal structure/design/implementation of the item being tested is known to the tester.
- Gray Box Testing - A test where the internal structure is partially known
- Tripwire Test (personal terminology) - A test that verifies a function compared to a previous run of that function. The test shows whether the behavior of the function has changed, not whether that change represents a bug.
- Automated Test - A test driven by software rather than humans.
- Manual Test - A test driven by humans rather than software.
- Cyborg Test (personal terminology) - A manual test which is assisted by automated technology. This could a test that is mostly automated, but requires some user intervention.
Other Terms
- Mock - A simulation of a complex object or service by some simpler mechanism, for purposes of testing.
- Health Check - A test which verifies the current correct functionality of running software.
Analysis
Breaking this down according to the kind of test, I think the following are true:
- Solipsistic Unit Test generally tell you whether your application code is correct or has bug. Generally the issue is not in the test code.
- Solitary Unit Tests, after some initial work to stabilize them, generally tell you whether your application code is correct or has bug. The more you mock, the more the errors tend to be in the test code itself, since mocks can be wrong.
- Sociable Unit Tests mostly tell you application code is correct or has bug. Generally the issue is not in the test code, although the error could be in the components your test depends on.
- End-to-End tests mostly tell you whether your test code is correct or has a bug. After that, they test for errors in dependent services, or the generalized issues with connectivity.
End-to-End Tests
End-to-End tests seem more like Health Checks than tests per se. Having them run against released software would increase the value of running them as tests against pre-released software. If the live test works, but the pre-release test does not, it suggests that any issue is not simply connectivity or a downstream service dependency.
On the other hand, I think manual testing has a place in testing UI code. An API should have well-enough defined behavior so that it is testable, and since it is intended for use by software, rather than humans, tests are naturally automatable. So for a UI manual testing (augmented where useful by automation) has a place. I could see this being very useful when testing across multiple browser configurations.
References
- Martin Fowler, The Practical Test Pyramid
- Alister Scott, Testing Pyramids & Ice-Cream Cones
- Software Testing Fundamentals (Many definitions)
- International Software Testing Qualifications Board (ISTQB) (Some more formal definitions)
- Kaner, Falk, Nguyen. Testing Computer Software. Wiley Computer Publishing, 1999 in Wikipedia Functional_testing (Functional and Systems Testing)
- Next →
Web Sketchpad