From d75d3d38ac33d09031ec6178f1fc6b3324a0b0ef Mon Sep 17 00:00:00 2001 From: saul Date: Thu, 11 Apr 2024 16:48:48 +1200 Subject: [PATCH] Update cli tests and add age parameter to list. --- packages/cli/src/commands/list.ts | 15 ++++++++++----- packages/cli/test/list.spec.ts | 18 +++++++++--------- 2 files changed, 19 insertions(+), 14 deletions(-) diff --git a/packages/cli/src/commands/list.ts b/packages/cli/src/commands/list.ts index c63880ba..45a41d97 100644 --- a/packages/cli/src/commands/list.ts +++ b/packages/cli/src/commands/list.ts @@ -6,7 +6,12 @@ export const command = 'list' export const desc = 'List all items.' -export const builder = createBuilder({}) +export const builder = createBuilder({ + age: { + type: 'number', + default: 60000 + } +}) const formatSize = (size: number): string => { if (size > Math.pow(1000, 3)) { @@ -73,19 +78,17 @@ export const handler = createHandler(async function * (argv) { blocks: number size: number }> => { - const age = 60000 - if (argv.client == null) { throw new Error('Failed to connect to daemon.') } const [[{ status, blocks, size }], [agedStateData], [{ peers }]] = await Promise.all([ argv.client.getState([cid]), - argv.client.getState([cid], { age }), + argv.client.getState([cid], { age: argv.age }), argv.client.countPeers([cid]) ]) - const speed = agedStateData.size / (age / 1000) + const speed = agedStateData.size / (argv.age / 1000) if (status === 'COMPLETED') { completed.count++ @@ -118,6 +121,8 @@ export const handler = createHandler(async function * (argv) { 'CID'.padEnd(62) ].join('') + yield '' + yield * pipe( getDataFuncs, i => parallel(i, { ordered: false, concurrency: 5 }), diff --git a/packages/cli/test/list.spec.ts b/packages/cli/test/list.spec.ts index d82f6882..f2a07f11 100644 --- a/packages/cli/test/list.spec.ts +++ b/packages/cli/test/list.spec.ts @@ -23,13 +23,13 @@ describe('list', () => { ] it('text', async () => { - const params = mockParams({ list: items, countPeers: [{ cid, peers: 1 }], getState: [{ cid, status: 'COMPLETED', size: 50, blocks: 5 }] }, { group: 'group-abc' }) + const params = mockParams({ list: items, countPeers: [{ cid, peers: 1 }], getState: [{ cid, status: 'COMPLETED', size: 50, blocks: 5 }] }, { group: 'group-abc', age: 5000 }) const response = await all(handler(params)) const expected = [ [ - 'Name'.padEnd(20), + 'Name'.padEnd(50), 'Size'.padEnd(27), 'Speed'.padEnd(27), 'Blocks'.padEnd(20), @@ -42,14 +42,13 @@ describe('list', () => { 'R-Strategy'.padEnd(12), 'CID'.padEnd(62) ].join(''), - '/', - ' my-dir/', + '', [ - ' file ', - '50 B/500 B (10%) ', - '10 B/s (45 s) ', - '5/50 (10%) ', - 'COMPLETED ', + '/my-dir/file'.padEnd(50), + '50 B/500 B (10%)'.padEnd(27), + '10 B/s (45 s)'.padEnd(27), + '5/50 (10%)'.padEnd(20), + 'COMPLETED'.padEnd(15), '1 0 1 ', 'QmaCpDMG false all ', 'QmNnooDu7bfjPFoTZYxMNLWUQJyrVwtbZg5gBMjTezGAJN ' @@ -79,6 +78,7 @@ describe('list', () => { getState: [{ cid, status: 'COMPLETED', size: 50, blocks: 5 }] }, { group: 'group-abc', + age: 5000, json: true })