@mx-space/api-client 1.0.0-beta.2 → 1.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 (508) hide show
  1. package/.eslintcache +1 -0
  2. package/__tests__/adaptors/axios.spec.ts +7 -0
  3. package/__tests__/adaptors/ky.spec.ts +9 -0
  4. package/__tests__/adaptors/umi-request.spec.ts +7 -0
  5. package/__tests__/contronllers/aggregate.test.ts +389 -0
  6. package/__tests__/contronllers/category.test.ts +284 -0
  7. package/__tests__/contronllers/comment.test.ts +113 -0
  8. package/__tests__/contronllers/link.test.ts +95 -0
  9. package/__tests__/contronllers/note.test.ts +120 -0
  10. package/__tests__/contronllers/page.test.ts +49 -0
  11. package/__tests__/contronllers/post.test.ts +77 -0
  12. package/__tests__/contronllers/recently.test.ts +49 -0
  13. package/__tests__/contronllers/say.test.ts +106 -0
  14. package/__tests__/contronllers/search.test.ts +81 -0
  15. package/__tests__/contronllers/serverless.test.ts +19 -0
  16. package/__tests__/contronllers/snippet.test.ts +38 -0
  17. package/__tests__/contronllers/topic.test.ts +17 -0
  18. package/__tests__/contronllers/user.test.ts +59 -0
  19. package/__tests__/core/client.test.ts +293 -0
  20. package/__tests__/helpers/adaptor-test.ts +108 -0
  21. package/__tests__/helpers/e2e-mock-server.ts +22 -0
  22. package/__tests__/helpers/global-fetch.ts +39 -0
  23. package/__tests__/helpers/instance.ts +11 -0
  24. package/__tests__/helpers/response.ts +76 -0
  25. package/__tests__/mock/algolia.json +446 -0
  26. package/__tests__/utils/auto-bind.spec.ts +27 -0
  27. package/__tests__/utils/camelcase-keys.spec.ts +86 -0
  28. package/__tests__/utils/index.test.ts +33 -0
  29. package/__tests__/utils/path.spec.ts +8 -0
  30. package/adaptors/axios.ts +44 -0
  31. package/adaptors/ky.ts +76 -0
  32. package/adaptors/umi-request.ts +38 -0
  33. package/controllers/aggregate.ts +6 -6
  34. package/controllers/base.ts +3 -3
  35. package/controllers/category.ts +7 -7
  36. package/controllers/comment.ts +8 -8
  37. package/controllers/link.ts +3 -3
  38. package/controllers/note.ts +15 -11
  39. package/controllers/page.ts +7 -7
  40. package/controllers/post.ts +9 -9
  41. package/controllers/project.ts +3 -3
  42. package/controllers/recently.ts +5 -5
  43. package/controllers/say.ts +5 -5
  44. package/controllers/search.ts +8 -8
  45. package/controllers/severless.ts +4 -4
  46. package/controllers/snippet.ts +4 -4
  47. package/controllers/topic.ts +5 -5
  48. package/controllers/user.ts +5 -5
  49. package/core/attach-request.ts +43 -0
  50. package/core/client.ts +252 -0
  51. package/core/error.ts +10 -0
  52. package/core/index.ts +2 -0
  53. package/coverage/lcov-report/__tests__/helpers/adaptor-test.ts.html +405 -0
  54. package/coverage/lcov-report/__tests__/helpers/e2e-mock-server.ts.html +150 -0
  55. package/coverage/lcov-report/__tests__/helpers/index.html +236 -0
  56. package/coverage/lcov-report/__tests__/helpers/instance.ts.html +120 -0
  57. package/coverage/lcov-report/__tests__/helpers/response.ts.html +231 -0
  58. package/dist/adaptors/axios.cjs.map +1 -1
  59. package/dist/adaptors/axios.d.ts +2 -2
  60. package/dist/adaptors/axios.js.map +1 -1
  61. package/dist/adaptors/axios.min.cjs.map +1 -1
  62. package/dist/adaptors/axios.min.js.map +1 -1
  63. package/dist/adaptors/axios.umd.js.map +1 -1
  64. package/dist/adaptors/axios.umd.min.js.map +1 -1
  65. package/dist/adaptors/ky.cjs.map +1 -1
  66. package/dist/adaptors/ky.d.ts +1 -1
  67. package/dist/adaptors/ky.js.map +1 -1
  68. package/dist/adaptors/ky.min.cjs +1 -1
  69. package/dist/adaptors/ky.min.cjs.map +1 -1
  70. package/dist/adaptors/ky.min.js +1 -1
  71. package/dist/adaptors/ky.min.js.map +1 -1
  72. package/dist/adaptors/ky.umd.js.map +1 -1
  73. package/dist/adaptors/ky.umd.min.js +1 -1
  74. package/dist/adaptors/ky.umd.min.js.map +1 -1
  75. package/dist/adaptors/umi-request.cjs.map +1 -1
  76. package/dist/adaptors/umi-request.d.ts +2 -2
  77. package/dist/adaptors/umi-request.js.map +1 -1
  78. package/dist/adaptors/umi-request.min.cjs.map +1 -1
  79. package/dist/adaptors/umi-request.min.js.map +1 -1
  80. package/dist/adaptors/umi-request.umd.js.map +1 -1
  81. package/dist/adaptors/umi-request.umd.min.js.map +1 -1
  82. package/dist/index.cjs.map +1 -1
  83. package/dist/index.js.map +1 -1
  84. package/dist/index.min.cjs.map +1 -1
  85. package/dist/index.min.js.map +1 -1
  86. package/dist/index.umd.js.map +1 -1
  87. package/dist/index.umd.min.js.map +1 -1
  88. package/index.ts +1 -0
  89. package/interfaces/adapter.ts +1 -1
  90. package/interfaces/client.ts +2 -2
  91. package/interfaces/request.ts +1 -1
  92. package/models/aggregate.ts +7 -7
  93. package/models/base.ts +4 -0
  94. package/models/category.ts +2 -2
  95. package/models/comment.ts +2 -2
  96. package/models/link.ts +1 -1
  97. package/models/note.ts +8 -2
  98. package/models/page.ts +1 -1
  99. package/models/post.ts +2 -2
  100. package/models/project.ts +1 -1
  101. package/models/recently.ts +5 -10
  102. package/models/say.ts +1 -1
  103. package/models/snippet.ts +1 -1
  104. package/models/topic.ts +1 -1
  105. package/models/user.ts +1 -1
  106. package/package.json +9 -29
  107. package/rollup.config.js +150 -0
  108. package/utils/auto-bind.ts +48 -0
  109. package/utils/camelcase-keys.ts +26 -0
  110. package/utils/index.ts +53 -0
  111. package/utils/path.ts +6 -0
  112. package/build/index.cjs.js +0 -980
  113. package/build/index.cjs.js.map +0 -1
  114. package/build/index.cjs.min.js +0 -2
  115. package/build/index.cjs.min.js.map +0 -1
  116. package/build/index.esm.min.mjs +0 -2
  117. package/build/index.esm.min.mjs.map +0 -1
  118. package/build/index.esm.mjs +0 -958
  119. package/build/index.esm.mjs.map +0 -1
  120. package/build/index.umd.js +0 -986
  121. package/build/index.umd.js.map +0 -1
  122. package/build/index.umd.min.js +0 -2
  123. package/build/index.umd.min.js.map +0 -1
  124. package/esm/adaptors/axios.d.ts +0 -4
  125. package/esm/adaptors/axios.js +0 -36
  126. package/esm/adaptors/axios.js.map +0 -1
  127. package/esm/adaptors/ky.d.ts +0 -23
  128. package/esm/adaptors/ky.js +0 -61
  129. package/esm/adaptors/ky.js.map +0 -1
  130. package/esm/adaptors/umi-request.d.ts +0 -4
  131. package/esm/adaptors/umi-request.js +0 -30
  132. package/esm/adaptors/umi-request.js.map +0 -1
  133. package/esm/controllers/aggregate.d.ts +0 -64
  134. package/esm/controllers/aggregate.js +0 -42
  135. package/esm/controllers/aggregate.js.map +0 -1
  136. package/esm/controllers/base.d.ts +0 -43
  137. package/esm/controllers/base.js +0 -27
  138. package/esm/controllers/base.js.map +0 -1
  139. package/esm/controllers/category.d.ts +0 -115
  140. package/esm/controllers/category.js +0 -68
  141. package/esm/controllers/category.js.map +0 -1
  142. package/esm/controllers/comment.d.ts +0 -81
  143. package/esm/controllers/comment.js +0 -47
  144. package/esm/controllers/comment.js.map +0 -1
  145. package/esm/controllers/index.d.ts +0 -18
  146. package/esm/controllers/index.js +0 -55
  147. package/esm/controllers/index.js.map +0 -1
  148. package/esm/controllers/link.d.ts +0 -20
  149. package/esm/controllers/link.js +0 -21
  150. package/esm/controllers/link.js.map +0 -1
  151. package/esm/controllers/note.d.ts +0 -103
  152. package/esm/controllers/note.js +0 -68
  153. package/esm/controllers/note.js.map +0 -1
  154. package/esm/controllers/page.d.ts +0 -59
  155. package/esm/controllers/page.js +0 -42
  156. package/esm/controllers/page.js.map +0 -1
  157. package/esm/controllers/post.d.ts +0 -72
  158. package/esm/controllers/post.js +0 -52
  159. package/esm/controllers/post.js.map +0 -1
  160. package/esm/controllers/project.d.ts +0 -15
  161. package/esm/controllers/project.js +0 -12
  162. package/esm/controllers/project.js.map +0 -1
  163. package/esm/controllers/recently.d.ts +0 -61
  164. package/esm/controllers/recently.js +0 -31
  165. package/esm/controllers/recently.js.map +0 -1
  166. package/esm/controllers/say.d.ts +0 -37
  167. package/esm/controllers/say.js +0 -21
  168. package/esm/controllers/say.js.map +0 -1
  169. package/esm/controllers/search.d.ts +0 -247
  170. package/esm/controllers/search.js +0 -28
  171. package/esm/controllers/search.js.map +0 -1
  172. package/esm/controllers/severless.d.ts +0 -24
  173. package/esm/controllers/severless.js +0 -16
  174. package/esm/controllers/severless.js.map +0 -1
  175. package/esm/controllers/snippet.d.ts +0 -24
  176. package/esm/controllers/snippet.js +0 -19
  177. package/esm/controllers/snippet.js.map +0 -1
  178. package/esm/controllers/topic.d.ts +0 -26
  179. package/esm/controllers/topic.js +0 -18
  180. package/esm/controllers/topic.js.map +0 -1
  181. package/esm/controllers/user.d.ts +0 -70
  182. package/esm/controllers/user.js +0 -40
  183. package/esm/controllers/user.js.map +0 -1
  184. package/esm/core/attach-request.d.ts +0 -2
  185. package/esm/core/attach-request.js +0 -36
  186. package/esm/core/attach-request.js.map +0 -1
  187. package/esm/core/client.d.ts +0 -29
  188. package/esm/core/client.js +0 -186
  189. package/esm/core/client.js.map +0 -1
  190. package/esm/core/error.d.ts +0 -6
  191. package/esm/core/error.js +0 -9
  192. package/esm/core/error.js.map +0 -1
  193. package/esm/core/index.d.ts +0 -2
  194. package/esm/core/index.js +0 -3
  195. package/esm/core/index.js.map +0 -1
  196. package/esm/dtos/comment.d.ts +0 -6
  197. package/esm/dtos/comment.js +0 -3
  198. package/esm/dtos/comment.js.map +0 -1
  199. package/esm/index.d.ts +0 -7
  200. package/esm/index.js +0 -7
  201. package/esm/index.js.map +0 -1
  202. package/esm/interfaces/adapter.d.ts +0 -14
  203. package/esm/interfaces/adapter.js +0 -2
  204. package/esm/interfaces/adapter.js.map +0 -1
  205. package/esm/interfaces/client.d.ts +0 -13
  206. package/esm/interfaces/client.js +0 -2
  207. package/esm/interfaces/client.js.map +0 -1
  208. package/esm/interfaces/controller.d.ts +0 -4
  209. package/esm/interfaces/controller.js +0 -2
  210. package/esm/interfaces/controller.js.map +0 -1
  211. package/esm/interfaces/instance.d.ts +0 -7
  212. package/esm/interfaces/instance.js +0 -2
  213. package/esm/interfaces/instance.js.map +0 -1
  214. package/esm/interfaces/options.d.ts +0 -1
  215. package/esm/interfaces/options.js +0 -2
  216. package/esm/interfaces/options.js.map +0 -1
  217. package/esm/interfaces/params.d.ts +0 -4
  218. package/esm/interfaces/params.js +0 -2
  219. package/esm/interfaces/params.js.map +0 -1
  220. package/esm/interfaces/request.d.ts +0 -43
  221. package/esm/interfaces/request.js +0 -2
  222. package/esm/interfaces/request.js.map +0 -1
  223. package/esm/interfaces/types.d.ts +0 -2
  224. package/esm/interfaces/types.js +0 -2
  225. package/esm/interfaces/types.js.map +0 -1
  226. package/esm/models/aggregate.d.ts +0 -53
  227. package/esm/models/aggregate.js +0 -6
  228. package/esm/models/aggregate.js.map +0 -1
  229. package/esm/models/base.d.ts +0 -38
  230. package/esm/models/base.js +0 -2
  231. package/esm/models/base.js.map +0 -1
  232. package/esm/models/category.d.ts +0 -22
  233. package/esm/models/category.js +0 -6
  234. package/esm/models/category.js.map +0 -1
  235. package/esm/models/comment.d.ts +0 -37
  236. package/esm/models/comment.js +0 -13
  237. package/esm/models/comment.js.map +0 -1
  238. package/esm/models/index.d.ts +0 -14
  239. package/esm/models/index.js +0 -15
  240. package/esm/models/index.js.map +0 -1
  241. package/esm/models/link.d.ts +0 -22
  242. package/esm/models/link.js +0 -14
  243. package/esm/models/link.js.map +0 -1
  244. package/esm/models/note.d.ts +0 -33
  245. package/esm/models/note.js +0 -2
  246. package/esm/models/note.js.map +0 -1
  247. package/esm/models/page.d.ts +0 -14
  248. package/esm/models/page.js +0 -7
  249. package/esm/models/page.js.map +0 -1
  250. package/esm/models/post.d.ts +0 -17
  251. package/esm/models/post.js +0 -2
  252. package/esm/models/post.js.map +0 -1
  253. package/esm/models/project.d.ts +0 -11
  254. package/esm/models/project.js +0 -2
  255. package/esm/models/project.js.map +0 -1
  256. package/esm/models/recently.d.ts +0 -26
  257. package/esm/models/recently.js +0 -7
  258. package/esm/models/recently.js.map +0 -1
  259. package/esm/models/say.d.ts +0 -6
  260. package/esm/models/say.js +0 -2
  261. package/esm/models/say.js.map +0 -1
  262. package/esm/models/setting.d.ts +0 -66
  263. package/esm/models/setting.js +0 -2
  264. package/esm/models/setting.js.map +0 -1
  265. package/esm/models/snippet.d.ts +0 -18
  266. package/esm/models/snippet.js +0 -8
  267. package/esm/models/snippet.js.map +0 -1
  268. package/esm/models/topic.d.ts +0 -8
  269. package/esm/models/topic.js +0 -2
  270. package/esm/models/topic.js.map +0 -1
  271. package/esm/models/user.d.ts +0 -21
  272. package/esm/models/user.js +0 -2
  273. package/esm/models/user.js.map +0 -1
  274. package/esm/utils/auto-bind.d.ts +0 -4
  275. package/esm/utils/auto-bind.js +0 -36
  276. package/esm/utils/auto-bind.js.map +0 -1
  277. package/esm/utils/camelcase-keys.d.ts +0 -6
  278. package/esm/utils/camelcase-keys.js +0 -23
  279. package/esm/utils/camelcase-keys.js.map +0 -1
  280. package/esm/utils/index.d.ts +0 -5
  281. package/esm/utils/index.js +0 -43
  282. package/esm/utils/index.js.map +0 -1
  283. package/esm/utils/path.d.ts +0 -1
  284. package/esm/utils/path.js +0 -7
  285. package/esm/utils/path.js.map +0 -1
  286. package/esm/vitest.config.d.ts +0 -2
  287. package/esm/vitest.config.js +0 -12
  288. package/esm/vitest.config.js.map +0 -1
  289. package/lib/adaptors/axios.d.ts +0 -4
  290. package/lib/adaptors/axios.js +0 -42
  291. package/lib/adaptors/axios.js.map +0 -1
  292. package/lib/adaptors/ky.d.ts +0 -23
  293. package/lib/adaptors/ky.js +0 -68
  294. package/lib/adaptors/ky.js.map +0 -1
  295. package/lib/adaptors/umi-request.d.ts +0 -4
  296. package/lib/adaptors/umi-request.js +0 -33
  297. package/lib/adaptors/umi-request.js.map +0 -1
  298. package/lib/controllers/aggregate.d.ts +0 -64
  299. package/lib/controllers/aggregate.js +0 -46
  300. package/lib/controllers/aggregate.js.map +0 -1
  301. package/lib/controllers/base.d.ts +0 -43
  302. package/lib/controllers/base.js +0 -31
  303. package/lib/controllers/base.js.map +0 -1
  304. package/lib/controllers/category.d.ts +0 -115
  305. package/lib/controllers/category.js +0 -72
  306. package/lib/controllers/category.js.map +0 -1
  307. package/lib/controllers/comment.d.ts +0 -81
  308. package/lib/controllers/comment.js +0 -51
  309. package/lib/controllers/comment.js.map +0 -1
  310. package/lib/controllers/index.d.ts +0 -18
  311. package/lib/controllers/index.js +0 -72
  312. package/lib/controllers/index.js.map +0 -1
  313. package/lib/controllers/link.d.ts +0 -20
  314. package/lib/controllers/link.js +0 -25
  315. package/lib/controllers/link.js.map +0 -1
  316. package/lib/controllers/note.d.ts +0 -103
  317. package/lib/controllers/note.js +0 -72
  318. package/lib/controllers/note.js.map +0 -1
  319. package/lib/controllers/page.d.ts +0 -59
  320. package/lib/controllers/page.js +0 -46
  321. package/lib/controllers/page.js.map +0 -1
  322. package/lib/controllers/post.d.ts +0 -72
  323. package/lib/controllers/post.js +0 -56
  324. package/lib/controllers/post.js.map +0 -1
  325. package/lib/controllers/project.d.ts +0 -15
  326. package/lib/controllers/project.js +0 -16
  327. package/lib/controllers/project.js.map +0 -1
  328. package/lib/controllers/recently.d.ts +0 -61
  329. package/lib/controllers/recently.js +0 -35
  330. package/lib/controllers/recently.js.map +0 -1
  331. package/lib/controllers/say.d.ts +0 -37
  332. package/lib/controllers/say.js +0 -25
  333. package/lib/controllers/say.js.map +0 -1
  334. package/lib/controllers/search.d.ts +0 -247
  335. package/lib/controllers/search.js +0 -32
  336. package/lib/controllers/search.js.map +0 -1
  337. package/lib/controllers/severless.d.ts +0 -24
  338. package/lib/controllers/severless.js +0 -20
  339. package/lib/controllers/severless.js.map +0 -1
  340. package/lib/controllers/snippet.d.ts +0 -24
  341. package/lib/controllers/snippet.js +0 -23
  342. package/lib/controllers/snippet.js.map +0 -1
  343. package/lib/controllers/topic.d.ts +0 -26
  344. package/lib/controllers/topic.js +0 -22
  345. package/lib/controllers/topic.js.map +0 -1
  346. package/lib/controllers/user.d.ts +0 -70
  347. package/lib/controllers/user.js +0 -44
  348. package/lib/controllers/user.js.map +0 -1
  349. package/lib/core/attach-request.d.ts +0 -2
  350. package/lib/core/attach-request.js +0 -40
  351. package/lib/core/attach-request.js.map +0 -1
  352. package/lib/core/client.d.ts +0 -29
  353. package/lib/core/client.js +0 -190
  354. package/lib/core/client.js.map +0 -1
  355. package/lib/core/error.d.ts +0 -6
  356. package/lib/core/error.js +0 -13
  357. package/lib/core/error.js.map +0 -1
  358. package/lib/core/index.d.ts +0 -2
  359. package/lib/core/index.js +0 -19
  360. package/lib/core/index.js.map +0 -1
  361. package/lib/dtos/comment.d.ts +0 -6
  362. package/lib/dtos/comment.js +0 -7
  363. package/lib/dtos/comment.js.map +0 -1
  364. package/lib/index.d.ts +0 -7
  365. package/lib/index.js +0 -27
  366. package/lib/index.js.map +0 -1
  367. package/lib/interfaces/adapter.d.ts +0 -14
  368. package/lib/interfaces/adapter.js +0 -3
  369. package/lib/interfaces/adapter.js.map +0 -1
  370. package/lib/interfaces/client.d.ts +0 -13
  371. package/lib/interfaces/client.js +0 -3
  372. package/lib/interfaces/client.js.map +0 -1
  373. package/lib/interfaces/controller.d.ts +0 -4
  374. package/lib/interfaces/controller.js +0 -3
  375. package/lib/interfaces/controller.js.map +0 -1
  376. package/lib/interfaces/instance.d.ts +0 -7
  377. package/lib/interfaces/instance.js +0 -3
  378. package/lib/interfaces/instance.js.map +0 -1
  379. package/lib/interfaces/options.d.ts +0 -1
  380. package/lib/interfaces/options.js +0 -3
  381. package/lib/interfaces/options.js.map +0 -1
  382. package/lib/interfaces/params.d.ts +0 -4
  383. package/lib/interfaces/params.js +0 -3
  384. package/lib/interfaces/params.js.map +0 -1
  385. package/lib/interfaces/request.d.ts +0 -43
  386. package/lib/interfaces/request.js +0 -3
  387. package/lib/interfaces/request.js.map +0 -1
  388. package/lib/interfaces/types.d.ts +0 -2
  389. package/lib/interfaces/types.js +0 -3
  390. package/lib/interfaces/types.js.map +0 -1
  391. package/lib/models/aggregate.d.ts +0 -53
  392. package/lib/models/aggregate.js +0 -9
  393. package/lib/models/aggregate.js.map +0 -1
  394. package/lib/models/base.d.ts +0 -38
  395. package/lib/models/base.js +0 -3
  396. package/lib/models/base.js.map +0 -1
  397. package/lib/models/category.d.ts +0 -22
  398. package/lib/models/category.js +0 -9
  399. package/lib/models/category.js.map +0 -1
  400. package/lib/models/comment.d.ts +0 -37
  401. package/lib/models/comment.js +0 -16
  402. package/lib/models/comment.js.map +0 -1
  403. package/lib/models/index.d.ts +0 -14
  404. package/lib/models/index.js +0 -31
  405. package/lib/models/index.js.map +0 -1
  406. package/lib/models/link.d.ts +0 -22
  407. package/lib/models/link.js +0 -17
  408. package/lib/models/link.js.map +0 -1
  409. package/lib/models/note.d.ts +0 -33
  410. package/lib/models/note.js +0 -3
  411. package/lib/models/note.js.map +0 -1
  412. package/lib/models/page.d.ts +0 -14
  413. package/lib/models/page.js +0 -10
  414. package/lib/models/page.js.map +0 -1
  415. package/lib/models/post.d.ts +0 -17
  416. package/lib/models/post.js +0 -3
  417. package/lib/models/post.js.map +0 -1
  418. package/lib/models/project.d.ts +0 -11
  419. package/lib/models/project.js +0 -3
  420. package/lib/models/project.js.map +0 -1
  421. package/lib/models/recently.d.ts +0 -26
  422. package/lib/models/recently.js +0 -10
  423. package/lib/models/recently.js.map +0 -1
  424. package/lib/models/say.d.ts +0 -6
  425. package/lib/models/say.js +0 -3
  426. package/lib/models/say.js.map +0 -1
  427. package/lib/models/setting.d.ts +0 -66
  428. package/lib/models/setting.js +0 -3
  429. package/lib/models/setting.js.map +0 -1
  430. package/lib/models/snippet.d.ts +0 -18
  431. package/lib/models/snippet.js +0 -11
  432. package/lib/models/snippet.js.map +0 -1
  433. package/lib/models/topic.d.ts +0 -8
  434. package/lib/models/topic.js +0 -3
  435. package/lib/models/topic.js.map +0 -1
  436. package/lib/models/user.d.ts +0 -21
  437. package/lib/models/user.js +0 -3
  438. package/lib/models/user.js.map +0 -1
  439. package/lib/utils/auto-bind.d.ts +0 -4
  440. package/lib/utils/auto-bind.js +0 -40
  441. package/lib/utils/auto-bind.js.map +0 -1
  442. package/lib/utils/camelcase-keys.d.ts +0 -6
  443. package/lib/utils/camelcase-keys.js +0 -28
  444. package/lib/utils/camelcase-keys.js.map +0 -1
  445. package/lib/utils/index.d.ts +0 -5
  446. package/lib/utils/index.js +0 -50
  447. package/lib/utils/index.js.map +0 -1
  448. package/lib/utils/path.d.ts +0 -1
  449. package/lib/utils/path.js +0 -11
  450. package/lib/utils/path.js.map +0 -1
  451. package/lib/vitest.config.d.ts +0 -2
  452. package/lib/vitest.config.js +0 -17
  453. package/lib/vitest.config.js.map +0 -1
  454. package/types/adaptors/axios.d.ts +0 -4
  455. package/types/adaptors/ky.d.ts +0 -23
  456. package/types/adaptors/umi-request.d.ts +0 -4
  457. package/types/controllers/aggregate.d.ts +0 -64
  458. package/types/controllers/base.d.ts +0 -43
  459. package/types/controllers/category.d.ts +0 -115
  460. package/types/controllers/comment.d.ts +0 -81
  461. package/types/controllers/index.d.ts +0 -18
  462. package/types/controllers/link.d.ts +0 -20
  463. package/types/controllers/note.d.ts +0 -103
  464. package/types/controllers/page.d.ts +0 -59
  465. package/types/controllers/post.d.ts +0 -72
  466. package/types/controllers/project.d.ts +0 -15
  467. package/types/controllers/recently.d.ts +0 -61
  468. package/types/controllers/say.d.ts +0 -37
  469. package/types/controllers/search.d.ts +0 -247
  470. package/types/controllers/severless.d.ts +0 -24
  471. package/types/controllers/snippet.d.ts +0 -24
  472. package/types/controllers/topic.d.ts +0 -26
  473. package/types/controllers/user.d.ts +0 -70
  474. package/types/core/attach-request.d.ts +0 -2
  475. package/types/core/client.d.ts +0 -29
  476. package/types/core/error.d.ts +0 -6
  477. package/types/core/index.d.ts +0 -2
  478. package/types/dtos/comment.d.ts +0 -6
  479. package/types/index.d.ts +0 -7
  480. package/types/interfaces/adapter.d.ts +0 -14
  481. package/types/interfaces/client.d.ts +0 -13
  482. package/types/interfaces/controller.d.ts +0 -4
  483. package/types/interfaces/instance.d.ts +0 -7
  484. package/types/interfaces/options.d.ts +0 -1
  485. package/types/interfaces/params.d.ts +0 -4
  486. package/types/interfaces/request.d.ts +0 -43
  487. package/types/interfaces/types.d.ts +0 -2
  488. package/types/models/aggregate.d.ts +0 -53
  489. package/types/models/base.d.ts +0 -38
  490. package/types/models/category.d.ts +0 -22
  491. package/types/models/comment.d.ts +0 -37
  492. package/types/models/index.d.ts +0 -14
  493. package/types/models/link.d.ts +0 -22
  494. package/types/models/note.d.ts +0 -33
  495. package/types/models/page.d.ts +0 -14
  496. package/types/models/post.d.ts +0 -17
  497. package/types/models/project.d.ts +0 -11
  498. package/types/models/recently.d.ts +0 -26
  499. package/types/models/say.d.ts +0 -6
  500. package/types/models/setting.d.ts +0 -66
  501. package/types/models/snippet.d.ts +0 -18
  502. package/types/models/topic.d.ts +0 -8
  503. package/types/models/user.d.ts +0 -21
  504. package/types/utils/auto-bind.d.ts +0 -4
  505. package/types/utils/camelcase-keys.d.ts +0 -6
  506. package/types/utils/index.d.ts +0 -5
  507. package/types/utils/path.d.ts +0 -1
  508. package/types/vitest.config.d.ts +0 -2
@@ -0,0 +1,284 @@
1
+ import camelcaseKeys from 'camelcase-keys'
2
+
3
+ import { mockRequestInstance } from '~/__tests__/helpers/instance'
4
+ import { mockResponse } from '~/__tests__/helpers/response'
5
+ import { CategoryController } from '~/controllers'
6
+
7
+ describe('test Category client', () => {
8
+ const client = mockRequestInstance(CategoryController)
9
+
10
+ test('GET /categories', async () => {
11
+ const mocked = mockResponse('/categories', {
12
+ data: [
13
+ {
14
+ id: '5eb2c62a613a5ab0642f1f7a',
15
+ type: 0,
16
+ count: 34,
17
+ name: '编程',
18
+ slug: 'programming',
19
+ created: '2020-05-06T14:14:02.339Z',
20
+ },
21
+ ],
22
+ })
23
+
24
+ const data = await client.category.getAllCategories()
25
+ expect(data.$raw.data).toEqual(mocked)
26
+ expect(data.data).toEqual(mocked.data)
27
+ })
28
+
29
+ describe('GET /categories/:id', () => {
30
+ test('get by slug', async () => {
31
+ const mocked = mockResponse('/categories/programming', {
32
+ data: {
33
+ id: '5eb2c62a613a5ab0642f1f7a',
34
+ type: 0,
35
+ count: 2,
36
+ name: '编程',
37
+ slug: 'programming',
38
+ created: '2020-05-06T14:14:02.339Z',
39
+ children: [
40
+ {
41
+ id: '611748895c2f6f4d3ba0d9b3',
42
+ title: 'pageproxy,为 spa 提供初始数据注入',
43
+ slug: 'pageproxy-spa-inject',
44
+ created: '2021-08-14T04:37:29.880Z',
45
+ },
46
+ {
47
+ id: '60cffff50ec52e0349cbb29f',
48
+ title: '曲折的 Vue 3 重构后台之路',
49
+ slug: 'mx-space-vue-3',
50
+ created: '2021-06-21T02:56:53.126Z',
51
+ },
52
+ ],
53
+ },
54
+ })
55
+
56
+ const data = await client.category.getCategoryByIdOrSlug('programming')
57
+ expect(data).toEqual(mocked.data)
58
+ expect(data.count).toEqual(mocked.data.count)
59
+ })
60
+
61
+ test('get by id', async () => {
62
+ const mocked = mockResponse('/categories/5eb2c62a613a5ab0642f1f7a', {
63
+ data: {
64
+ id: '5eb2c62a613a5ab0642f1f7a',
65
+ type: 0,
66
+ count: 2,
67
+ name: '编程',
68
+ slug: 'programming',
69
+ created: '2020-05-06T14:14:02.339Z',
70
+ children: [
71
+ {
72
+ id: '611748895c2f6f4d3ba0d9b3',
73
+ title: 'pageproxy,为 spa 提供初始数据注入',
74
+ slug: 'pageproxy-spa-inject',
75
+ created: '2021-08-14T04:37:29.880Z',
76
+ },
77
+ {
78
+ id: '60cffff50ec52e0349cbb29f',
79
+ title: '曲折的 Vue 3 重构后台之路',
80
+ slug: 'mx-space-vue-3',
81
+ created: '2021-06-21T02:56:53.126Z',
82
+ },
83
+ ],
84
+ },
85
+ })
86
+
87
+ const data = await client.category.getCategoryByIdOrSlug(
88
+ '5eb2c62a613a5ab0642f1f7a',
89
+ )
90
+ expect(data).toEqual(mocked.data)
91
+ expect(data.count).toEqual(mocked.data.count)
92
+ })
93
+ })
94
+
95
+ test('GET /categories/:tagName', async () => {
96
+ const mocked = mockResponse('/categories/react?tag=1', {
97
+ tag: 'react',
98
+ data: [
99
+ {
100
+ id: '607bfcedc98328a0d941a409',
101
+ title: '虚拟列表与 Scroll Restoration',
102
+ slug: 'visualize-list-scroll-restoration',
103
+ category: {
104
+ id: '5eb2c62a613a5ab0642f1f7a',
105
+ type: 0,
106
+ name: '编程',
107
+ slug: 'programming',
108
+ },
109
+ created: '2021-04-18T09:33:33.271Z',
110
+ },
111
+ ],
112
+ })
113
+
114
+ const data = await client.category.getTagByName('react')
115
+ expect(data.tag).toEqual('react')
116
+ expect(data.data).toEqual(mocked.data)
117
+ })
118
+
119
+ test('GET /categories?type=0', async () => {
120
+ const mocked = mockResponse('/categories?type=0', {
121
+ data: [
122
+ {
123
+ id: '5eb2c62a613a5ab0642f1f7a',
124
+ type: 0,
125
+ count: 34,
126
+ name: '编程',
127
+ slug: 'programming',
128
+ created: '2020-05-06T14:14:02.339Z',
129
+ },
130
+ ],
131
+ })
132
+
133
+ const data = await client.category.getAllCategories()
134
+ expect(data.data).toEqual(mocked.data)
135
+ expect(data.$raw.data).toEqual(mocked)
136
+ })
137
+
138
+ test('GET /categories?type=1', async () => {
139
+ const mocked = mockResponse('/categories?type=1', {
140
+ data: [
141
+ {
142
+ count: 2,
143
+ name: 'docker',
144
+ },
145
+ {
146
+ count: 1,
147
+ name: 'react',
148
+ },
149
+ ],
150
+ })
151
+ const data = await client.category.getAllTags()
152
+ expect(data.data).toEqual(mocked.data)
153
+ expect(data.$raw.data).toEqual(mocked)
154
+ })
155
+
156
+ describe('GET /categories?ids=', () => {
157
+ it('should get with ids array', async () => {
158
+ const mocked = mockResponse(
159
+ '/categories?ids=5ed5be418f3d6b6cb9ab7700,5eb2c62a613a5ab0642f1f7b',
160
+ {
161
+ entries: {
162
+ '5ed5be418f3d6b6cb9ab7700': {
163
+ id: '5ed5be418f3d6b6cb9ab7700',
164
+ type: 0,
165
+ count: 2,
166
+ slug: 'reprint',
167
+ name: '转载',
168
+ created: '2020-06-02T02:49:37.424Z',
169
+ children: [
170
+ {
171
+ id: '6005562e6b14b33be8afc1c3',
172
+ allow_comment: true,
173
+ copyright: false,
174
+ tags: [],
175
+ count: {
176
+ read: 221,
177
+ like: 3,
178
+ },
179
+ title: '[reprint] Your Own Time Zone',
180
+ slug: 'your-own-time-zone',
181
+ category_id: '5ed5be418f3d6b6cb9ab7700',
182
+ modified: '2021-01-18T09:41:37.380Z',
183
+ created: '2021-01-18T09:34:38.550Z',
184
+ },
185
+ ],
186
+ },
187
+ '5eb2c62a613a5ab0642f1f7b': {
188
+ id: '5eb2c62a613a5ab0642f1f7b',
189
+ type: 0,
190
+ count: 19,
191
+ name: '折腾',
192
+ slug: 'Z-Turn',
193
+ created: '2020-05-06T14:14:02.356Z',
194
+ children: [
195
+ {
196
+ id: '5eb2c62a613a5ab0642f1f95',
197
+ title: '从零开始的 Redux',
198
+ slug: 'learn-redux',
199
+ created: '2020-01-08T08:24:00.000Z',
200
+ modified: '2020-11-14T06:50:19.164Z',
201
+ category_id: '5eb2c62a613a5ab0642f1f7b',
202
+ copyright: true,
203
+ count: {
204
+ read: 309,
205
+ like: 2,
206
+ },
207
+ allow_comment: true,
208
+ tags: [],
209
+ },
210
+ ],
211
+ },
212
+ },
213
+ },
214
+ )
215
+
216
+ const data = await client.category.getCategoryDetail([
217
+ '5ed5be418f3d6b6cb9ab7700',
218
+ '5eb2c62a613a5ab0642f1f7b',
219
+ ])
220
+
221
+ expect(data).toEqual(
222
+ new Map([
223
+ [
224
+ '5ed5be418f3d6b6cb9ab7700',
225
+ camelcaseKeys(mocked.entries['5ed5be418f3d6b6cb9ab7700'], {
226
+ deep: true,
227
+ }),
228
+ ],
229
+ [
230
+ '5eb2c62a613a5ab0642f1f7b',
231
+ camelcaseKeys(mocked.entries['5eb2c62a613a5ab0642f1f7b'], {
232
+ deep: true,
233
+ }),
234
+ ],
235
+ ]),
236
+ )
237
+
238
+ expect(data.$raw.data).toEqual(mocked)
239
+ })
240
+
241
+ it('should get with single id', async () => {
242
+ const mocked = mockResponse('/categories?ids=5ed5be418f3d6b6cb9ab7700', {
243
+ entries: {
244
+ '5ed5be418f3d6b6cb9ab7700': {
245
+ id: '5ed5be418f3d6b6cb9ab7700',
246
+ type: 0,
247
+ count: 2,
248
+ slug: 'reprint',
249
+ name: '转载',
250
+ created: '2020-06-02T02:49:37.424Z',
251
+ children: [
252
+ {
253
+ id: '6005562e6b14b33be8afc1c3',
254
+ allow_comment: true,
255
+ copyright: false,
256
+ tags: [],
257
+ count: {
258
+ read: 221,
259
+ like: 3,
260
+ },
261
+ title: '[reprint] Your Own Time Zone',
262
+ slug: 'your-own-time-zone',
263
+ category_id: '5ed5be418f3d6b6cb9ab7700',
264
+ modified: '2021-01-18T09:41:37.380Z',
265
+ created: '2021-01-18T09:34:38.550Z',
266
+ },
267
+ ],
268
+ },
269
+ },
270
+ })
271
+
272
+ const data = await client.category.getCategoryDetail(
273
+ '5ed5be418f3d6b6cb9ab7700',
274
+ )
275
+ expect(data).toEqual(
276
+ camelcaseKeys(mocked.entries['5ed5be418f3d6b6cb9ab7700'], {
277
+ deep: true,
278
+ }),
279
+ )
280
+
281
+ expect(data.$raw.data).toEqual(mocked)
282
+ })
283
+ })
284
+ })
@@ -0,0 +1,113 @@
1
+ import camelcaseKeys from 'camelcase-keys'
2
+
3
+ import { mockRequestInstance } from '~/__tests__/helpers/instance'
4
+ import { mockResponse } from '~/__tests__/helpers/response'
5
+ import { CommentController } from '~/controllers/comment'
6
+
7
+ describe('test note client', () => {
8
+ const client = mockRequestInstance(CommentController)
9
+
10
+ test('get comment by id', async () => {
11
+ mockResponse('/comments/11111', {
12
+ ref_type: 'Page',
13
+ state: 1,
14
+ children: [],
15
+ comments_index: 1,
16
+ id: '6188b80b6290547080c9e1f3',
17
+ author: 'yss',
18
+ text: '做的框架模板不错. (•౪• ) ',
19
+ url: 'https://gitee.com/kmyss/',
20
+ key: '#26',
21
+ ref: '5e0318319332d06503619337',
22
+ created: '2021-11-08T05:39:23.010Z',
23
+ avatar:
24
+ 'https://sdn.geekzu.org/avatar/8675fa376c044b0d93a23374549c4248?d=retro',
25
+ })
26
+
27
+ const data = await client.comment.getById('11111')
28
+ expect(data.children).toEqual([])
29
+ expect(data.text).toBeDefined()
30
+ })
31
+
32
+ test('get comment by ref id', async () => {
33
+ const comments = [
34
+ {
35
+ ref_type: 'Page',
36
+ state: 1,
37
+ children: [],
38
+ comments_index: 1,
39
+ id: '6188b80b6290547080c9e1f3',
40
+ author: 'yss',
41
+ text: '做的框架模板不错. (•౪• ) ',
42
+ url: 'https://gitee.com/kmyss/',
43
+ key: '#26',
44
+ ref: '5e0318319332d06503619337',
45
+ created: '2021-11-08T05:39:23.010Z',
46
+ avatar:
47
+ 'https://sdn.geekzu.org/avatar/8675fa376c044b0d93a23374549c4248?d=retro',
48
+ },
49
+ ]
50
+ mockResponse(
51
+ '/comments/ref/5e0318319332d06503619337',
52
+ {
53
+ data: comments,
54
+ pagination: {
55
+ total: 23,
56
+ current_page: 1,
57
+ total_page: 3,
58
+ size: 10,
59
+ has_next_page: true,
60
+ has_prev_page: false,
61
+ },
62
+ },
63
+ 'get',
64
+ )
65
+
66
+ const data = await client.comment.getByRefId('5e0318319332d06503619337')
67
+
68
+ expect(data.data).toEqual(camelcaseKeys(comments, { deep: true }))
69
+ expect(data.pagination.total).toEqual(23)
70
+ expect(data.pagination.hasNextPage).toEqual(true)
71
+ })
72
+
73
+ it('should comment successfully', async () => {
74
+ mockResponse(
75
+ '/comments/1',
76
+ {
77
+ id: '1',
78
+ text: 'bar',
79
+ },
80
+ 'post',
81
+ )
82
+
83
+ const data = await client.comment.comment('1', {
84
+ author: 'foo',
85
+ text: 'bar',
86
+ mail: 'xx@aa.com',
87
+ })
88
+
89
+ expect(data).toEqual({
90
+ id: '1',
91
+ text: 'bar',
92
+ })
93
+ })
94
+
95
+ it('should reply comment successfully', async () => {
96
+ mockResponse(
97
+ '/comments/reply/1',
98
+ {
99
+ id: '1',
100
+ text: 'bar',
101
+ },
102
+ 'post',
103
+ )
104
+
105
+ const data = await client.comment.reply('1', {
106
+ author: 'f',
107
+ text: 'bar',
108
+ mail: 'a@q.com',
109
+ })
110
+
111
+ expect(data).toEqual({ id: '1', text: 'bar' })
112
+ })
113
+ })
@@ -0,0 +1,95 @@
1
+ import camelcaseKeys from 'camelcase-keys'
2
+
3
+ import { mockRequestInstance } from '~/__tests__/helpers/instance'
4
+ import { mockResponse } from '~/__tests__/helpers/response'
5
+ import { LinkController } from '~/controllers'
6
+
7
+ describe('test link client, /links', () => {
8
+ const client = mockRequestInstance(LinkController)
9
+
10
+ test('GET /', async () => {
11
+ const mocked = mockResponse('/links?size=10&page=1', {
12
+ data: [
13
+ {
14
+ type: 0,
15
+ state: 0,
16
+ id: '615c191ed5db15a1000e3ca6',
17
+ url: 'https://barry-flynn.github.io/',
18
+ avatar: 'https://i.loli.net/2021/09/09/5belKgmrkjN8ZQ7.jpg',
19
+ description: '星河滚烫,无问西东。',
20
+ name: '百里飞洋の博客',
21
+ created: '2021-10-05T09:21:34.257Z',
22
+ hide: false,
23
+ },
24
+ // ...
25
+ ],
26
+ pagination: {
27
+ total: 43,
28
+ current_page: 1,
29
+ total_page: 5,
30
+ size: 10,
31
+ has_next_page: true,
32
+ has_prev_page: false,
33
+ },
34
+ })
35
+
36
+ const data = await client.link.getAllPaginated(1, 10)
37
+ expect(data.$raw.data).toEqual(mocked)
38
+ expect(data).toEqual(camelcaseKeys(mocked, { deep: true }))
39
+ })
40
+
41
+ it('should `friend` == `link`', () => {
42
+ expect(client.link).toEqual(client.friend)
43
+ })
44
+
45
+ test('GET /all', async () => {
46
+ const mocked = mockResponse('/links/all', {
47
+ data: [],
48
+ })
49
+
50
+ const data = await client.link.getAll()
51
+ expect(data.$raw.data).toEqual(mocked)
52
+ expect(data).toEqual(camelcaseKeys(mocked, { deep: true }))
53
+ })
54
+
55
+ test('GET /:id', async () => {
56
+ const mocked = mockResponse('/links/5eaabe10cd5bca719652179d', {
57
+ id: '5eaabe10cd5bca719652179d',
58
+ name: '静かな森',
59
+ url: 'https://innei.ren',
60
+ avatar: 'https://cdn.innei.ren/avatar.png',
61
+ created: '2020-04-30T12:01:20.738Z',
62
+ type: 0,
63
+ description: '致虚极,守静笃。',
64
+ state: 0,
65
+ })
66
+ const data = await client.link.getById('5eaabe10cd5bca719652179d')
67
+ expect(data.$raw.data).toEqual(mocked)
68
+ expect(data).toEqual(camelcaseKeys(mocked, { deep: true }))
69
+ })
70
+
71
+ test('GET /audit', async () => {
72
+ const mocked = mockResponse('/links/audit', {
73
+ can: true,
74
+ })
75
+
76
+ const allowed = await client.link.canApplyLink()
77
+
78
+ expect(allowed).toEqual(mocked.can)
79
+ })
80
+
81
+ test('POST /audit', async () => {
82
+ const payload = {
83
+ author: '',
84
+ avatar: '',
85
+ name: '',
86
+ url: '',
87
+ description: '',
88
+ email: '',
89
+ }
90
+ mockResponse('/links/audit', 'OK', 'post', payload)
91
+ const res = await client.link.applyLink(payload)
92
+
93
+ expect(res).toEqual('OK')
94
+ })
95
+ })
@@ -0,0 +1,120 @@
1
+ import { vi } from 'vitest'
2
+
3
+ import { mockRequestInstance } from '~/__tests__/helpers/instance'
4
+ import { mockResponse } from '~/__tests__/helpers/response'
5
+ import { axiosAdaptor } from '~/adaptors/axios'
6
+ import { NoteController } from '~/controllers'
7
+ import { RequestError } from '~/core'
8
+
9
+ const { spyOn } = vi
10
+
11
+ describe('test note client', () => {
12
+ const client = mockRequestInstance(NoteController)
13
+
14
+ it('should get note list', async () => {
15
+ mockResponse('/notes', {
16
+ data: [],
17
+ pagination: {},
18
+ })
19
+
20
+ const data = await client.note.getList()
21
+ expect(data).toEqual({ data: [], pagination: {} })
22
+ })
23
+
24
+ it('should get post list filter filed', async () => {
25
+ const mocked = mockResponse('/notes?page=1&size=1&select=created+title', {
26
+ data: [{}],
27
+ })
28
+
29
+ const data = await client.note.getList(1, 1, {
30
+ select: ['created', 'title'],
31
+ })
32
+ expect(data).toEqual(mocked)
33
+ })
34
+
35
+ it('should get latest note', async () => {
36
+ mockResponse('/notes/latest', { data: { title: '1' } })
37
+ const data = await client.note.getLatest()
38
+ expect(data.data.title).toBe('1')
39
+ })
40
+
41
+ it('should get middle list of note', async () => {
42
+ mockResponse('/notes/list/1', {
43
+ data: [
44
+ {
45
+ id: '1',
46
+ },
47
+ {
48
+ id: '2',
49
+ },
50
+ ],
51
+ size: 2,
52
+ })
53
+ const data = await client.note.getMiddleList('1')
54
+ expect(data).toEqual({
55
+ data: [
56
+ {
57
+ id: '1',
58
+ },
59
+ {
60
+ id: '2',
61
+ },
62
+ ],
63
+ size: 2,
64
+ })
65
+ })
66
+
67
+ it('should get single note', async () => {
68
+ mockResponse('/notes/1', { title: '1' })
69
+
70
+ const data = await client.note.getNoteById('1')
71
+
72
+ expect(data).toStrictEqual({ title: '1' })
73
+ expect(data.$raw).toBeDefined()
74
+ })
75
+
76
+ it('should get note by nid', async () => {
77
+ mockResponse('/notes/nid/1', { data: { title: '1' } })
78
+
79
+ const data = await client.note.getNoteById(1)
80
+ expect(data.data.title).toBe('1')
81
+ })
82
+
83
+ it('should get note by nid query single result', async () => {
84
+ mockResponse('/notes/nid/1', { title: '1' })
85
+
86
+ const data = await client.note.getNoteById(1, undefined, true)
87
+ expect(data.title).toBe('1')
88
+ })
89
+
90
+ it('should like note', async () => {
91
+ mockResponse('/notes/like/1', null)
92
+
93
+ const data = await client.note.likeIt('1')
94
+
95
+ expect(data).toBeNull()
96
+ })
97
+
98
+ it('should forbidden if no password provide', async () => {
99
+ spyOn(axiosAdaptor, 'get').mockRejectedValue({
100
+ response: {
101
+ data: {
102
+ message: 'password required',
103
+ },
104
+ status: 403,
105
+ },
106
+ })
107
+
108
+ await expect(client.note.getNoteById('1')).rejects.toThrowError(
109
+ RequestError,
110
+ )
111
+ })
112
+
113
+ test('GET /notes/topics/:id', async () => {
114
+ mockResponse('/notes/topics/11111111', { data: [], pagination: {} })
115
+
116
+ const data = await client.note.getNoteByTopicId('11111111')
117
+
118
+ expect(data).toEqual({ data: [], pagination: {} })
119
+ })
120
+ })
@@ -0,0 +1,49 @@
1
+ import { mockRequestInstance } from '~/__tests__/helpers/instance'
2
+ import { mockResponse } from '~/__tests__/helpers/response'
3
+ import { PageController } from '~/controllers/page'
4
+
5
+ describe('test page client', () => {
6
+ const client = mockRequestInstance(PageController)
7
+
8
+ it('should get page list', async () => {
9
+ mockResponse('/pages?size=10&page=1', {
10
+ data: [],
11
+ pagination: {},
12
+ })
13
+ const data = await client.page.getList()
14
+ expect(data).toEqual({ data: [], pagination: {} })
15
+ })
16
+
17
+ it('should get post list filter filed', async () => {
18
+ const mocked = mockResponse('/pages?page=1&size=1&select=created+title', {
19
+ data: [{}],
20
+ })
21
+
22
+ const data = await client.page.getList(1, 1, {
23
+ select: ['created', 'title'],
24
+ })
25
+ expect(data).toEqual(mocked)
26
+ })
27
+
28
+ it('should get single page', async () => {
29
+ mockResponse('/pages/1', {
30
+ title: '1',
31
+ })
32
+
33
+ const data = await client.page.getById('1')
34
+
35
+ expect(data).toStrictEqual({ title: '1' })
36
+ expect(data.$raw).toBeDefined()
37
+ })
38
+
39
+ it('should get by slug', async () => {
40
+ mockResponse('/pages/slug/about', {
41
+ title: 'about',
42
+ text: 'about!',
43
+ })
44
+
45
+ const data = await client.page.getBySlug('about')
46
+ expect(data.title).toBe('about')
47
+ expect(data.text).toBe('about!')
48
+ })
49
+ })