var common     = require('../../common');
var connection = common.createConnection();
var assert     = require('assert');

common.useTestDb(connection);

var table = 'nested_test';
connection.query([
  'CREATE TEMPORARY TABLE `' + table + '` (',
  '`id` int(11) unsigned NOT NULL AUTO_INCREMENT,',
  '`title` varchar(255),',
  'PRIMARY KEY (`id`)',
  ') ENGINE=InnoDB DEFAULT CHARSET=utf8'
].join('\n'));

connection.query('INSERT INTO ' + table + ' SET ?', {title: 'test'});

var options1 = {
  nestTables: true,
  sql: 'SELECT * FROM ' + table
};
var options2 = {
  nestTables: '_',
  sql: 'SELECT * FROM ' + table
};
var options3 = {
  rowsAsArray: true,
  sql: 'SELECT * FROM ' + table
};
var rows1, rows2, rows3, rows1e, rows2e, rows3e;

connection.query(options1, function(err, _rows) {
  if (err) throw err;

  rows1 = _rows;
});

connection.query(options2, function(err, _rows) {
  if (err) throw err;

  rows2 = _rows;
});

connection.query(options3, function(err, _rows) {
  if (err) throw err;

  rows3 = _rows;
});

connection.execute(options1, function(err, _rows) {
  if (err) throw err;

  rows1e = _rows;
});

connection.execute(options2, function(err, _rows) {
  if (err) throw err;

  rows2e = _rows;
});

connection.execute(options3, function(err, _rows) {
  if (err) throw err;

  rows3e = _rows;
});

connection.end();

process.on('exit', function() {
  assert.equal(rows1.length, 1);
  assert.equal(rows1[0].nested_test.id, 1);
  assert.equal(rows1[0].nested_test.title, 'test');
  
  assert.equal(rows2.length, 1);
  assert.equal(rows2[0].nested_test_id, 1);
  assert.equal(rows2[0].nested_test_title, 'test');

  assert.equal(Array.isArray(rows3[0]), true);
  assert.equal(rows3[0][0], 1);
  assert.equal(rows3[0][1], 'test');

  assert.deepEqual(rows1, rows1e);
  assert.deepEqual(rows2, rows2e);
  assert.deepEqual(rows3, rows3e);
});