From 7b52a68aff67c4bb228eafb5d99000dfce741a02 Mon Sep 17 00:00:00 2001 From: Kevin Yu Date: Wed, 14 Jun 2023 09:36:13 -0700 Subject: [PATCH] Support numeric values when applying template variables to SQL queries --- src/sql/utils/utils.test.ts | 10 ++++++++++ src/sql/utils/utils.ts | 2 +- 2 files changed, 11 insertions(+), 1 deletion(-) diff --git a/src/sql/utils/utils.test.ts b/src/sql/utils/utils.test.ts index a07047e..ad88b3b 100644 --- a/src/sql/utils/utils.test.ts +++ b/src/sql/utils/utils.test.ts @@ -12,6 +12,7 @@ describe('filterQuery', () => { const scopedVars: Record = { $simple: 'foo', + $numeric: 123, $multiple: ['foo', 'bar'], }; // simplified version of getTemplateSrv().replace @@ -35,6 +36,15 @@ describe('applySQLTemplateVariables', () => { expect(res.rawSQL).toEqual('select * from foo'); }); + it('should replace a numeric var', () => { + const res = applySQLTemplateVariables( + { ...mockQuery, rawSQL: 'select * from $numeric' }, + scopedVars, + getTemplateSrv + ); + expect(res.rawSQL).toEqual('select * from 123'); + }); + it('should replace a multiple var', () => { const res = applySQLTemplateVariables( { ...mockQuery, rawSQL: 'select * from foo where var in ($multiple)' }, diff --git a/src/sql/utils/utils.ts b/src/sql/utils/utils.ts index 81b7cba..b08e08f 100644 --- a/src/sql/utils/utils.ts +++ b/src/sql/utils/utils.ts @@ -22,7 +22,7 @@ export function applySQLTemplateVariables( } function interpolateVariable(value: string | string[]) { - if (typeof value === 'string') { + if (typeof value === 'string' || typeof value === 'number') { return value; }