|
1 | | -/* Copyright (c) 2018, 2023, Oracle and/or its affiliates. */ |
| 1 | +/* Copyright (c) 2018, 2025, Oracle and/or its affiliates. */ |
2 | 2 |
|
3 | 3 | /****************************************************************************** |
4 | 4 | * |
@@ -494,4 +494,81 @@ describe('162. getStmtInfo.js', function() { |
494 | 494 | const result = await conn.execute(sql, expectedRes); |
495 | 495 | assert.deepStrictEqual(result.rows[0], expectedRes); |
496 | 496 | }); |
| 497 | + |
| 498 | + it('162.37 Duplicate column aliases', async function() { |
| 499 | + const sql = `SELECT 1 a, 'abc' a FROM dual`; |
| 500 | + |
| 501 | + const info = await conn.getStatementInfo(sql); |
| 502 | + assert.strictEqual(info.metaData[0].name, 'A'); |
| 503 | + assert.strictEqual(info.metaData[1].name, 'A_1'); |
| 504 | + const result = await conn.execute(sql); |
| 505 | + assert.deepStrictEqual(result.rows[0], [1, 'abc']); |
| 506 | + }); |
| 507 | + |
| 508 | + it('162.38 Simple table columns without aliases', async function() { |
| 509 | + const sql = `SELECT num, content FROM ${tableName}`; |
| 510 | + |
| 511 | + const info = await conn.getStatementInfo(sql); |
| 512 | + assert.strictEqual(info.metaData[0].name, 'NUM'); |
| 513 | + assert.strictEqual(info.metaData[1].name, 'CONTENT'); |
| 514 | + }); |
| 515 | + |
| 516 | + it('162.39 Mixed aliases and table columns', async function() { |
| 517 | + const sql = `SELECT num, content AS value, 'literal' AS lit FROM ${tableName}`; |
| 518 | + |
| 519 | + const info = await conn.getStatementInfo(sql); |
| 520 | + assert.strictEqual(info.metaData[0].name, 'NUM'); |
| 521 | + assert.strictEqual(info.metaData[1].name, 'VALUE'); |
| 522 | + assert.strictEqual(info.metaData[2].name, 'LIT'); |
| 523 | + }); |
| 524 | + |
| 525 | + it('162.40 Very long column alias names', async function() { |
| 526 | + const longName = 'A'.repeat(30); |
| 527 | + |
| 528 | + const sql = `SELECT 1 AS "${longName}", 2 AS "${longName}" FROM dual`; |
| 529 | + const info = await conn.getStatementInfo(sql); |
| 530 | + assert.notStrictEqual(info.metaData[0].name, info.metaData[1].name); |
| 531 | + }); |
| 532 | + |
| 533 | + it('162.41 Single character duplicate aliases', async function() { |
| 534 | + const sql = `SELECT 1 AS "A", 2 AS "A" FROM dual`; |
| 535 | + |
| 536 | + const info = await conn.getStatementInfo(sql); |
| 537 | + assert.strictEqual(info.metaData[0].name, 'A'); |
| 538 | + assert.strictEqual(info.metaData[1].name, 'A_1'); |
| 539 | + }); |
| 540 | + |
| 541 | + it('162.42 Numeric aliases converted to strings', async function() { |
| 542 | + const sql = `SELECT 1 AS "1", 2 AS "1" FROM dual`; |
| 543 | + |
| 544 | + const info = await conn.getStatementInfo(sql); |
| 545 | + assert.strictEqual(info.metaData[0].name, '1'); |
| 546 | + assert.strictEqual(info.metaData[1].name, '1_1'); |
| 547 | + }); |
| 548 | + |
| 549 | + it('162.43 Special character aliases', async function() { |
| 550 | + const sql = `SELECT 1 AS "@#$", 2 AS "@#$" FROM dual`; |
| 551 | + |
| 552 | + const info = await conn.getStatementInfo(sql); |
| 553 | + assert.strictEqual(info.metaData[0].name, '@#$'); |
| 554 | + assert.strictEqual(info.metaData[1].name, '@#$_1'); |
| 555 | + }); |
| 556 | + |
| 557 | + it('162.44 Metadata consistency between output formats - duplicate aliases', async function() { |
| 558 | + const sql = `SELECT sysdate as A, sysdate as A FROM dual`; |
| 559 | + |
| 560 | + // Test with array format |
| 561 | + const infoArray = await conn.getStatementInfo(sql); |
| 562 | + const resultArray = await conn.execute(sql, [], { outFormat: oracledb.OUT_FORMAT_ARRAY }); |
| 563 | + |
| 564 | + // Test with object format |
| 565 | + const infoObject = await conn.getStatementInfo(sql); |
| 566 | + const resultObject = await conn.execute(sql, [], { outFormat: oracledb.OUT_FORMAT_OBJECT }); |
| 567 | + |
| 568 | + assert.deepStrictEqual(infoArray.metaData, infoObject.metaData); |
| 569 | + assert.deepStrictEqual(resultArray.metaData, resultObject.metaData); |
| 570 | + |
| 571 | + assert.strictEqual(infoArray.metaData[0].name, 'A'); |
| 572 | + assert.strictEqual(infoArray.metaData[1].name, 'A_1'); |
| 573 | + }); |
497 | 574 | }); |
0 commit comments