|
| 1 | +'use strict'; |
| 2 | + |
| 3 | +const common = require('../../common'); |
| 4 | +const connection = common.createConnection().promise(); |
| 5 | +const assert = require('assert'); |
| 6 | + |
| 7 | +// test data stores |
| 8 | +const testData = [ |
| 9 | + { |
| 10 | + column_charset: 'tis620', |
| 11 | + column_name: '平仮名', |
| 12 | + data: 'กขค', |
| 13 | + result_charset: 'utf8', |
| 14 | + }, |
| 15 | + { |
| 16 | + column_charset: 'tis620', |
| 17 | + column_name: '平仮名', |
| 18 | + data: 'กขค', |
| 19 | + result_charset: null, |
| 20 | + }, |
| 21 | + { |
| 22 | + column_charset: 'tis620', |
| 23 | + column_name: '平仮名', |
| 24 | + data: 'กขค', |
| 25 | + result_charset: 'utf8', |
| 26 | + }, |
| 27 | + { |
| 28 | + column_charset: 'tis620', |
| 29 | + column_name: '平仮名', |
| 30 | + data: 'กขค', |
| 31 | + result_charset: 'utf8mb3', |
| 32 | + }, |
| 33 | + { |
| 34 | + column_charset: 'utf16', |
| 35 | + column_name: 'กขค', |
| 36 | + data: 'กขค', |
| 37 | + result_charset: 'tis620', |
| 38 | + }, |
| 39 | +]; |
| 40 | + |
| 41 | +const resultData = []; |
| 42 | + |
| 43 | +(async () => { |
| 44 | + for (let i = 0; i < testData.length; ++i) { |
| 45 | + const entry = testData[i]; |
| 46 | + |
| 47 | + await connection.query('DROP TABLE IF EXISTS `test-charset-encoding2`'); |
| 48 | + await connection.query('SET NAMES "utf8mb4"'); |
| 49 | + await connection.query( |
| 50 | + 'CREATE TABLE IF NOT EXISTS `test-charset-encoding2` ' + |
| 51 | + `( \`${entry.column_name}\` VARCHAR(1000) CHARACTER SET "${entry.column_charset}")` |
| 52 | + ); |
| 53 | + await connection.query('INSERT INTO `test-charset-encoding2` values(?)', [ |
| 54 | + entry.data, |
| 55 | + ]); |
| 56 | + await connection.query('SET character_set_results = ?', [ |
| 57 | + entry.result_charset, |
| 58 | + ]); |
| 59 | + const result = await connection.query( |
| 60 | + 'SELECT * from `test-charset-encoding2`' |
| 61 | + ); |
| 62 | + resultData.push(result[0][0]); |
| 63 | + } |
| 64 | + connection.end(); |
| 65 | + for (let i = 0; i < testData.length; ++i) { |
| 66 | + const data = {}; |
| 67 | + data[testData[i].column_name] = testData[i].data; |
| 68 | + assert.deepEqual(resultData[i], data); |
| 69 | + } |
| 70 | +})(); |
0 commit comments