X-Git-Url: http://git.scottworley.com/inverse-tax/blobdiff_plain/5789fd4b97bc2bb94caa7b6ae288f649f432bdc3..26460571b7a61f69a90d2bb3152774f7badbe734:/tax.test.js?ds=inline diff --git a/tax.test.js b/tax.test.js index 6fcc15c..067ca91 100644 --- a/tax.test.js +++ b/tax.test.js @@ -22,3 +22,24 @@ test("sum", () => { test("tax", () => { assert.strictEqual(tax([[10, 100, .01], [100, Infinity, .1]], 150), 5.9); }); + +test("merge tax tables", () => { + function rand(limit = 100) { + return Math.round(Math.random() * limit); + } + function make_random_tax_table(min_threshold) { + if (rand(2)) return []; + const start = min_threshold === undefined ? rand() : min_threshold; + const end = start + 1 + rand(); + return [[start, end, rand()]].concat(make_random_tax_table(end)); + } + for (var i = 0; i < 1000; i++) { + const t1 = make_random_tax_table(); + const t2 = make_random_tax_table(); + const combined = merge_tax_tables(t1, t2); + for (var j = 0; j < 10; j++) { + const income = rand(250); + assert.strictEqual(tax(t1, income) + tax(t2, income), tax(combined, income)); + } + } +});