Testland
Browse all skills & agents

decision-table-test-design

Derives human-readable manual test cases from a business-rule spec via a decision table: identify conditions and actions, build the full 2^n-column matrix, collapse columns with irrelevant entries, strike infeasible combinations, then emit one test case per remaining column (each feasible column is one coverage item per ISTQB CTFL v4.0 section 4.2.3). Deep single-technique walkthrough, unlike test-case-ideation-from-story in qa-process (broad multi-lens case matrix from a story); output is manual step/expected cases, unlike boundary-value-generator in qa-test-data (parameterized test code); covers derivation, not case field structure like test-case-anatomy-reference in qa-test-management. Use when a spec's outcome depends on interacting conditions (pricing, eligibility, discounts, routing rules) rather than the boundaries of a single input.

decision-table-test-design

Overview

Per ISTQB CTFL Syllabus v4.0.1 §4.2.3, "decision tables are used for testing the implementation of requirements that specify how different combinations of conditions result in different outcomes" and are "an effective way of recording complex logic, such as business rules." This skill walks that derivation end to end: spec in, human-readable manual test cases out (step/expected tables, not code).

All syllabus claims below come from the official v4.0.1 PDF (2024-09-15) fetched from istqb.org on 2026-06-10. One worked example (a shipping-fee rule) is carried through every step.

When to use (and when EP/BVA wins)

Use a decision table when:

  • The spec is business-rule logic with interacting conditions: the outcome depends on the combination of conditions, not on any single condition alone (pricing, discount stacking, eligibility, approval routing, feature gating).
  • A reviewer needs to check the spec for completeness. §4.2.3 names this as a strength of the technique: it "provides a systematic approach to identify all the combinations of conditions, some of which might otherwise be overlooked" and "helps to find any gaps or contradictions in the requirements" (CTFL v4.0.1 §4.2.3).

Prefer equivalence partitioning / boundary value analysis instead when a single input's range drives the behavior (e.g. "age must be 18-120"): EP/BVA exercises the edges of one partition; a decision table exercises the cross-product of several conditions. The two compose: derive the rule columns here, then hand each numeric threshold (like the $50 below) to boundary-value-generator for edge values. For a broad first-pass case matrix across many lenses, use test-case-ideation-from-story instead; this skill is the deep walkthrough of one technique.

Worked example spec (used in every step)

Shipping fee rules. Premium members always ship free (standard or express). Non-members: standard shipping is free for orders of $50 or more, otherwise $5.99; express shipping is a flat $14.99. Express is only offered at checkout for orders of $50 or more (courier minimum).

Step 1 - Identify conditions and actions

Per §4.2.3, "the conditions and the resulting actions of the system are defined. These form the rows of the table. Each column corresponds to a decision rule that defines a unique combination of conditions, along with the associated actions" (CTFL v4.0.1).

Extract from the spec:

IDConditions (Boolean)
C1Customer is a premium member
C2Order total is $50 or more
C3Express shipping selected
IDActions
A1Charge $0.00 (free shipping)
A2Charge $5.99 standard fee
A3Charge $14.99 express fee

Guidance: make each condition atomic (one yes/no question) and independently settable by a tester. "Member with a large order" is two conditions, not one. Every distinct outcome in the spec becomes an action row; if an outcome appears in the spec but in no action row, you mis-extracted.

Step 2 - Build the full table (2^n columns)

"A full decision table has enough columns to cover every combination of conditions" (CTFL v4.0.1 §4.2.3). For n Boolean conditions that is 2^n columns; here 2^3 = 8.

Notation, per the same section: T means the condition is satisfied, F not satisfied, a dash (written - here) means the condition's value "is irrelevant for the action outcome", and N/A means the condition "is infeasible for a given rule". For actions, X means the action should occur and blank means it should not. The syllabus adds that "other notations may also be used."

Fill every column mechanically from the spec:

R1R2R3R4R5R6R7R8
C1 memberTTTTFFFF
C2 total >= $50TTFFTTFF
C3 expressTFTFTFTF
A1 freeXX?XX?
A2 $5.99X
A3 $14.99X?

R3 and R7 already smell: the spec says express is only offered at $50 or more, so "express selected on a sub-$50 order" may not be reachable. Mark them ? for now; Step 4 resolves it. Do not skip building the full table: the mechanical cross-product is precisely what surfaces the combinations "which might otherwise be overlooked" (§4.2.3).

Step 3 - Collapse with irrelevant (dash) entries

The table "can also be minimized by merging columns, in which some conditions do not affect the outcome, into a single column" (CTFL v4.0.1 §4.2.3). (Formal minimization algorithms are explicitly "out of scope of this syllabus"; pairwise inspection is enough at this scale.)

A merge is legal only if every expansion of the dash is feasible and produces identical actions.

  • R2 + R4 (member, standard): free either way; C2 does not affect the outcome. Merge into one column with C2 = -. Legal.
  • R1 + R3 (member, express) and R5 + R7 (non-member, express) look mergeable on the same logic, but R3 and R7 are the columns flagged ? in Step 2. Hold both merges until the feasibility check.

Step 4 - Spot infeasible combinations

"The table can be simplified by deleting columns containing infeasible combinations of conditions" (CTFL v4.0.1 §4.2.3).

Re-read the spec for constraints that make condition combinations unreachable. Here: express is never offered below $50, so C3 = T with C2 = F cannot occur. R3 and R7 are infeasible; delete them. That kills the held merges from Step 3: C2 is not irrelevant in the express columns, because only one of its values is reachable there. A naive R1 + R3 merge would have produced a test case for an impossible state.

Final collapsed table (5 feasible columns):

P1P2P3P4P5
C1 memberTTFFF
C2 total >= $50T-TTF
C3 expressTFTFF
A1 freeXXX
A2 $5.99X
A3 $14.99X

The infeasible columns are not test-less: add one constraint check outside the table that verifies the infeasibility itself holds (the express option is absent from checkout below $50). If that check fails, the table must be rebuilt with R3/R7 feasible.

Step 5 - One test case per remaining column

Per §4.2.3, "the coverage items are the columns containing feasible combinations of conditions", 100% coverage means test cases "exercise all these columns", and "coverage is measured as the number of exercised columns, divided by the total number of feasible columns" (CTFL v4.0.1). Here: 5 feasible columns = 5 coverage items; the 5 cases below = 100% decision table coverage (5/5).

For a dash entry, pick one concrete value (P2 below uses $20; pairing with BVA would add $49.99/$50.00 around the threshold).

TC IDColumnSetupActionExpected result
TC-DT-1P1Member account; cart total $80.00Select express at checkoutShipping line shows $0.00; order total unchanged
TC-DT-2P2Member account; cart total $20.00Select standard at checkoutShipping line shows $0.00
TC-DT-3P3Non-member account; cart total $80.00Select express at checkoutShipping line shows $14.99
TC-DT-4P4Non-member account; cart total $80.00Select standard at checkoutShipping line shows $0.00
TC-DT-5P5Non-member account; cart total $20.00Select standard at checkoutShipping line shows $5.99
TC-DT-6(constraint)Non-member account; cart total $20.00Open shipping options at checkoutExpress option is not offered

Each row expands into a full runnable script (preconditions, per-step expected results, sign-off) via manual-test-script-author; this skill's output is the derivation plus the case table above.

Limited-entry vs extended-entry tables

Per §4.2.3: "in limited-entry decision tables all the values of the conditions and actions (except for irrelevant or infeasible ones) are shown as Boolean values", while "in extended-entry decision tables some or all the conditions and actions may also take on multiple values (e.g., ranges of numbers, equivalence partitions, discrete values)" (CTFL v4.0.1).

The tables above are limited-entry. If the spec later adds a tier (orders of $200 or more ship express free for everyone), prefer one extended-entry condition over two correlated Booleans:

E1E2E3
C1 memberFFF
C2 order total< $50$50 to $199.99>= $200
C3 expressFTT
Action: fee$5.99$14.99$0.00

Extended entries keep correlated conditions (total >= $50, total >= $200) in one row, which avoids manufacturing infeasible columns like "total >= $200 but not >= $50".

Anti-patterns

Anti-patternWhy it failsFix
Testing only the happy columnsThe spec's gaps live in the F-heavy columns; §4.2.3's whole point is combinations "which might otherwise be overlooked"One test case per feasible column; coverage = exercised/feasible columns
Skipping infeasible-combination analysisNaive collapses (R1 + R3 here) produce test cases for unreachable states; testers burn time failing to set them upStep 4 before finalizing any merge; add a constraint check per deleted column
Collapsing before checking actions matchA dash that hides two different outcomes silently deletes a ruleMerge only when every expansion yields identical action rows
Tables with many conditions, no reduction§4.2.3: "the number of rules grows exponentially with the number of conditions"Per §4.2.3, use "a minimized decision table or a risk-based approach"; or split the rule set per feature
Non-atomic conditions ("member with big order")Column semantics become ambiguous; collapse logic breaksOne yes/no question per condition row (Step 1)
No action row for an outcome in the specThe table cannot reveal the contradiction it was built to findRe-extract actions until every spec outcome maps to a row

Limitations

  • Stateless rules only. Decision tables model input-combination logic. If the outcome depends on history (what happened before this event), use state-transition-test-design.
  • Combination coverage, not boundary coverage. A column says "total >= $50 is true"; it does not test $49.99 vs $50.00. Pair each threshold with boundary-value-generator.
  • Minimization is informal here. Formal minimization algorithms are out of CTFL scope per §4.2.3; for large tables expect to lean on risk-based selection rather than perfect minimal form.

References