@graphql-hive/federation-gateway-audit 0.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.
Files changed (293) hide show
  1. package/.changeset/@graphql-hive_federation-gateway-audit-293-dependencies.md +5 -0
  2. package/.changeset/README.md +9 -0
  3. package/.changeset/config.json +18 -0
  4. package/.changeset/funky-times-cry.md +5 -0
  5. package/.github/CONTRIBUTING.md +9 -0
  6. package/.github/workflows/ci.yaml +97 -0
  7. package/.github/workflows/release.yml +58 -0
  8. package/LICENSE +21 -0
  9. package/README.md +113 -0
  10. package/REPORT.md +812 -0
  11. package/dist/cli.js +547 -0
  12. package/dist/env-Dj2M4ll3.cjs +15 -0
  13. package/dist/env-j1f_SZtG.js +13 -0
  14. package/dist/env-j1f_SZtG.mjs +13 -0
  15. package/dist/index--3rcSZqA.js +227 -0
  16. package/dist/index-0MDIXUzP.cjs +589 -0
  17. package/dist/index-19eD5lFk.mjs +163 -0
  18. package/dist/index-1ZtG04bN.js +222 -0
  19. package/dist/index-1nZTfbJn.cjs +168 -0
  20. package/dist/index-1smMXABT.mjs +227 -0
  21. package/dist/index-2oy7cA9A.js +225 -0
  22. package/dist/index-3BM15w2Y.mjs +234 -0
  23. package/dist/index-3CyAnc7j.js +234 -0
  24. package/dist/index-4Vj-ND7j.mjs +213 -0
  25. package/dist/index-4swHVe9x.cjs +507 -0
  26. package/dist/index-6itLA31k.js +382 -0
  27. package/dist/index-6qNpP2wc.mjs +238 -0
  28. package/dist/index-81CiuWlP.mjs +333 -0
  29. package/dist/index-8FxjbyOU.cjs +236 -0
  30. package/dist/index-A2YbwKzc.mjs +288 -0
  31. package/dist/index-B-YHHt9g.js +333 -0
  32. package/dist/index-B0coRevy.mjs +337 -0
  33. package/dist/index-B1NAc0TI.cjs +215 -0
  34. package/dist/index-B1WvIzTg.js +371 -0
  35. package/dist/index-B38OpRtf.js +166 -0
  36. package/dist/index-B3aDw4Tt.js +359 -0
  37. package/dist/index-B55AdoQy.js +273 -0
  38. package/dist/index-B7cr8XE-.js +194 -0
  39. package/dist/index-B7zN3YzE.cjs +683 -0
  40. package/dist/index-B8X923W3.mjs +262 -0
  41. package/dist/index-B958BFYC.cjs +224 -0
  42. package/dist/index-B9T896rB.mjs +163 -0
  43. package/dist/index-BA3ERnyq.mjs +234 -0
  44. package/dist/index-BDMi6sOm.cjs +252 -0
  45. package/dist/index-BDNWXFb_.mjs +304 -0
  46. package/dist/index-BEMScD_X.cjs +173 -0
  47. package/dist/index-BF0H5kP0.cjs +384 -0
  48. package/dist/index-BGC0_vWj.cjs +335 -0
  49. package/dist/index-BGNmWPAk.js +381 -0
  50. package/dist/index-BGUm947D.cjs +229 -0
  51. package/dist/index-BJB0tRA1.js +550 -0
  52. package/dist/index-BKcwbRZx.cjs +339 -0
  53. package/dist/index-BKpVb_h9.cjs +236 -0
  54. package/dist/index-BPFol6Ww.mjs +129 -0
  55. package/dist/index-BPza8i2Q.mjs +213 -0
  56. package/dist/index-BQQgQaGz.cjs +552 -0
  57. package/dist/index-BReFIfq_.cjs +361 -0
  58. package/dist/index-BS7JyQSU.js +250 -0
  59. package/dist/index-BSWSgZCO.cjs +252 -0
  60. package/dist/index-BStXx4OK.js +705 -0
  61. package/dist/index-BSwOAvti.js +288 -0
  62. package/dist/index-BWO8QbMB.mjs +587 -0
  63. package/dist/index-BYEdADrG.cjs +227 -0
  64. package/dist/index-B_eGT6oX.js +225 -0
  65. package/dist/index-B_u5Boud.js +333 -0
  66. package/dist/index-BaH3FI9i.cjs +361 -0
  67. package/dist/index-BaluTf1I.cjs +707 -0
  68. package/dist/index-BblYlZ3A.cjs +131 -0
  69. package/dist/index-BcZC0OIN.js +234 -0
  70. package/dist/index-Bcjyyjhh.mjs +259 -0
  71. package/dist/index-BcoW0aPo.cjs +165 -0
  72. package/dist/index-BdNZKlDU.js +284 -0
  73. package/dist/index-Bf81cAA1.mjs +444 -0
  74. package/dist/index-Bg3H3fgZ.js +259 -0
  75. package/dist/index-Bgl_1Y6Q.mjs +681 -0
  76. package/dist/index-BgmItHIB.mjs +129 -0
  77. package/dist/index-BgryMCqm.mjs +213 -0
  78. package/dist/index-Bh6a3eXK.mjs +227 -0
  79. package/dist/index-BhPDIfmU.js +304 -0
  80. package/dist/index-BiTzMTFn.js +304 -0
  81. package/dist/index-BjbmOyBP.cjs +215 -0
  82. package/dist/index-BjwZX2iS.mjs +273 -0
  83. package/dist/index-Bm8hqSRd.cjs +168 -0
  84. package/dist/index-BmOn6xYL.js +228 -0
  85. package/dist/index-BmQrhPXB.cjs +131 -0
  86. package/dist/index-Bnb8TpOO.js +280 -0
  87. package/dist/index-BndUB2KV.mjs +381 -0
  88. package/dist/index-Bo74nI4n.js +129 -0
  89. package/dist/index-BoGmP6Cy.cjs +230 -0
  90. package/dist/index-BodMjESw.mjs +250 -0
  91. package/dist/index-BpJZCoVH.mjs +250 -0
  92. package/dist/index-Br-Y1qC_.cjs +446 -0
  93. package/dist/index-BrFtcRgi.mjs +194 -0
  94. package/dist/index-BsPxDJAB.mjs +238 -0
  95. package/dist/index-Bu7pZnPO.cjs +170 -0
  96. package/dist/index-Bu8SXnTf.mjs +227 -0
  97. package/dist/index-BuNNRp3W.mjs +117 -0
  98. package/dist/index-Bwh8HVkw.cjs +384 -0
  99. package/dist/index-BxK3Y72_.js +227 -0
  100. package/dist/index-BxPUzymh.cjs +208 -0
  101. package/dist/index-ByUUB7Zn.js +250 -0
  102. package/dist/index-ByUr80PD.cjs +306 -0
  103. package/dist/index-ByZa9qm8.mjs +273 -0
  104. package/dist/index-BzPCjhuQ.cjs +264 -0
  105. package/dist/index-Bz_LTy1A.mjs +222 -0
  106. package/dist/index-C05_HMLC.js +225 -0
  107. package/dist/index-C15P-_1j.cjs +229 -0
  108. package/dist/index-C1GgHOiD.js +228 -0
  109. package/dist/index-C4Pk-zTm.mjs +227 -0
  110. package/dist/index-C4dnTlBf.js +262 -0
  111. package/dist/index-C6LW00iX.mjs +505 -0
  112. package/dist/index-C6nkQ480.js +225 -0
  113. package/dist/index-C8Mu4K9Q.cjs +383 -0
  114. package/dist/index-C8mB7yWC.mjs +288 -0
  115. package/dist/index-C9Eh7qBC.js +273 -0
  116. package/dist/index-CAJ9YPxc.js +681 -0
  117. package/dist/index-CD03pVUt.cjs +373 -0
  118. package/dist/index-CD8GiuIg.js +227 -0
  119. package/dist/index-CHB_0VqK.mjs +333 -0
  120. package/dist/index-CKEgb_R7.cjs +215 -0
  121. package/dist/index-CLsasg69.js +228 -0
  122. package/dist/index-CMdC_Cah.js +213 -0
  123. package/dist/index-CNOcqGKC.cjs +227 -0
  124. package/dist/index-CNvZCDZa.js +166 -0
  125. package/dist/index-CO0GiXGE.js +168 -0
  126. package/dist/index-COGhiFjk.mjs +284 -0
  127. package/dist/index-COIlelpZ.mjs +262 -0
  128. package/dist/index-CPph-RFN.mjs +168 -0
  129. package/dist/index-CPu_XkjY.mjs +304 -0
  130. package/dist/index-CQ5t4ZXm.js +117 -0
  131. package/dist/index-CQeQ1nto.js +681 -0
  132. package/dist/index-CSc_T8Lu.js +218 -0
  133. package/dist/index-CUFKuE64.js +550 -0
  134. package/dist/index-CW8h3l6M.js +262 -0
  135. package/dist/index-CWrng7Hd.mjs +550 -0
  136. package/dist/index-CWuObqnS.mjs +587 -0
  137. package/dist/index-CX7-wc6X.cjs +1837 -0
  138. package/dist/index-CXviN8qZ.cjs +224 -0
  139. package/dist/index-CY9mowWW.mjs +705 -0
  140. package/dist/index-C_pTgB_1.js +194 -0
  141. package/dist/index-C_qaNb-X.mjs +225 -0
  142. package/dist/index-Ca0FeU7u.js +505 -0
  143. package/dist/index-Cb3ImEjd.cjs +165 -0
  144. package/dist/index-Cbhvi8yk.cjs +229 -0
  145. package/dist/index-Cc3vrs6_.mjs +228 -0
  146. package/dist/index-CcIXvx40.mjs +171 -0
  147. package/dist/index-CdaeeF3f.cjs +306 -0
  148. package/dist/index-CddVoIp2.js +213 -0
  149. package/dist/index-CeiRxGcN.mjs +218 -0
  150. package/dist/index-ChefKWWr.mjs +381 -0
  151. package/dist/index-Cj2ocjXI.cjs +227 -0
  152. package/dist/index-CkWEXzTN.js +129 -0
  153. package/dist/index-Ckhb9QAu.cjs +264 -0
  154. package/dist/index-CklJfQlf.cjs +220 -0
  155. package/dist/index-Cmh7PJUd.mjs +372 -0
  156. package/dist/index-Cn0ZJkAv.mjs +280 -0
  157. package/dist/index-CqTzarV1.mjs +198 -0
  158. package/dist/index-CrUbbFxE.js +284 -0
  159. package/dist/index-CsKaFB2K.mjs +228 -0
  160. package/dist/index-Cu8Ii5r7.cjs +335 -0
  161. package/dist/index-Cuw9ylL-.mjs +371 -0
  162. package/dist/index-CwOULUAt.mjs +382 -0
  163. package/dist/index-CyVnRqjE.cjs +196 -0
  164. package/dist/index-D-1dDKiZ.mjs +227 -0
  165. package/dist/index-D00bnaJy.cjs +220 -0
  166. package/dist/index-D07xiOJ6.cjs +446 -0
  167. package/dist/index-D1Ip6ro6.js +458 -0
  168. package/dist/index-D1Ymvd2b.cjs +286 -0
  169. package/dist/index-D5jOBT3f.cjs +240 -0
  170. package/dist/index-D5tEp8IU.js +337 -0
  171. package/dist/index-D7WuGKYY.cjs +227 -0
  172. package/dist/index-D8Dp6TnQ.cjs +1837 -0
  173. package/dist/index-D9OKpqgG.js +381 -0
  174. package/dist/index-DBMI2EcB.cjs +170 -0
  175. package/dist/index-DBRUKV0U.mjs +225 -0
  176. package/dist/index-DEvExC5x.cjs +119 -0
  177. package/dist/index-DEzxU_gQ.cjs +507 -0
  178. package/dist/index-DFypMD6R.cjs +261 -0
  179. package/dist/index-DHRqE92a.cjs +290 -0
  180. package/dist/index-DISym5OL.js +198 -0
  181. package/dist/index-DJ3ndv3i.mjs +705 -0
  182. package/dist/index-DJXP-Gmp.js +218 -0
  183. package/dist/index-DJlXDQOY.cjs +200 -0
  184. package/dist/index-DLW4GEJl.cjs +229 -0
  185. package/dist/index-DLu9E2Vq.js +238 -0
  186. package/dist/index-DM4ddIL6.js +382 -0
  187. package/dist/index-DMgHLbwU.cjs +339 -0
  188. package/dist/index-DN-ScBql.mjs +458 -0
  189. package/dist/index-DOkkIHER.js +163 -0
  190. package/dist/index-DRY8sDun.cjs +165 -0
  191. package/dist/index-DS3cjugP.mjs +171 -0
  192. package/dist/index-DS86eFsI.mjs +1835 -0
  193. package/dist/index-DUlT8CJ2.js +458 -0
  194. package/dist/index-DV1F4nxP.js +372 -0
  195. package/dist/index-DXsAcJ-o.mjs +359 -0
  196. package/dist/index-DZws2w4w.cjs +229 -0
  197. package/dist/index-D_HiVe2_.cjs +200 -0
  198. package/dist/index-Da6L5V_Z.mjs +681 -0
  199. package/dist/index-Dbb-jnWf.js +206 -0
  200. package/dist/index-DdXy_-T9.js +444 -0
  201. package/dist/index-DddNFRG3.js +337 -0
  202. package/dist/index-DejhKwvw.cjs +173 -0
  203. package/dist/index-DfBdD-5Z.cjs +383 -0
  204. package/dist/index-Df_KCbC4.mjs +213 -0
  205. package/dist/index-DiDq1sL6.cjs +240 -0
  206. package/dist/index-DiuJQ9Mq.js +198 -0
  207. package/dist/index-Djqj3DWJ.js +171 -0
  208. package/dist/index-Dk0q-ENv.mjs +166 -0
  209. package/dist/index-DlFElztE.mjs +163 -0
  210. package/dist/index-DlkxQ-B5.mjs +359 -0
  211. package/dist/index-Dm5kpK9t.js +227 -0
  212. package/dist/index-Dp8mobro.js +444 -0
  213. package/dist/index-DpBWZa1x.cjs +683 -0
  214. package/dist/index-DrkXuLUZ.js +227 -0
  215. package/dist/index-Dsq1FK90.cjs +275 -0
  216. package/dist/index-DtmhGgM8.cjs +282 -0
  217. package/dist/index-Du5MxO_2.mjs +505 -0
  218. package/dist/index-DveYQLCZ.cjs +460 -0
  219. package/dist/index-DxHMqS-W.js +117 -0
  220. package/dist/index-DyTApTHI.cjs +282 -0
  221. package/dist/index-DyTSkAm4.cjs +208 -0
  222. package/dist/index-DygJOEne.mjs +550 -0
  223. package/dist/index-DzAewrkw.js +238 -0
  224. package/dist/index-ESWdD7ek.cjs +215 -0
  225. package/dist/index-EuKHpnHv.mjs +117 -0
  226. package/dist/index-F1A7LMlw.mjs +228 -0
  227. package/dist/index-FP6hvgSw.cjs +552 -0
  228. package/dist/index-GDSrKnPp.mjs +198 -0
  229. package/dist/index-GMCZo-KH.js +222 -0
  230. package/dist/index-IQJLr7nR.js +288 -0
  231. package/dist/index-IawHHRZX.mjs +206 -0
  232. package/dist/index-Jk7MG7tE.cjs +286 -0
  233. package/dist/index-JtGxTXPr.mjs +337 -0
  234. package/dist/index-KAC20a9r.js +359 -0
  235. package/dist/index-LVWQqV-v.js +163 -0
  236. package/dist/index-Ls2fI7y4.js +163 -0
  237. package/dist/index-NB1VDvjW.cjs +374 -0
  238. package/dist/index-NIEZaRYg.cjs +261 -0
  239. package/dist/index-PQXUx1ZR.mjs +1835 -0
  240. package/dist/index-PyaLRKuk.mjs +168 -0
  241. package/dist/index-QQGo-BV1.mjs +444 -0
  242. package/dist/index-QXYDkAsQ.cjs +119 -0
  243. package/dist/index-SmEIf5jz.mjs +259 -0
  244. package/dist/index-UJhFwnD_.mjs +284 -0
  245. package/dist/index-UVyXzNlG.js +705 -0
  246. package/dist/index-UgyHGpUU.mjs +163 -0
  247. package/dist/index-UhQiJabs.cjs +707 -0
  248. package/dist/index-VvuhRvnC.mjs +218 -0
  249. package/dist/index-WPXuueaq.mjs +194 -0
  250. package/dist/index-X4u6bs58.js +259 -0
  251. package/dist/index-XZiO6uje.cjs +275 -0
  252. package/dist/index-YOlsBREZ.cjs +230 -0
  253. package/dist/index-Ytb942t9.js +587 -0
  254. package/dist/index-_2dg_MWu.cjs +460 -0
  255. package/dist/index-eFEW10em.js +213 -0
  256. package/dist/index-eq8bbEej.mjs +225 -0
  257. package/dist/index-f7FiDQMk.js +171 -0
  258. package/dist/index-fBzI1kbw.mjs +225 -0
  259. package/dist/index-fdDnq3vQ.js +163 -0
  260. package/dist/index-fqmAgjhG.js +206 -0
  261. package/dist/index-ikGyewP-.cjs +165 -0
  262. package/dist/index-jft-1bQ6.cjs +230 -0
  263. package/dist/index-l8e8ip4U.js +168 -0
  264. package/dist/index-lkBiml03.js +1835 -0
  265. package/dist/index-mm-YMeoi.js +505 -0
  266. package/dist/index-o7g3iua7.cjs +290 -0
  267. package/dist/index-ojnncNWd.js +587 -0
  268. package/dist/index-q9SCjCJM.mjs +280 -0
  269. package/dist/index-rn-_7-wp.cjs +196 -0
  270. package/dist/index-s27DHpTG.js +1835 -0
  271. package/dist/index-s2HuXM4d.mjs +206 -0
  272. package/dist/index-sbc7nDv3.js +213 -0
  273. package/dist/index-tx0X6vuE.mjs +222 -0
  274. package/dist/index-uCwv2hr-.mjs +166 -0
  275. package/dist/index-vHngHSlz.js +280 -0
  276. package/dist/index-xOtG5E4u.cjs +589 -0
  277. package/dist/index-zJk-Nm6b.mjs +458 -0
  278. package/dist/index-zqxgDrLR.mjs +382 -0
  279. package/dist/index.cjs +233 -0
  280. package/dist/index.d.cts +9 -0
  281. package/dist/index.d.cts.map +1 -0
  282. package/dist/index.d.ts +9 -0
  283. package/dist/index.d.ts.map +1 -0
  284. package/dist/index.js +230 -0
  285. package/dist/index.mjs +230 -0
  286. package/dist/testkit-BtZjdl4n.js +269 -0
  287. package/dist/testkit-BtZjdl4n.mjs +269 -0
  288. package/dist/testkit-C920qivh.js +281 -0
  289. package/dist/testkit-C920qivh.mjs +281 -0
  290. package/dist/testkit-CAf-AsDy.cjs +273 -0
  291. package/dist/testkit-D0rTQ6MD.cjs +286 -0
  292. package/makefile +47 -0
  293. package/package.json +89 -0
@@ -0,0 +1,163 @@
1
+ import { c as createSubgraph, a as createTest, s as serve } from './testkit-BtZjdl4n.js';
2
+ import '@apollo/composition';
3
+ import 'graphql';
4
+ import 'fets';
5
+ import '@apollo/subgraph';
6
+ import 'graphql-yoga';
7
+
8
+ const users = [
9
+ {
10
+ id: "u1",
11
+ name: "u1-name"
12
+ },
13
+ {
14
+ id: "u2",
15
+ name: "u2-name"
16
+ }
17
+ ];
18
+
19
+ var a = createSubgraph("a", {
20
+ typeDefs: (
21
+ /* GraphQL */
22
+ `
23
+ extend schema
24
+ @link(
25
+ url: "https://specs.apollo.dev/federation/v2.3"
26
+ import: ["@key", "@shareable"]
27
+ )
28
+
29
+ input UsersFilter {
30
+ first: Int!
31
+ }
32
+
33
+ type User @key(fields: "id") {
34
+ id: ID!
35
+ name: String! @shareable
36
+ }
37
+
38
+ type Query {
39
+ usersInA(filter: UsersFilter!): [User!]
40
+ }
41
+ `
42
+ ),
43
+ resolvers: {
44
+ Query: {
45
+ usersInA(_, { filter }) {
46
+ if ("offset" in filter) {
47
+ return [];
48
+ }
49
+ return users;
50
+ }
51
+ },
52
+ User: {
53
+ __resolveReference(key) {
54
+ const user = users.find((user2) => user2.id === key.id);
55
+ if (!user) {
56
+ return null;
57
+ }
58
+ return user;
59
+ }
60
+ }
61
+ }
62
+ });
63
+
64
+ var b = createSubgraph("b", {
65
+ typeDefs: (
66
+ /* GraphQL */
67
+ `
68
+ extend schema
69
+ @link(
70
+ url: "https://specs.apollo.dev/federation/v2.3"
71
+ import: ["@key", "@shareable"]
72
+ )
73
+
74
+ input UsersFilter {
75
+ offset: Int
76
+ first: Int!
77
+ }
78
+
79
+ type User @key(fields: "id") {
80
+ id: ID!
81
+ name: String! @shareable
82
+ }
83
+
84
+ type Query {
85
+ usersInB(filter: UsersFilter!): [User!]
86
+ }
87
+ `
88
+ ),
89
+ resolvers: {
90
+ Query: {
91
+ usersInB(_, { filter }) {
92
+ if ("offset" in filter) {
93
+ return [];
94
+ }
95
+ return users;
96
+ }
97
+ },
98
+ User: {
99
+ __resolveReference(key) {
100
+ const user = users.find((user2) => user2.id === key.id);
101
+ if (!user) {
102
+ return null;
103
+ }
104
+ return user;
105
+ }
106
+ }
107
+ }
108
+ });
109
+
110
+ var test = [
111
+ createTest(
112
+ /* GraphQL */
113
+ `
114
+ query {
115
+ usersInA(filter: { first: 1 }) {
116
+ id
117
+ }
118
+ }
119
+ `,
120
+ {
121
+ data: {
122
+ usersInA: [
123
+ {
124
+ id: "u1"
125
+ },
126
+ {
127
+ id: "u2"
128
+ }
129
+ ]
130
+ }
131
+ }
132
+ ),
133
+ createTest(
134
+ /* GraphQL */
135
+ `
136
+ query {
137
+ usersInA(filter: { first: 1, offset: 2 }) {
138
+ id
139
+ }
140
+ }
141
+ `,
142
+ {
143
+ errors: true
144
+ }
145
+ ),
146
+ createTest(
147
+ /* GraphQL */
148
+ `
149
+ query {
150
+ usersInB(filter: { first: 1, offset: 2 }) {
151
+ id
152
+ }
153
+ }
154
+ `,
155
+ {
156
+ errors: true
157
+ }
158
+ )
159
+ ];
160
+
161
+ var index = serve("input-object-intersection", [a, b], test);
162
+
163
+ export { index as default };
@@ -0,0 +1,163 @@
1
+ import { c as createSubgraph, a as createTest, s as serve } from './testkit-C920qivh.js';
2
+ import '@apollo/composition';
3
+ import 'graphql';
4
+ import 'fets';
5
+ import '@apollo/subgraph';
6
+ import 'graphql-yoga';
7
+
8
+ const posts = [
9
+ {
10
+ id: "p1",
11
+ createdAt: "p1-createdAt"
12
+ },
13
+ {
14
+ id: "p2",
15
+ createdAt: "p2-createdAt"
16
+ }
17
+ ];
18
+
19
+ var a = createSubgraph("a", {
20
+ typeDefs: (
21
+ /* GraphQL */
22
+ `
23
+ extend schema
24
+ @link(
25
+ url: "https://specs.apollo.dev/federation/v2.3"
26
+ import: ["@key", "@shareable"]
27
+ )
28
+
29
+ type Post @key(fields: "id") {
30
+ id: ID!
31
+ createdAt: String! @shareable
32
+ }
33
+
34
+ type Query {
35
+ feed: [Post] @shareable
36
+ aFeed: [Post]
37
+ }
38
+ `
39
+ ),
40
+ resolvers: {
41
+ Query: {
42
+ feed() {
43
+ return posts;
44
+ },
45
+ aFeed() {
46
+ return [posts[1]];
47
+ }
48
+ },
49
+ Post: {
50
+ __resolveReference(key) {
51
+ const post = posts.find((p) => p.id === key.id);
52
+ if (!post) {
53
+ return null;
54
+ }
55
+ return {
56
+ id: post.id,
57
+ createdAt: post.createdAt
58
+ };
59
+ }
60
+ }
61
+ }
62
+ });
63
+
64
+ var b = createSubgraph("b", {
65
+ typeDefs: (
66
+ /* GraphQL */
67
+ `
68
+ extend schema
69
+ @link(
70
+ url: "https://specs.apollo.dev/federation/v2.3"
71
+ import: ["@key", "@override", "@shareable"]
72
+ )
73
+
74
+ type Post @key(fields: "id") {
75
+ id: ID!
76
+ createdAt: String! @override(from: "non-existing") @shareable
77
+ }
78
+
79
+ type Query {
80
+ feed: [Post] @shareable
81
+ bFeed: [Post]
82
+ }
83
+ `
84
+ ),
85
+ resolvers: {
86
+ Query: {
87
+ feed() {
88
+ return posts;
89
+ },
90
+ bFeed() {
91
+ return [posts[0]];
92
+ }
93
+ },
94
+ Post: {
95
+ __resolveReference(key) {
96
+ const post = posts.find((p) => p.id === key.id);
97
+ if (!post) {
98
+ return null;
99
+ }
100
+ return {
101
+ id: post.id,
102
+ createdAt: post.createdAt
103
+ };
104
+ }
105
+ }
106
+ }
107
+ });
108
+
109
+ var test = [
110
+ createTest(
111
+ /* GraphQL */
112
+ `
113
+ query {
114
+ feed {
115
+ createdAt
116
+ }
117
+ }
118
+ `,
119
+ {
120
+ data: {
121
+ feed: [
122
+ {
123
+ createdAt: "p1-createdAt"
124
+ },
125
+ {
126
+ createdAt: "p2-createdAt"
127
+ }
128
+ ]
129
+ }
130
+ }
131
+ ),
132
+ createTest(
133
+ /* GraphQL */
134
+ `
135
+ query {
136
+ aFeed {
137
+ createdAt
138
+ }
139
+ bFeed {
140
+ createdAt
141
+ }
142
+ }
143
+ `,
144
+ {
145
+ data: {
146
+ aFeed: [
147
+ {
148
+ createdAt: "p2-createdAt"
149
+ }
150
+ ],
151
+ bFeed: [
152
+ {
153
+ createdAt: "p1-createdAt"
154
+ }
155
+ ]
156
+ }
157
+ }
158
+ )
159
+ ];
160
+
161
+ var index = serve("unavailable-override", [a, b], test);
162
+
163
+ export { index as default };
@@ -0,0 +1,374 @@
1
+ 'use strict';
2
+
3
+ var testkit = require('./testkit-CAf-AsDy.cjs');
4
+ var env = require('./env-Dj2M4ll3.cjs');
5
+ require('@apollo/composition');
6
+ require('graphql');
7
+ require('fets');
8
+ require('@apollo/subgraph');
9
+ require('graphql-yoga');
10
+
11
+ const products = [
12
+ {
13
+ id: "p1",
14
+ categories: ["c1", "c2"]
15
+ },
16
+ {
17
+ id: "p2",
18
+ categories: ["c3", "c2"]
19
+ }
20
+ ];
21
+ const categories = [
22
+ {
23
+ id: "c1",
24
+ name: "Category 1",
25
+ subCategories: ["c2"]
26
+ },
27
+ {
28
+ id: "c2",
29
+ name: "Category 2",
30
+ subCategories: ["c3"]
31
+ },
32
+ {
33
+ id: "c3",
34
+ name: "Category 3",
35
+ subCategories: ["c1"]
36
+ }
37
+ ];
38
+
39
+ var allProducts = testkit.createSubgraph("all-products", {
40
+ typeDefs: (
41
+ /* GraphQL */
42
+ `
43
+ extend schema
44
+ @link(
45
+ url: "https://specs.apollo.dev/federation/v2.3"
46
+ import: ["@key", "@shareable"]
47
+ )
48
+
49
+ type Product @key(fields: "id") {
50
+ id: ID!
51
+ }
52
+ `
53
+ ),
54
+ resolvers: {
55
+ Product: {
56
+ __resolveReference(key) {
57
+ if (env.shouldPunishForPoorPlans()) {
58
+ throw new Error("You should be using the categories subgraph!");
59
+ }
60
+ const product = products.find((p) => p.id === key.id);
61
+ if (!product) {
62
+ return null;
63
+ }
64
+ return {
65
+ id: product.id
66
+ };
67
+ }
68
+ }
69
+ }
70
+ });
71
+
72
+ var category = testkit.createSubgraph("category", {
73
+ typeDefs: (
74
+ /* GraphQL */
75
+ `
76
+ extend schema
77
+ @link(
78
+ url: "https://specs.apollo.dev/federation/v2.3"
79
+ import: ["@key", "@shareable", "@external", "@provides"]
80
+ )
81
+
82
+ type Query {
83
+ products: [Product]
84
+ @shareable
85
+ @provides(fields: "categories { id name subCategories { id name } }")
86
+ }
87
+
88
+ type Product @key(fields: "id") {
89
+ id: ID!
90
+ categories: [Category] @external
91
+ }
92
+
93
+ type Category @key(fields: "id") {
94
+ id: ID!
95
+ """
96
+ This field is provided by Query.products
97
+ and we deliberately don't resolve it.
98
+ The test suite is about checking if @provides is used correctly.
99
+ """
100
+ name: String
101
+ subCategories: [Category] @external
102
+ }
103
+ `
104
+ ),
105
+ resolvers: {
106
+ Query: {
107
+ products() {
108
+ return products.map((p) => ({
109
+ id: p.id,
110
+ categories: p.categories.map((catId) => {
111
+ const cat = categories.find((c) => c.id === catId);
112
+ if (!cat) {
113
+ return null;
114
+ }
115
+ return {
116
+ id: cat.id,
117
+ name: cat.name,
118
+ subCategories: cat.subCategories.map((subCatId) => {
119
+ const subCat = categories.find((c) => c.id === subCatId);
120
+ if (!subCat) {
121
+ return null;
122
+ }
123
+ return {
124
+ id: subCat.id,
125
+ name: subCat.name
126
+ };
127
+ })
128
+ };
129
+ })
130
+ }));
131
+ }
132
+ },
133
+ Product: {
134
+ __resolveReference(key, context) {
135
+ if (env.shouldPunishForPoorPlans()) {
136
+ throw new Error("You should be using the categories subgraph!");
137
+ }
138
+ const product = products.find((p) => p.id === key.id);
139
+ if (!product) {
140
+ return null;
141
+ }
142
+ return {
143
+ id: product.id
144
+ };
145
+ }
146
+ },
147
+ Category: {
148
+ __resolveReference(key, context) {
149
+ if (env.shouldPunishForPoorPlans()) {
150
+ throw new Error("You should be using the categories subgraph!");
151
+ }
152
+ const cat = categories.find((c) => c.id === key.id);
153
+ if (!cat) {
154
+ return null;
155
+ }
156
+ return {
157
+ id: cat.id
158
+ // We explicitly don't resolve `name` here
159
+ // name: cat.name,
160
+ };
161
+ }
162
+ }
163
+ }
164
+ });
165
+
166
+ var subcategories = testkit.createSubgraph("subcategories", {
167
+ typeDefs: (
168
+ /* GraphQL */
169
+ `
170
+ extend schema
171
+ @link(
172
+ url: "https://specs.apollo.dev/federation/v2.3"
173
+ import: ["@key", "@shareable"]
174
+ )
175
+
176
+ type Product @key(fields: "id") {
177
+ id: ID!
178
+ categories: [Category] @shareable
179
+ }
180
+
181
+ type Category @key(fields: "id") {
182
+ id: ID!
183
+ subCategories: [Category] @shareable
184
+ }
185
+ `
186
+ ),
187
+ resolvers: {
188
+ Product: {
189
+ __resolveReference(key, context) {
190
+ if (env.shouldPunishForPoorPlans()) {
191
+ throw new Error("You should be using the categories subgraph!");
192
+ }
193
+ const product = products.find((p) => p.id === key.id);
194
+ if (!product) {
195
+ return null;
196
+ }
197
+ return {
198
+ id: product.id,
199
+ categories: product.categories
200
+ };
201
+ },
202
+ categories(product, _a, context) {
203
+ if (env.shouldPunishForPoorPlans()) {
204
+ throw new Error("You should be using the categories subgraph!");
205
+ }
206
+ return product.categories.map((catId) => {
207
+ const cat = categories.find((c) => c.id === catId);
208
+ if (!cat) {
209
+ return null;
210
+ }
211
+ return {
212
+ id: cat.id,
213
+ subCategories: cat.subCategories
214
+ };
215
+ });
216
+ }
217
+ },
218
+ Category: {
219
+ __resolveReference(key) {
220
+ const cat = categories.find((c) => c.id === key.id);
221
+ if (!cat) {
222
+ return null;
223
+ }
224
+ return {
225
+ id: cat.id,
226
+ subCategories: cat.subCategories
227
+ };
228
+ },
229
+ subCategories(category) {
230
+ return category.subCategories.map((catId) => {
231
+ const cat = categories.find((c) => c.id === catId);
232
+ if (!cat) {
233
+ return null;
234
+ }
235
+ return {
236
+ id: cat.id,
237
+ subCategories: cat.subCategories
238
+ };
239
+ });
240
+ }
241
+ }
242
+ }
243
+ });
244
+
245
+ var test = [
246
+ testkit.createTest(
247
+ /* GraphQL */
248
+ `
249
+ query {
250
+ products {
251
+ id
252
+ categories {
253
+ id
254
+ name
255
+ }
256
+ }
257
+ }
258
+ `,
259
+ {
260
+ data: {
261
+ products: [
262
+ {
263
+ id: "p1",
264
+ categories: [
265
+ {
266
+ id: "c1",
267
+ name: "Category 1"
268
+ },
269
+ {
270
+ id: "c2",
271
+ name: "Category 2"
272
+ }
273
+ ]
274
+ },
275
+ {
276
+ id: "p2",
277
+ categories: [
278
+ {
279
+ id: "c3",
280
+ name: "Category 3"
281
+ },
282
+ {
283
+ id: "c2",
284
+ name: "Category 2"
285
+ }
286
+ ]
287
+ }
288
+ ]
289
+ }
290
+ }
291
+ ),
292
+ testkit.createTest(
293
+ /* GraphQL */
294
+ `
295
+ query {
296
+ products {
297
+ id
298
+ categories {
299
+ id
300
+ name
301
+ subCategories {
302
+ id
303
+ name
304
+ }
305
+ }
306
+ }
307
+ }
308
+ `,
309
+ {
310
+ data: {
311
+ products: [
312
+ {
313
+ id: "p1",
314
+ categories: [
315
+ {
316
+ id: "c1",
317
+ name: "Category 1",
318
+ subCategories: [
319
+ {
320
+ id: "c2",
321
+ name: "Category 2"
322
+ }
323
+ ]
324
+ },
325
+ {
326
+ id: "c2",
327
+ name: "Category 2",
328
+ subCategories: [
329
+ {
330
+ id: "c3",
331
+ name: "Category 3"
332
+ }
333
+ ]
334
+ }
335
+ ]
336
+ },
337
+ {
338
+ id: "p2",
339
+ categories: [
340
+ {
341
+ id: "c3",
342
+ name: "Category 3",
343
+ subCategories: [
344
+ {
345
+ id: "c1",
346
+ name: "Category 1"
347
+ }
348
+ ]
349
+ },
350
+ {
351
+ id: "c2",
352
+ name: "Category 2",
353
+ subCategories: [
354
+ {
355
+ id: "c3",
356
+ name: "Category 3"
357
+ }
358
+ ]
359
+ }
360
+ ]
361
+ }
362
+ ]
363
+ }
364
+ }
365
+ )
366
+ ];
367
+
368
+ var index = testkit.serve(
369
+ "nested-provides",
370
+ [allProducts, category, subcategories],
371
+ test
372
+ );
373
+
374
+ exports.default = index;