|
1 | 1 | import { describe, expect, test } from 'vitest'; |
2 | 2 |
|
3 | | -import { type Data, histogram } from './histogram.js'; |
| 3 | +import { type Data, histogram, pointMinMax, valueMinMaxSymbols } from './histogram.js'; |
4 | 4 |
|
5 | 5 | describe('histogram', () => { |
6 | 6 | test('simple', () => { |
@@ -223,6 +223,27 @@ describe('histogram', () => { |
223 | 223 | ), |
224 | 224 | ); |
225 | 225 | }); |
| 226 | + |
| 227 | + const U = undefined; |
| 228 | + |
| 229 | + test.each` |
| 230 | + value | minVal | maxVal | width | padding | symbols | expected |
| 231 | + ${0.5} | ${0} | ${1} | ${11} | ${' '} | ${valueMinMaxSymbols} | ${'┣━━━━●━━━━┫'} |
| 232 | + ${0.5} | ${0} | ${1} | ${11} | ${U} | ${undefined} | ${'┣━━━━●━━━━┫'} |
| 233 | + ${0.5} | ${U} | ${U} | ${11} | ${'.'} | ${undefined} | ${'.....●.....'} |
| 234 | + ${0.6} | ${0} | ${1.0} | ${11} | ${' '} | ${valueMinMaxSymbols} | ${'┣━━━━━●━━━┫'} |
| 235 | + ${0.6} | ${0} | ${0.6} | ${11} | ${' '} | ${valueMinMaxSymbols} | ${'┣━━━━━● '} |
| 236 | + ${0.6} | ${0} | ${0.6} | ${11} | ${'.'} | ${valueMinMaxSymbols} | ${'┣━━━━━●....'} |
| 237 | + ${0.6} | ${0.6} | ${1} | ${11} | ${'.'} | ${valueMinMaxSymbols} | ${'......●━━━┫'} |
| 238 | + ${0.5} | ${0.4} | ${0.8} | ${11} | ${'.'} | ${undefined} | ${'....┣●━━┫..'} |
| 239 | + `( |
| 240 | + 'pointMinMax $value, $minVal, $maxVal, $width, $padding, $symbols', |
| 241 | + ({ value, minVal, maxVal, width, padding, symbols, expected }) => { |
| 242 | + const r = pointMinMax(value, minVal, maxVal, width, padding, symbols); |
| 243 | + expect(r.length).toBe(width); |
| 244 | + expect(r).toBe(expected); |
| 245 | + }, |
| 246 | + ); |
226 | 247 | }); |
227 | 248 |
|
228 | 249 | function sampleData(num: number, scale = 1, step = 5): Data { |
|
0 commit comments