@smartive/graphql-magic 9.1.2 → 10.0.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/.eslintrc +2 -10
- package/.github/workflows/release.yml +1 -1
- package/.gqmrc.json +6 -0
- package/CHANGELOG.md +2 -2
- package/README.md +1 -1
- package/dist/bin/gqm.cjs +684 -330
- package/dist/cjs/index.cjs +998 -554
- package/dist/esm/api/execute.js +1 -1
- package/dist/esm/api/execute.js.map +1 -1
- package/dist/esm/client/mutations.d.ts +2 -2
- package/dist/esm/client/mutations.js +5 -4
- package/dist/esm/client/mutations.js.map +1 -1
- package/dist/esm/client/queries.d.ts +12 -17
- package/dist/esm/client/queries.js +30 -50
- package/dist/esm/client/queries.js.map +1 -1
- package/dist/esm/context.d.ts +1 -2
- package/dist/esm/db/generate.d.ts +3 -3
- package/dist/esm/db/generate.js +31 -29
- package/dist/esm/db/generate.js.map +1 -1
- package/dist/esm/migrations/generate.d.ts +3 -4
- package/dist/esm/migrations/generate.js +114 -107
- package/dist/esm/migrations/generate.js.map +1 -1
- package/dist/esm/models/index.d.ts +1 -0
- package/dist/esm/models/index.js +1 -0
- package/dist/esm/models/index.js.map +1 -1
- package/dist/esm/models/model-definitions.d.ts +189 -0
- package/dist/esm/models/model-definitions.js +2 -0
- package/dist/esm/models/model-definitions.js.map +1 -0
- package/dist/esm/models/models.d.ts +128 -174
- package/dist/esm/models/models.js +411 -1
- package/dist/esm/models/models.js.map +1 -1
- package/dist/esm/models/mutation-hook.d.ts +2 -2
- package/dist/esm/models/utils.d.ts +35 -497
- package/dist/esm/models/utils.js +21 -144
- package/dist/esm/models/utils.js.map +1 -1
- package/dist/esm/permissions/check.d.ts +3 -3
- package/dist/esm/permissions/check.js +14 -7
- package/dist/esm/permissions/check.js.map +1 -1
- package/dist/esm/permissions/generate.js +6 -6
- package/dist/esm/permissions/generate.js.map +1 -1
- package/dist/esm/resolvers/filters.d.ts +8 -0
- package/dist/esm/resolvers/filters.js +28 -25
- package/dist/esm/resolvers/filters.js.map +1 -1
- package/dist/esm/resolvers/index.d.ts +1 -0
- package/dist/esm/resolvers/index.js +1 -0
- package/dist/esm/resolvers/index.js.map +1 -1
- package/dist/esm/resolvers/mutations.js +85 -21
- package/dist/esm/resolvers/mutations.js.map +1 -1
- package/dist/esm/resolvers/node.d.ts +13 -15
- package/dist/esm/resolvers/node.js +41 -36
- package/dist/esm/resolvers/node.js.map +1 -1
- package/dist/esm/resolvers/resolver.js +19 -49
- package/dist/esm/resolvers/resolver.js.map +1 -1
- package/dist/esm/resolvers/resolvers.d.ts +1 -8
- package/dist/esm/resolvers/resolvers.js +15 -7
- package/dist/esm/resolvers/resolvers.js.map +1 -1
- package/dist/esm/resolvers/selects.d.ts +3 -0
- package/dist/esm/resolvers/selects.js +50 -0
- package/dist/esm/resolvers/selects.js.map +1 -0
- package/dist/esm/resolvers/utils.d.ts +12 -4
- package/dist/esm/resolvers/utils.js +30 -22
- package/dist/esm/resolvers/utils.js.map +1 -1
- package/dist/esm/schema/generate.d.ts +4 -4
- package/dist/esm/schema/generate.js +122 -131
- package/dist/esm/schema/generate.js.map +1 -1
- package/dist/esm/schema/utils.d.ts +1 -1
- package/dist/esm/schema/utils.js +2 -1
- package/dist/esm/schema/utils.js.map +1 -1
- package/knexfile.ts +31 -0
- package/migrations/20230912185644_setup.ts +127 -0
- package/package.json +16 -14
- package/src/api/execute.ts +1 -1
- package/src/bin/gqm/gqm.ts +25 -23
- package/src/bin/gqm/parse-models.ts +5 -5
- package/src/bin/gqm/settings.ts +13 -4
- package/src/bin/gqm/static-eval.ts +5 -0
- package/src/bin/gqm/templates.ts +23 -3
- package/src/client/mutations.ts +11 -5
- package/src/client/queries.ts +43 -80
- package/src/context.ts +1 -2
- package/src/db/generate.ts +41 -41
- package/src/migrations/generate.ts +165 -146
- package/src/models/index.ts +1 -0
- package/src/models/model-definitions.ts +168 -0
- package/src/models/models.ts +510 -166
- package/src/models/mutation-hook.ts +2 -2
- package/src/models/utils.ts +53 -187
- package/src/permissions/check.ts +19 -11
- package/src/permissions/generate.ts +6 -6
- package/src/resolvers/filters.ts +44 -28
- package/src/resolvers/index.ts +1 -0
- package/src/resolvers/mutations.ts +98 -36
- package/src/resolvers/node.ts +79 -51
- package/src/resolvers/resolver.ts +20 -74
- package/src/resolvers/resolvers.ts +18 -7
- package/src/resolvers/selects.ts +77 -0
- package/src/resolvers/utils.ts +41 -25
- package/src/schema/generate.ts +106 -127
- package/src/schema/utils.ts +2 -1
- package/tests/api/__snapshots__/inheritance.spec.ts.snap +83 -0
- package/tests/api/inheritance.spec.ts +130 -0
- package/tests/generated/api/index.ts +1174 -0
- package/tests/generated/client/index.ts +1163 -0
- package/tests/generated/client/mutations.ts +109 -0
- package/tests/generated/db/index.ts +291 -0
- package/tests/generated/db/knex.ts +14 -0
- package/tests/generated/models.json +675 -0
- package/tests/generated/schema.graphql +325 -0
- package/tests/unit/__snapshots__/resolve.spec.ts.snap +23 -0
- package/tests/unit/queries.spec.ts +5 -5
- package/tests/unit/resolve.spec.ts +8 -8
- package/tests/utils/database/knex.ts +5 -13
- package/tests/utils/database/seed.ts +57 -18
- package/tests/utils/models.ts +62 -7
- package/tests/utils/server.ts +5 -5
- package/tsconfig.eslint.json +1 -0
- package/tests/unit/__snapshots__/generate.spec.ts.snap +0 -128
- package/tests/unit/generate.spec.ts +0 -8
- package/tests/utils/database/schema.ts +0 -64
- package/tests/utils/generate-migration.ts +0 -24
|
@@ -0,0 +1,130 @@
|
|
|
1
|
+
import { gql } from '../../src';
|
|
2
|
+
import { DELETE_REVIEW, RESTORE_REVIEW } from '../generated/client/mutations';
|
|
3
|
+
import { REVIEW_ID } from '../utils/database/seed';
|
|
4
|
+
import { withServer } from '../utils/server';
|
|
5
|
+
|
|
6
|
+
describe('inheritance', () => {
|
|
7
|
+
describe('queries', () => {
|
|
8
|
+
it('root type listQuery', async () => {
|
|
9
|
+
await withServer(async (request) => {
|
|
10
|
+
expect(
|
|
11
|
+
await request(gql`
|
|
12
|
+
query GetReactions {
|
|
13
|
+
reactions {
|
|
14
|
+
type
|
|
15
|
+
content
|
|
16
|
+
... on Review {
|
|
17
|
+
rating
|
|
18
|
+
}
|
|
19
|
+
}
|
|
20
|
+
}
|
|
21
|
+
`)
|
|
22
|
+
).toMatchSnapshot();
|
|
23
|
+
});
|
|
24
|
+
});
|
|
25
|
+
|
|
26
|
+
it('root type query', async () => {
|
|
27
|
+
await withServer(async (request) => {
|
|
28
|
+
expect(
|
|
29
|
+
await request(gql`
|
|
30
|
+
query GetReaction {
|
|
31
|
+
reaction(where: { id: "${REVIEW_ID}" }) {
|
|
32
|
+
type
|
|
33
|
+
content
|
|
34
|
+
... on Review {
|
|
35
|
+
rating
|
|
36
|
+
}
|
|
37
|
+
}
|
|
38
|
+
}
|
|
39
|
+
`)
|
|
40
|
+
).toMatchSnapshot();
|
|
41
|
+
});
|
|
42
|
+
});
|
|
43
|
+
|
|
44
|
+
it('sub type listQuery', async () => {
|
|
45
|
+
await withServer(async (request) => {
|
|
46
|
+
expect(
|
|
47
|
+
await request(gql`
|
|
48
|
+
query GetReviews {
|
|
49
|
+
reviews {
|
|
50
|
+
type
|
|
51
|
+
content
|
|
52
|
+
rating
|
|
53
|
+
}
|
|
54
|
+
}
|
|
55
|
+
`)
|
|
56
|
+
).toMatchSnapshot();
|
|
57
|
+
});
|
|
58
|
+
});
|
|
59
|
+
|
|
60
|
+
it('sub type query', async () => {
|
|
61
|
+
await withServer(async (request) => {
|
|
62
|
+
expect(
|
|
63
|
+
await request(gql`
|
|
64
|
+
query GetReview {
|
|
65
|
+
review(where: { id: "${REVIEW_ID}" }) {
|
|
66
|
+
type
|
|
67
|
+
content
|
|
68
|
+
rating
|
|
69
|
+
}
|
|
70
|
+
}
|
|
71
|
+
`)
|
|
72
|
+
).toMatchSnapshot();
|
|
73
|
+
});
|
|
74
|
+
});
|
|
75
|
+
|
|
76
|
+
// TODO
|
|
77
|
+
// root type -> root type relation
|
|
78
|
+
// root type -> sub type relation
|
|
79
|
+
// sub type -> root type relation
|
|
80
|
+
// sub type -> sub type relation
|
|
81
|
+
// reverse relations...
|
|
82
|
+
// basically all schema possibilities...
|
|
83
|
+
});
|
|
84
|
+
|
|
85
|
+
describe('mutations', () => {
|
|
86
|
+
it('create', async () => {
|
|
87
|
+
await withServer(async (request) => {
|
|
88
|
+
expect(
|
|
89
|
+
await request(
|
|
90
|
+
gql`
|
|
91
|
+
mutation CreateReview($data: CreateReview!) {
|
|
92
|
+
createReview(data: $data) {
|
|
93
|
+
content
|
|
94
|
+
rating
|
|
95
|
+
}
|
|
96
|
+
}
|
|
97
|
+
`,
|
|
98
|
+
{ data: { content: 'A review', rating: 5 } }
|
|
99
|
+
)
|
|
100
|
+
).toMatchSnapshot();
|
|
101
|
+
});
|
|
102
|
+
});
|
|
103
|
+
|
|
104
|
+
it('update', async () => {
|
|
105
|
+
await withServer(async (request) => {
|
|
106
|
+
expect(
|
|
107
|
+
await request(
|
|
108
|
+
gql`
|
|
109
|
+
mutation UpdateReview($id: ID!, $data: UpdateReview!) {
|
|
110
|
+
updateReview(where: { id: $id }, data: $data) {
|
|
111
|
+
content
|
|
112
|
+
rating
|
|
113
|
+
}
|
|
114
|
+
}
|
|
115
|
+
`,
|
|
116
|
+
{ id: REVIEW_ID, data: { content: 'A review', rating: 5 } }
|
|
117
|
+
)
|
|
118
|
+
).toMatchSnapshot();
|
|
119
|
+
});
|
|
120
|
+
});
|
|
121
|
+
|
|
122
|
+
it('delete and restore', async () => {
|
|
123
|
+
await withServer(async (request) => {
|
|
124
|
+
expect(await request(DELETE_REVIEW, { id: REVIEW_ID })).toMatchSnapshot();
|
|
125
|
+
|
|
126
|
+
expect(await request(RESTORE_REVIEW, { id: REVIEW_ID })).toMatchSnapshot();
|
|
127
|
+
});
|
|
128
|
+
});
|
|
129
|
+
});
|
|
130
|
+
});
|