mirror of
https://github.com/DeNNiiInc/dbgate.git
synced 2026-04-18 03:16:01 +00:00
Add binary data handling in query tests with enhanced stream handler
This commit is contained in:
@@ -49,6 +49,32 @@ class StreamHandler {
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
class BinaryTestStreamHandler {
|
||||||
|
constructor(resolve, reject, expectedValue) {
|
||||||
|
this.resolve = resolve;
|
||||||
|
this.reject = reject;
|
||||||
|
this.expectedValue = expectedValue;
|
||||||
|
this.rowsReceived = [];
|
||||||
|
}
|
||||||
|
row(row) {
|
||||||
|
try {
|
||||||
|
this.rowsReceived.push(row);
|
||||||
|
if (this.expectedValue) {
|
||||||
|
expect(row).toEqual(this.expectedValue);
|
||||||
|
}
|
||||||
|
} catch (error) {
|
||||||
|
this.reject(error);
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
recordset(columns) {}
|
||||||
|
done(result) {
|
||||||
|
this.resolve(this.rowsReceived);
|
||||||
|
}
|
||||||
|
info(msg) {}
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
function executeStreamItem(driver, conn, sql) {
|
function executeStreamItem(driver, conn, sql) {
|
||||||
return new Promise(resolve => {
|
return new Promise(resolve => {
|
||||||
const handler = new StreamHandler(resolve);
|
const handler = new StreamHandler(resolve);
|
||||||
@@ -226,8 +252,8 @@ describe('Query', () => {
|
|||||||
|
|
||||||
test.each(engines.filter(x => x.binaryDataType).map(engine => [engine.label, engine]))(
|
test.each(engines.filter(x => x.binaryDataType).map(engine => [engine.label, engine]))(
|
||||||
'Binary',
|
'Binary',
|
||||||
testWrapper(async (conn, driver, engine) => {
|
testWrapper(async (dbhan, driver, engine) => {
|
||||||
await runCommandOnDriver(conn, driver, dmp =>
|
await runCommandOnDriver(dbhan, driver, dmp =>
|
||||||
dmp.createTable({
|
dmp.createTable({
|
||||||
pureName: 't1',
|
pureName: 't1',
|
||||||
columns: [
|
columns: [
|
||||||
@@ -239,16 +265,35 @@ describe('Query', () => {
|
|||||||
},
|
},
|
||||||
})
|
})
|
||||||
);
|
);
|
||||||
const structure = await driver.analyseFull(conn);
|
const structure = await driver.analyseFull(dbhan);
|
||||||
const table = structure.tables.find(x => x.pureName == 't1');
|
const table = structure.tables.find(x => x.pureName == 't1');
|
||||||
|
|
||||||
await runCommandOnDriver(conn, driver, dmp => dmp.put("INSERT INTO ~t1 (~val) VALUES (%v)", {$binary: {base64: 'iVBORw0KWgo='}}));
|
const dmp = driver.createDumper();
|
||||||
const res2 = await runQueryOnDriver(conn, driver, dmp => dmp.put('SELECT ~val FROM ~t1'));
|
dmp.putCmd("INSERT INTO ~t1 (~val) VALUES (%v)", {
|
||||||
|
$binary: { base64: 'iVBORw0KWgo=' },
|
||||||
|
});
|
||||||
|
await driver.query(dbhan, dmp.s, {discardResult: true});
|
||||||
|
|
||||||
const row = res2.rows[0];
|
const dmp2 = driver.createDumper();
|
||||||
|
dmp2.put('SELECT ~val FROM ~t1');
|
||||||
|
const res = await driver.query(dbhan, dmp2.s);
|
||||||
|
|
||||||
|
const row = res.rows[0];
|
||||||
const keys = Object.keys(row);
|
const keys = Object.keys(row);
|
||||||
expect(keys.length).toEqual(1);
|
expect(keys.length).toEqual(1);
|
||||||
expect(row[keys[0]]).toEqual({$binary: {base64: 'iVBORw0KWgo='}});
|
expect(row[keys[0]]).toEqual({$binary: {base64: 'iVBORw0KWgo='}});
|
||||||
|
|
||||||
|
const res2 = await driver.readQuery(dbhan, dmp2.s);
|
||||||
|
const rows = await Array.fromAsync(res2);
|
||||||
|
const rowsVal = rows.filter(r => r.val != null);
|
||||||
|
|
||||||
|
expect(rowsVal.length).toEqual(1);
|
||||||
|
expect(rowsVal[0].val).toEqual({$binary: {base64: 'iVBORw0KWgo='}});
|
||||||
|
|
||||||
|
const res3 = await new Promise((resolve, reject) => {
|
||||||
|
const handler = new BinaryTestStreamHandler(resolve, reject, {val: {$binary: {base64: 'iVBORw0KWgo='}}});
|
||||||
|
driver.stream(dbhan, dmp2.s, handler);
|
||||||
|
});
|
||||||
})
|
})
|
||||||
);
|
);
|
||||||
});
|
});
|
||||||
|
|||||||
Reference in New Issue
Block a user