@docusaurus/plugin-content-docs 2.0.0-beta.fc64c12e4 → 2.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 (236) hide show
  1. package/lib/categoryGeneratedIndex.d.ts +12 -0
  2. package/lib/categoryGeneratedIndex.js +37 -0
  3. package/lib/cli.d.ts +3 -2
  4. package/lib/cli.js +57 -73
  5. package/lib/client/docsClientUtils.d.ts +9 -28
  6. package/lib/client/docsClientUtils.js +34 -43
  7. package/lib/client/index.d.ts +81 -0
  8. package/lib/client/index.js +67 -0
  9. package/lib/constants.d.ts +4 -0
  10. package/lib/constants.js +4 -1
  11. package/lib/docs.d.ts +33 -6
  12. package/lib/docs.js +201 -78
  13. package/{src/__tests__/__fixtures__/site-with-autogenerated-sidebar/docusaurus.config.js → lib/frontMatter.d.ts} +4 -8
  14. package/lib/{docFrontMatter.js → frontMatter.js} +22 -3
  15. package/lib/globalData.d.ts +3 -3
  16. package/lib/globalData.js +35 -6
  17. package/lib/index.d.ts +3 -3
  18. package/lib/index.js +120 -153
  19. package/lib/lastUpdate.d.ts +4 -6
  20. package/lib/lastUpdate.js +22 -26
  21. package/lib/markdown/index.d.ts +3 -6
  22. package/lib/markdown/index.js +3 -3
  23. package/lib/markdown/linkify.d.ts +1 -1
  24. package/lib/markdown/linkify.js +6 -3
  25. package/lib/numberPrefix.d.ts +1 -1
  26. package/lib/numberPrefix.js +16 -21
  27. package/lib/options.d.ts +3 -5
  28. package/lib/options.js +34 -26
  29. package/lib/props.d.ts +7 -2
  30. package/lib/props.js +84 -13
  31. package/lib/routes.d.ts +29 -0
  32. package/lib/routes.js +96 -0
  33. package/lib/server-export.d.ts +9 -0
  34. package/lib/server-export.js +25 -0
  35. package/lib/{sidebarItemsGenerator.d.ts → sidebars/generator.d.ts} +1 -7
  36. package/lib/sidebars/generator.js +209 -0
  37. package/lib/sidebars/index.d.ts +13 -0
  38. package/lib/sidebars/index.js +92 -0
  39. package/lib/sidebars/normalization.d.ts +13 -0
  40. package/lib/sidebars/normalization.js +59 -0
  41. package/lib/sidebars/postProcessor.d.ts +11 -0
  42. package/lib/sidebars/postProcessor.js +81 -0
  43. package/lib/sidebars/processor.d.ts +10 -0
  44. package/lib/sidebars/processor.js +79 -0
  45. package/lib/sidebars/types.d.ts +183 -0
  46. package/lib/{docFrontMatter.d.ts → sidebars/types.js} +2 -2
  47. package/lib/sidebars/utils.d.ts +55 -0
  48. package/lib/sidebars/utils.js +259 -0
  49. package/lib/sidebars/validation.d.ts +11 -0
  50. package/lib/sidebars/validation.js +143 -0
  51. package/lib/slug.d.ts +5 -4
  52. package/lib/slug.js +28 -18
  53. package/{src/__tests__/__fixtures__/sidebars/sidebars-first-level-not-category.js → lib/tags.d.ts} +3 -14
  54. package/lib/tags.js +21 -0
  55. package/lib/translations.d.ts +3 -3
  56. package/lib/translations.js +100 -93
  57. package/lib/types.d.ts +13 -192
  58. package/lib/versions/files.d.ts +50 -0
  59. package/lib/versions/files.js +141 -0
  60. package/lib/versions/index.d.ts +36 -0
  61. package/lib/versions/index.js +154 -0
  62. package/lib/versions/validation.d.ts +17 -0
  63. package/lib/versions/validation.js +71 -0
  64. package/package.json +44 -30
  65. package/src/categoryGeneratedIndex.ts +60 -0
  66. package/src/cli.ts +88 -118
  67. package/src/client/docsClientUtils.ts +44 -71
  68. package/src/client/index.ts +158 -0
  69. package/src/constants.ts +4 -2
  70. package/src/docs.ts +277 -80
  71. package/src/frontMatter.ts +63 -0
  72. package/src/globalData.ts +57 -7
  73. package/src/index.ts +174 -221
  74. package/src/lastUpdate.ts +27 -38
  75. package/src/markdown/index.ts +10 -16
  76. package/src/markdown/linkify.ts +7 -4
  77. package/src/numberPrefix.ts +19 -26
  78. package/src/options.ts +38 -38
  79. package/src/plugin-content-docs.d.ts +570 -91
  80. package/src/props.ts +121 -20
  81. package/src/routes.ts +159 -0
  82. package/src/server-export.ts +26 -0
  83. package/src/sidebars/README.md +10 -0
  84. package/src/sidebars/generator.ts +292 -0
  85. package/src/sidebars/index.ts +118 -0
  86. package/src/sidebars/normalization.ts +91 -0
  87. package/src/sidebars/postProcessor.ts +112 -0
  88. package/src/sidebars/processor.ts +123 -0
  89. package/src/sidebars/types.ts +280 -0
  90. package/src/sidebars/utils.ts +393 -0
  91. package/src/sidebars/validation.ts +179 -0
  92. package/src/slug.ts +41 -22
  93. package/src/tags.ts +20 -0
  94. package/src/translations.ts +155 -124
  95. package/src/types.ts +17 -259
  96. package/src/versions/files.ts +216 -0
  97. package/src/versions/index.ts +246 -0
  98. package/src/versions/validation.ts +115 -0
  99. package/lib/.tsbuildinfo +0 -1
  100. package/lib/sidebarItemsGenerator.js +0 -215
  101. package/lib/sidebars.d.ts +0 -45
  102. package/lib/sidebars.js +0 -354
  103. package/lib/theme/hooks/useDocs.d.ts +0 -20
  104. package/lib/theme/hooks/useDocs.js +0 -75
  105. package/lib/versions.d.ts +0 -16
  106. package/lib/versions.js +0 -319
  107. package/src/__tests__/__fixtures__/bad-id-site/docs/invalid-id.md +0 -5
  108. package/src/__tests__/__fixtures__/bad-slug-on-doc-home-site/docs/docWithSlug.md +0 -5
  109. package/src/__tests__/__fixtures__/empty-site/docusaurus.config.js +0 -16
  110. package/src/__tests__/__fixtures__/empty-site/sidebars.json +0 -1
  111. package/src/__tests__/__fixtures__/sidebars/sidebars-category-shorthand.js +0 -34
  112. package/src/__tests__/__fixtures__/sidebars/sidebars-category-wrong-items.json +0 -11
  113. package/src/__tests__/__fixtures__/sidebars/sidebars-category-wrong-label.json +0 -11
  114. package/src/__tests__/__fixtures__/sidebars/sidebars-category.js +0 -44
  115. package/src/__tests__/__fixtures__/sidebars/sidebars-collapsed-first-level.json +0 -20
  116. package/src/__tests__/__fixtures__/sidebars/sidebars-collapsed.json +0 -21
  117. package/src/__tests__/__fixtures__/sidebars/sidebars-doc-id-not-string.json +0 -10
  118. package/src/__tests__/__fixtures__/sidebars/sidebars-link-wrong-href.json +0 -11
  119. package/src/__tests__/__fixtures__/sidebars/sidebars-link-wrong-label.json +0 -11
  120. package/src/__tests__/__fixtures__/sidebars/sidebars-link.json +0 -11
  121. package/src/__tests__/__fixtures__/sidebars/sidebars-unknown-type.json +0 -14
  122. package/src/__tests__/__fixtures__/sidebars/sidebars-wrong-field.json +0 -20
  123. package/src/__tests__/__fixtures__/sidebars/sidebars.json +0 -20
  124. package/src/__tests__/__fixtures__/simple-site/docs/_partials/somePartial.md +0 -3
  125. package/src/__tests__/__fixtures__/simple-site/docs/_partials/subfolder/somePartial.md +0 -3
  126. package/src/__tests__/__fixtures__/simple-site/docs/_somePartial.md +0 -3
  127. package/src/__tests__/__fixtures__/simple-site/docs/foo/bar.md +0 -69
  128. package/src/__tests__/__fixtures__/simple-site/docs/foo/baz.md +0 -70
  129. package/src/__tests__/__fixtures__/simple-site/docs/headingAsTitle.md +0 -1
  130. package/src/__tests__/__fixtures__/simple-site/docs/hello.md +0 -53
  131. package/src/__tests__/__fixtures__/simple-site/docs/ipsum.md +0 -5
  132. package/src/__tests__/__fixtures__/simple-site/docs/lorem.md +0 -6
  133. package/src/__tests__/__fixtures__/simple-site/docs/rootAbsoluteSlug.md +0 -5
  134. package/src/__tests__/__fixtures__/simple-site/docs/rootRelativeSlug.md +0 -5
  135. package/src/__tests__/__fixtures__/simple-site/docs/rootResolvedSlug.md +0 -5
  136. package/src/__tests__/__fixtures__/simple-site/docs/rootTryToEscapeSlug.md +0 -5
  137. package/src/__tests__/__fixtures__/simple-site/docs/slugs/absoluteSlug.md +0 -5
  138. package/src/__tests__/__fixtures__/simple-site/docs/slugs/relativeSlug.md +0 -5
  139. package/src/__tests__/__fixtures__/simple-site/docs/slugs/resolvedSlug.md +0 -5
  140. package/src/__tests__/__fixtures__/simple-site/docs/slugs/tryToEscapeSlug.md +0 -5
  141. package/src/__tests__/__fixtures__/simple-site/docusaurus.config.js +0 -14
  142. package/src/__tests__/__fixtures__/simple-site/sidebars.json +0 -23
  143. package/src/__tests__/__fixtures__/simple-site/wrong-sidebars.json +0 -7
  144. package/src/__tests__/__fixtures__/site-with-autogenerated-sidebar/docs/0-getting-started.md +0 -3
  145. package/src/__tests__/__fixtures__/site-with-autogenerated-sidebar/docs/1-installation.md +0 -3
  146. package/src/__tests__/__fixtures__/site-with-autogenerated-sidebar/docs/3-API/00_api-overview.md +0 -3
  147. package/src/__tests__/__fixtures__/site-with-autogenerated-sidebar/docs/3-API/01_Core APIs/0 --- Client API.md +0 -1
  148. package/src/__tests__/__fixtures__/site-with-autogenerated-sidebar/docs/3-API/01_Core APIs/1 --- Server API.md +0 -1
  149. package/src/__tests__/__fixtures__/site-with-autogenerated-sidebar/docs/3-API/02_Extension APIs/0. Plugin API.md +0 -1
  150. package/src/__tests__/__fixtures__/site-with-autogenerated-sidebar/docs/3-API/02_Extension APIs/1. Theme API.md +0 -1
  151. package/src/__tests__/__fixtures__/site-with-autogenerated-sidebar/docs/3-API/02_Extension APIs/_category_.yml +0 -1
  152. package/src/__tests__/__fixtures__/site-with-autogenerated-sidebar/docs/3-API/03_api-end.md +0 -3
  153. package/src/__tests__/__fixtures__/site-with-autogenerated-sidebar/docs/3-API/_category_.json +0 -3
  154. package/src/__tests__/__fixtures__/site-with-autogenerated-sidebar/docs/Guides/0-guide2.5.md +0 -8
  155. package/src/__tests__/__fixtures__/site-with-autogenerated-sidebar/docs/Guides/02-guide2.md +0 -7
  156. package/src/__tests__/__fixtures__/site-with-autogenerated-sidebar/docs/Guides/_category_.json +0 -3
  157. package/src/__tests__/__fixtures__/site-with-autogenerated-sidebar/docs/Guides/a-guide4.md +0 -7
  158. package/src/__tests__/__fixtures__/site-with-autogenerated-sidebar/docs/Guides/b-guide5.md +0 -7
  159. package/src/__tests__/__fixtures__/site-with-autogenerated-sidebar/docs/Guides/guide3.md +0 -8
  160. package/src/__tests__/__fixtures__/site-with-autogenerated-sidebar/docs/Guides/z-guide1.md +0 -8
  161. package/src/__tests__/__fixtures__/site-with-autogenerated-sidebar/partialAutogeneratedSidebars.js +0 -23
  162. package/src/__tests__/__fixtures__/site-with-autogenerated-sidebar/partialAutogeneratedSidebars2.js +0 -16
  163. package/src/__tests__/__fixtures__/site-with-doc-label/docs/hello-1.md +0 -7
  164. package/src/__tests__/__fixtures__/site-with-doc-label/docs/hello-2.md +0 -8
  165. package/src/__tests__/__fixtures__/site-with-doc-label/docusaurus.config.js +0 -14
  166. package/src/__tests__/__fixtures__/site-with-doc-label/sidebars.json +0 -14
  167. package/src/__tests__/__fixtures__/versioned-site/community/team.md +0 -1
  168. package/src/__tests__/__fixtures__/versioned-site/community_sidebars.json +0 -3
  169. package/src/__tests__/__fixtures__/versioned-site/community_versioned_docs/version-1.0.0/team.md +0 -1
  170. package/src/__tests__/__fixtures__/versioned-site/community_versioned_sidebars/version-1.0.0-sidebars.json +0 -3
  171. package/src/__tests__/__fixtures__/versioned-site/community_versions.json +0 -1
  172. package/src/__tests__/__fixtures__/versioned-site/docs/foo/bar.md +0 -4
  173. package/src/__tests__/__fixtures__/versioned-site/docs/hello.md +0 -1
  174. package/src/__tests__/__fixtures__/versioned-site/docs/slugs/absoluteSlug.md +0 -5
  175. package/src/__tests__/__fixtures__/versioned-site/docs/slugs/relativeSlug.md +0 -5
  176. package/src/__tests__/__fixtures__/versioned-site/docs/slugs/resolvedSlug.md +0 -5
  177. package/src/__tests__/__fixtures__/versioned-site/docs/slugs/tryToEscapeSlug.md +0 -5
  178. package/src/__tests__/__fixtures__/versioned-site/docusaurus.config.js +0 -18
  179. package/src/__tests__/__fixtures__/versioned-site/i18n/en/docusaurus-plugin-content-docs/version-1.0.0/hello.md +0 -1
  180. package/src/__tests__/__fixtures__/versioned-site/i18n/en/docusaurus-plugin-content-docs-community/current/team.md +0 -5
  181. package/src/__tests__/__fixtures__/versioned-site/i18n/fr/docusaurus-plugin-content-docs/version-1.0.0/hello.md +0 -1
  182. package/src/__tests__/__fixtures__/versioned-site/sidebars.json +0 -10
  183. package/src/__tests__/__fixtures__/versioned-site/versioned_docs/version-1.0.0/foo/bar.md +0 -4
  184. package/src/__tests__/__fixtures__/versioned-site/versioned_docs/version-1.0.0/foo/baz.md +0 -1
  185. package/src/__tests__/__fixtures__/versioned-site/versioned_docs/version-1.0.0/hello.md +0 -1
  186. package/src/__tests__/__fixtures__/versioned-site/versioned_docs/version-1.0.1/_partials/somePartial.md +0 -3
  187. package/src/__tests__/__fixtures__/versioned-site/versioned_docs/version-1.0.1/_partials/subfolder/somePartial.md +0 -3
  188. package/src/__tests__/__fixtures__/versioned-site/versioned_docs/version-1.0.1/_somePartial.md +0 -3
  189. package/src/__tests__/__fixtures__/versioned-site/versioned_docs/version-1.0.1/foo/bar.md +0 -1
  190. package/src/__tests__/__fixtures__/versioned-site/versioned_docs/version-1.0.1/hello.md +0 -1
  191. package/src/__tests__/__fixtures__/versioned-site/versioned_docs/version-withSlugs/rootAbsoluteSlug.md +0 -5
  192. package/src/__tests__/__fixtures__/versioned-site/versioned_docs/version-withSlugs/rootRelativeSlug.md +0 -5
  193. package/src/__tests__/__fixtures__/versioned-site/versioned_docs/version-withSlugs/rootResolvedSlug.md +0 -5
  194. package/src/__tests__/__fixtures__/versioned-site/versioned_docs/version-withSlugs/rootTryToEscapeSlug.md +0 -5
  195. package/src/__tests__/__fixtures__/versioned-site/versioned_docs/version-withSlugs/slugs/absoluteSlug.md +0 -5
  196. package/src/__tests__/__fixtures__/versioned-site/versioned_docs/version-withSlugs/slugs/relativeSlug.md +0 -5
  197. package/src/__tests__/__fixtures__/versioned-site/versioned_docs/version-withSlugs/slugs/resolvedSlug.md +0 -5
  198. package/src/__tests__/__fixtures__/versioned-site/versioned_docs/version-withSlugs/slugs/tryToEscapeSlug.md +0 -5
  199. package/src/__tests__/__fixtures__/versioned-site/versioned_sidebars/version-1.0.0-sidebars.json +0 -11
  200. package/src/__tests__/__fixtures__/versioned-site/versioned_sidebars/version-1.0.1-sidebars.json +0 -10
  201. package/src/__tests__/__fixtures__/versioned-site/versioned_sidebars/version-withSlugs-sidebars.json +0 -5
  202. package/src/__tests__/__fixtures__/versioned-site/versions.json +0 -5
  203. package/src/__tests__/__snapshots__/cli.test.ts.snap +0 -95
  204. package/src/__tests__/__snapshots__/index.test.ts.snap +0 -1926
  205. package/src/__tests__/__snapshots__/sidebars.test.ts.snap +0 -233
  206. package/src/__tests__/__snapshots__/translations.test.ts.snap +0 -484
  207. package/src/__tests__/cli.test.ts +0 -337
  208. package/src/__tests__/docFrontMatter.test.ts +0 -244
  209. package/src/__tests__/docs.test.ts +0 -878
  210. package/src/__tests__/index.test.ts +0 -1885
  211. package/src/__tests__/lastUpdate.test.ts +0 -69
  212. package/src/__tests__/numberPrefix.test.ts +0 -199
  213. package/src/__tests__/options.test.ts +0 -272
  214. package/src/__tests__/sidebarItemsGenerator.test.ts +0 -358
  215. package/src/__tests__/sidebars.test.ts +0 -746
  216. package/src/__tests__/slug.test.ts +0 -109
  217. package/src/__tests__/translations.test.ts +0 -158
  218. package/src/__tests__/versions.test.ts +0 -741
  219. package/src/client/__tests__/docsClientUtils.test.ts +0 -371
  220. package/src/docFrontMatter.ts +0 -41
  221. package/src/markdown/__tests__/__fixtures__/docs/doc-localized.md +0 -1
  222. package/src/markdown/__tests__/__fixtures__/docs/doc1.md +0 -13
  223. package/src/markdown/__tests__/__fixtures__/docs/doc2.md +0 -12
  224. package/src/markdown/__tests__/__fixtures__/docs/doc4.md +0 -19
  225. package/src/markdown/__tests__/__fixtures__/docs/doc5.md +0 -6
  226. package/src/markdown/__tests__/__fixtures__/docs/subdir/doc3.md +0 -3
  227. package/src/markdown/__tests__/__fixtures__/versioned_docs/version-1.0.0/doc2.md +0 -7
  228. package/src/markdown/__tests__/__fixtures__/versioned_docs/version-1.0.0/subdir/doc1.md +0 -3
  229. package/src/markdown/__tests__/__snapshots__/linkify.test.ts.snap +0 -82
  230. package/src/markdown/__tests__/linkify.test.ts +0 -190
  231. package/src/sidebarItemsGenerator.ts +0 -315
  232. package/src/sidebars.ts +0 -589
  233. package/src/theme/hooks/useDocs.ts +0 -103
  234. package/src/versions.ts +0 -572
  235. package/tsconfig.json +0 -9
  236. package/types.d.ts +0 -13
@@ -1,741 +0,0 @@
1
- /**
2
- * Copyright (c) Facebook, Inc. and its affiliates.
3
- *
4
- * This source code is licensed under the MIT license found in the
5
- * LICENSE file in the root directory of this source tree.
6
- */
7
-
8
- import path from 'path';
9
- import {
10
- getVersionsFilePath,
11
- getVersionedDocsDirPath,
12
- getVersionedSidebarsDirPath,
13
- readVersionsMetadata,
14
- } from '../versions';
15
- import {DEFAULT_OPTIONS} from '../options';
16
- import {DEFAULT_PLUGIN_ID} from '@docusaurus/core/lib/constants';
17
- import {PluginOptions, VersionMetadata} from '../types';
18
- import {I18n} from '@docusaurus/types';
19
-
20
- const DefaultI18N: I18n = {
21
- currentLocale: 'en',
22
- locales: ['en'],
23
- defaultLocale: 'en',
24
- localeConfigs: {},
25
- };
26
-
27
- describe('version paths', () => {
28
- test('getVersionsFilePath', () => {
29
- expect(getVersionsFilePath('someSiteDir', DEFAULT_PLUGIN_ID)).toBe(
30
- `someSiteDir${path.sep}versions.json`,
31
- );
32
- expect(getVersionsFilePath('otherSite/dir', 'pluginId')).toBe(
33
- `otherSite${path.sep}dir${path.sep}pluginId_versions.json`,
34
- );
35
- });
36
-
37
- test('getVersionedDocsDirPath', () => {
38
- expect(getVersionedDocsDirPath('someSiteDir', DEFAULT_PLUGIN_ID)).toBe(
39
- `someSiteDir${path.sep}versioned_docs`,
40
- );
41
- expect(getVersionedDocsDirPath('otherSite/dir', 'pluginId')).toBe(
42
- `otherSite${path.sep}dir${path.sep}pluginId_versioned_docs`,
43
- );
44
- });
45
-
46
- test('getVersionedSidebarsDirPath', () => {
47
- expect(getVersionedSidebarsDirPath('someSiteDir', DEFAULT_PLUGIN_ID)).toBe(
48
- `someSiteDir${path.sep}versioned_sidebars`,
49
- );
50
- expect(getVersionedSidebarsDirPath('otherSite/dir', 'pluginId')).toBe(
51
- `otherSite${path.sep}dir${path.sep}pluginId_versioned_sidebars`,
52
- );
53
- });
54
- });
55
-
56
- describe('simple site', () => {
57
- async function loadSite() {
58
- const simpleSiteDir = path.resolve(
59
- path.join(__dirname, '__fixtures__', 'simple-site'),
60
- );
61
- const defaultOptions: PluginOptions = {
62
- id: DEFAULT_PLUGIN_ID,
63
- ...DEFAULT_OPTIONS,
64
- };
65
- const defaultContext = {
66
- siteDir: simpleSiteDir,
67
- baseUrl: '/',
68
- i18n: DefaultI18N,
69
- };
70
-
71
- const vCurrent: VersionMetadata = {
72
- contentPath: path.join(simpleSiteDir, 'docs'),
73
- contentPathLocalized: path.join(
74
- simpleSiteDir,
75
- 'i18n/en/docusaurus-plugin-content-docs/current',
76
- ),
77
- isLast: true,
78
- routePriority: -1,
79
- sidebarFilePath: undefined,
80
- versionLabel: 'Next',
81
- versionName: 'current',
82
- versionPath: '/docs',
83
- versionBanner: 'none',
84
- };
85
- return {simpleSiteDir, defaultOptions, defaultContext, vCurrent};
86
- }
87
-
88
- test('readVersionsMetadata simple site', async () => {
89
- const {defaultOptions, defaultContext, vCurrent} = await loadSite();
90
-
91
- const versionsMetadata = readVersionsMetadata({
92
- options: defaultOptions,
93
- context: defaultContext,
94
- });
95
-
96
- expect(versionsMetadata).toEqual([vCurrent]);
97
- });
98
-
99
- test('readVersionsMetadata simple site with base url', async () => {
100
- const {defaultOptions, defaultContext, vCurrent} = await loadSite();
101
-
102
- const versionsMetadata = readVersionsMetadata({
103
- options: defaultOptions,
104
- context: {
105
- ...defaultContext,
106
- baseUrl: '/myBaseUrl',
107
- },
108
- });
109
-
110
- expect(versionsMetadata).toEqual([
111
- {
112
- ...vCurrent,
113
- versionPath: '/myBaseUrl/docs',
114
- },
115
- ]);
116
- });
117
-
118
- test('readVersionsMetadata simple site with current version config', async () => {
119
- const {defaultOptions, defaultContext, vCurrent} = await loadSite();
120
-
121
- const versionsMetadata = readVersionsMetadata({
122
- options: {
123
- ...defaultOptions,
124
- versions: {
125
- current: {
126
- label: 'current-label',
127
- path: 'current-path',
128
- },
129
- },
130
- },
131
- context: {
132
- ...defaultContext,
133
- baseUrl: '/myBaseUrl',
134
- },
135
- });
136
-
137
- expect(versionsMetadata).toEqual([
138
- {
139
- ...vCurrent,
140
- versionPath: '/myBaseUrl/docs/current-path',
141
- versionLabel: 'current-label',
142
- routePriority: undefined,
143
- sidebarFilePath: undefined,
144
- versionEditUrl: undefined,
145
- versionEditUrlLocalized: undefined,
146
- },
147
- ]);
148
- });
149
-
150
- test('readVersionsMetadata simple site with unknown lastVersion should throw', async () => {
151
- const {defaultOptions, defaultContext} = await loadSite();
152
-
153
- expect(() =>
154
- readVersionsMetadata({
155
- options: {...defaultOptions, lastVersion: 'unknownVersionName'},
156
- context: defaultContext,
157
- }),
158
- ).toThrowErrorMatchingInlineSnapshot(
159
- `"Docs option lastVersion=unknownVersionName is invalid. Available version names are: current"`,
160
- );
161
- });
162
-
163
- test('readVersionsMetadata simple site with unknown version configurations should throw', async () => {
164
- const {defaultOptions, defaultContext} = await loadSite();
165
-
166
- expect(() =>
167
- readVersionsMetadata({
168
- options: {
169
- ...defaultOptions,
170
- versions: {
171
- current: {label: 'current'},
172
- unknownVersionName1: {label: 'unknownVersionName1'},
173
- unknownVersionName2: {label: 'unknownVersionName2'},
174
- },
175
- },
176
- context: defaultContext,
177
- }),
178
- ).toThrowErrorMatchingInlineSnapshot(
179
- `"Invalid docs option \\"versions\\": unknown versions (unknownVersionName1,unknownVersionName2) found. Available version names are: current"`,
180
- );
181
- });
182
-
183
- test('readVersionsMetadata simple site with disableVersioning while single version should throw', async () => {
184
- const {defaultOptions, defaultContext} = await loadSite();
185
-
186
- expect(() =>
187
- readVersionsMetadata({
188
- options: {...defaultOptions, disableVersioning: true},
189
- context: defaultContext,
190
- }),
191
- ).toThrowErrorMatchingInlineSnapshot(
192
- `"Docs: using \\"disableVersioning=true\\" option on a non-versioned site does not make sense."`,
193
- );
194
- });
195
-
196
- test('readVersionsMetadata simple site without including current version should throw', async () => {
197
- const {defaultOptions, defaultContext} = await loadSite();
198
-
199
- expect(() =>
200
- readVersionsMetadata({
201
- options: {...defaultOptions, includeCurrentVersion: false},
202
- context: defaultContext,
203
- }),
204
- ).toThrowErrorMatchingInlineSnapshot(
205
- `"It is not possible to use docs without any version. Please check the configuration of these options: \\"includeCurrentVersion=false\\", \\"disableVersioning=false\\"."`,
206
- );
207
- });
208
- });
209
-
210
- describe('versioned site, pluginId=default', () => {
211
- async function loadSite() {
212
- const versionedSiteDir = path.resolve(
213
- path.join(__dirname, '__fixtures__', 'versioned-site'),
214
- );
215
- const defaultOptions: PluginOptions = {
216
- id: DEFAULT_PLUGIN_ID,
217
- ...DEFAULT_OPTIONS,
218
- sidebarPath: 'sidebars.json',
219
- };
220
- const defaultContext = {
221
- siteDir: versionedSiteDir,
222
- baseUrl: '/',
223
- i18n: DefaultI18N,
224
- };
225
-
226
- const vCurrent: VersionMetadata = {
227
- contentPath: path.join(versionedSiteDir, 'docs'),
228
- contentPathLocalized: path.join(
229
- versionedSiteDir,
230
- 'i18n/en/docusaurus-plugin-content-docs/current',
231
- ),
232
- isLast: false,
233
- routePriority: undefined,
234
- sidebarFilePath: path.join(versionedSiteDir, 'sidebars.json'),
235
- versionLabel: 'Next',
236
- versionName: 'current',
237
- versionPath: '/docs/next',
238
- versionBanner: 'unreleased',
239
- };
240
-
241
- const v101: VersionMetadata = {
242
- contentPath: path.join(versionedSiteDir, 'versioned_docs/version-1.0.1'),
243
- contentPathLocalized: path.join(
244
- versionedSiteDir,
245
- 'i18n/en/docusaurus-plugin-content-docs/version-1.0.1',
246
- ),
247
- isLast: true,
248
- routePriority: -1,
249
- sidebarFilePath: path.join(
250
- versionedSiteDir,
251
- 'versioned_sidebars/version-1.0.1-sidebars.json',
252
- ),
253
- versionLabel: '1.0.1',
254
- versionName: '1.0.1',
255
- versionPath: '/docs',
256
- versionBanner: 'none',
257
- };
258
-
259
- const v100: VersionMetadata = {
260
- contentPath: path.join(versionedSiteDir, 'versioned_docs/version-1.0.0'),
261
- contentPathLocalized: path.join(
262
- versionedSiteDir,
263
- 'i18n/en/docusaurus-plugin-content-docs/version-1.0.0',
264
- ),
265
- isLast: false,
266
- routePriority: undefined,
267
- sidebarFilePath: path.join(
268
- versionedSiteDir,
269
- 'versioned_sidebars/version-1.0.0-sidebars.json',
270
- ),
271
- versionLabel: '1.0.0',
272
- versionName: '1.0.0',
273
- versionPath: '/docs/1.0.0',
274
- versionBanner: 'unmaintained',
275
- };
276
-
277
- const vwithSlugs: VersionMetadata = {
278
- contentPath: path.join(
279
- versionedSiteDir,
280
- 'versioned_docs/version-withSlugs',
281
- ),
282
- contentPathLocalized: path.join(
283
- versionedSiteDir,
284
- 'i18n/en/docusaurus-plugin-content-docs/version-withSlugs',
285
- ),
286
- isLast: false,
287
- routePriority: undefined,
288
- sidebarFilePath: path.join(
289
- versionedSiteDir,
290
- 'versioned_sidebars/version-withSlugs-sidebars.json',
291
- ),
292
- versionLabel: 'withSlugs',
293
- versionName: 'withSlugs',
294
- versionPath: '/docs/withSlugs',
295
- versionBanner: 'unmaintained',
296
- };
297
-
298
- return {
299
- versionedSiteDir,
300
- defaultOptions,
301
- defaultContext,
302
- vCurrent,
303
- v101,
304
- v100,
305
- vwithSlugs,
306
- };
307
- }
308
-
309
- test('readVersionsMetadata versioned site', async () => {
310
- const {
311
- defaultOptions,
312
- defaultContext,
313
- vCurrent,
314
- v101,
315
- v100,
316
- vwithSlugs,
317
- } = await loadSite();
318
-
319
- const versionsMetadata = readVersionsMetadata({
320
- options: defaultOptions,
321
- context: defaultContext,
322
- });
323
-
324
- expect(versionsMetadata).toEqual([vCurrent, v101, v100, vwithSlugs]);
325
- });
326
-
327
- test('readVersionsMetadata versioned site with includeCurrentVersion=false', async () => {
328
- const {
329
- defaultOptions,
330
- defaultContext,
331
- v101,
332
- v100,
333
- vwithSlugs,
334
- } = await loadSite();
335
-
336
- const versionsMetadata = readVersionsMetadata({
337
- options: {...defaultOptions, includeCurrentVersion: false},
338
- context: defaultContext,
339
- });
340
-
341
- expect(versionsMetadata).toEqual([
342
- // vCurrent removed
343
- v101,
344
- v100,
345
- vwithSlugs,
346
- ]);
347
- });
348
-
349
- test('readVersionsMetadata versioned site with version options', async () => {
350
- const {
351
- defaultOptions,
352
- defaultContext,
353
- vCurrent,
354
- v101,
355
- v100,
356
- vwithSlugs,
357
- } = await loadSite();
358
-
359
- const versionsMetadata = readVersionsMetadata({
360
- options: {
361
- ...defaultOptions,
362
- lastVersion: '1.0.0',
363
- versions: {
364
- current: {
365
- path: 'current-path',
366
- banner: 'unmaintained',
367
- },
368
- '1.0.0': {
369
- label: '1.0.0-label',
370
- banner: 'unreleased',
371
- },
372
- },
373
- },
374
- context: defaultContext,
375
- });
376
-
377
- expect(versionsMetadata).toEqual([
378
- {
379
- ...vCurrent,
380
- versionPath: '/docs/current-path',
381
- versionBanner: 'unmaintained',
382
- },
383
- {
384
- ...v101,
385
- isLast: false,
386
- routePriority: undefined,
387
- versionPath: '/docs/1.0.1',
388
- versionBanner: 'unreleased',
389
- },
390
- {
391
- ...v100,
392
- isLast: true,
393
- routePriority: -1,
394
- versionLabel: '1.0.0-label',
395
- versionPath: '/docs',
396
- versionBanner: 'unreleased',
397
- },
398
- vwithSlugs,
399
- ]);
400
- });
401
-
402
- test('readVersionsMetadata versioned site with editUrl', async () => {
403
- const {
404
- defaultOptions,
405
- defaultContext,
406
- vCurrent,
407
- v101,
408
- v100,
409
- vwithSlugs,
410
- } = await loadSite();
411
-
412
- const versionsMetadata = readVersionsMetadata({
413
- options: {
414
- ...defaultOptions,
415
- editUrl: 'https://github.com/facebook/docusaurus/edit/master/website/',
416
- },
417
- context: defaultContext,
418
- });
419
-
420
- expect(versionsMetadata).toEqual([
421
- {
422
- ...vCurrent,
423
- versionEditUrl:
424
- 'https://github.com/facebook/docusaurus/edit/master/website/docs',
425
- versionEditUrlLocalized:
426
- 'https://github.com/facebook/docusaurus/edit/master/website/i18n/en/docusaurus-plugin-content-docs/current',
427
- },
428
- {
429
- ...v101,
430
- versionEditUrl:
431
- 'https://github.com/facebook/docusaurus/edit/master/website/versioned_docs/version-1.0.1',
432
- versionEditUrlLocalized:
433
- 'https://github.com/facebook/docusaurus/edit/master/website/i18n/en/docusaurus-plugin-content-docs/version-1.0.1',
434
- },
435
- {
436
- ...v100,
437
- versionEditUrl:
438
- 'https://github.com/facebook/docusaurus/edit/master/website/versioned_docs/version-1.0.0',
439
- versionEditUrlLocalized:
440
- 'https://github.com/facebook/docusaurus/edit/master/website/i18n/en/docusaurus-plugin-content-docs/version-1.0.0',
441
- },
442
- {
443
- ...vwithSlugs,
444
- versionEditUrl:
445
- 'https://github.com/facebook/docusaurus/edit/master/website/versioned_docs/version-withSlugs',
446
- versionEditUrlLocalized:
447
- 'https://github.com/facebook/docusaurus/edit/master/website/i18n/en/docusaurus-plugin-content-docs/version-withSlugs',
448
- },
449
- ]);
450
- });
451
-
452
- test('readVersionsMetadata versioned site with editUrl and editCurrentVersion=true', async () => {
453
- const {
454
- defaultOptions,
455
- defaultContext,
456
- vCurrent,
457
- v101,
458
- v100,
459
- vwithSlugs,
460
- } = await loadSite();
461
-
462
- const versionsMetadata = readVersionsMetadata({
463
- options: {
464
- ...defaultOptions,
465
- editUrl: 'https://github.com/facebook/docusaurus/edit/master/website/',
466
- editCurrentVersion: true,
467
- },
468
- context: defaultContext,
469
- });
470
-
471
- expect(versionsMetadata).toEqual([
472
- {
473
- ...vCurrent,
474
- versionEditUrl:
475
- 'https://github.com/facebook/docusaurus/edit/master/website/docs',
476
- versionEditUrlLocalized:
477
- 'https://github.com/facebook/docusaurus/edit/master/website/i18n/en/docusaurus-plugin-content-docs/current',
478
- },
479
- {
480
- ...v101,
481
- versionEditUrl:
482
- 'https://github.com/facebook/docusaurus/edit/master/website/docs',
483
- versionEditUrlLocalized:
484
- 'https://github.com/facebook/docusaurus/edit/master/website/i18n/en/docusaurus-plugin-content-docs/current',
485
- },
486
- {
487
- ...v100,
488
- versionEditUrl:
489
- 'https://github.com/facebook/docusaurus/edit/master/website/docs',
490
- versionEditUrlLocalized:
491
- 'https://github.com/facebook/docusaurus/edit/master/website/i18n/en/docusaurus-plugin-content-docs/current',
492
- },
493
- {
494
- ...vwithSlugs,
495
- versionEditUrl:
496
- 'https://github.com/facebook/docusaurus/edit/master/website/docs',
497
- versionEditUrlLocalized:
498
- 'https://github.com/facebook/docusaurus/edit/master/website/i18n/en/docusaurus-plugin-content-docs/current',
499
- },
500
- ]);
501
- });
502
-
503
- test('readVersionsMetadata versioned site with onlyIncludeVersions option', async () => {
504
- const {defaultOptions, defaultContext, v101, vwithSlugs} = await loadSite();
505
-
506
- const versionsMetadata = readVersionsMetadata({
507
- options: {
508
- ...defaultOptions,
509
- // Order reversed on purpose: should not have any impact
510
- onlyIncludeVersions: [vwithSlugs.versionName, v101.versionName],
511
- },
512
- context: defaultContext,
513
- });
514
-
515
- expect(versionsMetadata).toEqual([v101, vwithSlugs]);
516
- });
517
-
518
- test('readVersionsMetadata versioned site with disableVersioning', async () => {
519
- const {defaultOptions, defaultContext, vCurrent} = await loadSite();
520
-
521
- const versionsMetadata = readVersionsMetadata({
522
- options: {...defaultOptions, disableVersioning: true},
523
- context: defaultContext,
524
- });
525
-
526
- expect(versionsMetadata).toEqual([
527
- {
528
- ...vCurrent,
529
- isLast: true,
530
- routePriority: -1,
531
- versionPath: '/docs',
532
- versionBanner: 'none',
533
- },
534
- ]);
535
- });
536
-
537
- test('readVersionsMetadata versioned site with all versions disabled', async () => {
538
- const {defaultOptions, defaultContext} = await loadSite();
539
-
540
- expect(() =>
541
- readVersionsMetadata({
542
- options: {
543
- ...defaultOptions,
544
- includeCurrentVersion: false,
545
- disableVersioning: true,
546
- },
547
- context: defaultContext,
548
- }),
549
- ).toThrowErrorMatchingInlineSnapshot(
550
- `"It is not possible to use docs without any version. Please check the configuration of these options: \\"includeCurrentVersion=false\\", \\"disableVersioning=true\\"."`,
551
- );
552
- });
553
-
554
- test('readVersionsMetadata versioned site with empty onlyIncludeVersions', async () => {
555
- const {defaultOptions, defaultContext} = await loadSite();
556
-
557
- expect(() =>
558
- readVersionsMetadata({
559
- options: {
560
- ...defaultOptions,
561
- onlyIncludeVersions: [],
562
- },
563
- context: defaultContext,
564
- }),
565
- ).toThrowErrorMatchingInlineSnapshot(
566
- `"Invalid docs option \\"onlyIncludeVersions\\": an empty array is not allowed, at least one version is needed."`,
567
- );
568
- });
569
-
570
- test('readVersionsMetadata versioned site with unknown versions in onlyIncludeVersions', async () => {
571
- const {defaultOptions, defaultContext} = await loadSite();
572
-
573
- expect(() =>
574
- readVersionsMetadata({
575
- options: {
576
- ...defaultOptions,
577
- onlyIncludeVersions: ['unknownVersion1', 'unknownVersion2'],
578
- },
579
- context: defaultContext,
580
- }),
581
- ).toThrowErrorMatchingInlineSnapshot(
582
- `"Invalid docs option \\"onlyIncludeVersions\\": unknown versions (unknownVersion1,unknownVersion2) found. Available version names are: current, 1.0.1, 1.0.0, withSlugs"`,
583
- );
584
- });
585
-
586
- test('readVersionsMetadata versioned site with lastVersion not in onlyIncludeVersions', async () => {
587
- const {defaultOptions, defaultContext} = await loadSite();
588
-
589
- expect(() =>
590
- readVersionsMetadata({
591
- options: {
592
- ...defaultOptions,
593
- lastVersion: '1.0.1',
594
- onlyIncludeVersions: ['current', '1.0.0'],
595
- },
596
- context: defaultContext,
597
- }),
598
- ).toThrowErrorMatchingInlineSnapshot(
599
- `"Invalid docs option \\"lastVersion\\": if you use both the \\"onlyIncludeVersions\\" and \\"lastVersion\\" options, then \\"lastVersion\\" must be present in the provided \\"onlyIncludeVersions\\" array."`,
600
- );
601
- });
602
-
603
- test('readVersionsMetadata versioned site with invalid versions.json file', async () => {
604
- const {defaultOptions, defaultContext} = await loadSite();
605
-
606
- const mock = jest.spyOn(JSON, 'parse').mockImplementationOnce(() => {
607
- return {
608
- invalid: 'json',
609
- };
610
- });
611
-
612
- expect(() => {
613
- readVersionsMetadata({
614
- options: defaultOptions,
615
- context: defaultContext,
616
- });
617
- }).toThrowErrorMatchingInlineSnapshot(
618
- `"The versions file should contain an array of versions! Found content: {\\"invalid\\":\\"json\\"}"`,
619
- );
620
- mock.mockRestore();
621
- });
622
- });
623
-
624
- describe('versioned site, pluginId=community', () => {
625
- async function loadSite() {
626
- const versionedSiteDir = path.resolve(
627
- path.join(__dirname, '__fixtures__', 'versioned-site'),
628
- );
629
- const defaultOptions: PluginOptions = {
630
- ...DEFAULT_OPTIONS,
631
- id: 'community',
632
- path: 'community',
633
- routeBasePath: 'communityBasePath',
634
- sidebarPath: 'sidebars.json',
635
- };
636
- const defaultContext = {
637
- siteDir: versionedSiteDir,
638
- baseUrl: '/',
639
- i18n: DefaultI18N,
640
- };
641
-
642
- const vCurrent: VersionMetadata = {
643
- contentPath: path.join(versionedSiteDir, 'community'),
644
- contentPathLocalized: path.join(
645
- versionedSiteDir,
646
- 'i18n/en/docusaurus-plugin-content-docs-community/current',
647
- ),
648
- isLast: false,
649
- routePriority: undefined,
650
- sidebarFilePath: path.join(versionedSiteDir, 'sidebars.json'),
651
- versionLabel: 'Next',
652
- versionName: 'current',
653
- versionPath: '/communityBasePath/next',
654
- versionBanner: 'unreleased',
655
- };
656
-
657
- const v100: VersionMetadata = {
658
- contentPath: path.join(
659
- versionedSiteDir,
660
- 'community_versioned_docs/version-1.0.0',
661
- ),
662
- contentPathLocalized: path.join(
663
- versionedSiteDir,
664
- 'i18n/en/docusaurus-plugin-content-docs-community/version-1.0.0',
665
- ),
666
- isLast: true,
667
- routePriority: -1,
668
- sidebarFilePath: path.join(
669
- versionedSiteDir,
670
- 'community_versioned_sidebars/version-1.0.0-sidebars.json',
671
- ),
672
- versionLabel: '1.0.0',
673
- versionName: '1.0.0',
674
- versionPath: '/communityBasePath',
675
- versionBanner: 'none',
676
- };
677
-
678
- return {versionedSiteDir, defaultOptions, defaultContext, vCurrent, v100};
679
- }
680
-
681
- test('readVersionsMetadata versioned site (community)', async () => {
682
- const {defaultOptions, defaultContext, vCurrent, v100} = await loadSite();
683
-
684
- const versionsMetadata = readVersionsMetadata({
685
- options: defaultOptions,
686
- context: defaultContext,
687
- });
688
-
689
- expect(versionsMetadata).toEqual([vCurrent, v100]);
690
- });
691
-
692
- test('readVersionsMetadata versioned site (community) with includeCurrentVersion=false', async () => {
693
- const {defaultOptions, defaultContext, v100} = await loadSite();
694
-
695
- const versionsMetadata = readVersionsMetadata({
696
- options: {...defaultOptions, includeCurrentVersion: false},
697
- context: defaultContext,
698
- });
699
-
700
- expect(versionsMetadata).toEqual([
701
- // vCurrent removed
702
- v100,
703
- ]);
704
- });
705
-
706
- test('readVersionsMetadata versioned site (community) with disableVersioning', async () => {
707
- const {defaultOptions, defaultContext, vCurrent} = await loadSite();
708
-
709
- const versionsMetadata = readVersionsMetadata({
710
- options: {...defaultOptions, disableVersioning: true},
711
- context: defaultContext,
712
- });
713
-
714
- expect(versionsMetadata).toEqual([
715
- {
716
- ...vCurrent,
717
- isLast: true,
718
- routePriority: -1,
719
- versionPath: '/communityBasePath',
720
- versionBanner: 'none',
721
- },
722
- ]);
723
- });
724
-
725
- test('readVersionsMetadata versioned site (community) with all versions disabled', async () => {
726
- const {defaultOptions, defaultContext} = await loadSite();
727
-
728
- expect(() =>
729
- readVersionsMetadata({
730
- options: {
731
- ...defaultOptions,
732
- includeCurrentVersion: false,
733
- disableVersioning: true,
734
- },
735
- context: defaultContext,
736
- }),
737
- ).toThrowErrorMatchingInlineSnapshot(
738
- `"It is not possible to use docs without any version. Please check the configuration of these options: \\"includeCurrentVersion=false\\", \\"disableVersioning=true\\"."`,
739
- );
740
- });
741
- });