Commit 002b4d34 by Daniel Lee

mysql: fix interpolation for numbers in temp vars

parent 68829a82
...@@ -20,7 +20,15 @@ export class MysqlDatasource { ...@@ -20,7 +20,15 @@ export class MysqlDatasource {
return '\'' + value + '\''; return '\'' + value + '\'';
} }
if (typeof value === 'number') {
return value;
}
var quotedValues = _.map(value, function(val) { var quotedValues = _.map(value, function(val) {
if (typeof value === 'number') {
return value;
}
return '\'' + val + '\''; return '\'' + val + '\'';
}); });
return quotedValues.join(','); return quotedValues.join(',');
......
...@@ -193,4 +193,24 @@ describe('MySQLDatasource', function() { ...@@ -193,4 +193,24 @@ describe('MySQLDatasource', function() {
expect(results[0].value).to.be('same'); expect(results[0].value).to.be('same');
}); });
}); });
describe('When interpolating variables', () => {
describe('and value is a string', () => {
it('should return a quoted value', () => {
expect(ctx.ds.interpolateVariable('abc')).to.eql('\'abc\'');
});
});
describe('and value is a number', () => {
it('should return an unquoted value', () => {
expect(ctx.ds.interpolateVariable(1000)).to.eql(1000);
});
});
describe('and value is an array of strings', () => {
it('should return comma separated quoted values', () => {
expect(ctx.ds.interpolateVariable(['a', 'b', 'c'])).to.eql('\'a\',\'b\',\'c\'');
});
});
});
}); });
Markdown is supported
0% or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment