X-Git-Url: http://git.scottworley.com/inverse-tax/blobdiff_plain/26460571b7a61f69a90d2bb3152774f7badbe734..a659a4f09cf859b2a63dc5c15f0d4589220c9a83:/tax.test.js diff --git a/tax.test.js b/tax.test.js index 067ca91..b495918 100644 --- a/tax.test.js +++ b/tax.test.js @@ -6,6 +6,24 @@ function test(description, f) { f(); } +function near(a, b, epsilon = 1e-6) { + return Math.abs(a - b) < epsilon; +} + +function rand(limit = 100) { + return Math.round(Math.random() * limit); +} + +function make_random_tax_table() { + function make_random_table(min_threshold) { + if (rand(2)) return []; + const start = min_threshold === undefined ? rand() : min_threshold; + const end = start + 1 + rand(); + return [[start, rand()]].concat(make_random_table(end)); + } + return tax_table_from_table(make_random_table()); +} + test("parse tax table", () => { const parsed = parse_tax_table(' 1 2\n10 4\n'); assert.strictEqual(parsed.length, 2); @@ -24,22 +42,20 @@ test("tax", () => { }); 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)); + assert.ok(near(tax(t1, income) + tax(t2, income), tax(combined, income))); } } }); + +test("invert", () => { + assert.strictEqual(invert([ ])(10), 10); + assert.strictEqual(invert([[ 0, Infinity, .1]])( 9), 10); + assert.strictEqual(invert([[10, Infinity, .1]])(19), 20); + assert.strictEqual(invert([[0, 100, .1], [100, Infinity, .2]])(170), 200); +});