diff --git a/CHANGELOG.md b/CHANGELOG.md index c3646dc..f38c1f7 100644 --- a/CHANGELOG.md +++ b/CHANGELOG.md @@ -1,3 +1,9 @@ +# Unreleased + +## New features + +- Added optional `real_time_microseconds` field to the `ClickHouseSummary` interface (see https://github.com/ClickHouse/ClickHouse/pull/69032) + # 1.5.0 (Node.js) ## New features diff --git a/docker-compose.yml b/docker-compose.yml index 15a1bd5..d2f4ec8 100644 --- a/docker-compose.yml +++ b/docker-compose.yml @@ -1,4 +1,4 @@ -version: '3.8' +#version: '3.8' services: clickhouse: image: 'clickhouse/clickhouse-server:${CLICKHOUSE_VERSION-24.8-alpine}' diff --git a/packages/client-common/src/clickhouse_types.ts b/packages/client-common/src/clickhouse_types.ts index 81f5ebd..c436270 100644 --- a/packages/client-common/src/clickhouse_types.ts +++ b/packages/client-common/src/clickhouse_types.ts @@ -27,6 +27,8 @@ export interface ClickHouseSummary { result_rows: string result_bytes: string elapsed_ns: string + /** Available only after ClickHouse 24.9 */ + real_time_microseconds?: string } export type ResponseHeaders = Record diff --git a/packages/client-node/__tests__/integration/node_summary.test.ts b/packages/client-node/__tests__/integration/node_summary.test.ts index ad42dfa..14e8ee6 100644 --- a/packages/client-node/__tests__/integration/node_summary.test.ts +++ b/packages/client-node/__tests__/integration/node_summary.test.ts @@ -30,48 +30,69 @@ whenOnEnv( values: jsonValues, format: 'JSONEachRow', }) - expect(insertSummary).toEqual({ - read_rows: '5', - read_bytes: jasmine.any(String), - written_rows: '5', - written_bytes: jasmine.any(String), - total_rows_to_read: '0', - result_rows: '5', - result_bytes: jasmine.any(String), - elapsed_ns: jasmine.any(String), - }) + expect(insertSummary).toEqual( + jasmine.objectContaining({ + read_rows: '5', + read_bytes: jasmine.any(String), + written_rows: '5', + written_bytes: jasmine.any(String), + total_rows_to_read: '0', + result_rows: '5', + result_bytes: jasmine.any(String), + elapsed_ns: jasmine.any(String), + }), + ) + assertRealTimeMicroseconds(insertSummary) const { summary: execSummary } = await client.exec({ - query: `INSERT INTO ${tableName} SELECT * FROM ${tableName}`, - }) - expect(execSummary).toEqual({ - read_rows: '5', - read_bytes: jasmine.any(String), - written_rows: '5', - written_bytes: jasmine.any(String), - total_rows_to_read: '5', - result_rows: '5', - result_bytes: jasmine.any(String), - elapsed_ns: jasmine.any(String), + query: `INSERT INTO ${tableName} + SELECT * + FROM ${tableName}`, }) + expect(execSummary).toEqual( + jasmine.objectContaining({ + read_rows: '5', + read_bytes: jasmine.any(String), + written_rows: '5', + written_bytes: jasmine.any(String), + total_rows_to_read: '5', + result_rows: '5', + result_bytes: jasmine.any(String), + elapsed_ns: jasmine.any(String), + }), + ) + assertRealTimeMicroseconds(execSummary) }) it('should provide summary for command', async () => { const { summary } = await client.command({ - query: `INSERT INTO ${tableName} VALUES (144, 'Hello', [2, 4]), (255, 'World', [3, 5])`, + query: `INSERT INTO ${tableName} + VALUES (144, 'Hello', [2, 4]), + (255, 'World', [3, 5])`, clickhouse_settings: { wait_end_of_query: 1, }, }) - expect(summary).toEqual({ - read_rows: '2', - read_bytes: jasmine.any(String), - written_rows: '2', - written_bytes: jasmine.any(String), - total_rows_to_read: '0', - result_rows: '2', - result_bytes: jasmine.any(String), - elapsed_ns: jasmine.any(String), - }) + expect(summary).toEqual( + jasmine.objectContaining({ + read_rows: '2', + read_bytes: jasmine.any(String), + written_rows: '2', + written_bytes: jasmine.any(String), + total_rows_to_read: '0', + result_rows: '2', + result_bytes: jasmine.any(String), + elapsed_ns: jasmine.any(String), + }), + ) + assertRealTimeMicroseconds(summary) }) + + function assertRealTimeMicroseconds(summary: any) { + // FIXME: remove this condition after 24.9 is released + if (process.env['CLICKHOUSE_VERSION'] === 'head') { + expect(summary.real_time_microseconds).toBeDefined() + expect(summary.real_time_microseconds).toMatch(/^\d+$/) + } + } })