-
-
Notifications
You must be signed in to change notification settings - Fork 627
Commit
This commit does not belong to any branch on this repository, and may belong to a fork outside of the repository.
feat: improved inspection of columns (#2112)
* feat: improved inspection of column definition objects * remove console.log * lint * lint * display type length modifiers for non-default column lengths * add a unit test for column definition custom inspect * fix unit test * fix tests * fix unit test
- Loading branch information
Showing
6 changed files
with
272 additions
and
21 deletions.
There are no files selected for viewing
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
102 changes: 102 additions & 0 deletions
102
test/builtin-runner/integration/connection/test-column-inspect.mjs
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,102 @@ | ||
import { describe, it, before, after } from 'node:test'; | ||
import assert from 'node:assert'; | ||
import util from 'node:util'; | ||
import common from '../../../common.js'; | ||
|
||
describe( | ||
'custom inspect for column definition', | ||
{ timeout: 1000 }, | ||
async () => { | ||
let connection; | ||
|
||
before(async () => { | ||
connection = await common.createConnection().promise(); | ||
connection.query(`DROP TABLE IF EXISTS test_fields`); | ||
}); | ||
|
||
after(async () => { | ||
await connection.end(); | ||
}); | ||
|
||
it('should map fields to a schema-like description when depth is > 1', async () => { | ||
const schema = ` | ||
id INT NOT NULL AUTO_INCREMENT, | ||
weight INT(2) UNSIGNED ZEROFILL, | ||
usignedInt INT UNSIGNED NOT NULL, | ||
signedInt INT NOT NULL, | ||
unsignedShort SMALLINT UNSIGNED NOT NULL, | ||
signedShort SMALLINT NOT NULL, | ||
tinyIntUnsigned TINYINT UNSIGNED NOT NULL, | ||
tinyIntSigned TINYINT NOT NULL, | ||
mediumIntUnsigned MEDIUMINT UNSIGNED NOT NULL, | ||
mediumIntSigned MEDIUMINT NOT NULL, | ||
bigIntSigned BIGINT NOT NULL, | ||
bigIntUnsigned BIGINT UNSIGNED NOT NULL, | ||
longText_ LONGTEXT NOT NULL, | ||
mediumText_ MEDIUMTEXT NOT NULL, | ||
text_ TEXT NOT NULL, | ||
tinyText_ TINYTEXT NOT NULL, | ||
varString_1000 VARCHAR(1000) NOT NULL, | ||
decimalDefault DECIMAL, | ||
decimal13_10 DECIMAL(13,10), | ||
floatDefault FLOAT, | ||
float11_7 FLOAT(11,7), | ||
dummyLastFieldToAllowForTrailingComma INT, | ||
`; | ||
await connection.query( | ||
`CREATE TEMPORARY TABLE test_fields (${schema} PRIMARY KEY (id))` | ||
); | ||
const [_, columns] = await connection.query('select * from test_fields'); | ||
const inspectResults = util.inspect(columns); | ||
const schemaArray = schema | ||
.split('\n') | ||
.map((line) => line.trim()) | ||
.filter((line) => line.length > 0) | ||
.map((line) => { | ||
const words = line.split(' '); | ||
const name = `\`${words[0]}\``; | ||
return [name, ...words.slice(1)].join(' '); | ||
}); | ||
|
||
const normalizedInspectResults = inspectResults | ||
.split('\n') | ||
.slice(1, -2) // remove "[" and "]" lines and also last dummy field | ||
.map((line) => line.trim()) | ||
// remove primary key - it's not in the schema explicitly but worth having in inspect | ||
.map(line => line.split('PRIMARY KEY ').join('')); | ||
|
||
for (let l = 0; l < normalizedInspectResults.length; l++) { | ||
const inspectLine = normalizedInspectResults[l]; | ||
const schemaLine = schemaArray[l]; | ||
assert.equal(inspectLine, schemaLine); | ||
} | ||
}); | ||
|
||
it.only('should show detailed description when depth is < 1', async () => { | ||
await connection.query(` | ||
CREATE TEMPORARY TABLE test_fields2 ( | ||
id INT, | ||
decimal13_10 DECIMAL(13,10) UNSIGNED NOT NULL, | ||
PRIMARY KEY (id) | ||
) | ||
`); | ||
const [_, columns] = await connection.query('select * from test_fields2'); | ||
const inspectResults = util.inspect(columns[1]); | ||
assert.deepEqual(inspectResults, util.inspect({ | ||
catalog: 'def', | ||
schema: 'test', | ||
name: 'decimal13_10', | ||
orgName: 'decimal13_10', | ||
table: 'test_fields2', | ||
orgTable: 'test_fields2', | ||
characterSet: 63, | ||
encoding: 'binary', | ||
columnLength: 14, | ||
type: 246, | ||
flags: [ 'NOT NULL' ], | ||
decimals: 10, | ||
typeName: 'NEWDECIMAL' | ||
})); | ||
}); | ||
} | ||
); |
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Oops, something went wrong.