polen 0.10.0-next.11 → 0.10.0-next.12

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 (324) hide show
  1. package/build/api/builder/builder.js +1 -1
  2. package/build/api/builder/builder.js.map +1 -1
  3. package/build/api/config/load.js +1 -1
  4. package/build/api/config/load.js.map +1 -1
  5. package/build/api/vite/plugins/build.js +1 -1
  6. package/build/api/vite/plugins/build.js.map +1 -1
  7. package/build/api/vite/plugins/core.d.ts.map +1 -1
  8. package/build/api/vite/plugins/core.js +0 -2
  9. package/build/api/vite/plugins/core.js.map +1 -1
  10. package/build/api/vite/plugins/pages.js +1 -1
  11. package/build/api/vite/plugins/pages.js.map +1 -1
  12. package/build/exports/components.d.ts +4 -1
  13. package/build/exports/components.d.ts.map +1 -1
  14. package/build/exports/components.js +4 -1
  15. package/build/exports/components.js.map +1 -1
  16. package/build/lib/demos/config-schema.d.ts +6 -6
  17. package/build/lib/github-actions/runner.js +2 -2
  18. package/build/lib/github-actions/runner.js.map +1 -1
  19. package/build/lib/graphql-document/$$.d.ts +5 -0
  20. package/build/lib/graphql-document/$$.d.ts.map +1 -0
  21. package/build/lib/graphql-document/$$.js +5 -0
  22. package/build/lib/graphql-document/$$.js.map +1 -0
  23. package/build/lib/graphql-document/$.d.ts +2 -0
  24. package/build/lib/graphql-document/$.d.ts.map +1 -0
  25. package/build/lib/graphql-document/$.js +2 -0
  26. package/build/lib/graphql-document/$.js.map +1 -0
  27. package/build/lib/graphql-document/analysis.d.ts +44 -0
  28. package/build/lib/graphql-document/analysis.d.ts.map +1 -0
  29. package/build/lib/graphql-document/analysis.js +361 -0
  30. package/build/lib/graphql-document/analysis.js.map +1 -0
  31. package/build/lib/graphql-document/components/GraphQLDocument.d.ts +42 -0
  32. package/build/lib/graphql-document/components/GraphQLDocument.d.ts.map +1 -0
  33. package/build/lib/graphql-document/components/GraphQLDocument.js +173 -0
  34. package/build/lib/graphql-document/components/GraphQLDocument.js.map +1 -0
  35. package/build/lib/graphql-document/components/GraphQLDocumentWithSchema.d.ts +7 -0
  36. package/build/lib/graphql-document/components/GraphQLDocumentWithSchema.d.ts.map +1 -0
  37. package/build/lib/graphql-document/components/GraphQLDocumentWithSchema.js +45 -0
  38. package/build/lib/graphql-document/components/GraphQLDocumentWithSchema.js.map +1 -0
  39. package/build/lib/graphql-document/components/HoverTooltip.d.ts +35 -0
  40. package/build/lib/graphql-document/components/HoverTooltip.d.ts.map +1 -0
  41. package/build/lib/graphql-document/components/HoverTooltip.js +132 -0
  42. package/build/lib/graphql-document/components/HoverTooltip.js.map +1 -0
  43. package/build/lib/graphql-document/components/IdentifierLink.d.ts +37 -0
  44. package/build/lib/graphql-document/components/IdentifierLink.d.ts.map +1 -0
  45. package/build/lib/graphql-document/components/IdentifierLink.js +141 -0
  46. package/build/lib/graphql-document/components/IdentifierLink.js.map +1 -0
  47. package/build/lib/graphql-document/components/index.d.ts +5 -0
  48. package/build/lib/graphql-document/components/index.d.ts.map +1 -0
  49. package/build/lib/graphql-document/components/index.js +5 -0
  50. package/build/lib/graphql-document/components/index.js.map +1 -0
  51. package/build/lib/graphql-document/example.d.ts +25 -0
  52. package/build/lib/graphql-document/example.d.ts.map +1 -0
  53. package/build/lib/graphql-document/example.js +140 -0
  54. package/build/lib/graphql-document/example.js.map +1 -0
  55. package/build/lib/graphql-document/graphql-document.d.ts +35 -0
  56. package/build/lib/graphql-document/graphql-document.d.ts.map +1 -0
  57. package/build/lib/graphql-document/graphql-document.js +36 -0
  58. package/build/lib/graphql-document/graphql-document.js.map +1 -0
  59. package/build/lib/graphql-document/positioning-simple.d.ts +68 -0
  60. package/build/lib/graphql-document/positioning-simple.d.ts.map +1 -0
  61. package/build/lib/graphql-document/positioning-simple.js +197 -0
  62. package/build/lib/graphql-document/positioning-simple.js.map +1 -0
  63. package/build/lib/graphql-document/schema-context.d.ts +8 -0
  64. package/build/lib/graphql-document/schema-context.d.ts.map +1 -0
  65. package/build/lib/graphql-document/schema-context.js +11 -0
  66. package/build/lib/graphql-document/schema-context.js.map +1 -0
  67. package/build/lib/graphql-document/schema-integration-example.d.ts +27 -0
  68. package/build/lib/graphql-document/schema-integration-example.d.ts.map +1 -0
  69. package/build/lib/graphql-document/schema-integration-example.js +297 -0
  70. package/build/lib/graphql-document/schema-integration-example.js.map +1 -0
  71. package/build/lib/graphql-document/schema-integration.d.ts +135 -0
  72. package/build/lib/graphql-document/schema-integration.d.ts.map +1 -0
  73. package/build/lib/graphql-document/schema-integration.js +328 -0
  74. package/build/lib/graphql-document/schema-integration.js.map +1 -0
  75. package/build/lib/graphql-document/types.d.ts +117 -0
  76. package/build/lib/graphql-document/types.d.ts.map +1 -0
  77. package/build/lib/graphql-document/types.js +2 -0
  78. package/build/lib/graphql-document/types.js.map +1 -0
  79. package/build/template/components/ArgumentAnnotation.js +10 -0
  80. package/build/template/components/ArgumentAnnotation.js.map +1 -0
  81. package/build/template/components/ArgumentList.js +9 -0
  82. package/build/template/components/ArgumentList.js.map +1 -0
  83. package/build/template/components/ArgumentListAnnotation.js +15 -0
  84. package/build/template/components/ArgumentListAnnotation.js.map +1 -0
  85. package/build/template/components/Changelog.js +44 -0
  86. package/build/template/components/Changelog.js.map +1 -0
  87. package/build/template/components/{CodeBlock.jsx → CodeBlock.js} +4 -5
  88. package/build/template/components/{CodeBlock.jsx.map → CodeBlock.js.map} +1 -1
  89. package/build/template/components/{CodeBlockEnhancer.jsx → CodeBlockEnhancer.js} +4 -4
  90. package/build/template/components/CodeBlockEnhancer.js.map +1 -0
  91. package/build/template/components/DeprecationReason.js +9 -0
  92. package/build/template/components/DeprecationReason.js.map +1 -0
  93. package/build/template/components/Description.js +9 -0
  94. package/build/template/components/Description.js.map +1 -0
  95. package/build/template/components/Field.js +14 -0
  96. package/build/template/components/Field.js.map +1 -0
  97. package/build/template/components/{FieldList.jsx → FieldList.js} +4 -5
  98. package/build/template/components/FieldList.js.map +1 -0
  99. package/build/template/components/{FieldListSection.jsx → FieldListSection.js} +4 -6
  100. package/build/template/components/FieldListSection.js.map +1 -0
  101. package/build/template/components/HamburgerMenu.js +30 -0
  102. package/build/template/components/HamburgerMenu.js.map +1 -0
  103. package/build/template/components/Link.d.ts +1 -1
  104. package/build/template/components/{Link.jsx → Link.js} +4 -5
  105. package/build/template/components/Link.js.map +1 -0
  106. package/build/template/components/Logo.js +20 -0
  107. package/build/template/components/Logo.js.map +1 -0
  108. package/build/template/components/MDXComponents.d.ts +11 -0
  109. package/build/template/components/MDXComponents.d.ts.map +1 -0
  110. package/build/template/components/MDXComponents.js +70 -0
  111. package/build/template/components/MDXComponents.js.map +1 -0
  112. package/build/template/components/{Markdown.jsx → Markdown.js} +3 -2
  113. package/build/template/components/Markdown.js.map +1 -0
  114. package/build/template/components/MissingSchema.d.ts +1 -1
  115. package/build/template/components/MissingSchema.d.ts.map +1 -1
  116. package/build/template/components/MissingSchema.js +5 -0
  117. package/build/template/components/MissingSchema.js.map +1 -0
  118. package/build/template/components/NamedType.js +12 -0
  119. package/build/template/components/NamedType.js.map +1 -0
  120. package/build/template/components/NotFound.js +7 -0
  121. package/build/template/components/NotFound.js.map +1 -0
  122. package/build/template/components/{RadixLink.jsx → RadixLink.js} +1 -1
  123. package/build/template/components/RadixLink.js.map +1 -0
  124. package/build/template/components/TestComponent.d.ts +5 -0
  125. package/build/template/components/TestComponent.d.ts.map +1 -0
  126. package/build/template/components/TestComponent.js +7 -0
  127. package/build/template/components/TestComponent.js.map +1 -0
  128. package/build/template/components/Texts/{MinorHeading.jsx → MinorHeading.js} +4 -3
  129. package/build/template/components/Texts/MinorHeading.js.map +1 -0
  130. package/build/template/components/Texts/texts.js +1 -1
  131. package/build/template/components/Texts/texts.js.map +1 -1
  132. package/build/template/components/ThemeToggle.js +9 -0
  133. package/build/template/components/ThemeToggle.js.map +1 -0
  134. package/build/template/components/{TypeAnnotation.jsx → TypeAnnotation.js} +8 -18
  135. package/build/template/components/TypeAnnotation.js.map +1 -0
  136. package/build/template/components/TypeFieldsLinkList.js +9 -0
  137. package/build/template/components/TypeFieldsLinkList.js.map +1 -0
  138. package/build/template/components/TypeIndex.js +17 -0
  139. package/build/template/components/TypeIndex.js.map +1 -0
  140. package/build/template/components/content/$$.d.ts +1 -0
  141. package/build/template/components/content/$$.d.ts.map +1 -1
  142. package/build/template/components/content/$$.js +1 -0
  143. package/build/template/components/content/$$.js.map +1 -1
  144. package/build/template/components/content/GraphQLDocumentWithSchema.d.ts +8 -0
  145. package/build/template/components/content/GraphQLDocumentWithSchema.d.ts.map +1 -0
  146. package/build/template/components/content/GraphQLDocumentWithSchema.js +16 -0
  147. package/build/template/components/content/GraphQLDocumentWithSchema.js.map +1 -0
  148. package/build/template/components/content/GraphQLDocumentWrapper.d.ts +7 -0
  149. package/build/template/components/content/GraphQLDocumentWrapper.d.ts.map +1 -0
  150. package/build/template/components/content/GraphQLDocumentWrapper.js +62 -0
  151. package/build/template/components/content/GraphQLDocumentWrapper.js.map +1 -0
  152. package/build/template/components/graphql/graphql.d.ts +2 -2
  153. package/build/template/components/graphql/graphql.js +3 -0
  154. package/build/template/components/graphql/graphql.js.map +1 -0
  155. package/build/template/components/graphql/index.d.ts +1 -1
  156. package/build/template/components/graphql/index.js +1 -1
  157. package/build/template/components/graphql/index.js.map +1 -1
  158. package/build/template/components/graphql/{type-kind-icon.jsx → type-kind-icon.js} +3 -2
  159. package/build/template/components/graphql/type-kind-icon.js.map +1 -0
  160. package/build/template/components/graphql/type-link.js +11 -0
  161. package/build/template/components/graphql/type-link.js.map +1 -0
  162. package/build/template/components/sidebar/Sidebar.d.ts +1 -1
  163. package/build/template/components/sidebar/Sidebar.d.ts.map +1 -1
  164. package/build/template/components/sidebar/Sidebar.js +11 -0
  165. package/build/template/components/sidebar/Sidebar.js.map +1 -0
  166. package/build/template/components/sidebar/{SidebarItem.jsx → SidebarItem.js} +15 -32
  167. package/build/template/components/sidebar/SidebarItem.js.map +1 -0
  168. package/build/template/components/sidebar/ToggleButton.d.ts +1 -1
  169. package/build/template/components/sidebar/ToggleButton.d.ts.map +1 -1
  170. package/build/template/components/sidebar/ToggleButton.js +5 -0
  171. package/build/template/components/sidebar/ToggleButton.js.map +1 -0
  172. package/build/template/contexts/{ThemeContext.jsx → ThemeContext.js} +3 -4
  173. package/build/template/contexts/{ThemeContext.jsx.map → ThemeContext.js.map} +1 -1
  174. package/build/template/entry.client.d.ts +1 -0
  175. package/build/template/entry.client.d.ts.map +1 -1
  176. package/build/template/{entry.client.jsx → entry.client.js} +5 -6
  177. package/build/template/entry.client.js.map +1 -0
  178. package/build/template/routes/changelog.d.ts +1 -1
  179. package/build/template/routes/{changelog.jsx → changelog.js} +5 -4
  180. package/build/template/routes/changelog.js.map +1 -0
  181. package/build/template/routes/{index.jsx → index.js} +3 -2
  182. package/build/template/routes/index.js.map +1 -0
  183. package/build/template/routes/reference.$type.$field.d.ts +1 -1
  184. package/build/template/routes/{reference.$type.$field.jsx → reference.$type.$field.js} +6 -5
  185. package/build/template/routes/reference.$type.$field.js.map +1 -0
  186. package/build/template/routes/reference.$type.d.ts +1 -1
  187. package/build/template/routes/{reference.$type.jsx → reference.$type.js} +6 -5
  188. package/build/template/routes/reference.$type.js.map +1 -0
  189. package/build/template/routes/reference.d.ts +2 -2
  190. package/build/template/routes/{reference.jsx → reference.js} +6 -7
  191. package/build/template/routes/reference.js.map +1 -0
  192. package/build/template/routes/root.d.ts +2 -2
  193. package/build/template/routes/root.d.ts.map +1 -1
  194. package/build/template/routes/{root.jsx → root.js} +46 -88
  195. package/build/template/routes/root.js.map +1 -0
  196. package/build/template/routes.js +5 -0
  197. package/build/template/routes.js.map +1 -0
  198. package/build/template/server/app.js +1 -1
  199. package/build/template/server/app.js.map +1 -1
  200. package/build/template/server/{render-page.jsx → render-page.js} +3 -4
  201. package/build/template/server/render-page.js.map +1 -0
  202. package/build/template/server/ssg/generate.js +1 -1
  203. package/build/template/server/ssg/generate.js.map +1 -1
  204. package/build/template/server/ssg/get-route-paths.js +1 -1
  205. package/build/template/server/ssg/get-route-paths.js.map +1 -1
  206. package/build/template/server/view.js +1 -1
  207. package/build/template/server/view.js.map +1 -1
  208. package/package.json +56 -8
  209. package/src/api/vite/plugins/core.ts +0 -3
  210. package/src/api/vite/plugins/pages.ts +1 -1
  211. package/src/exports/components.ts +4 -1
  212. package/src/lib/graphql-document/$$.ts +4 -0
  213. package/src/lib/graphql-document/$.test.ts +132 -0
  214. package/src/lib/graphql-document/$.ts +1 -0
  215. package/src/lib/graphql-document/README.md +102 -0
  216. package/src/lib/graphql-document/analysis.ts +415 -0
  217. package/src/lib/graphql-document/components/GraphQLDocument.tsx +284 -0
  218. package/src/lib/graphql-document/components/GraphQLDocument.unit.test.ts +188 -0
  219. package/src/lib/graphql-document/components/GraphQLDocumentWithSchema.tsx +70 -0
  220. package/src/lib/graphql-document/components/HoverTooltip.tsx +282 -0
  221. package/src/lib/graphql-document/components/IdentifierLink.tsx +221 -0
  222. package/src/lib/graphql-document/components/index.ts +4 -0
  223. package/src/lib/graphql-document/demo.md +155 -0
  224. package/src/lib/graphql-document/example.ts +163 -0
  225. package/src/lib/graphql-document/graphql-document.ts +37 -0
  226. package/src/lib/graphql-document/positioning-simple.test.ts +252 -0
  227. package/src/lib/graphql-document/positioning-simple.ts +271 -0
  228. package/src/lib/graphql-document/schema-context.tsx +20 -0
  229. package/src/lib/graphql-document/schema-integration-example.ts +341 -0
  230. package/src/lib/graphql-document/schema-integration.test.ts +365 -0
  231. package/src/lib/graphql-document/schema-integration.ts +497 -0
  232. package/src/lib/graphql-document/types.ts +129 -0
  233. package/src/template/components/ArgumentAnnotation.tsx +1 -1
  234. package/src/template/components/ArgumentList.tsx +1 -1
  235. package/src/template/components/ArgumentListAnnotation.tsx +2 -2
  236. package/src/template/components/CodeBlockEnhancer.tsx +21 -21
  237. package/src/template/components/DeprecationReason.tsx +1 -1
  238. package/src/template/components/Description.tsx +1 -1
  239. package/src/template/components/Field.tsx +4 -4
  240. package/src/template/components/FieldList.tsx +1 -1
  241. package/src/template/components/FieldListSection.tsx +1 -1
  242. package/src/template/components/Link.tsx +2 -2
  243. package/src/template/components/MDXComponents.tsx +101 -0
  244. package/src/template/components/NamedType.tsx +2 -2
  245. package/src/template/components/TestComponent.tsx +6 -0
  246. package/src/template/components/TypeAnnotation.tsx +1 -1
  247. package/src/template/components/TypeFieldsLinkList.tsx +1 -1
  248. package/src/template/components/TypeIndex.tsx +1 -1
  249. package/src/template/components/content/$$.ts +1 -0
  250. package/src/template/components/content/GraphQLDocumentWithSchema.tsx +18 -0
  251. package/src/template/components/content/GraphQLDocumentWrapper.tsx +82 -0
  252. package/src/template/components/graphql/graphql.tsx +2 -2
  253. package/src/template/components/graphql/index.ts +1 -1
  254. package/src/template/components/graphql/type-link.tsx +2 -2
  255. package/src/template/entry.client.tsx +2 -2
  256. package/src/template/routes/changelog.tsx +1 -1
  257. package/src/template/routes/reference.$type.$field.tsx +3 -3
  258. package/src/template/routes/reference.$type.tsx +3 -3
  259. package/src/template/routes/reference.tsx +3 -3
  260. package/src/template/routes/root.tsx +36 -25
  261. package/src/template/routes.tsx +1 -1
  262. package/src/template/server/app.ts +1 -1
  263. package/src/template/server/ssg/generate.ts +1 -1
  264. package/src/template/server/ssg/get-route-paths.ts +1 -1
  265. package/src/template/server/view.ts +1 -1
  266. package/src/template/styles/code-block.css +32 -0
  267. package/build/template/components/ArgumentAnnotation.jsx +0 -16
  268. package/build/template/components/ArgumentAnnotation.jsx.map +0 -1
  269. package/build/template/components/ArgumentList.jsx +0 -16
  270. package/build/template/components/ArgumentList.jsx.map +0 -1
  271. package/build/template/components/ArgumentListAnnotation.jsx +0 -23
  272. package/build/template/components/ArgumentListAnnotation.jsx.map +0 -1
  273. package/build/template/components/Changelog.jsx +0 -68
  274. package/build/template/components/Changelog.jsx.map +0 -1
  275. package/build/template/components/CodeBlockEnhancer.jsx.map +0 -1
  276. package/build/template/components/DeprecationReason.jsx +0 -10
  277. package/build/template/components/DeprecationReason.jsx.map +0 -1
  278. package/build/template/components/Description.jsx +0 -10
  279. package/build/template/components/Description.jsx.map +0 -1
  280. package/build/template/components/Field.jsx +0 -22
  281. package/build/template/components/Field.jsx.map +0 -1
  282. package/build/template/components/FieldList.jsx.map +0 -1
  283. package/build/template/components/FieldListSection.jsx.map +0 -1
  284. package/build/template/components/HamburgerMenu.jsx +0 -53
  285. package/build/template/components/HamburgerMenu.jsx.map +0 -1
  286. package/build/template/components/Link.jsx.map +0 -1
  287. package/build/template/components/Logo.jsx +0 -29
  288. package/build/template/components/Logo.jsx.map +0 -1
  289. package/build/template/components/Markdown.jsx.map +0 -1
  290. package/build/template/components/MissingSchema.jsx +0 -4
  291. package/build/template/components/MissingSchema.jsx.map +0 -1
  292. package/build/template/components/NamedType.jsx +0 -17
  293. package/build/template/components/NamedType.jsx.map +0 -1
  294. package/build/template/components/NotFound.jsx +0 -26
  295. package/build/template/components/NotFound.jsx.map +0 -1
  296. package/build/template/components/RadixLink.jsx.map +0 -1
  297. package/build/template/components/Texts/MinorHeading.jsx.map +0 -1
  298. package/build/template/components/ThemeToggle.jsx +0 -10
  299. package/build/template/components/ThemeToggle.jsx.map +0 -1
  300. package/build/template/components/TypeAnnotation.jsx.map +0 -1
  301. package/build/template/components/TypeFieldsLinkList.jsx +0 -17
  302. package/build/template/components/TypeFieldsLinkList.jsx.map +0 -1
  303. package/build/template/components/TypeIndex.jsx +0 -27
  304. package/build/template/components/TypeIndex.jsx.map +0 -1
  305. package/build/template/components/graphql/graphql.jsx +0 -3
  306. package/build/template/components/graphql/graphql.jsx.map +0 -1
  307. package/build/template/components/graphql/type-kind-icon.jsx.map +0 -1
  308. package/build/template/components/graphql/type-link.jsx +0 -16
  309. package/build/template/components/graphql/type-link.jsx.map +0 -1
  310. package/build/template/components/sidebar/Sidebar.jsx +0 -15
  311. package/build/template/components/sidebar/Sidebar.jsx.map +0 -1
  312. package/build/template/components/sidebar/SidebarItem.jsx.map +0 -1
  313. package/build/template/components/sidebar/ToggleButton.jsx +0 -6
  314. package/build/template/components/sidebar/ToggleButton.jsx.map +0 -1
  315. package/build/template/entry.client.jsx.map +0 -1
  316. package/build/template/routes/changelog.jsx.map +0 -1
  317. package/build/template/routes/index.jsx.map +0 -1
  318. package/build/template/routes/reference.$type.$field.jsx.map +0 -1
  319. package/build/template/routes/reference.$type.jsx.map +0 -1
  320. package/build/template/routes/reference.jsx.map +0 -1
  321. package/build/template/routes/root.jsx.map +0 -1
  322. package/build/template/routes.jsx +0 -5
  323. package/build/template/routes.jsx.map +0 -1
  324. package/build/template/server/render-page.jsx.map +0 -1
@@ -0,0 +1,365 @@
1
+ import { buildSchema } from 'graphql'
2
+ import { describe, expect, it } from 'vitest'
3
+ import { analyzeWithSchema, createPolenSchemaResolver } from './schema-integration.ts'
4
+
5
+ // Test schema
6
+ const testSchema = buildSchema(`
7
+ """
8
+ A user in the system
9
+ """
10
+ type User {
11
+ """
12
+ The user's unique identifier
13
+ """
14
+ id: ID!
15
+
16
+ """
17
+ The user's full name
18
+ """
19
+ name: String!
20
+
21
+ """
22
+ The user's email address
23
+ """
24
+ email: String!
25
+
26
+ """
27
+ User's posts
28
+ """
29
+ posts(
30
+ """
31
+ Maximum number of posts to return
32
+ """
33
+ first: Int = 10
34
+
35
+ """
36
+ Filter posts after this cursor
37
+ """
38
+ after: String
39
+ ): [Post!]!
40
+
41
+ """
42
+ @deprecated Use profile.avatar instead
43
+ """
44
+ avatar: String @deprecated(reason: "Use profile.avatar instead")
45
+ }
46
+
47
+ """
48
+ A blog post
49
+ """
50
+ type Post {
51
+ id: ID!
52
+ title: String!
53
+ content: String!
54
+ author: User!
55
+ }
56
+
57
+ """
58
+ Input for creating a user
59
+ """
60
+ input CreateUserInput {
61
+ name: String!
62
+ email: String!
63
+ }
64
+
65
+ type Query {
66
+ """
67
+ Get a user by ID
68
+ """
69
+ user(id: ID!): User
70
+
71
+ """
72
+ Search for users
73
+ """
74
+ users(query: String!): [User!]!
75
+ }
76
+
77
+ type Mutation {
78
+ """
79
+ Create a new user
80
+ """
81
+ createUser(input: CreateUserInput!): User!
82
+ }
83
+
84
+ """
85
+ Custom directive for validation
86
+ """
87
+ directive @validate(pattern: String!) on FIELD_DEFINITION | INPUT_FIELD_DEFINITION
88
+ `)
89
+
90
+ describe('Schema Integration', () => {
91
+ describe('PolenSchemaResolver', () => {
92
+ const resolver = createPolenSchemaResolver(testSchema)
93
+
94
+ describe('Type Resolution', () => {
95
+ it('should resolve existing types', () => {
96
+ const identifier = {
97
+ name: 'User',
98
+ kind: 'Type' as const,
99
+ position: { start: 0, end: 4, line: 1, column: 1 },
100
+ schemaPath: ['User'],
101
+ context: { selectionPath: [] },
102
+ }
103
+
104
+ const resolution = resolver.resolveIdentifier(identifier)
105
+
106
+ expect(resolution).toBeDefined()
107
+ expect(resolution!.exists).toBe(true)
108
+ expect(resolution!.referenceUrl).toBe('/reference/User')
109
+ expect(resolution!.documentation?.description).toContain('A user in the system')
110
+ expect(resolution!.documentation?.typeInfo).toBe('User')
111
+ })
112
+
113
+ it('should handle non-existent types', () => {
114
+ const identifier = {
115
+ name: 'NonExistentType',
116
+ kind: 'Type' as const,
117
+ position: { start: 0, end: 15, line: 1, column: 1 },
118
+ schemaPath: ['NonExistentType'],
119
+ context: { selectionPath: [] },
120
+ }
121
+
122
+ const resolution = resolver.resolveIdentifier(identifier)
123
+
124
+ expect(resolution).toBeDefined()
125
+ expect(resolution!.exists).toBe(false)
126
+ expect(resolution!.referenceUrl).toBe('/reference/NonExistentType')
127
+ expect(resolution!.documentation).toBeUndefined()
128
+ })
129
+ })
130
+
131
+ describe('Field Resolution', () => {
132
+ it('should resolve existing fields', () => {
133
+ const identifier = {
134
+ name: 'name',
135
+ kind: 'Field' as const,
136
+ position: { start: 0, end: 4, line: 1, column: 1 },
137
+ parentType: 'User',
138
+ schemaPath: ['User', 'name'],
139
+ context: { selectionPath: ['name'] },
140
+ }
141
+
142
+ const resolution = resolver.resolveIdentifier(identifier)
143
+
144
+ expect(resolution).toBeDefined()
145
+ expect(resolution!.exists).toBe(true)
146
+ expect(resolution!.referenceUrl).toBe('/reference/User#name')
147
+ expect(resolution!.documentation?.description).toContain("The user's full name")
148
+ expect(resolution!.documentation?.typeInfo).toBe('String!')
149
+ })
150
+
151
+ it('should detect deprecated fields', () => {
152
+ const identifier = {
153
+ name: 'avatar',
154
+ kind: 'Field' as const,
155
+ position: { start: 0, end: 6, line: 1, column: 1 },
156
+ parentType: 'User',
157
+ schemaPath: ['User', 'avatar'],
158
+ context: { selectionPath: ['avatar'] },
159
+ }
160
+
161
+ const resolution = resolver.resolveIdentifier(identifier)
162
+
163
+ expect(resolution).toBeDefined()
164
+ expect(resolution!.exists).toBe(true)
165
+ expect(resolution!.deprecated).toBeDefined()
166
+ expect(resolution!.deprecated!.reason).toBe('Use profile.avatar instead')
167
+ })
168
+
169
+ it('should handle non-existent fields', () => {
170
+ const identifier = {
171
+ name: 'nonExistentField',
172
+ kind: 'Field' as const,
173
+ position: { start: 0, end: 16, line: 1, column: 1 },
174
+ parentType: 'User',
175
+ schemaPath: ['User', 'nonExistentField'],
176
+ context: { selectionPath: ['nonExistentField'] },
177
+ }
178
+
179
+ const resolution = resolver.resolveIdentifier(identifier)
180
+
181
+ expect(resolution).toBeDefined()
182
+ expect(resolution!.exists).toBe(false)
183
+ expect(resolution!.referenceUrl).toBe('/reference/User#nonExistentField')
184
+ })
185
+ })
186
+
187
+ describe('Argument Resolution', () => {
188
+ it('should resolve field arguments', () => {
189
+ const identifier = {
190
+ name: 'first',
191
+ kind: 'Argument' as const,
192
+ position: { start: 0, end: 5, line: 1, column: 1 },
193
+ parentType: 'User',
194
+ schemaPath: ['User', 'posts', 'first'],
195
+ context: { selectionPath: ['posts'] },
196
+ }
197
+
198
+ const resolution = resolver.resolveIdentifier(identifier)
199
+
200
+ expect(resolution).toBeDefined()
201
+ expect(resolution!.exists).toBe(true)
202
+ expect(resolution!.referenceUrl).toBe('/reference/User#posts-first')
203
+ expect(resolution!.documentation?.description).toContain('Maximum number of posts')
204
+ expect(resolution!.documentation?.typeInfo).toBe('Int')
205
+ expect(resolution!.documentation?.defaultValue).toBe('10')
206
+ })
207
+ })
208
+
209
+ describe('Variable Resolution', () => {
210
+ it('should handle variables', () => {
211
+ const identifier = {
212
+ name: 'id',
213
+ kind: 'Variable' as const,
214
+ position: { start: 0, end: 2, line: 1, column: 1 },
215
+ schemaPath: ['id'],
216
+ context: { selectionPath: [] },
217
+ }
218
+
219
+ const resolution = resolver.resolveIdentifier(identifier)
220
+
221
+ expect(resolution).toBeDefined()
222
+ expect(resolution!.exists).toBe(true)
223
+ expect(resolution!.referenceUrl).toBe('/reference#variables')
224
+ expect(resolution!.documentation?.typeInfo).toBe('Variable')
225
+ expect(resolution!.documentation?.description).toBe('Query variable: $id')
226
+ })
227
+ })
228
+
229
+ describe('Directive Resolution', () => {
230
+ it('should resolve directives', () => {
231
+ const identifier = {
232
+ name: 'validate',
233
+ kind: 'Directive' as const,
234
+ position: { start: 0, end: 8, line: 1, column: 1 },
235
+ schemaPath: ['validate'],
236
+ context: { selectionPath: [] },
237
+ }
238
+
239
+ const resolution = resolver.resolveIdentifier(identifier)
240
+
241
+ expect(resolution).toBeDefined()
242
+ expect(resolution!.exists).toBe(true)
243
+ expect(resolution!.referenceUrl).toBe('/reference/directives#validate')
244
+ expect(resolution!.documentation?.description).toContain('Custom directive for validation')
245
+ })
246
+ })
247
+
248
+ describe('URL Generation', () => {
249
+ it('should generate correct URLs with custom base path', () => {
250
+ const customResolver = createPolenSchemaResolver(testSchema, {
251
+ basePath: '/docs/schema',
252
+ })
253
+
254
+ expect(customResolver.generateReferenceLink(['User'])).toBe('/docs/schema/User')
255
+ expect(customResolver.generateReferenceLink(['User', 'name'])).toBe('/docs/schema/User#name')
256
+ expect(customResolver.generateReferenceLink(['User', 'posts', 'first'])).toBe('/docs/schema/User#posts-first')
257
+ })
258
+
259
+ it('should handle fragment configuration', () => {
260
+ const noFragmentResolver = createPolenSchemaResolver(testSchema, {
261
+ includeFragments: false,
262
+ })
263
+
264
+ expect(noFragmentResolver.generateReferenceLink(['User', 'name'])).toBe('/reference/User')
265
+ })
266
+ })
267
+
268
+ describe('Documentation Extraction', () => {
269
+ it('should extract type documentation', () => {
270
+ const docs = resolver.getDocumentation(['User'])
271
+
272
+ expect(docs).toBeDefined()
273
+ expect(docs!.description).toContain('A user in the system')
274
+ expect(docs!.typeInfo).toBe('User')
275
+ })
276
+
277
+ it('should extract field documentation', () => {
278
+ const docs = resolver.getDocumentation(['User', 'email'])
279
+
280
+ expect(docs).toBeDefined()
281
+ expect(docs!.description).toContain("The user's email address")
282
+ expect(docs!.typeInfo).toBe('String!')
283
+ })
284
+
285
+ it('should extract argument documentation', () => {
286
+ const docs = resolver.getDocumentation(['User', 'posts', 'after'])
287
+
288
+ expect(docs).toBeDefined()
289
+ expect(docs!.description).toContain('Filter posts after this cursor')
290
+ expect(docs!.typeInfo).toBe('String')
291
+ })
292
+ })
293
+
294
+ describe('Schema Validation', () => {
295
+ it('should return all types', () => {
296
+ const types = resolver.getAllTypes()
297
+
298
+ expect(types).toContain('User')
299
+ expect(types).toContain('Post')
300
+ expect(types).toContain('CreateUserInput')
301
+ expect(types).toContain('Query')
302
+ expect(types).toContain('Mutation')
303
+ expect(types).not.toContain('__Schema') // Should filter introspection types
304
+ })
305
+
306
+ it('should check type existence', () => {
307
+ expect(resolver.typeExists('User')).toBe(true)
308
+ expect(resolver.typeExists('NonExistentType')).toBe(false)
309
+ })
310
+ })
311
+ })
312
+
313
+ describe('Schema-Aware Analysis', () => {
314
+ it('should perform complete schema-aware analysis', () => {
315
+ const source = `
316
+ query GetUser($id: ID!) {
317
+ user(id: $id) {
318
+ name
319
+ email
320
+ avatar
321
+ }
322
+ }
323
+ `
324
+
325
+ const result = analyzeWithSchema(source, testSchema)
326
+
327
+ expect(result.analysis.isValid).toBe(true)
328
+ expect(result.resolutions.size).toBeGreaterThan(0)
329
+ expect(result.schemaErrors.length).toBeGreaterThan(0)
330
+
331
+ // Should have deprecation warning for avatar field
332
+ const deprecationWarning = result.schemaErrors.find(
333
+ error => error.message.includes('avatar') && error.message.includes('deprecated'),
334
+ )
335
+ expect(deprecationWarning).toBeDefined()
336
+ expect(deprecationWarning!.severity).toBe('warning')
337
+ })
338
+
339
+ it('should resolve identifiers correctly', () => {
340
+ const source = `
341
+ query {
342
+ user(id: "123") {
343
+ name
344
+ }
345
+ }
346
+ `
347
+
348
+ const result = analyzeWithSchema(source, testSchema)
349
+
350
+ // Find the name field resolution
351
+ const nameField = result.analysis.identifiers.all.find(
352
+ id => id.name === 'name' && id.kind === 'Field',
353
+ )
354
+ expect(nameField).toBeDefined()
355
+
356
+ const nameResolutionKey = `${nameField!.position.start}-${nameField!.name}-${nameField!.kind}`
357
+ const nameResolution = result.resolutions.get(nameResolutionKey)
358
+
359
+ expect(nameResolution).toBeDefined()
360
+ expect(nameResolution!.exists).toBe(true)
361
+ expect(nameResolution!.referenceUrl).toBe('/reference/User#name')
362
+ expect(nameResolution!.documentation?.typeInfo).toBe('String!')
363
+ })
364
+ })
365
+ })