@livestore/livestore 0.0.0-snapshot-29dc6acb4ddfcb70ac29c4ae18419710d194e555 → 0.0.0-snapshot-669b49b56c8abe87f4e11263af7cbf506deab38e

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.
Files changed (81) hide show
  1. package/dist/.tsbuildinfo +1 -1
  2. package/dist/global-state.d.ts +1 -1
  3. package/dist/global-state.d.ts.map +1 -1
  4. package/dist/global-state.js +1 -1
  5. package/dist/global-state.js.map +1 -1
  6. package/dist/index.d.ts +6 -6
  7. package/dist/index.d.ts.map +1 -1
  8. package/dist/index.js +5 -5
  9. package/dist/index.js.map +1 -1
  10. package/dist/{live-queries → reactiveQueries}/base-class.d.ts +4 -8
  11. package/dist/reactiveQueries/base-class.d.ts.map +1 -0
  12. package/dist/{live-queries → reactiveQueries}/base-class.js +0 -2
  13. package/dist/reactiveQueries/base-class.js.map +1 -0
  14. package/dist/{live-queries → reactiveQueries}/computed.d.ts +13 -4
  15. package/dist/reactiveQueries/computed.d.ts.map +1 -0
  16. package/dist/{live-queries → reactiveQueries}/computed.js +23 -4
  17. package/dist/reactiveQueries/computed.js.map +1 -0
  18. package/dist/{live-queries → reactiveQueries}/graphql.d.ts +8 -4
  19. package/dist/reactiveQueries/graphql.d.ts.map +1 -0
  20. package/dist/{live-queries → reactiveQueries}/graphql.js +16 -2
  21. package/dist/reactiveQueries/graphql.js.map +1 -0
  22. package/dist/reactiveQueries/sql.d.ts +49 -0
  23. package/dist/reactiveQueries/sql.d.ts.map +1 -0
  24. package/dist/reactiveQueries/sql.js +130 -0
  25. package/dist/reactiveQueries/sql.js.map +1 -0
  26. package/dist/reactiveQueries/sql.test.d.ts +2 -0
  27. package/dist/reactiveQueries/sql.test.d.ts.map +1 -0
  28. package/dist/reactiveQueries/sql.test.js +284 -0
  29. package/dist/reactiveQueries/sql.test.js.map +1 -0
  30. package/dist/row-query.d.ts +33 -0
  31. package/dist/row-query.d.ts.map +1 -0
  32. package/dist/row-query.js +80 -0
  33. package/dist/row-query.js.map +1 -0
  34. package/dist/store/create-store.d.ts +1 -1
  35. package/dist/store/create-store.d.ts.map +1 -1
  36. package/dist/store/devtools.d.ts +1 -1
  37. package/dist/store/devtools.d.ts.map +1 -1
  38. package/dist/store/devtools.js.map +1 -1
  39. package/dist/store/store-types.d.ts +2 -2
  40. package/dist/store/store-types.d.ts.map +1 -1
  41. package/dist/store/store.d.ts +3 -8
  42. package/dist/store/store.d.ts.map +1 -1
  43. package/dist/store/store.js +4 -32
  44. package/dist/store/store.js.map +1 -1
  45. package/dist/utils/tests/fixture.d.ts +132 -168
  46. package/dist/utils/tests/fixture.d.ts.map +1 -1
  47. package/package.json +5 -5
  48. package/src/global-state.ts +1 -1
  49. package/src/index.ts +5 -8
  50. package/src/{live-queries → reactiveQueries}/base-class.ts +5 -10
  51. package/src/{live-queries → reactiveQueries}/computed.ts +29 -5
  52. package/src/{live-queries → reactiveQueries}/graphql.ts +21 -6
  53. package/src/reactiveQueries/sql.test.ts +308 -0
  54. package/src/reactiveQueries/sql.ts +226 -0
  55. package/src/row-query.ts +196 -0
  56. package/src/store/create-store.ts +1 -1
  57. package/src/store/devtools.ts +1 -1
  58. package/src/store/store-types.ts +2 -2
  59. package/src/store/store.ts +7 -44
  60. package/dist/live-queries/base-class.d.ts.map +0 -1
  61. package/dist/live-queries/base-class.js.map +0 -1
  62. package/dist/live-queries/computed.d.ts.map +0 -1
  63. package/dist/live-queries/computed.js.map +0 -1
  64. package/dist/live-queries/db.d.ts +0 -66
  65. package/dist/live-queries/db.d.ts.map +0 -1
  66. package/dist/live-queries/db.js +0 -199
  67. package/dist/live-queries/db.js.map +0 -1
  68. package/dist/live-queries/db.test.d.ts +0 -2
  69. package/dist/live-queries/db.test.d.ts.map +0 -1
  70. package/dist/live-queries/db.test.js +0 -117
  71. package/dist/live-queries/db.test.js.map +0 -1
  72. package/dist/live-queries/graphql.d.ts.map +0 -1
  73. package/dist/live-queries/graphql.js.map +0 -1
  74. package/dist/row-query-utils.d.ts +0 -17
  75. package/dist/row-query-utils.d.ts.map +0 -1
  76. package/dist/row-query-utils.js +0 -30
  77. package/dist/row-query-utils.js.map +0 -1
  78. package/src/live-queries/__snapshots__/db.test.ts.snap +0 -301
  79. package/src/live-queries/db.test.ts +0 -153
  80. package/src/live-queries/db.ts +0 -350
  81. package/src/row-query-utils.ts +0 -65
@@ -1,117 +0,0 @@
1
- import { Effect, Schema } from '@livestore/utils/effect';
2
- import * as otel from '@opentelemetry/api';
3
- import { BasicTracerProvider, InMemorySpanExporter, SimpleSpanProcessor } from '@opentelemetry/sdk-trace-base';
4
- import { describe, expect, it } from 'vitest';
5
- import { computed, queryDb, rawSqlMutation, sql } from '../index.js';
6
- import { makeTodoMvc, tables } from '../utils/tests/fixture.js';
7
- import { getSimplifiedRootSpan } from '../utils/tests/otel.js';
8
- /*
9
- TODO write tests for:
10
-
11
- - sql queries without and with `map` (incl. callback and schemas)
12
- - optional and explicit `queriedTables` argument
13
- */
14
- describe('otel', () => {
15
- let cachedProvider;
16
- const makeQuery = Effect.gen(function* () {
17
- const exporter = new InMemorySpanExporter();
18
- const provider = cachedProvider ?? new BasicTracerProvider();
19
- cachedProvider = provider;
20
- provider.addSpanProcessor(new SimpleSpanProcessor(exporter));
21
- provider.register();
22
- const otelTracer = otel.trace.getTracer('test');
23
- const span = otelTracer.startSpan('test');
24
- const otelContext = otel.trace.setSpan(otel.context.active(), span);
25
- const { store } = yield* makeTodoMvc({ otelTracer, otelContext });
26
- return {
27
- store,
28
- otelTracer,
29
- exporter,
30
- span,
31
- provider,
32
- };
33
- });
34
- it('otel', async () => {
35
- const { exporter } = await Effect.gen(function* () {
36
- const { store, exporter, span } = yield* makeQuery;
37
- const query$ = queryDb({
38
- query: `select * from todos`,
39
- schema: Schema.Array(tables.todos.schema),
40
- queriedTables: new Set(['todos']),
41
- });
42
- expect(query$.run()).toMatchInlineSnapshot('[]');
43
- store.mutate(rawSqlMutation({ sql: sql `INSERT INTO todos (id, text, completed) VALUES ('t1', 'buy milk', 0)` }));
44
- expect(query$.run()).toMatchInlineSnapshot(`
45
- [
46
- {
47
- "completed": false,
48
- "id": "t1",
49
- "text": "buy milk",
50
- },
51
- ]
52
- `);
53
- query$.destroy();
54
- span.end();
55
- return { exporter };
56
- }).pipe(Effect.scoped, Effect.tapCauseLogPretty, Effect.runPromise);
57
- expect(getSimplifiedRootSpan(exporter)).toMatchSnapshot();
58
- });
59
- it('with thunks', async () => {
60
- const { exporter } = await Effect.gen(function* () {
61
- const { store, exporter, span } = yield* makeQuery;
62
- const defaultTodo = { id: '', text: '', completed: false };
63
- const filter = computed(() => `where completed = 0`, { label: 'where-filter' });
64
- const query$ = queryDb((get) => ({
65
- query: `select * from todos ${get(filter)}`,
66
- schema: Schema.Array(tables.todos.schema).pipe(Schema.headOrElse(() => defaultTodo)),
67
- }), { label: 'all todos' });
68
- expect(query$.run()).toMatchInlineSnapshot(`
69
- {
70
- "completed": false,
71
- "id": "",
72
- "text": "",
73
- }
74
- `);
75
- store.mutate(rawSqlMutation({ sql: sql `INSERT INTO todos (id, text, completed) VALUES ('t1', 'buy milk', 0)` }));
76
- expect(query$.run()).toMatchInlineSnapshot(`
77
- {
78
- "completed": false,
79
- "id": "t1",
80
- "text": "buy milk",
81
- }
82
- `);
83
- query$.destroy();
84
- span.end();
85
- return { exporter };
86
- }).pipe(Effect.scoped, Effect.tapCauseLogPretty, Effect.runPromise);
87
- expect(getSimplifiedRootSpan(exporter)).toMatchSnapshot();
88
- });
89
- it('with thunks with query builder and without labels', async () => {
90
- const { exporter } = await Effect.gen(function* () {
91
- const { store, exporter, span } = yield* makeQuery;
92
- const defaultTodo = { id: '', text: '', completed: false };
93
- const filter = computed(() => ({ completed: false }));
94
- const query$ = queryDb((get) => tables.todos.query.where(get(filter)).first({ fallback: () => defaultTodo }));
95
- expect(query$.run()).toMatchInlineSnapshot(`
96
- {
97
- "completed": false,
98
- "id": "",
99
- "text": "",
100
- }
101
- `);
102
- store.mutate(rawSqlMutation({ sql: sql `INSERT INTO todos (id, text, completed) VALUES ('t1', 'buy milk', 0)` }));
103
- expect(query$.run()).toMatchInlineSnapshot(`
104
- {
105
- "completed": false,
106
- "id": "t1",
107
- "text": "buy milk",
108
- }
109
- `);
110
- query$.destroy();
111
- span.end();
112
- return { exporter };
113
- }).pipe(Effect.scoped, Effect.tapCauseLogPretty, Effect.runPromise);
114
- expect(getSimplifiedRootSpan(exporter)).toMatchSnapshot();
115
- });
116
- });
117
- //# sourceMappingURL=db.test.js.map
@@ -1 +0,0 @@
1
- {"version":3,"file":"db.test.js","sourceRoot":"","sources":["../../src/live-queries/db.test.ts"],"names":[],"mappings":"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"}
@@ -1 +0,0 @@
1
- {"version":3,"file":"graphql.d.ts","sourceRoot":"","sources":["../../src/live-queries/graphql.ts"],"names":[],"mappings":"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"}
@@ -1 +0,0 @@
1
- {"version":3,"file":"graphql.js","sourceRoot":"","sources":["../../src/live-queries/graphql.ts"],"names":[],"mappings":"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"}
@@ -1,17 +0,0 @@
1
- import type { QueryInfo } from '@livestore/common';
2
- import { SessionIdSymbol } from '@livestore/common';
3
- import { DbSchema } from '@livestore/common/schema';
4
- import type * as otel from '@opentelemetry/api';
5
- import type { LiveQuery, QueryContext } from './live-queries/base-class.js';
6
- export declare const rowQueryLabel: (table: DbSchema.TableDefBase, id: string | SessionIdSymbol | undefined) => string;
7
- export declare const deriveColQuery: {
8
- <TQuery extends LiveQuery<any, QueryInfo.None>, TCol extends keyof TQuery['__result!'] & string>(query$: TQuery, colName: TCol): LiveQuery<TQuery['__result!'][TCol], QueryInfo.None>;
9
- <TQuery extends LiveQuery<any, QueryInfo.Row>, TCol extends keyof TQuery['__result!'] & string>(query$: TQuery, colName: TCol): LiveQuery<TQuery['__result!'][TCol], QueryInfo.Col>;
10
- };
11
- export declare const makeExecBeforeFirstRun: ({ id, insertValues, table, otelContext: otelContext_, }: {
12
- id?: string | SessionIdSymbol;
13
- insertValues?: any;
14
- table: DbSchema.TableDefBase;
15
- otelContext: otel.Context | undefined;
16
- }) => ({ store }: QueryContext) => undefined;
17
- //# sourceMappingURL=row-query-utils.d.ts.map
@@ -1 +0,0 @@
1
- {"version":3,"file":"row-query-utils.d.ts","sourceRoot":"","sources":["../src/row-query-utils.ts"],"names":[],"mappings":"AAAA,OAAO,KAAK,EAAsB,SAAS,EAAE,MAAM,mBAAmB,CAAA;AACtE,OAAO,EAAE,eAAe,EAAE,MAAM,mBAAmB,CAAA;AACnD,OAAO,EAAE,QAAQ,EAAE,MAAM,0BAA0B,CAAA;AAEnD,OAAO,KAAK,KAAK,IAAI,MAAM,oBAAoB,CAAA;AAE/C,OAAO,KAAK,EAAE,SAAS,EAAgB,YAAY,EAAE,MAAM,8BAA8B,CAAA;AAGzF,eAAO,MAAM,aAAa,UAAW,QAAQ,CAAC,YAAY,MAAM,MAAM,GAAG,eAAe,GAAG,SAAS,WACM,CAAA;AAE1G,eAAO,MAAM,cAAc,EAAE;IAC3B,CAAC,MAAM,SAAS,SAAS,CAAC,GAAG,EAAE,SAAS,CAAC,IAAI,CAAC,EAAE,IAAI,SAAS,MAAM,MAAM,CAAC,WAAW,CAAC,GAAG,MAAM,EAC7F,MAAM,EAAE,MAAM,EACd,OAAO,EAAE,IAAI,GACZ,SAAS,CAAC,MAAM,CAAC,WAAW,CAAC,CAAC,IAAI,CAAC,EAAE,SAAS,CAAC,IAAI,CAAC,CAAA;IACvD,CAAC,MAAM,SAAS,SAAS,CAAC,GAAG,EAAE,SAAS,CAAC,GAAG,CAAC,EAAE,IAAI,SAAS,MAAM,MAAM,CAAC,WAAW,CAAC,GAAG,MAAM,EAC5F,MAAM,EAAE,MAAM,EACd,OAAO,EAAE,IAAI,GACZ,SAAS,CAAC,MAAM,CAAC,WAAW,CAAC,CAAC,IAAI,CAAC,EAAE,SAAS,CAAC,GAAG,CAAC,CAAA;CASvD,CAAA;AAED,eAAO,MAAM,sBAAsB,4DAM9B;IACD,EAAE,CAAC,EAAE,MAAM,GAAG,eAAe,CAAA;IAC7B,YAAY,CAAC,EAAE,GAAG,CAAA;IAClB,KAAK,EAAE,QAAQ,CAAC,YAAY,CAAA;IAC5B,WAAW,EAAE,IAAI,CAAC,OAAO,GAAG,SAAS,CAAA;CACtC,iBACW,YAAY,cAqBvB,CAAA"}
@@ -1,30 +0,0 @@
1
- import { SessionIdSymbol } from '@livestore/common';
2
- import { DbSchema } from '@livestore/common/schema';
3
- import { shouldNeverHappen } from '@livestore/utils';
4
- import { computed } from './live-queries/computed.js';
5
- export const rowQueryLabel = (table, id) => `row:${table.sqliteDef.name}${id === undefined ? '' : id === SessionIdSymbol ? `:sessionId` : `:${id}`}`;
6
- export const deriveColQuery = (query$, colName) => {
7
- return computed((get) => get(query$)[colName], {
8
- label: `deriveColQuery:${query$.label}:${colName}`,
9
- queryInfo: query$.queryInfo._tag === 'Row'
10
- ? { _tag: 'Col', table: query$.queryInfo.table, column: colName, id: query$.queryInfo.id }
11
- : undefined,
12
- });
13
- };
14
- export const makeExecBeforeFirstRun = ({ id, insertValues, table, otelContext: otelContext_, }) => ({ store }) => {
15
- const otelContext = otelContext_ ?? store.otel.queriesSpanContext;
16
- if (table.options.isSingleton === false) {
17
- const idStr = id === SessionIdSymbol ? store.sessionId : id;
18
- const rowExists = store.syncDbWrapper.select(`SELECT 1 FROM '${table.sqliteDef.name}' WHERE id = ?`, {
19
- bindValues: [idStr],
20
- }).length === 1;
21
- if (rowExists)
22
- return;
23
- if (DbSchema.tableHasDerivedMutations(table) === false) {
24
- return shouldNeverHappen(`Cannot insert row for table "${table.sqliteDef.name}" which does not have 'deriveMutations: true' set`);
25
- }
26
- // NOTE It's important that we only mutate and don't refresh here, as this function is called during a render
27
- store.mutateWithoutRefresh(table.insert({ id, ...insertValues }), { otelContext, coordinatorMode: 'default' });
28
- }
29
- };
30
- //# sourceMappingURL=row-query-utils.js.map
@@ -1 +0,0 @@
1
- {"version":3,"file":"row-query-utils.js","sourceRoot":"","sources":["../src/row-query-utils.ts"],"names":[],"mappings":"AACA,OAAO,EAAE,eAAe,EAAE,MAAM,mBAAmB,CAAA;AACnD,OAAO,EAAE,QAAQ,EAAE,MAAM,0BAA0B,CAAA;AACnD,OAAO,EAAE,iBAAiB,EAAE,MAAM,kBAAkB,CAAA;AAIpD,OAAO,EAAE,QAAQ,EAAE,MAAM,4BAA4B,CAAA;AAErD,MAAM,CAAC,MAAM,aAAa,GAAG,CAAC,KAA4B,EAAE,EAAwC,EAAE,EAAE,CACtG,OAAO,KAAK,CAAC,SAAS,CAAC,IAAI,GAAG,EAAE,KAAK,SAAS,CAAC,CAAC,CAAC,EAAE,CAAC,CAAC,CAAC,EAAE,KAAK,eAAe,CAAC,CAAC,CAAC,YAAY,CAAC,CAAC,CAAC,IAAI,EAAE,EAAE,EAAE,CAAA;AAE1G,MAAM,CAAC,MAAM,cAAc,GASvB,CAAC,MAAoB,EAAE,OAAe,EAAE,EAAE;IAC5C,OAAO,QAAQ,CAAC,CAAC,GAAG,EAAE,EAAE,CAAC,GAAG,CAAC,MAAM,CAAC,CAAC,OAAO,CAAC,EAAE;QAC7C,KAAK,EAAE,kBAAkB,MAAM,CAAC,KAAK,IAAI,OAAO,EAAE;QAClD,SAAS,EACP,MAAM,CAAC,SAAS,CAAC,IAAI,KAAK,KAAK;YAC7B,CAAC,CAAC,EAAE,IAAI,EAAE,KAAK,EAAE,KAAK,EAAE,MAAM,CAAC,SAAS,CAAC,KAAK,EAAE,MAAM,EAAE,OAAO,EAAE,EAAE,EAAE,MAAM,CAAC,SAAS,CAAC,EAAE,EAAE;YAC1F,CAAC,CAAC,SAAS;KAChB,CAAQ,CAAA;AACX,CAAC,CAAA;AAED,MAAM,CAAC,MAAM,sBAAsB,GACjC,CAAC,EACC,EAAE,EACF,YAAY,EACZ,KAAK,EACL,WAAW,EAAE,YAAY,GAM1B,EAAE,EAAE,CACL,CAAC,EAAE,KAAK,EAAgB,EAAE,EAAE;IAC1B,MAAM,WAAW,GAAG,YAAY,IAAI,KAAK,CAAC,IAAI,CAAC,kBAAkB,CAAA;IAEjE,IAAI,KAAK,CAAC,OAAO,CAAC,WAAW,KAAK,KAAK,EAAE,CAAC;QACxC,MAAM,KAAK,GAAG,EAAE,KAAK,eAAe,CAAC,CAAC,CAAC,KAAK,CAAC,SAAS,CAAC,CAAC,CAAC,EAAG,CAAA;QAC5D,MAAM,SAAS,GACb,KAAK,CAAC,aAAa,CAAC,MAAM,CAAC,kBAAkB,KAAK,CAAC,SAAS,CAAC,IAAI,gBAAgB,EAAE;YACjF,UAAU,EAAE,CAAC,KAAK,CAA8B;SACjD,CAAC,CAAC,MAAM,KAAK,CAAC,CAAA;QAEjB,IAAI,SAAS;YAAE,OAAM;QAErB,IAAI,QAAQ,CAAC,wBAAwB,CAAC,KAAK,CAAC,KAAK,KAAK,EAAE,CAAC;YACvD,OAAO,iBAAiB,CACtB,gCAAgC,KAAK,CAAC,SAAS,CAAC,IAAI,mDAAmD,CACxG,CAAA;QACH,CAAC;QAED,6GAA6G;QAC7G,KAAK,CAAC,oBAAoB,CAAC,KAAK,CAAC,MAAM,CAAC,EAAE,EAAE,EAAE,GAAG,YAAY,EAAE,CAAC,EAAE,EAAE,WAAW,EAAE,eAAe,EAAE,SAAS,EAAE,CAAC,CAAA;IAChH,CAAC;AACH,CAAC,CAAA"}
@@ -1,301 +0,0 @@
1
- // Vitest Snapshot v1, https://vitest.dev/guide/snapshot.html
2
-
3
- exports[`otel > otel 3`] = `
4
- {
5
- "_name": "test",
6
- "children": [
7
- {
8
- "_name": "livestore.in-memory-db:execute",
9
- "attributes": {
10
- "sql.query": "
11
- PRAGMA page_size=32768;
12
- PRAGMA cache_size=10000;
13
- PRAGMA journal_mode='MEMORY'; -- we don't flush to disk before committing a write
14
- PRAGMA synchronous='OFF';
15
- PRAGMA temp_store='MEMORY';
16
- PRAGMA foreign_keys='ON'; -- we want foreign key constraints to be enforced
17
- ",
18
- },
19
- },
20
- {
21
- "_name": "LiveStore:mutations",
22
- "children": [
23
- {
24
- "_name": "LiveStore:mutate",
25
- "attributes": {
26
- "livestore.mutateLabel": "mutate",
27
- },
28
- "children": [
29
- {
30
- "_name": "LiveStore:processWrites",
31
- "attributes": {
32
- "livestore.mutateLabel": "mutate",
33
- },
34
- "children": [
35
- {
36
- "_name": "LiveStore:mutateWithoutRefresh",
37
- "attributes": {
38
- "livestore.args": "{
39
- "sql": "INSERT INTO todos (id, text, completed) VALUES ('t1', 'buy milk', 0)"
40
- }",
41
- "livestore.mutation": "livestore.RawSql",
42
- },
43
- "children": [
44
- {
45
- "_name": "livestore.in-memory-db:execute",
46
- "attributes": {
47
- "sql.query": "INSERT INTO todos (id, text, completed) VALUES ('t1', 'buy milk', 0)",
48
- },
49
- },
50
- ],
51
- },
52
- ],
53
- },
54
- ],
55
- },
56
- ],
57
- },
58
- {
59
- "_name": "LiveStore:queries",
60
- "children": [
61
- {
62
- "_name": "db:select * from todos",
63
- "attributes": {
64
- "sql.query": "select * from todos",
65
- "sql.rowsCount": 0,
66
- },
67
- "children": [
68
- {
69
- "_name": "sql-in-memory-select",
70
- "attributes": {
71
- "sql.cached": false,
72
- "sql.query": "select * from todos",
73
- "sql.rowsCount": 0,
74
- },
75
- },
76
- ],
77
- },
78
- {
79
- "_name": "db:select * from todos",
80
- "attributes": {
81
- "sql.query": "select * from todos",
82
- "sql.rowsCount": 1,
83
- },
84
- "children": [
85
- {
86
- "_name": "sql-in-memory-select",
87
- "attributes": {
88
- "sql.cached": false,
89
- "sql.query": "select * from todos",
90
- "sql.rowsCount": 1,
91
- },
92
- },
93
- ],
94
- },
95
- ],
96
- },
97
- ],
98
- }
99
- `;
100
-
101
- exports[`otel > with thunks 3`] = `
102
- {
103
- "_name": "test",
104
- "children": [
105
- {
106
- "_name": "livestore.in-memory-db:execute",
107
- "attributes": {
108
- "sql.query": "
109
- PRAGMA page_size=32768;
110
- PRAGMA cache_size=10000;
111
- PRAGMA journal_mode='MEMORY'; -- we don't flush to disk before committing a write
112
- PRAGMA synchronous='OFF';
113
- PRAGMA temp_store='MEMORY';
114
- PRAGMA foreign_keys='ON'; -- we want foreign key constraints to be enforced
115
- ",
116
- },
117
- },
118
- {
119
- "_name": "LiveStore:mutations",
120
- "children": [
121
- {
122
- "_name": "LiveStore:mutate",
123
- "attributes": {
124
- "livestore.mutateLabel": "mutate",
125
- },
126
- "children": [
127
- {
128
- "_name": "LiveStore:processWrites",
129
- "attributes": {
130
- "livestore.mutateLabel": "mutate",
131
- },
132
- "children": [
133
- {
134
- "_name": "LiveStore:mutateWithoutRefresh",
135
- "attributes": {
136
- "livestore.args": "{
137
- "sql": "INSERT INTO todos (id, text, completed) VALUES ('t1', 'buy milk', 0)"
138
- }",
139
- "livestore.mutation": "livestore.RawSql",
140
- },
141
- "children": [
142
- {
143
- "_name": "livestore.in-memory-db:execute",
144
- "attributes": {
145
- "sql.query": "INSERT INTO todos (id, text, completed) VALUES ('t1', 'buy milk', 0)",
146
- },
147
- },
148
- ],
149
- },
150
- ],
151
- },
152
- ],
153
- },
154
- ],
155
- },
156
- {
157
- "_name": "LiveStore:queries",
158
- "children": [
159
- {
160
- "_name": "db:select * from todos where completed = 0",
161
- "attributes": {
162
- "sql.query": "select * from todos where completed = 0",
163
- "sql.rowsCount": 0,
164
- },
165
- "children": [
166
- {
167
- "_name": "js:where-filter",
168
- },
169
- {
170
- "_name": "sql-in-memory-select",
171
- "attributes": {
172
- "sql.cached": false,
173
- "sql.query": "select * from todos where completed = 0",
174
- "sql.rowsCount": 0,
175
- },
176
- },
177
- ],
178
- },
179
- {
180
- "_name": "db:select * from todos where completed = 0",
181
- "attributes": {
182
- "sql.query": "select * from todos where completed = 0",
183
- "sql.rowsCount": 1,
184
- },
185
- "children": [
186
- {
187
- "_name": "sql-in-memory-select",
188
- "attributes": {
189
- "sql.cached": false,
190
- "sql.query": "select * from todos where completed = 0",
191
- "sql.rowsCount": 1,
192
- },
193
- },
194
- ],
195
- },
196
- ],
197
- },
198
- ],
199
- }
200
- `;
201
-
202
- exports[`otel > with thunks with query builder and without labels 3`] = `
203
- {
204
- "_name": "test",
205
- "children": [
206
- {
207
- "_name": "livestore.in-memory-db:execute",
208
- "attributes": {
209
- "sql.query": "
210
- PRAGMA page_size=32768;
211
- PRAGMA cache_size=10000;
212
- PRAGMA journal_mode='MEMORY'; -- we don't flush to disk before committing a write
213
- PRAGMA synchronous='OFF';
214
- PRAGMA temp_store='MEMORY';
215
- PRAGMA foreign_keys='ON'; -- we want foreign key constraints to be enforced
216
- ",
217
- },
218
- },
219
- {
220
- "_name": "LiveStore:mutations",
221
- "children": [
222
- {
223
- "_name": "LiveStore:mutate",
224
- "attributes": {
225
- "livestore.mutateLabel": "mutate",
226
- },
227
- "children": [
228
- {
229
- "_name": "LiveStore:processWrites",
230
- "attributes": {
231
- "livestore.mutateLabel": "mutate",
232
- },
233
- "children": [
234
- {
235
- "_name": "LiveStore:mutateWithoutRefresh",
236
- "attributes": {
237
- "livestore.args": "{
238
- "sql": "INSERT INTO todos (id, text, completed) VALUES ('t1', 'buy milk', 0)"
239
- }",
240
- "livestore.mutation": "livestore.RawSql",
241
- },
242
- "children": [
243
- {
244
- "_name": "livestore.in-memory-db:execute",
245
- "attributes": {
246
- "sql.query": "INSERT INTO todos (id, text, completed) VALUES ('t1', 'buy milk', 0)",
247
- },
248
- },
249
- ],
250
- },
251
- ],
252
- },
253
- ],
254
- },
255
- ],
256
- },
257
- {
258
- "_name": "LiveStore:queries",
259
- "children": [
260
- {
261
- "_name": "db:SELECT * FROM 'todos' WHERE completed = ? LIMIT ?",
262
- "attributes": {
263
- "sql.query": "SELECT * FROM 'todos' WHERE completed = ? LIMIT ?",
264
- "sql.rowsCount": 0,
265
- },
266
- "children": [
267
- {
268
- "_name": "js:() => ({ completed: false })",
269
- },
270
- {
271
- "_name": "sql-in-memory-select",
272
- "attributes": {
273
- "sql.cached": false,
274
- "sql.query": "SELECT * FROM 'todos' WHERE completed = ? LIMIT ?",
275
- "sql.rowsCount": 0,
276
- },
277
- },
278
- ],
279
- },
280
- {
281
- "_name": "db:SELECT * FROM 'todos' WHERE completed = ? LIMIT ?",
282
- "attributes": {
283
- "sql.query": "SELECT * FROM 'todos' WHERE completed = ? LIMIT ?",
284
- "sql.rowsCount": 1,
285
- },
286
- "children": [
287
- {
288
- "_name": "sql-in-memory-select",
289
- "attributes": {
290
- "sql.cached": false,
291
- "sql.query": "SELECT * FROM 'todos' WHERE completed = ? LIMIT ?",
292
- "sql.rowsCount": 1,
293
- },
294
- },
295
- ],
296
- },
297
- ],
298
- },
299
- ],
300
- }
301
- `;
@@ -1,153 +0,0 @@
1
- import { Effect, Schema } from '@livestore/utils/effect'
2
- import * as otel from '@opentelemetry/api'
3
- import { BasicTracerProvider, InMemorySpanExporter, SimpleSpanProcessor } from '@opentelemetry/sdk-trace-base'
4
- import { describe, expect, it } from 'vitest'
5
-
6
- import { computed, queryDb, rawSqlMutation, sql } from '../index.js'
7
- import { makeTodoMvc, tables } from '../utils/tests/fixture.js'
8
- import { getSimplifiedRootSpan } from '../utils/tests/otel.js'
9
-
10
- /*
11
- TODO write tests for:
12
-
13
- - sql queries without and with `map` (incl. callback and schemas)
14
- - optional and explicit `queriedTables` argument
15
- */
16
-
17
- describe('otel', () => {
18
- let cachedProvider: BasicTracerProvider | undefined
19
-
20
- const makeQuery = Effect.gen(function* () {
21
- const exporter = new InMemorySpanExporter()
22
-
23
- const provider = cachedProvider ?? new BasicTracerProvider()
24
- cachedProvider = provider
25
- provider.addSpanProcessor(new SimpleSpanProcessor(exporter))
26
- provider.register()
27
-
28
- const otelTracer = otel.trace.getTracer('test')
29
-
30
- const span = otelTracer.startSpan('test')
31
- const otelContext = otel.trace.setSpan(otel.context.active(), span)
32
-
33
- const { store } = yield* makeTodoMvc({ otelTracer, otelContext })
34
-
35
- return {
36
- store,
37
- otelTracer,
38
- exporter,
39
- span,
40
- provider,
41
- }
42
- })
43
-
44
- it('otel', async () => {
45
- const { exporter } = await Effect.gen(function* () {
46
- const { store, exporter, span } = yield* makeQuery
47
-
48
- const query$ = queryDb({
49
- query: `select * from todos`,
50
- schema: Schema.Array(tables.todos.schema),
51
- queriedTables: new Set(['todos']),
52
- })
53
- expect(query$.run()).toMatchInlineSnapshot('[]')
54
-
55
- store.mutate(rawSqlMutation({ sql: sql`INSERT INTO todos (id, text, completed) VALUES ('t1', 'buy milk', 0)` }))
56
-
57
- expect(query$.run()).toMatchInlineSnapshot(`
58
- [
59
- {
60
- "completed": false,
61
- "id": "t1",
62
- "text": "buy milk",
63
- },
64
- ]
65
- `)
66
-
67
- query$.destroy()
68
- span.end()
69
-
70
- return { exporter }
71
- }).pipe(Effect.scoped, Effect.tapCauseLogPretty, Effect.runPromise)
72
-
73
- expect(getSimplifiedRootSpan(exporter)).toMatchSnapshot()
74
- })
75
-
76
- it('with thunks', async () => {
77
- const { exporter } = await Effect.gen(function* () {
78
- const { store, exporter, span } = yield* makeQuery
79
-
80
- const defaultTodo = { id: '', text: '', completed: false }
81
-
82
- const filter = computed(() => `where completed = 0`, { label: 'where-filter' })
83
- const query$ = queryDb(
84
- (get) => ({
85
- query: `select * from todos ${get(filter)}`,
86
- schema: Schema.Array(tables.todos.schema).pipe(Schema.headOrElse(() => defaultTodo)),
87
- }),
88
- { label: 'all todos' },
89
- )
90
-
91
- expect(query$.run()).toMatchInlineSnapshot(`
92
- {
93
- "completed": false,
94
- "id": "",
95
- "text": "",
96
- }
97
- `)
98
-
99
- store.mutate(rawSqlMutation({ sql: sql`INSERT INTO todos (id, text, completed) VALUES ('t1', 'buy milk', 0)` }))
100
-
101
- expect(query$.run()).toMatchInlineSnapshot(`
102
- {
103
- "completed": false,
104
- "id": "t1",
105
- "text": "buy milk",
106
- }
107
- `)
108
-
109
- query$.destroy()
110
- span.end()
111
-
112
- return { exporter }
113
- }).pipe(Effect.scoped, Effect.tapCauseLogPretty, Effect.runPromise)
114
-
115
- expect(getSimplifiedRootSpan(exporter)).toMatchSnapshot()
116
- })
117
-
118
- it('with thunks with query builder and without labels', async () => {
119
- const { exporter } = await Effect.gen(function* () {
120
- const { store, exporter, span } = yield* makeQuery
121
-
122
- const defaultTodo = { id: '', text: '', completed: false }
123
-
124
- const filter = computed(() => ({ completed: false }))
125
- const query$ = queryDb((get) => tables.todos.query.where(get(filter)).first({ fallback: () => defaultTodo }))
126
-
127
- expect(query$.run()).toMatchInlineSnapshot(`
128
- {
129
- "completed": false,
130
- "id": "",
131
- "text": "",
132
- }
133
- `)
134
-
135
- store.mutate(rawSqlMutation({ sql: sql`INSERT INTO todos (id, text, completed) VALUES ('t1', 'buy milk', 0)` }))
136
-
137
- expect(query$.run()).toMatchInlineSnapshot(`
138
- {
139
- "completed": false,
140
- "id": "t1",
141
- "text": "buy milk",
142
- }
143
- `)
144
-
145
- query$.destroy()
146
- span.end()
147
-
148
- return { exporter }
149
- }).pipe(Effect.scoped, Effect.tapCauseLogPretty, Effect.runPromise)
150
-
151
- expect(getSimplifiedRootSpan(exporter)).toMatchSnapshot()
152
- })
153
- })