@slonik/sql-tag 47.3.2 → 48.1.0
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/dist/Logger.js +2 -5
- package/dist/Logger.js.map +1 -1
- package/dist/factories/createPrimitiveValueExpressions.d.ts +1 -1
- package/dist/factories/createPrimitiveValueExpressions.d.ts.map +1 -1
- package/dist/factories/createPrimitiveValueExpressions.js +8 -12
- package/dist/factories/createPrimitiveValueExpressions.js.map +1 -1
- package/dist/factories/createSqlTag.d.ts +3 -3
- package/dist/factories/createSqlTag.d.ts.map +1 -1
- package/dist/factories/createSqlTag.js +39 -43
- package/dist/factories/createSqlTag.js.map +1 -1
- package/dist/factories/createSqlTag.test/array.test.js +18 -23
- package/dist/factories/createSqlTag.test/array.test.js.map +1 -1
- package/dist/factories/createSqlTag.test/date.test.js +7 -12
- package/dist/factories/createSqlTag.test/date.test.js.map +1 -1
- package/dist/factories/createSqlTag.test/identifier.test.js +9 -14
- package/dist/factories/createSqlTag.test/identifier.test.js.map +1 -1
- package/dist/factories/createSqlTag.test/interval.test.js +9 -14
- package/dist/factories/createSqlTag.test/interval.test.js.map +1 -1
- package/dist/factories/createSqlTag.test/join.test.js +21 -26
- package/dist/factories/createSqlTag.test/join.test.js.map +1 -1
- package/dist/factories/createSqlTag.test/json.test.js +21 -26
- package/dist/factories/createSqlTag.test/json.test.js.map +1 -1
- package/dist/factories/createSqlTag.test/jsonb.test.js +21 -26
- package/dist/factories/createSqlTag.test/jsonb.test.js.map +1 -1
- package/dist/factories/createSqlTag.test/literalValue.test.js +6 -11
- package/dist/factories/createSqlTag.test/literalValue.test.js.map +1 -1
- package/dist/factories/createSqlTag.test/sql.test.js +17 -22
- package/dist/factories/createSqlTag.test/sql.test.js.map +1 -1
- package/dist/factories/createSqlTag.test/timestamp.test.js +7 -12
- package/dist/factories/createSqlTag.test/timestamp.test.js.map +1 -1
- package/dist/factories/createSqlTag.test/type.test.js +7 -12
- package/dist/factories/createSqlTag.test/type.test.js.map +1 -1
- package/dist/factories/createSqlTag.test/typeAlias.test.js +12 -17
- package/dist/factories/createSqlTag.test/typeAlias.test.js.map +1 -1
- package/dist/factories/createSqlTag.test/unnest.test.js +19 -24
- package/dist/factories/createSqlTag.test/unnest.test.js.map +1 -1
- package/dist/factories/createSqlTag.test/uuid.test.js +7 -12
- package/dist/factories/createSqlTag.test/uuid.test.js.map +1 -1
- package/dist/factories/createSqlTokenSqlFragment.d.ts +1 -1
- package/dist/factories/createSqlTokenSqlFragment.d.ts.map +1 -1
- package/dist/factories/createSqlTokenSqlFragment.js +55 -59
- package/dist/factories/createSqlTokenSqlFragment.js.map +1 -1
- package/dist/index.d.ts +5 -5
- package/dist/index.d.ts.map +1 -1
- package/dist/index.js +4 -24
- package/dist/index.js.map +1 -1
- package/dist/regexRules/slonikPlaceholderRegexRule.js +1 -4
- package/dist/regexRules/slonikPlaceholderRegexRule.js.map +1 -1
- package/dist/sqlFragmentFactories/createArraySqlFragment.d.ts +1 -1
- package/dist/sqlFragmentFactories/createArraySqlFragment.d.ts.map +1 -1
- package/dist/sqlFragmentFactories/createArraySqlFragment.js +18 -22
- package/dist/sqlFragmentFactories/createArraySqlFragment.js.map +1 -1
- package/dist/sqlFragmentFactories/createBinarySqlFragment.d.ts +1 -1
- package/dist/sqlFragmentFactories/createBinarySqlFragment.d.ts.map +1 -1
- package/dist/sqlFragmentFactories/createBinarySqlFragment.js +7 -11
- package/dist/sqlFragmentFactories/createBinarySqlFragment.js.map +1 -1
- package/dist/sqlFragmentFactories/createDateSqlFragment.d.ts +1 -1
- package/dist/sqlFragmentFactories/createDateSqlFragment.d.ts.map +1 -1
- package/dist/sqlFragmentFactories/createDateSqlFragment.js +7 -11
- package/dist/sqlFragmentFactories/createDateSqlFragment.js.map +1 -1
- package/dist/sqlFragmentFactories/createFragmentSqlFragment.d.ts +1 -1
- package/dist/sqlFragmentFactories/createFragmentSqlFragment.d.ts.map +1 -1
- package/dist/sqlFragmentFactories/createFragmentSqlFragment.js +10 -14
- package/dist/sqlFragmentFactories/createFragmentSqlFragment.js.map +1 -1
- package/dist/sqlFragmentFactories/createIdentifierSqlFragment.d.ts +1 -1
- package/dist/sqlFragmentFactories/createIdentifierSqlFragment.d.ts.map +1 -1
- package/dist/sqlFragmentFactories/createIdentifierSqlFragment.js +7 -11
- package/dist/sqlFragmentFactories/createIdentifierSqlFragment.js.map +1 -1
- package/dist/sqlFragmentFactories/createIntervalSqlFragment.d.ts +1 -1
- package/dist/sqlFragmentFactories/createIntervalSqlFragment.d.ts.map +1 -1
- package/dist/sqlFragmentFactories/createIntervalSqlFragment.js +16 -20
- package/dist/sqlFragmentFactories/createIntervalSqlFragment.js.map +1 -1
- package/dist/sqlFragmentFactories/createJsonSqlFragment.d.ts +1 -1
- package/dist/sqlFragmentFactories/createJsonSqlFragment.d.ts.map +1 -1
- package/dist/sqlFragmentFactories/createJsonSqlFragment.js +18 -22
- package/dist/sqlFragmentFactories/createJsonSqlFragment.js.map +1 -1
- package/dist/sqlFragmentFactories/createListSqlFragment.d.ts +1 -1
- package/dist/sqlFragmentFactories/createListSqlFragment.d.ts.map +1 -1
- package/dist/sqlFragmentFactories/createListSqlFragment.js +16 -20
- package/dist/sqlFragmentFactories/createListSqlFragment.js.map +1 -1
- package/dist/sqlFragmentFactories/createQuerySqlFragment.d.ts +1 -1
- package/dist/sqlFragmentFactories/createQuerySqlFragment.d.ts.map +1 -1
- package/dist/sqlFragmentFactories/createQuerySqlFragment.js +10 -14
- package/dist/sqlFragmentFactories/createQuerySqlFragment.js.map +1 -1
- package/dist/sqlFragmentFactories/createTimestampSqlFragment.d.ts +1 -1
- package/dist/sqlFragmentFactories/createTimestampSqlFragment.d.ts.map +1 -1
- package/dist/sqlFragmentFactories/createTimestampSqlFragment.js +8 -12
- package/dist/sqlFragmentFactories/createTimestampSqlFragment.js.map +1 -1
- package/dist/sqlFragmentFactories/createUnnestSqlFragment.d.ts +1 -1
- package/dist/sqlFragmentFactories/createUnnestSqlFragment.d.ts.map +1 -1
- package/dist/sqlFragmentFactories/createUnnestSqlFragment.js +17 -21
- package/dist/sqlFragmentFactories/createUnnestSqlFragment.js.map +1 -1
- package/dist/sqlFragmentFactories/createUuidSqlFragment.d.ts +1 -1
- package/dist/sqlFragmentFactories/createUuidSqlFragment.d.ts.map +1 -1
- package/dist/sqlFragmentFactories/createUuidSqlFragment.js +7 -11
- package/dist/sqlFragmentFactories/createUuidSqlFragment.js.map +1 -1
- package/dist/tokens.js +14 -17
- package/dist/tokens.js.map +1 -1
- package/dist/types.d.ts +6 -6
- package/dist/types.d.ts.map +1 -1
- package/dist/types.js +1 -2
- package/dist/utilities/countArrayDimensions.js +1 -5
- package/dist/utilities/countArrayDimensions.js.map +1 -1
- package/dist/utilities/countArrayDimensions.test.js +6 -11
- package/dist/utilities/countArrayDimensions.test.js.map +1 -1
- package/dist/utilities/escapeIdentifier.js +1 -5
- package/dist/utilities/escapeIdentifier.js.map +1 -1
- package/dist/utilities/escapeIdentifier.test.js +6 -11
- package/dist/utilities/escapeIdentifier.test.js.map +1 -1
- package/dist/utilities/escapeLiteralValue.js +1 -5
- package/dist/utilities/escapeLiteralValue.js.map +1 -1
- package/dist/utilities/escapeLiteralValue.test.js +7 -12
- package/dist/utilities/escapeLiteralValue.test.js.map +1 -1
- package/dist/utilities/formatSlonikPlaceholder.js +1 -5
- package/dist/utilities/formatSlonikPlaceholder.js.map +1 -1
- package/dist/utilities/hasOwnProperty.js +1 -5
- package/dist/utilities/hasOwnProperty.js.map +1 -1
- package/dist/utilities/isPlainObject.js +1 -5
- package/dist/utilities/isPlainObject.js.map +1 -1
- package/dist/utilities/isPrimitiveValueExpression.js +1 -5
- package/dist/utilities/isPrimitiveValueExpression.js.map +1 -1
- package/dist/utilities/isSqlToken.d.ts +1 -1
- package/dist/utilities/isSqlToken.d.ts.map +1 -1
- package/dist/utilities/isSqlToken.js +20 -24
- package/dist/utilities/isSqlToken.js.map +1 -1
- package/dist/utilities/safeStringify.js +3 -7
- package/dist/utilities/safeStringify.js.map +1 -1
- package/dist/utilities/stripArrayNotation.js +1 -5
- package/dist/utilities/stripArrayNotation.js.map +1 -1
- package/dist/utilities/stripArrayNotation.test.js +6 -11
- package/dist/utilities/stripArrayNotation.test.js.map +1 -1
- package/package.json +17 -36
- package/src/factories/createPrimitiveValueExpressions.ts +3 -3
- package/src/factories/createSqlTag.test/array.test.ts +2 -2
- package/src/factories/createSqlTag.test/date.test.ts +2 -2
- package/src/factories/createSqlTag.test/identifier.test.ts +2 -2
- package/src/factories/createSqlTag.test/interval.test.ts +2 -2
- package/src/factories/createSqlTag.test/join.test.ts +2 -2
- package/src/factories/createSqlTag.test/json.test.ts +2 -2
- package/src/factories/createSqlTag.test/jsonb.test.ts +2 -2
- package/src/factories/createSqlTag.test/literalValue.test.ts +2 -2
- package/src/factories/createSqlTag.test/sql.test.ts +4 -3
- package/src/factories/createSqlTag.test/timestamp.test.ts +2 -2
- package/src/factories/createSqlTag.test/type.test.ts +1 -1
- package/src/factories/createSqlTag.test/typeAlias.test.ts +3 -2
- package/src/factories/createSqlTag.test/unnest.test.ts +2 -2
- package/src/factories/createSqlTag.test/uuid.test.ts +2 -2
- package/src/factories/createSqlTag.ts +17 -16
- package/src/factories/createSqlTokenSqlFragment.ts +14 -14
- package/src/index.ts +5 -5
- package/src/sqlFragmentFactories/createArraySqlFragment.ts +7 -7
- package/src/sqlFragmentFactories/createBinarySqlFragment.ts +3 -3
- package/src/sqlFragmentFactories/createDateSqlFragment.ts +3 -3
- package/src/sqlFragmentFactories/createFragmentSqlFragment.ts +4 -4
- package/src/sqlFragmentFactories/createIdentifierSqlFragment.ts +3 -3
- package/src/sqlFragmentFactories/createIntervalSqlFragment.ts +3 -3
- package/src/sqlFragmentFactories/createJsonSqlFragment.ts +10 -10
- package/src/sqlFragmentFactories/createListSqlFragment.ts +11 -11
- package/src/sqlFragmentFactories/createQuerySqlFragment.ts +4 -4
- package/src/sqlFragmentFactories/createTimestampSqlFragment.ts +3 -3
- package/src/sqlFragmentFactories/createUnnestSqlFragment.ts +11 -11
- package/src/sqlFragmentFactories/createUuidSqlFragment.ts +3 -3
- package/src/types.ts +9 -6
- package/src/utilities/countArrayDimensions.test.ts +1 -1
- package/src/utilities/escapeIdentifier.test.ts +1 -1
- package/src/utilities/escapeLiteralValue.test.ts +1 -1
- package/src/utilities/isSqlToken.ts +3 -3
- package/src/utilities/stripArrayNotation.test.ts +1 -1
|
@@ -1,81 +1,76 @@
|
|
|
1
|
-
|
|
2
|
-
|
|
3
|
-
|
|
4
|
-
|
|
5
|
-
|
|
6
|
-
const tokens_1 = require("../../tokens");
|
|
7
|
-
const createSqlTag_1 = require("../createSqlTag");
|
|
8
|
-
const ava_1 = __importDefault(require("ava"));
|
|
9
|
-
const sql = (0, createSqlTag_1.createSqlTag)();
|
|
10
|
-
(0, ava_1.default)('creates a list of values', (t) => {
|
|
1
|
+
import { FragmentToken } from '../../tokens.js';
|
|
2
|
+
import { createSqlTag } from '../createSqlTag.js';
|
|
3
|
+
import test from 'ava';
|
|
4
|
+
const sql = createSqlTag();
|
|
5
|
+
test('creates a list of values', (t) => {
|
|
11
6
|
const query = sql.fragment `SELECT (${sql.join([1, 2, 3], sql.fragment `, `)})`;
|
|
12
7
|
t.deepEqual(query, {
|
|
13
8
|
sql: 'SELECT ($slonik_1, $slonik_2, $slonik_3)',
|
|
14
|
-
type:
|
|
9
|
+
type: FragmentToken,
|
|
15
10
|
values: [1, 2, 3],
|
|
16
11
|
});
|
|
17
12
|
});
|
|
18
|
-
(
|
|
13
|
+
test('creates a list of values using glue', (t) => {
|
|
19
14
|
const query = sql.fragment `SELECT ${sql.join([sql.fragment `TRUE`, sql.fragment `TRUE`], sql.fragment ` AND `)}`;
|
|
20
15
|
t.deepEqual(query, {
|
|
21
16
|
sql: 'SELECT TRUE AND TRUE',
|
|
22
|
-
type:
|
|
17
|
+
type: FragmentToken,
|
|
23
18
|
values: [],
|
|
24
19
|
});
|
|
25
20
|
});
|
|
26
|
-
(
|
|
21
|
+
test('interpolates SQL tokens', (t) => {
|
|
27
22
|
const query = sql.fragment `SELECT (${sql.join([1, sql.fragment `foo`, 3], sql.fragment `, `)})`;
|
|
28
23
|
t.deepEqual(query, {
|
|
29
24
|
sql: 'SELECT ($slonik_1, foo, $slonik_2)',
|
|
30
|
-
type:
|
|
25
|
+
type: FragmentToken,
|
|
31
26
|
values: [1, 3],
|
|
32
27
|
});
|
|
33
28
|
});
|
|
34
|
-
(
|
|
29
|
+
test('interpolates SQL tokens with bound values', (t) => {
|
|
35
30
|
const query = sql.fragment `SELECT ${sql.join([1, sql.fragment `to_timestamp(${2}), ${3}`, 4], sql.fragment `, `)}`;
|
|
36
31
|
t.deepEqual(query, {
|
|
37
32
|
sql: 'SELECT $slonik_1, to_timestamp($slonik_2), $slonik_3, $slonik_4',
|
|
38
|
-
type:
|
|
33
|
+
type: FragmentToken,
|
|
39
34
|
values: [1, 2, 3, 4],
|
|
40
35
|
});
|
|
41
36
|
});
|
|
42
|
-
(
|
|
37
|
+
test('offsets positional parameter indexes', (t) => {
|
|
43
38
|
const query = sql.fragment `SELECT ${1}, ${sql.join([1, sql.fragment `to_timestamp(${2}), ${3}`, 4], sql.fragment `, `)}, ${3}`;
|
|
44
39
|
t.deepEqual(query, {
|
|
45
40
|
sql: 'SELECT $slonik_1, $slonik_2, to_timestamp($slonik_3), $slonik_4, $slonik_5, $slonik_6',
|
|
46
|
-
type:
|
|
41
|
+
type: FragmentToken,
|
|
47
42
|
values: [1, 1, 2, 3, 4, 3],
|
|
48
43
|
});
|
|
49
44
|
});
|
|
50
|
-
(
|
|
45
|
+
test('supports bigint', (t) => {
|
|
51
46
|
const query = sql.fragment `SELECT ${1n}, ${sql.join([sql.fragment `to_timestamp(${2n})`, 3n], sql.fragment `, `)}, ${4n}`;
|
|
52
47
|
t.deepEqual(query, {
|
|
53
48
|
sql: 'SELECT $slonik_1, to_timestamp($slonik_2), $slonik_3, $slonik_4',
|
|
54
|
-
type:
|
|
49
|
+
type: FragmentToken,
|
|
55
50
|
values: [1n, 2n, 3n, 4n],
|
|
56
51
|
});
|
|
57
52
|
});
|
|
58
|
-
(
|
|
53
|
+
test('nests expressions', (t) => {
|
|
59
54
|
const query = sql.fragment `SELECT ${sql.join([
|
|
60
55
|
sql.fragment `(${sql.join([1, 2], sql.fragment `, `)})`,
|
|
61
56
|
sql.fragment `(${sql.join([3, 4], sql.fragment `, `)})`,
|
|
62
57
|
], sql.fragment `, `)}`;
|
|
63
58
|
t.deepEqual(query, {
|
|
64
59
|
sql: 'SELECT ($slonik_1, $slonik_2), ($slonik_3, $slonik_4)',
|
|
65
|
-
type:
|
|
60
|
+
type: FragmentToken,
|
|
66
61
|
values: [1, 2, 3, 4],
|
|
67
62
|
});
|
|
68
63
|
});
|
|
69
|
-
(
|
|
64
|
+
test('binary join expressions', (t) => {
|
|
70
65
|
const data = Buffer.from('1f', 'hex');
|
|
71
66
|
const query = sql.fragment `SELECT (${sql.join(['a', sql.binary(data)], sql.fragment `, `)})`;
|
|
72
67
|
t.deepEqual(query, {
|
|
73
68
|
sql: 'SELECT ($slonik_1, $slonik_2)',
|
|
74
|
-
type:
|
|
69
|
+
type: FragmentToken,
|
|
75
70
|
values: ['a', data],
|
|
76
71
|
});
|
|
77
72
|
});
|
|
78
|
-
(
|
|
73
|
+
test('throws is member is not a SQL token or a primitive value expression', (t) => {
|
|
79
74
|
const error = t.throws(() => {
|
|
80
75
|
sql.fragment `${sql.join([
|
|
81
76
|
// @ts-expect-error - intentional
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"join.test.js","sourceRoot":"","sources":["../../../src/factories/createSqlTag.test/join.test.ts"],"names":[],"mappings":"
|
|
1
|
+
{"version":3,"file":"join.test.js","sourceRoot":"","sources":["../../../src/factories/createSqlTag.test/join.test.ts"],"names":[],"mappings":"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"}
|
|
@@ -1,23 +1,18 @@
|
|
|
1
|
-
|
|
2
|
-
|
|
3
|
-
|
|
4
|
-
|
|
5
|
-
|
|
6
|
-
const tokens_1 = require("../../tokens");
|
|
7
|
-
const createSqlTag_1 = require("../createSqlTag");
|
|
8
|
-
const ava_1 = __importDefault(require("ava"));
|
|
9
|
-
const sql = (0, createSqlTag_1.createSqlTag)();
|
|
10
|
-
(0, ava_1.default)('creates a value list (object)', (t) => {
|
|
1
|
+
import { FragmentToken } from '../../tokens.js';
|
|
2
|
+
import { createSqlTag } from '../createSqlTag.js';
|
|
3
|
+
import test from 'ava';
|
|
4
|
+
const sql = createSqlTag();
|
|
5
|
+
test('creates a value list (object)', (t) => {
|
|
11
6
|
const query = sql.fragment `SELECT ${sql.json({
|
|
12
7
|
foo: 'bar',
|
|
13
8
|
})}`;
|
|
14
9
|
t.deepEqual(query, {
|
|
15
10
|
sql: 'SELECT $slonik_1::json',
|
|
16
|
-
type:
|
|
11
|
+
type: FragmentToken,
|
|
17
12
|
values: ['{"foo":"bar"}'],
|
|
18
13
|
});
|
|
19
14
|
});
|
|
20
|
-
(
|
|
15
|
+
test('creates a value list (array)', (t) => {
|
|
21
16
|
const query = sql.fragment `SELECT ${sql.json([
|
|
22
17
|
{
|
|
23
18
|
foo: 'bar',
|
|
@@ -25,63 +20,63 @@ const sql = (0, createSqlTag_1.createSqlTag)();
|
|
|
25
20
|
])}`;
|
|
26
21
|
t.deepEqual(query, {
|
|
27
22
|
sql: 'SELECT $slonik_1::json',
|
|
28
|
-
type:
|
|
23
|
+
type: FragmentToken,
|
|
29
24
|
values: ['[{"foo":"bar"}]'],
|
|
30
25
|
});
|
|
31
26
|
});
|
|
32
|
-
(
|
|
27
|
+
test("stringifies NULL to 'null'::json", (t) => {
|
|
33
28
|
const query = sql.fragment `SELECT ${sql.json(null)}`;
|
|
34
29
|
t.deepEqual(query, {
|
|
35
30
|
sql: 'SELECT $slonik_1::json',
|
|
36
|
-
type:
|
|
31
|
+
type: FragmentToken,
|
|
37
32
|
values: ['null'],
|
|
38
33
|
});
|
|
39
34
|
});
|
|
40
|
-
(
|
|
35
|
+
test('JSON encodes string values', (t) => {
|
|
41
36
|
const query = sql.fragment `SELECT ${sql.json('example string')}`;
|
|
42
37
|
t.deepEqual(query, {
|
|
43
38
|
sql: 'SELECT $slonik_1::json',
|
|
44
|
-
type:
|
|
39
|
+
type: FragmentToken,
|
|
45
40
|
values: ['"example string"'],
|
|
46
41
|
});
|
|
47
42
|
});
|
|
48
|
-
(
|
|
49
|
-
const query = sql.fragment `SELECT ${sql.json(
|
|
43
|
+
test('JSON encodes numeric values', (t) => {
|
|
44
|
+
const query = sql.fragment `SELECT ${sql.json(1_234)}`;
|
|
50
45
|
t.deepEqual(query, {
|
|
51
46
|
sql: 'SELECT $slonik_1::json',
|
|
52
|
-
type:
|
|
47
|
+
type: FragmentToken,
|
|
53
48
|
values: ['1234'],
|
|
54
49
|
});
|
|
55
50
|
});
|
|
56
|
-
(
|
|
51
|
+
test('JSON encodes boolean values', (t) => {
|
|
57
52
|
const query = sql.fragment `SELECT ${sql.json(true)}`;
|
|
58
53
|
t.deepEqual(query, {
|
|
59
54
|
sql: 'SELECT $slonik_1::json',
|
|
60
|
-
type:
|
|
55
|
+
type: FragmentToken,
|
|
61
56
|
values: ['true'],
|
|
62
57
|
});
|
|
63
58
|
});
|
|
64
|
-
(
|
|
59
|
+
test('throws if payload is undefined', (t) => {
|
|
65
60
|
const error = t.throws(() => {
|
|
66
61
|
sql.fragment `SELECT ${sql.json(undefined)}`;
|
|
67
62
|
});
|
|
68
63
|
t.is(error?.message, 'JSON payload must not be undefined.');
|
|
69
64
|
});
|
|
70
|
-
(
|
|
65
|
+
test('throws if payload cannot be stringified (non-primitive object)', (t) => {
|
|
71
66
|
const error = t.throws(() => {
|
|
72
67
|
// @ts-expect-error - intentional
|
|
73
68
|
sql.fragment `SELECT ${sql.json(() => { })}`;
|
|
74
69
|
});
|
|
75
70
|
t.is(error?.message, 'JSON payload must be a primitive value or a plain object.');
|
|
76
71
|
});
|
|
77
|
-
(
|
|
72
|
+
test('Object types with optional properties are allowed', (t) => {
|
|
78
73
|
const testValue = {
|
|
79
74
|
foo: 'bar',
|
|
80
75
|
};
|
|
81
76
|
const query = sql.fragment `SELECT ${sql.json(testValue)}`;
|
|
82
77
|
t.deepEqual(query, {
|
|
83
78
|
sql: 'SELECT $slonik_1::json',
|
|
84
|
-
type:
|
|
79
|
+
type: FragmentToken,
|
|
85
80
|
values: ['{"foo":"bar"}'],
|
|
86
81
|
});
|
|
87
82
|
});
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"json.test.js","sourceRoot":"","sources":["../../../src/factories/createSqlTag.test/json.test.ts"],"names":[],"mappings":"
|
|
1
|
+
{"version":3,"file":"json.test.js","sourceRoot":"","sources":["../../../src/factories/createSqlTag.test/json.test.ts"],"names":[],"mappings":"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"}
|
|
@@ -1,23 +1,18 @@
|
|
|
1
|
-
|
|
2
|
-
|
|
3
|
-
|
|
4
|
-
|
|
5
|
-
|
|
6
|
-
const tokens_1 = require("../../tokens");
|
|
7
|
-
const createSqlTag_1 = require("../createSqlTag");
|
|
8
|
-
const ava_1 = __importDefault(require("ava"));
|
|
9
|
-
const sql = (0, createSqlTag_1.createSqlTag)();
|
|
10
|
-
(0, ava_1.default)('creates a value list (object)', (t) => {
|
|
1
|
+
import { FragmentToken } from '../../tokens.js';
|
|
2
|
+
import { createSqlTag } from '../createSqlTag.js';
|
|
3
|
+
import test from 'ava';
|
|
4
|
+
const sql = createSqlTag();
|
|
5
|
+
test('creates a value list (object)', (t) => {
|
|
11
6
|
const query = sql.fragment `SELECT ${sql.jsonb({
|
|
12
7
|
foo: 'bar',
|
|
13
8
|
})}`;
|
|
14
9
|
t.deepEqual(query, {
|
|
15
10
|
sql: 'SELECT $slonik_1::jsonb',
|
|
16
|
-
type:
|
|
11
|
+
type: FragmentToken,
|
|
17
12
|
values: ['{"foo":"bar"}'],
|
|
18
13
|
});
|
|
19
14
|
});
|
|
20
|
-
(
|
|
15
|
+
test('creates a value list (array)', (t) => {
|
|
21
16
|
const query = sql.fragment `SELECT ${sql.jsonb([
|
|
22
17
|
{
|
|
23
18
|
foo: 'bar',
|
|
@@ -25,63 +20,63 @@ const sql = (0, createSqlTag_1.createSqlTag)();
|
|
|
25
20
|
])}`;
|
|
26
21
|
t.deepEqual(query, {
|
|
27
22
|
sql: 'SELECT $slonik_1::jsonb',
|
|
28
|
-
type:
|
|
23
|
+
type: FragmentToken,
|
|
29
24
|
values: ['[{"foo":"bar"}]'],
|
|
30
25
|
});
|
|
31
26
|
});
|
|
32
|
-
(
|
|
27
|
+
test("stringifies NULL to 'null'::jsonb", (t) => {
|
|
33
28
|
const query = sql.fragment `SELECT ${sql.jsonb(null)}`;
|
|
34
29
|
t.deepEqual(query, {
|
|
35
30
|
sql: 'SELECT $slonik_1::jsonb',
|
|
36
|
-
type:
|
|
31
|
+
type: FragmentToken,
|
|
37
32
|
values: ['null'],
|
|
38
33
|
});
|
|
39
34
|
});
|
|
40
|
-
(
|
|
35
|
+
test('JSON encodes string values', (t) => {
|
|
41
36
|
const query = sql.fragment `SELECT ${sql.jsonb('example string')}`;
|
|
42
37
|
t.deepEqual(query, {
|
|
43
38
|
sql: 'SELECT $slonik_1::jsonb',
|
|
44
|
-
type:
|
|
39
|
+
type: FragmentToken,
|
|
45
40
|
values: ['"example string"'],
|
|
46
41
|
});
|
|
47
42
|
});
|
|
48
|
-
(
|
|
49
|
-
const query = sql.fragment `SELECT ${sql.jsonb(
|
|
43
|
+
test('JSON encodes numeric values', (t) => {
|
|
44
|
+
const query = sql.fragment `SELECT ${sql.jsonb(1_234)}`;
|
|
50
45
|
t.deepEqual(query, {
|
|
51
46
|
sql: 'SELECT $slonik_1::jsonb',
|
|
52
|
-
type:
|
|
47
|
+
type: FragmentToken,
|
|
53
48
|
values: ['1234'],
|
|
54
49
|
});
|
|
55
50
|
});
|
|
56
|
-
(
|
|
51
|
+
test('JSON encodes boolean values', (t) => {
|
|
57
52
|
const query = sql.fragment `SELECT ${sql.jsonb(true)}`;
|
|
58
53
|
t.deepEqual(query, {
|
|
59
54
|
sql: 'SELECT $slonik_1::jsonb',
|
|
60
|
-
type:
|
|
55
|
+
type: FragmentToken,
|
|
61
56
|
values: ['true'],
|
|
62
57
|
});
|
|
63
58
|
});
|
|
64
|
-
(
|
|
59
|
+
test('throws if payload is undefined', (t) => {
|
|
65
60
|
const error = t.throws(() => {
|
|
66
61
|
sql.fragment `SELECT ${sql.jsonb(undefined)}`;
|
|
67
62
|
});
|
|
68
63
|
t.is(error?.message, 'JSON payload must not be undefined.');
|
|
69
64
|
});
|
|
70
|
-
(
|
|
65
|
+
test('throws if payload cannot be stringified (non-primitive object)', (t) => {
|
|
71
66
|
const error = t.throws(() => {
|
|
72
67
|
// @ts-expect-error - intentional
|
|
73
68
|
sql.fragment `SELECT ${sql.jsonb(() => { })}`;
|
|
74
69
|
});
|
|
75
70
|
t.is(error?.message, 'JSON payload must be a primitive value or a plain object.');
|
|
76
71
|
});
|
|
77
|
-
(
|
|
72
|
+
test('Object types with optional properties are allowed', (t) => {
|
|
78
73
|
const testValue = {
|
|
79
74
|
foo: 'bar',
|
|
80
75
|
};
|
|
81
76
|
const query = sql.fragment `SELECT ${sql.jsonb(testValue)}`;
|
|
82
77
|
t.deepEqual(query, {
|
|
83
78
|
sql: 'SELECT $slonik_1::jsonb',
|
|
84
|
-
type:
|
|
79
|
+
type: FragmentToken,
|
|
85
80
|
values: ['{"foo":"bar"}'],
|
|
86
81
|
});
|
|
87
82
|
});
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"jsonb.test.js","sourceRoot":"","sources":["../../../src/factories/createSqlTag.test/jsonb.test.ts"],"names":[],"mappings":"
|
|
1
|
+
{"version":3,"file":"jsonb.test.js","sourceRoot":"","sources":["../../../src/factories/createSqlTag.test/jsonb.test.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,aAAa,EAAE,MAAM,iBAAiB,CAAC;AAChD,OAAO,EAAE,YAAY,EAAE,MAAM,oBAAoB,CAAC;AAClD,OAAO,IAAI,MAAM,KAAK,CAAC;AAEvB,MAAM,GAAG,GAAG,YAAY,EAAE,CAAC;AAE3B,IAAI,CAAC,+BAA+B,EAAE,CAAC,CAAC,EAAE,EAAE;IAC1C,MAAM,KAAK,GAAG,GAAG,CAAC,QAAQ,CAAA,UAAU,GAAG,CAAC,KAAK,CAAC;QAC5C,GAAG,EAAE,KAAK;KACX,CAAC,EAAE,CAAC;IAEL,CAAC,CAAC,SAAS,CAAC,KAAK,EAAE;QACjB,GAAG,EAAE,yBAAyB;QAC9B,IAAI,EAAE,aAAa;QACnB,MAAM,EAAE,CAAC,eAAe,CAAC;KAC1B,CAAC,CAAC;AACL,CAAC,CAAC,CAAC;AAEH,IAAI,CAAC,8BAA8B,EAAE,CAAC,CAAC,EAAE,EAAE;IACzC,MAAM,KAAK,GAAG,GAAG,CAAC,QAAQ,CAAA,UAAU,GAAG,CAAC,KAAK,CAAC;QAC5C;YACE,GAAG,EAAE,KAAK;SACX;KACF,CAAC,EAAE,CAAC;IAEL,CAAC,CAAC,SAAS,CAAC,KAAK,EAAE;QACjB,GAAG,EAAE,yBAAyB;QAC9B,IAAI,EAAE,aAAa;QACnB,MAAM,EAAE,CAAC,iBAAiB,CAAC;KAC5B,CAAC,CAAC;AACL,CAAC,CAAC,CAAC;AAEH,IAAI,CAAC,mCAAmC,EAAE,CAAC,CAAC,EAAE,EAAE;IAC9C,MAAM,KAAK,GAAG,GAAG,CAAC,QAAQ,CAAA,UAAU,GAAG,CAAC,KAAK,CAAC,IAAI,CAAC,EAAE,CAAC;IAEtD,CAAC,CAAC,SAAS,CAAC,KAAK,EAAE;QACjB,GAAG,EAAE,yBAAyB;QAC9B,IAAI,EAAE,aAAa;QACnB,MAAM,EAAE,CAAC,MAAM,CAAC;KACjB,CAAC,CAAC;AACL,CAAC,CAAC,CAAC;AAEH,IAAI,CAAC,4BAA4B,EAAE,CAAC,CAAC,EAAE,EAAE;IACvC,MAAM,KAAK,GAAG,GAAG,CAAC,QAAQ,CAAA,UAAU,GAAG,CAAC,KAAK,CAAC,gBAAgB,CAAC,EAAE,CAAC;IAElE,CAAC,CAAC,SAAS,CAAC,KAAK,EAAE;QACjB,GAAG,EAAE,yBAAyB;QAC9B,IAAI,EAAE,aAAa;QACnB,MAAM,EAAE,CAAC,kBAAkB,CAAC;KAC7B,CAAC,CAAC;AACL,CAAC,CAAC,CAAC;AAEH,IAAI,CAAC,6BAA6B,EAAE,CAAC,CAAC,EAAE,EAAE;IACxC,MAAM,KAAK,GAAG,GAAG,CAAC,QAAQ,CAAA,UAAU,GAAG,CAAC,KAAK,CAAC,KAAK,CAAC,EAAE,CAAC;IAEvD,CAAC,CAAC,SAAS,CAAC,KAAK,EAAE;QACjB,GAAG,EAAE,yBAAyB;QAC9B,IAAI,EAAE,aAAa;QACnB,MAAM,EAAE,CAAC,MAAM,CAAC;KACjB,CAAC,CAAC;AACL,CAAC,CAAC,CAAC;AAEH,IAAI,CAAC,6BAA6B,EAAE,CAAC,CAAC,EAAE,EAAE;IACxC,MAAM,KAAK,GAAG,GAAG,CAAC,QAAQ,CAAA,UAAU,GAAG,CAAC,KAAK,CAAC,IAAI,CAAC,EAAE,CAAC;IAEtD,CAAC,CAAC,SAAS,CAAC,KAAK,EAAE;QACjB,GAAG,EAAE,yBAAyB;QAC9B,IAAI,EAAE,aAAa;QACnB,MAAM,EAAE,CAAC,MAAM,CAAC;KACjB,CAAC,CAAC;AACL,CAAC,CAAC,CAAC;AAEH,IAAI,CAAC,gCAAgC,EAAE,CAAC,CAAC,EAAE,EAAE;IAC3C,MAAM,KAAK,GAAG,CAAC,CAAC,MAAM,CAAC,GAAG,EAAE;QAC1B,GAAG,CAAC,QAAQ,CAAA,UAAU,GAAG,CAAC,KAAK,CAAC,SAAS,CAAC,EAAE,CAAC;IAC/C,CAAC,CAAC,CAAC;IAEH,CAAC,CAAC,EAAE,CAAC,KAAK,EAAE,OAAO,EAAE,qCAAqC,CAAC,CAAC;AAC9D,CAAC,CAAC,CAAC;AAEH,IAAI,CAAC,gEAAgE,EAAE,CAAC,CAAC,EAAE,EAAE;IAC3E,MAAM,KAAK,GAAG,CAAC,CAAC,MAAM,CAAC,GAAG,EAAE;QAC1B,iCAAiC;QACjC,GAAG,CAAC,QAAQ,CAAA,UAAU,GAAG,CAAC,KAAK,CAAC,GAAG,EAAE,GAAE,CAAC,CAAC,EAAE,CAAC;IAC9C,CAAC,CAAC,CAAC;IAEH,CAAC,CAAC,EAAE,CACF,KAAK,EAAE,OAAO,EACd,2DAA2D,CAC5D,CAAC;AACJ,CAAC,CAAC,CAAC;AAEH,IAAI,CAAC,mDAAmD,EAAE,CAAC,CAAC,EAAE,EAAE;IAE9D,MAAM,SAAS,GAA6B;QAC1C,GAAG,EAAE,KAAK;KACX,CAAC;IAEF,MAAM,KAAK,GAAG,GAAG,CAAC,QAAQ,CAAA,UAAU,GAAG,CAAC,KAAK,CAAC,SAAS,CAAC,EAAE,CAAC;IAE3D,CAAC,CAAC,SAAS,CAAC,KAAK,EAAE;QACjB,GAAG,EAAE,yBAAyB;QAC9B,IAAI,EAAE,aAAa;QACnB,MAAM,EAAE,CAAC,eAAe,CAAC;KAC1B,CAAC,CAAC;AACL,CAAC,CAAC,CAAC"}
|
|
@@ -1,17 +1,12 @@
|
|
|
1
|
-
|
|
2
|
-
|
|
3
|
-
|
|
4
|
-
|
|
5
|
-
|
|
6
|
-
const tokens_1 = require("../../tokens");
|
|
7
|
-
const createSqlTag_1 = require("../createSqlTag");
|
|
8
|
-
const ava_1 = __importDefault(require("ava"));
|
|
9
|
-
const sql = (0, createSqlTag_1.createSqlTag)();
|
|
10
|
-
(0, ava_1.default)('creates an object describing a query with an inlined literal value', (t) => {
|
|
1
|
+
import { FragmentToken } from '../../tokens.js';
|
|
2
|
+
import { createSqlTag } from '../createSqlTag.js';
|
|
3
|
+
import test from 'ava';
|
|
4
|
+
const sql = createSqlTag();
|
|
5
|
+
test('creates an object describing a query with an inlined literal value', (t) => {
|
|
11
6
|
const query = sql.fragment `CREATE USER foo WITH PASSWORD ${sql.literalValue('bar')}`;
|
|
12
7
|
t.deepEqual(query, {
|
|
13
8
|
sql: "CREATE USER foo WITH PASSWORD 'bar'",
|
|
14
|
-
type:
|
|
9
|
+
type: FragmentToken,
|
|
15
10
|
values: [],
|
|
16
11
|
});
|
|
17
12
|
});
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"literalValue.test.js","sourceRoot":"","sources":["../../../src/factories/createSqlTag.test/literalValue.test.ts"],"names":[],"mappings":"
|
|
1
|
+
{"version":3,"file":"literalValue.test.js","sourceRoot":"","sources":["../../../src/factories/createSqlTag.test/literalValue.test.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,aAAa,EAAE,MAAM,iBAAiB,CAAC;AAChD,OAAO,EAAE,YAAY,EAAE,MAAM,oBAAoB,CAAC;AAClD,OAAO,IAAI,MAAM,KAAK,CAAC;AAEvB,MAAM,GAAG,GAAG,YAAY,EAAE,CAAC;AAE3B,IAAI,CAAC,oEAAoE,EAAE,CAAC,CAAC,EAAE,EAAE;IAC/E,MAAM,KAAK,GAAG,GAAG,CAAC,QAAQ,CAAA,iCAAiC,GAAG,CAAC,YAAY,CACzE,KAAK,CACN,EAAE,CAAC;IAEJ,CAAC,CAAC,SAAS,CAAC,KAAK,EAAE;QACjB,GAAG,EAAE,qCAAqC;QAC1C,IAAI,EAAE,aAAa;QACnB,MAAM,EAAE,EAAE;KACX,CAAC,CAAC;AACL,CAAC,CAAC,CAAC"}
|
|
@@ -1,18 +1,13 @@
|
|
|
1
|
-
|
|
2
|
-
|
|
3
|
-
|
|
4
|
-
|
|
5
|
-
|
|
6
|
-
const
|
|
7
|
-
const
|
|
8
|
-
const errors_1 = require("@slonik/errors");
|
|
9
|
-
const ava_1 = __importDefault(require("ava"));
|
|
10
|
-
const roarr_1 = require("roarr");
|
|
11
|
-
const test = ava_1.default;
|
|
12
|
-
const sql = (0, createSqlTag_1.createSqlTag)();
|
|
1
|
+
import { FragmentToken } from '../../tokens.js';
|
|
2
|
+
import { createSqlTag } from '../createSqlTag.js';
|
|
3
|
+
import { InvalidInputError } from '@slonik/errors';
|
|
4
|
+
import anyTest from 'ava';
|
|
5
|
+
import { ROARR } from 'roarr';
|
|
6
|
+
const test = anyTest;
|
|
7
|
+
const sql = createSqlTag();
|
|
13
8
|
test.beforeEach((t) => {
|
|
14
9
|
t.context.logs = [];
|
|
15
|
-
|
|
10
|
+
ROARR.write = (message) => {
|
|
16
11
|
t.context.logs.push(JSON.parse(message));
|
|
17
12
|
};
|
|
18
13
|
});
|
|
@@ -21,13 +16,13 @@ test('throws error if called as a function', (t) => {
|
|
|
21
16
|
// @ts-expect-error - intentional
|
|
22
17
|
sql.fragment([`SELECT 1`]);
|
|
23
18
|
});
|
|
24
|
-
t.true(error instanceof
|
|
19
|
+
t.true(error instanceof InvalidInputError);
|
|
25
20
|
});
|
|
26
21
|
test('creates an object describing a query', (t) => {
|
|
27
22
|
const query = sql.fragment `SELECT 1`;
|
|
28
23
|
t.deepEqual(query, {
|
|
29
24
|
sql: 'SELECT 1',
|
|
30
|
-
type:
|
|
25
|
+
type: FragmentToken,
|
|
31
26
|
values: [],
|
|
32
27
|
});
|
|
33
28
|
});
|
|
@@ -35,7 +30,7 @@ test('creates an object describing query value bindings', (t) => {
|
|
|
35
30
|
const query = sql.fragment `SELECT ${'foo'}`;
|
|
36
31
|
t.deepEqual(query, {
|
|
37
32
|
sql: 'SELECT $slonik_1',
|
|
38
|
-
type:
|
|
33
|
+
type: FragmentToken,
|
|
39
34
|
values: ['foo'],
|
|
40
35
|
});
|
|
41
36
|
});
|
|
@@ -43,7 +38,7 @@ test('creates an object describing query value bindings (multiple)', (t) => {
|
|
|
43
38
|
const query = sql.fragment `SELECT ${'foo'}, ${'bar'}`;
|
|
44
39
|
t.deepEqual(query, {
|
|
45
40
|
sql: 'SELECT $slonik_1, $slonik_2',
|
|
46
|
-
type:
|
|
41
|
+
type: FragmentToken,
|
|
47
42
|
values: ['foo', 'bar'],
|
|
48
43
|
});
|
|
49
44
|
});
|
|
@@ -52,7 +47,7 @@ test('nests sql templates', (t) => {
|
|
|
52
47
|
const query1 = sql.fragment `SELECT ${'baz'} FROM (${query0})`;
|
|
53
48
|
t.deepEqual(query1, {
|
|
54
49
|
sql: 'SELECT $slonik_1 FROM (SELECT $slonik_2 FROM bar)',
|
|
55
|
-
type:
|
|
50
|
+
type: FragmentToken,
|
|
56
51
|
values: ['baz', 'foo'],
|
|
57
52
|
});
|
|
58
53
|
});
|
|
@@ -94,7 +89,7 @@ test('copes with dollar-number in table name', (t) => {
|
|
|
94
89
|
const query1 = sql.fragment `CREATE TABLE ${query0}`;
|
|
95
90
|
t.deepEqual(query1, {
|
|
96
91
|
sql: 'CREATE TABLE discounted_to_$1 (offer_id INTEGER)',
|
|
97
|
-
type:
|
|
92
|
+
type: FragmentToken,
|
|
98
93
|
values: [],
|
|
99
94
|
});
|
|
100
95
|
});
|
|
@@ -106,7 +101,7 @@ test('copes with dollar-number in column name (CREATE TABLE)', (t) => {
|
|
|
106
101
|
const query1 = sql.fragment `CREATE TABLE ${query0}`;
|
|
107
102
|
t.deepEqual(query1, {
|
|
108
103
|
sql: 'CREATE TABLE offers (discounted_to_$1 BOOLEAN)',
|
|
109
|
-
type:
|
|
104
|
+
type: FragmentToken,
|
|
110
105
|
values: [],
|
|
111
106
|
});
|
|
112
107
|
});
|
|
@@ -118,7 +113,7 @@ test('copes with dollar-number in column name (SELECT)', (t) => {
|
|
|
118
113
|
const query1 = sql.fragment `SELECT * FROM offers WHERE ${query0}`;
|
|
119
114
|
t.deepEqual(query1, {
|
|
120
115
|
sql: 'SELECT * FROM offers WHERE "discounted_to_$1" IS TRUE',
|
|
121
|
-
type:
|
|
116
|
+
type: FragmentToken,
|
|
122
117
|
values: [],
|
|
123
118
|
});
|
|
124
119
|
});
|
|
@@ -139,7 +134,7 @@ test('copes with dollar-number in function definitions', (t) => {
|
|
|
139
134
|
LANGUAGE SQL
|
|
140
135
|
IMMUTABLE
|
|
141
136
|
RETURNS NULL ON NULL INPUT`,
|
|
142
|
-
type:
|
|
137
|
+
type: FragmentToken,
|
|
143
138
|
values: [],
|
|
144
139
|
});
|
|
145
140
|
});
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"sql.test.js","sourceRoot":"","sources":["../../../src/factories/createSqlTag.test/sql.test.ts"],"names":[],"mappings":"
|
|
1
|
+
{"version":3,"file":"sql.test.js","sourceRoot":"","sources":["../../../src/factories/createSqlTag.test/sql.test.ts"],"names":[],"mappings":"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"}
|
|
@@ -1,21 +1,16 @@
|
|
|
1
|
-
|
|
2
|
-
|
|
3
|
-
|
|
4
|
-
|
|
5
|
-
|
|
6
|
-
const tokens_1 = require("../../tokens");
|
|
7
|
-
const createSqlTag_1 = require("../createSqlTag");
|
|
8
|
-
const ava_1 = __importDefault(require("ava"));
|
|
9
|
-
const sql = (0, createSqlTag_1.createSqlTag)();
|
|
10
|
-
(0, ava_1.default)('binds a timestamp', (t) => {
|
|
1
|
+
import { FragmentToken } from '../../tokens.js';
|
|
2
|
+
import { createSqlTag } from '../createSqlTag.js';
|
|
3
|
+
import test from 'ava';
|
|
4
|
+
const sql = createSqlTag();
|
|
5
|
+
test('binds a timestamp', (t) => {
|
|
11
6
|
const query = sql.fragment `SELECT ${sql.timestamp(new Date('2022-08-19T03:27:24.951Z'))}`;
|
|
12
7
|
t.deepEqual(query, {
|
|
13
8
|
sql: 'SELECT to_timestamp($slonik_1)',
|
|
14
|
-
type:
|
|
9
|
+
type: FragmentToken,
|
|
15
10
|
values: ['1660879644.951'],
|
|
16
11
|
});
|
|
17
12
|
});
|
|
18
|
-
(
|
|
13
|
+
test('throws if not instance of Date', (t) => {
|
|
19
14
|
const error = t.throws(() => {
|
|
20
15
|
// @ts-expect-error - intentional
|
|
21
16
|
sql.fragment `SELECT ${sql.timestamp(1)}`;
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"timestamp.test.js","sourceRoot":"","sources":["../../../src/factories/createSqlTag.test/timestamp.test.ts"],"names":[],"mappings":"
|
|
1
|
+
{"version":3,"file":"timestamp.test.js","sourceRoot":"","sources":["../../../src/factories/createSqlTag.test/timestamp.test.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,aAAa,EAAE,MAAM,iBAAiB,CAAC;AAChD,OAAO,EAAE,YAAY,EAAE,MAAM,oBAAoB,CAAC;AAClD,OAAO,IAAI,MAAM,KAAK,CAAC;AAEvB,MAAM,GAAG,GAAG,YAAY,EAAE,CAAC;AAE3B,IAAI,CAAC,mBAAmB,EAAE,CAAC,CAAC,EAAE,EAAE;IAC9B,MAAM,KAAK,GAAG,GAAG,CAAC,QAAQ,CAAA,UAAU,GAAG,CAAC,SAAS,CAC/C,IAAI,IAAI,CAAC,0BAA0B,CAAC,CACrC,EAAE,CAAC;IAEJ,CAAC,CAAC,SAAS,CAAC,KAAK,EAAE;QACjB,GAAG,EAAE,gCAAgC;QACrC,IAAI,EAAE,aAAa;QACnB,MAAM,EAAE,CAAC,gBAAgB,CAAC;KAC3B,CAAC,CAAC;AACL,CAAC,CAAC,CAAC;AAEH,IAAI,CAAC,gCAAgC,EAAE,CAAC,CAAC,EAAE,EAAE;IAC3C,MAAM,KAAK,GAAG,CAAC,CAAC,MAAM,CAAC,GAAG,EAAE;QAC1B,iCAAiC;QACjC,GAAG,CAAC,QAAQ,CAAA,UAAU,GAAG,CAAC,SAAS,CAAC,CAAC,CAAC,EAAE,CAAC;IAC3C,CAAC,CAAC,CAAC;IAEH,CAAC,CAAC,EAAE,CACF,KAAK,EAAE,OAAO,EACd,wDAAwD,CACzD,CAAC;AACJ,CAAC,CAAC,CAAC"}
|
|
@@ -1,15 +1,10 @@
|
|
|
1
|
-
|
|
2
|
-
|
|
3
|
-
|
|
4
|
-
|
|
5
|
-
|
|
6
|
-
const
|
|
7
|
-
|
|
8
|
-
const zod_1 = require("zod");
|
|
9
|
-
const sql = (0, createSqlTag_1.createSqlTag)();
|
|
10
|
-
(0, ava_1.default)('describes zod object associated with the query', (t) => {
|
|
11
|
-
const zodObject = zod_1.z.object({
|
|
12
|
-
id: zod_1.z.number(),
|
|
1
|
+
import { createSqlTag } from '../createSqlTag.js';
|
|
2
|
+
import test from 'ava';
|
|
3
|
+
import { z } from 'zod';
|
|
4
|
+
const sql = createSqlTag();
|
|
5
|
+
test('describes zod object associated with the query', (t) => {
|
|
6
|
+
const zodObject = z.object({
|
|
7
|
+
id: z.number(),
|
|
13
8
|
});
|
|
14
9
|
const query = sql.type(zodObject) `
|
|
15
10
|
SELECT 1 id
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"type.test.js","sourceRoot":"","sources":["../../../src/factories/createSqlTag.test/type.test.ts"],"names":[],"mappings":"
|
|
1
|
+
{"version":3,"file":"type.test.js","sourceRoot":"","sources":["../../../src/factories/createSqlTag.test/type.test.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,YAAY,EAAE,MAAM,oBAAoB,CAAC;AAClD,OAAO,IAAI,MAAM,KAAK,CAAC;AACvB,OAAO,EAAE,CAAC,EAAE,MAAM,KAAK,CAAC;AAExB,MAAM,GAAG,GAAG,YAAY,EAAE,CAAC;AAE3B,IAAI,CAAC,gDAAgD,EAAE,CAAC,CAAC,EAAE,EAAE;IAC3D,MAAM,SAAS,GAAG,CAAC,CAAC,MAAM,CAAC;QACzB,EAAE,EAAE,CAAC,CAAC,MAAM,EAAE;KACf,CAAC,CAAC;IAEH,MAAM,KAAK,GAAG,GAAG,CAAC,IAAI,CAAC,SAAS,CAAC,CAAA;;GAEhC,CAAC;IAEF,CAAC,CAAC,EAAE,CAAC,KAAK,CAAC,MAAM,EAAE,SAAS,CAAC,CAAC;AAChC,CAAC,CAAC,CAAC"}
|