@cloudbase/oauth 0.1.1-alpha → 0.1.1-alpha.2

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 (332) hide show
  1. package/Dockerfile +15 -0
  2. package/README.md +1 -1
  3. package/_exmaple/assets/scripts/function/function.ts +99 -0
  4. package/_exmaple/assets/scripts/index.ts +99 -0
  5. package/_exmaple/assets/scripts/request.ts +11 -0
  6. package/_exmaple/index.html +15 -0
  7. package/_exmaple/package.json +33 -0
  8. package/_exmaple/tsconfig.json +71 -0
  9. package/_exmaple/typings.d.ts +0 -0
  10. package/_exmaple/webpack.config.js +42 -0
  11. package/cdnjs/1.0.0/cloudbase.auth.js +1 -0
  12. package/cdnjs/1.0.0/cloudbase.database.js +8 -0
  13. package/cdnjs/1.0.0/cloudbase.full.js +8 -0
  14. package/cdnjs/1.0.0/cloudbase.functions.js +1 -0
  15. package/cdnjs/1.0.0/cloudbase.js +1 -0
  16. package/cdnjs/1.0.0/cloudbase.storage.js +1 -0
  17. package/cdnjs/1.0.1/cloudbase.auth.js +1 -0
  18. package/cdnjs/1.0.1/cloudbase.database.js +8 -0
  19. package/cdnjs/1.0.1/cloudbase.full.js +8 -0
  20. package/cdnjs/1.0.1/cloudbase.functions.js +1 -0
  21. package/cdnjs/1.0.1/cloudbase.js +1 -0
  22. package/cdnjs/1.0.1/cloudbase.storage.js +1 -0
  23. package/cdnjs/1.0.2/cloudbase.auth.js +1 -0
  24. package/cdnjs/1.0.2/cloudbase.database.js +8 -0
  25. package/cdnjs/1.0.2/cloudbase.full.js +8 -0
  26. package/cdnjs/1.0.2/cloudbase.functions.js +1 -0
  27. package/cdnjs/1.0.2/cloudbase.js +1 -0
  28. package/cdnjs/1.0.2/cloudbase.storage.js +1 -0
  29. package/cdnjs/1.0.3/cloudbase.auth.js +1 -0
  30. package/cdnjs/1.0.3/cloudbase.database.js +8 -0
  31. package/cdnjs/1.0.3/cloudbase.full.js +8 -0
  32. package/cdnjs/1.0.3/cloudbase.functions.js +1 -0
  33. package/cdnjs/1.0.3/cloudbase.js +1 -0
  34. package/cdnjs/1.0.3/cloudbase.storage.js +1 -0
  35. package/cdnjs/1.0.4/cloudbase.auth.js +1 -0
  36. package/cdnjs/1.0.4/cloudbase.database.js +8 -0
  37. package/cdnjs/1.0.4/cloudbase.full.js +8 -0
  38. package/cdnjs/1.0.4/cloudbase.functions.js +1 -0
  39. package/cdnjs/1.0.4/cloudbase.js +1 -0
  40. package/cdnjs/1.0.4/cloudbase.storage.js +1 -0
  41. package/cdnjs/1.1.0/cloudbase.auth.js +1 -0
  42. package/cdnjs/1.1.0/cloudbase.database.js +8 -0
  43. package/cdnjs/1.1.0/cloudbase.full.js +8 -0
  44. package/cdnjs/1.1.0/cloudbase.functions.js +1 -0
  45. package/cdnjs/1.1.0/cloudbase.js +1 -0
  46. package/cdnjs/1.1.0/cloudbase.storage.js +1 -0
  47. package/cdnjs/1.1.1/cloudbase.auth.js +1 -0
  48. package/cdnjs/1.1.1/cloudbase.database.js +8 -0
  49. package/cdnjs/1.1.1/cloudbase.full.js +8 -0
  50. package/cdnjs/1.1.1/cloudbase.functions.js +1 -0
  51. package/cdnjs/1.1.1/cloudbase.js +1 -0
  52. package/cdnjs/1.1.1/cloudbase.storage.js +1 -0
  53. package/cdnjs/1.1.2/cloudbase.auth.js +1 -0
  54. package/cdnjs/1.1.2/cloudbase.database.js +8 -0
  55. package/cdnjs/1.1.2/cloudbase.full.js +8 -0
  56. package/cdnjs/1.1.2/cloudbase.functions.js +1 -0
  57. package/cdnjs/1.1.2/cloudbase.js +1 -0
  58. package/cdnjs/1.1.2/cloudbase.storage.js +1 -0
  59. package/cdnjs/1.1.3/cloudbase.auth.js +1 -0
  60. package/cdnjs/1.1.3/cloudbase.database.js +8 -0
  61. package/cdnjs/1.1.3/cloudbase.full.js +8 -0
  62. package/cdnjs/1.1.3/cloudbase.functions.js +1 -0
  63. package/cdnjs/1.1.3/cloudbase.js +1 -0
  64. package/cdnjs/1.1.3/cloudbase.storage.js +1 -0
  65. package/cdnjs/1.1.4/cloudbase.auth.js +1 -0
  66. package/cdnjs/1.1.4/cloudbase.database.js +8 -0
  67. package/cdnjs/1.1.4/cloudbase.full.js +8 -0
  68. package/cdnjs/1.1.4/cloudbase.functions.js +1 -0
  69. package/cdnjs/1.1.4/cloudbase.js +1 -0
  70. package/cdnjs/1.1.4/cloudbase.storage.js +1 -0
  71. package/cdnjs/1.2.1/cloudbase.auth.js +1 -0
  72. package/cdnjs/1.2.1/cloudbase.database.js +8 -0
  73. package/cdnjs/1.2.1/cloudbase.full.js +8 -0
  74. package/cdnjs/1.2.1/cloudbase.functions.js +1 -0
  75. package/cdnjs/1.2.1/cloudbase.js +1 -0
  76. package/cdnjs/1.2.1/cloudbase.storage.js +1 -0
  77. package/cdnjs/1.2.2/cloudbase.auth.js +1 -0
  78. package/cdnjs/1.2.2/cloudbase.database.js +8 -0
  79. package/cdnjs/1.2.2/cloudbase.full.js +8 -0
  80. package/cdnjs/1.2.2/cloudbase.functions.js +1 -0
  81. package/cdnjs/1.2.2/cloudbase.js +1 -0
  82. package/cdnjs/1.2.2/cloudbase.storage.js +1 -0
  83. package/cdnjs/1.2.3/cloudbase.auth.js +1 -0
  84. package/cdnjs/1.2.3/cloudbase.database.js +8 -0
  85. package/cdnjs/1.2.3/cloudbase.full.js +8 -0
  86. package/cdnjs/1.2.3/cloudbase.functions.js +1 -0
  87. package/cdnjs/1.2.3/cloudbase.js +1 -0
  88. package/cdnjs/1.2.3/cloudbase.storage.js +1 -0
  89. package/cdnjs/1.3.0/cloudbase.auth.js +1 -0
  90. package/cdnjs/1.3.0/cloudbase.database.js +8 -0
  91. package/cdnjs/1.3.0/cloudbase.full.js +8 -0
  92. package/cdnjs/1.3.0/cloudbase.functions.js +1 -0
  93. package/cdnjs/1.3.0/cloudbase.js +1 -0
  94. package/cdnjs/1.3.0/cloudbase.realtime.js +1 -0
  95. package/cdnjs/1.3.0/cloudbase.storage.js +1 -0
  96. package/cdnjs/1.3.1/cloudbase.auth.js +1 -0
  97. package/cdnjs/1.3.1/cloudbase.database.js +8 -0
  98. package/cdnjs/1.3.1/cloudbase.full.js +8 -0
  99. package/cdnjs/1.3.1/cloudbase.functions.js +1 -0
  100. package/cdnjs/1.3.1/cloudbase.js +1 -0
  101. package/cdnjs/1.3.1/cloudbase.realtime.js +1 -0
  102. package/cdnjs/1.3.1/cloudbase.storage.js +1 -0
  103. package/cdnjs/1.3.2/cloudbase.auth.js +1 -0
  104. package/cdnjs/1.3.2/cloudbase.database.js +8 -0
  105. package/cdnjs/1.3.2/cloudbase.full.js +8 -0
  106. package/cdnjs/1.3.2/cloudbase.functions.js +1 -0
  107. package/cdnjs/1.3.2/cloudbase.js +1 -0
  108. package/cdnjs/1.3.2/cloudbase.realtime.js +1 -0
  109. package/cdnjs/1.3.2/cloudbase.storage.js +1 -0
  110. package/cdnjs/1.3.3/cloudbase.auth.js +1 -0
  111. package/cdnjs/1.3.3/cloudbase.database.js +8 -0
  112. package/cdnjs/1.3.3/cloudbase.full.js +8 -0
  113. package/cdnjs/1.3.3/cloudbase.functions.js +1 -0
  114. package/cdnjs/1.3.3/cloudbase.js +1 -0
  115. package/cdnjs/1.3.3/cloudbase.realtime.js +1 -0
  116. package/cdnjs/1.3.3/cloudbase.storage.js +1 -0
  117. package/cdnjs/1.3.4-alpha.0/cloudbase.auth.js +1 -0
  118. package/cdnjs/1.3.4-alpha.0/cloudbase.database.js +8 -0
  119. package/cdnjs/1.3.4-alpha.0/cloudbase.full.js +8 -0
  120. package/cdnjs/1.3.4-alpha.0/cloudbase.functions.js +1 -0
  121. package/cdnjs/1.3.4-alpha.0/cloudbase.js +1 -0
  122. package/cdnjs/1.3.4-alpha.0/cloudbase.realtime.js +1 -0
  123. package/cdnjs/1.3.4-alpha.0/cloudbase.storage.js +1 -0
  124. package/cdnjs/1.3.5/cloudbase.analytics.js +1 -0
  125. package/cdnjs/1.3.5/cloudbase.auth.js +1 -0
  126. package/cdnjs/1.3.5/cloudbase.database.js +10 -0
  127. package/cdnjs/1.3.5/cloudbase.full.js +10 -0
  128. package/cdnjs/1.3.5/cloudbase.functions.js +1 -0
  129. package/cdnjs/1.3.5/cloudbase.js +1 -0
  130. package/cdnjs/1.3.5/cloudbase.realtime.js +1 -0
  131. package/cdnjs/1.3.5/cloudbase.storage.js +1 -0
  132. package/cdnjs/1.3.5-alpha.0/cloudbase.auth.js +1 -0
  133. package/cdnjs/1.3.5-alpha.0/cloudbase.database.js +10 -0
  134. package/cdnjs/1.3.5-alpha.0/cloudbase.full.js +10 -0
  135. package/cdnjs/1.3.5-alpha.0/cloudbase.functions.js +1 -0
  136. package/cdnjs/1.3.5-alpha.0/cloudbase.js +1 -0
  137. package/cdnjs/1.3.5-alpha.0/cloudbase.realtime.js +1 -0
  138. package/cdnjs/1.3.5-alpha.0/cloudbase.storage.js +1 -0
  139. package/cdnjs/1.4.0/cloudbase.analytics.js +1 -0
  140. package/cdnjs/1.4.0/cloudbase.auth.js +1 -0
  141. package/cdnjs/1.4.0/cloudbase.database.js +10 -0
  142. package/cdnjs/1.4.0/cloudbase.full.js +10 -0
  143. package/cdnjs/1.4.0/cloudbase.functions.js +1 -0
  144. package/cdnjs/1.4.0/cloudbase.js +1 -0
  145. package/cdnjs/1.4.0/cloudbase.realtime.js +1 -0
  146. package/cdnjs/1.4.0/cloudbase.storage.js +1 -0
  147. package/cdnjs/1.4.1/cloudbase.analytics.js +1 -0
  148. package/cdnjs/1.4.1/cloudbase.auth.js +1 -0
  149. package/cdnjs/1.4.1/cloudbase.database.js +10 -0
  150. package/cdnjs/1.4.1/cloudbase.full.js +10 -0
  151. package/cdnjs/1.4.1/cloudbase.functions.js +1 -0
  152. package/cdnjs/1.4.1/cloudbase.js +1 -0
  153. package/cdnjs/1.4.1/cloudbase.realtime.js +1 -0
  154. package/cdnjs/1.4.1/cloudbase.storage.js +1 -0
  155. package/cdnjs/1.4.1-alpha.0/cloudbase.analytics.js +1 -0
  156. package/cdnjs/1.4.1-alpha.0/cloudbase.auth.js +1 -0
  157. package/cdnjs/1.4.1-alpha.0/cloudbase.database.js +10 -0
  158. package/cdnjs/1.4.1-alpha.0/cloudbase.full.js +10 -0
  159. package/cdnjs/1.4.1-alpha.0/cloudbase.functions.js +1 -0
  160. package/cdnjs/1.4.1-alpha.0/cloudbase.js +1 -0
  161. package/cdnjs/1.4.1-alpha.0/cloudbase.realtime.js +1 -0
  162. package/cdnjs/1.4.1-alpha.0/cloudbase.storage.js +1 -0
  163. package/cdnjs/1.4.2-alpha.0/cloudbase.analytics.js +1 -0
  164. package/cdnjs/1.4.2-alpha.0/cloudbase.auth.js +1 -0
  165. package/cdnjs/1.4.2-alpha.0/cloudbase.database.js +10 -0
  166. package/cdnjs/1.4.2-alpha.0/cloudbase.full.js +10 -0
  167. package/cdnjs/1.4.2-alpha.0/cloudbase.functions.js +1 -0
  168. package/cdnjs/1.4.2-alpha.0/cloudbase.js +1 -0
  169. package/cdnjs/1.4.2-alpha.0/cloudbase.realtime.js +1 -0
  170. package/cdnjs/1.4.2-alpha.0/cloudbase.storage.js +1 -0
  171. package/cdnjs/1.5.0/cloudbase.analytics.js +1 -0
  172. package/cdnjs/1.5.0/cloudbase.auth.js +1 -0
  173. package/cdnjs/1.5.0/cloudbase.database.js +10 -0
  174. package/cdnjs/1.5.0/cloudbase.full.js +10 -0
  175. package/cdnjs/1.5.0/cloudbase.functions.js +1 -0
  176. package/cdnjs/1.5.0/cloudbase.js +1 -0
  177. package/cdnjs/1.5.0/cloudbase.realtime.js +1 -0
  178. package/cdnjs/1.5.0/cloudbase.storage.js +1 -0
  179. package/cdnjs/1.5.1/cloudbase.analytics.js +1 -0
  180. package/cdnjs/1.5.1/cloudbase.auth.js +1 -0
  181. package/cdnjs/1.5.1/cloudbase.database.js +26 -0
  182. package/cdnjs/1.5.1/cloudbase.full.js +26 -0
  183. package/cdnjs/1.5.1/cloudbase.functions.js +1 -0
  184. package/cdnjs/1.5.1/cloudbase.js +1 -0
  185. package/cdnjs/1.5.1/cloudbase.realtime.js +1 -0
  186. package/cdnjs/1.5.1/cloudbase.storage.js +1 -0
  187. package/cdnjs/1.5.1-alpha.0/cloudbase.analytics.js +1 -0
  188. package/cdnjs/1.5.1-alpha.0/cloudbase.auth.js +1 -0
  189. package/cdnjs/1.5.1-alpha.0/cloudbase.database.js +10 -0
  190. package/cdnjs/1.5.1-alpha.0/cloudbase.full.js +10 -0
  191. package/cdnjs/1.5.1-alpha.0/cloudbase.functions.js +1 -0
  192. package/cdnjs/1.5.1-alpha.0/cloudbase.js +1 -0
  193. package/cdnjs/1.5.1-alpha.0/cloudbase.realtime.js +1 -0
  194. package/cdnjs/1.5.1-alpha.0/cloudbase.storage.js +1 -0
  195. package/cdnjs/1.5.3-alpha.0/cloudbase.analytics.js +1 -0
  196. package/cdnjs/1.5.3-alpha.0/cloudbase.auth.js +1 -0
  197. package/cdnjs/1.5.3-alpha.0/cloudbase.database.js +26 -0
  198. package/cdnjs/1.5.3-alpha.0/cloudbase.full.js +26 -0
  199. package/cdnjs/1.5.3-alpha.0/cloudbase.functions.js +1 -0
  200. package/cdnjs/1.5.3-alpha.0/cloudbase.js +1 -0
  201. package/cdnjs/1.5.3-alpha.0/cloudbase.realtime.js +1 -0
  202. package/cdnjs/1.5.3-alpha.0/cloudbase.storage.js +1 -0
  203. package/cdnjs/1.6.0/cloudbase.analytics.js +1 -0
  204. package/cdnjs/1.6.0/cloudbase.auth.js +1 -0
  205. package/cdnjs/1.6.0/cloudbase.database.js +26 -0
  206. package/cdnjs/1.6.0/cloudbase.full.js +26 -0
  207. package/cdnjs/1.6.0/cloudbase.functions.js +1 -0
  208. package/cdnjs/1.6.0/cloudbase.js +1 -0
  209. package/cdnjs/1.6.0/cloudbase.realtime.js +1 -0
  210. package/cdnjs/1.6.0/cloudbase.storage.js +1 -0
  211. package/{CHANGELOG.md → changelog.md} +0 -0
  212. package/dist/README.md +153 -0
  213. package/{app → dist/app}/index.d.ts +1 -0
  214. package/{app → dist/app}/index.js +0 -0
  215. package/dist/app/index.js.map +1 -0
  216. package/{app → dist/app}/internal.d.ts +0 -0
  217. package/{app → dist/app}/internal.js +0 -0
  218. package/{app → dist/app}/internal.js.map +0 -0
  219. package/{app → dist/app}/openuri.d.ts +0 -0
  220. package/{app → dist/app}/openuri.js +2 -1
  221. package/{app → dist/app}/openuri.js.map +1 -1
  222. package/{app → dist/app}/request.d.ts +4 -3
  223. package/{app → dist/app}/request.js +20 -12
  224. package/dist/app/request.js.map +1 -0
  225. package/{app → dist/app}/storage.d.ts +0 -0
  226. package/{app → dist/app}/storage.js +0 -0
  227. package/{app → dist/app}/storage.js.map +0 -0
  228. package/{auth → dist/auth}/consts.d.ts +21 -4
  229. package/{auth → dist/auth}/consts.js +27 -5
  230. package/dist/auth/consts.js.map +1 -0
  231. package/{auth → dist/auth}/index.d.ts +83 -34
  232. package/{auth → dist/auth}/index.js +239 -92
  233. package/dist/auth/index.js.map +1 -0
  234. package/dist/auth/models.d.ts +284 -0
  235. package/{oauthclient → dist/auth}/models.js +1 -0
  236. package/dist/auth/models.js.map +1 -0
  237. package/{captcha → dist/captcha}/index.d.ts +0 -0
  238. package/{captcha → dist/captcha}/index.js +4 -2
  239. package/dist/captcha/index.js.map +1 -0
  240. package/dist/changelog.md +30 -0
  241. package/dist/function/index.d.ts +38 -0
  242. package/dist/function/index.js +80 -0
  243. package/dist/function/index.js.map +1 -0
  244. package/dist/index.d.ts +14 -0
  245. package/dist/index.js +24 -0
  246. package/dist/index.js.map +1 -0
  247. package/{oauthclient → dist/oauthclient}/consts.d.ts +0 -0
  248. package/{oauthclient → dist/oauthclient}/consts.js +0 -0
  249. package/{oauthclient → dist/oauthclient}/consts.js.map +0 -0
  250. package/{oauthclient → dist/oauthclient}/index.d.ts +0 -0
  251. package/{oauthclient → dist/oauthclient}/index.js +2 -2
  252. package/dist/oauthclient/index.js.map +1 -0
  253. package/{oauthclient → dist/oauthclient}/interface.d.ts +4 -0
  254. package/{oauthclient → dist/oauthclient}/interface.js +0 -0
  255. package/{oauthclient → dist/oauthclient}/interface.js.map +1 -1
  256. package/{oauthclient → dist/oauthclient}/models.d.ts +12 -11
  257. package/{auth → dist/oauthclient}/models.js +0 -0
  258. package/{oauthclient → dist/oauthclient}/models.js.map +0 -0
  259. package/{oauthclient → dist/oauthclient}/oauthclient.d.ts +11 -7
  260. package/{oauthclient → dist/oauthclient}/oauthclient.js +27 -12
  261. package/dist/oauthclient/oauthclient.js.map +1 -0
  262. package/dist/package.json +32 -0
  263. package/{utils/single-promise.d.ts → dist/utils/promise.d.ts} +3 -3
  264. package/{utils/single-promise.js → dist/utils/promise.js} +6 -6
  265. package/dist/utils/promise.js.map +1 -0
  266. package/{utils → dist/utils}/uuid.d.ts +0 -0
  267. package/{utils → dist/utils}/uuid.js +0 -0
  268. package/{utils → dist/utils}/uuid.js.map +0 -0
  269. package/docs/dev.md +71 -0
  270. package/docs/errlog.md +79 -0
  271. package/package.json +3 -2
  272. package/publish.sh +2 -0
  273. package/src/app/index.ts +83 -0
  274. package/src/app/internal.ts +26 -0
  275. package/src/app/openuri.ts +111 -0
  276. package/src/app/request.ts +66 -0
  277. package/src/app/storage.ts +58 -0
  278. package/src/auth/consts.ts +74 -0
  279. package/src/auth/index.ts +718 -0
  280. package/src/auth/models.ts +352 -0
  281. package/src/captcha/index.ts +170 -0
  282. package/src/function/index.ts +103 -0
  283. package/src/index.ts +32 -0
  284. package/src/oauthclient/consts.ts +48 -0
  285. package/src/oauthclient/index.ts +33 -0
  286. package/src/oauthclient/interface.ts +34 -0
  287. package/src/oauthclient/models.ts +50 -0
  288. package/src/oauthclient/oauthclient.ts +487 -0
  289. package/src/utils/promise.ts +41 -0
  290. package/src/utils/uuid.ts +11 -0
  291. package/test/e2e/cases/custom-login.test.js +122 -0
  292. package/test/e2e/cases/index.test.js +61 -0
  293. package/test/e2e/cases/login-state.test.js +89 -0
  294. package/test/e2e/environment.js +39 -0
  295. package/test/e2e/global_setup.js +33 -0
  296. package/test/e2e/global_teardown.js +15 -0
  297. package/test/e2e/setup.js +37 -0
  298. package/test/unit/index.test.js +89 -0
  299. package/test/web/cases/auth/index.js +256 -0
  300. package/test/web/cases/database/collection.js +173 -0
  301. package/test/web/cases/database/command.js +754 -0
  302. package/test/web/cases/database/date.js +122 -0
  303. package/test/web/cases/database/db.js +20 -0
  304. package/test/web/cases/database/document.js +160 -0
  305. package/test/web/cases/database/geo-advanced.js +327 -0
  306. package/test/web/cases/database/geo.js +105 -0
  307. package/test/web/cases/database/index.js +315 -0
  308. package/test/web/cases/database/order.js +83 -0
  309. package/test/web/cases/database/realtime.js +102 -0
  310. package/test/web/cases/database/regex.js +140 -0
  311. package/test/web/cases/ext/index.js +88 -0
  312. package/test/web/cases/function/index.js +77 -0
  313. package/test/web/cases/storage/cos.jpeg +0 -0
  314. package/test/web/cases/storage/index.js +207 -0
  315. package/test/web/index.html +63 -0
  316. package/test/web/index.js +109 -0
  317. package/test/web/util.js +80 -0
  318. package/tsconfig.json +35 -0
  319. package/wiki/README.md +75 -0
  320. package/app/index.js.map +0 -1
  321. package/app/request.js.map +0 -1
  322. package/auth/consts.js.map +0 -1
  323. package/auth/index.js.map +0 -1
  324. package/auth/models.d.ts +0 -158
  325. package/auth/models.js.map +0 -1
  326. package/captcha/index.js.map +0 -1
  327. package/index.d.ts +0 -8
  328. package/index.js +0 -17
  329. package/index.js.map +0 -1
  330. package/oauthclient/index.js.map +0 -1
  331. package/oauthclient/oauthclient.js.map +0 -1
  332. package/utils/single-promise.js.map +0 -1
@@ -0,0 +1,754 @@
1
+ // database command
2
+ import * as assert from 'power-assert';
3
+ import { callbackWithTryCatch, catchCallback, isSuccess } from '../../util';
4
+ import { registerCase } from '.';
5
+
6
+ export function registerCommand(app, collName) {
7
+ const db = app.database();
8
+ const collection = db.collection(collName);
9
+ const _ = db.command;
10
+
11
+ registerCase('database command: eq', async () => {
12
+ return new Promise(async resolve => {
13
+ try {
14
+ let res = await collection.add({ test: 'eq' }).catch(callbackWithTryCatch(err => {
15
+ assert(false, { err });
16
+ }, () => {
17
+ resolve();
18
+ }));
19
+ assert(isSuccess(0, res) && res.id, { res });
20
+
21
+ const query = {
22
+ test: _.eq('eq')
23
+ };
24
+
25
+ res = await collection.where(query).get().catch(callbackWithTryCatch(err => {
26
+ assert(false, { err });
27
+ }, () => {
28
+ resolve();
29
+ }));
30
+ assert(isSuccess(0, res) && res.data.length >= 1, { res });
31
+
32
+ res = await collection.where(query).remove().catch(callbackWithTryCatch(err => {
33
+ assert(false, { err });
34
+ }, () => {
35
+ resolve();
36
+ }));
37
+ assert(isSuccess(0, res) && res.deleted >= 1, { res });
38
+ } catch (e) {
39
+ catchCallback(e);
40
+ } finally {
41
+ resolve();
42
+ }
43
+ });
44
+ });
45
+
46
+ registerCase('database command: neq', async () => {
47
+ return new Promise(async resolve => {
48
+ try {
49
+ let res = await collection.add({ test: 'eq' }).catch(callbackWithTryCatch(err => {
50
+ assert(false, { err });
51
+ }, () => {
52
+ resolve();
53
+ }));
54
+ assert(isSuccess(0, res) && res.id, { res });
55
+
56
+ const query = {
57
+ test: _.neq('neq')
58
+ };
59
+
60
+ res = await collection.where(query).get().catch(callbackWithTryCatch(err => {
61
+ assert(false, { err });
62
+ }, () => {
63
+ resolve();
64
+ }));
65
+ assert(isSuccess(0, res) && res.data.length >= 1, { res });
66
+
67
+ res = await collection.where(query).remove().catch(callbackWithTryCatch(err => {
68
+ assert(false, { err });
69
+ }, () => {
70
+ resolve();
71
+ }));
72
+ assert(isSuccess(0, res) && res.deleted >= 1, { res });
73
+ } catch (e) {
74
+ catchCallback(e);
75
+ } finally {
76
+ resolve();
77
+ }
78
+ });
79
+ });
80
+
81
+ registerCase('database command: gt', async () => {
82
+ return new Promise(async resolve => {
83
+ try {
84
+ let res = await collection.add({ test: 100 }).catch(callbackWithTryCatch(err => {
85
+ assert(false, { err });
86
+ }, () => {
87
+ resolve();
88
+ }));
89
+ assert(isSuccess(0, res) && res.id, { res });
90
+
91
+ const query = {
92
+ test: _.gt(10)
93
+ };
94
+
95
+ res = await collection.where(query).get().catch(callbackWithTryCatch(err => {
96
+ assert(false, { err });
97
+ }, () => {
98
+ resolve();
99
+ }));
100
+ assert(isSuccess(0, res) && res.data.length >= 1, { res });
101
+
102
+ res = await collection.where(query).remove().catch(callbackWithTryCatch(err => {
103
+ assert(false, { err });
104
+ }, () => {
105
+ resolve();
106
+ }));
107
+ assert(isSuccess(0, res) && res.deleted >= 1, { res });
108
+ } catch (e) {
109
+ catchCallback(e);
110
+ } finally {
111
+ resolve();
112
+ }
113
+ });
114
+ });
115
+
116
+ registerCase('database command: gte', async () => {
117
+ return new Promise(async resolve => {
118
+ try {
119
+ let res = await collection.add({ test: 100 }).catch(callbackWithTryCatch(err => {
120
+ assert(false, { err });
121
+ }, () => {
122
+ resolve();
123
+ }));
124
+ assert(isSuccess(0, res) && res.id, { res });
125
+
126
+ const query = {
127
+ test: _.gte(100)
128
+ };
129
+
130
+ res = await collection.where(query).get().catch(callbackWithTryCatch(err => {
131
+ assert(false, { err });
132
+ }, () => {
133
+ resolve();
134
+ }));
135
+ assert(isSuccess(0, res) && res.data.length >= 1, { res });
136
+
137
+ res = await collection.where(query).remove().catch(callbackWithTryCatch(err => {
138
+ assert(false, { err });
139
+ }, () => {
140
+ resolve();
141
+ }));
142
+ assert(isSuccess(0, res) && res.deleted >= 1, { res });
143
+ } catch (e) {
144
+ catchCallback(e);
145
+ } finally {
146
+ resolve();
147
+ }
148
+ });
149
+ });
150
+
151
+ registerCase('database command: lt', async () => {
152
+ return new Promise(async resolve => {
153
+ try {
154
+ let res = await collection.add({ test: 100 }).catch(callbackWithTryCatch(err => {
155
+ assert(false, { err });
156
+ }, () => {
157
+ resolve();
158
+ }));
159
+ assert(isSuccess(0, res) && res.id, { res });
160
+
161
+ const query = {
162
+ test: _.lt(111)
163
+ };
164
+
165
+ res = await collection.where(query).get().catch(callbackWithTryCatch(err => {
166
+ assert(false, { err });
167
+ }, () => {
168
+ resolve();
169
+ }));
170
+ assert(isSuccess(0, res) && res.data.length >= 1, { res });
171
+
172
+ res = await collection.where(query).remove().catch(callbackWithTryCatch(err => {
173
+ assert(false, { err });
174
+ }, () => {
175
+ resolve();
176
+ }));
177
+ assert(isSuccess(0, res) && res.deleted >= 1, { res });
178
+ } catch (e) {
179
+ catchCallback(e);
180
+ } finally {
181
+ resolve();
182
+ }
183
+ });
184
+ });
185
+
186
+ registerCase('database command: lte', async () => {
187
+ return new Promise(async resolve => {
188
+ try {
189
+ let res = await collection.add({ test: 100 }).catch(callbackWithTryCatch(err => {
190
+ assert(false, { err });
191
+ }, () => {
192
+ resolve();
193
+ }));
194
+ assert(isSuccess(0, res) && res.id, { res });
195
+
196
+ const query = {
197
+ test: _.lte(100)
198
+ };
199
+
200
+ res = await collection.where(query).get().catch(callbackWithTryCatch(err => {
201
+ assert(false, { err });
202
+ }, () => {
203
+ resolve();
204
+ }));
205
+ assert(isSuccess(0, res) && res.data.length >= 1, { res });
206
+
207
+ res = await collection.where(query).remove().catch(callbackWithTryCatch(err => {
208
+ assert(false, { err });
209
+ }, () => {
210
+ resolve();
211
+ }));
212
+ assert(isSuccess(0, res) && res.deleted >= 1, { res });
213
+ } catch (e) {
214
+ catchCallback(e);
215
+ } finally {
216
+ resolve();
217
+ }
218
+ });
219
+ });
220
+
221
+ registerCase('database command: in', async () => {
222
+ return new Promise(async resolve => {
223
+ try {
224
+ let res = await collection.add({ test: [100, 10000] }).catch(callbackWithTryCatch(err => {
225
+ assert(false, { err });
226
+ }, () => {
227
+ resolve();
228
+ }));
229
+ assert(isSuccess(0, res) && res.id, { res });
230
+
231
+ const query = {
232
+ test: _.in([10000, 1000])
233
+ };
234
+
235
+ res = await collection.where(query).get().catch(callbackWithTryCatch(err => {
236
+ assert(false, { err });
237
+ }, () => {
238
+ resolve();
239
+ }));
240
+ assert(isSuccess(0, res) && res.data.length >= 1, { res });
241
+
242
+ res = await collection.where({ test: [100, 10000] }).remove().catch(callbackWithTryCatch(err => {
243
+ assert(false, { err });
244
+ }, () => {
245
+ resolve();
246
+ }));
247
+ assert(isSuccess(0, res) && res.deleted >= 1, { res });
248
+ } catch (e) {
249
+ catchCallback(e);
250
+ } finally {
251
+ resolve();
252
+ }
253
+ });
254
+ });
255
+
256
+ registerCase('database command: nin', async () => {
257
+ return new Promise(async resolve => {
258
+ try {
259
+ let res = await collection.add({ test: [100, 10000] }).catch(callbackWithTryCatch(err => {
260
+ assert(false, { err });
261
+ }, () => {
262
+ resolve();
263
+ }));
264
+ assert(isSuccess(0, res) && res.id, { res });
265
+
266
+ const query = {
267
+ test: _.nin([1000, 100000])
268
+ };
269
+
270
+ res = await collection.where(query).get().catch(callbackWithTryCatch(err => {
271
+ assert(false, { err });
272
+ }, () => {
273
+ resolve();
274
+ }));
275
+ assert(isSuccess(0, res) && res.data.length >= 1, { res });
276
+
277
+ res = await collection.where({ test: [100, 10000] }).remove().catch(callbackWithTryCatch(err => {
278
+ assert(false, { err });
279
+ }, () => {
280
+ resolve();
281
+ }));
282
+ assert(isSuccess(0, res) && res.deleted >= 1, { res });
283
+ } catch (e) {
284
+ catchCallback(e);
285
+ } finally {
286
+ resolve();
287
+ }
288
+ });
289
+ });
290
+
291
+ registerCase('database command: and with flow', async () => {
292
+ return new Promise(async resolve => {
293
+ try {
294
+ let res = await collection.add({ test: 100 }).catch(callbackWithTryCatch(err => {
295
+ assert(false, { err });
296
+ }, () => {
297
+ resolve();
298
+ }));
299
+ assert(isSuccess(0, res) && res.id, { res });
300
+
301
+ const query = {
302
+ test: _.gt(10).and(_.lt(1000))
303
+ };
304
+
305
+ res = await collection.where(query).get().catch(callbackWithTryCatch(err => {
306
+ assert(false, { err });
307
+ }, () => {
308
+ resolve();
309
+ }));
310
+ assert(isSuccess(0, res) && res.data.length >= 1, { res });
311
+
312
+ res = await collection.where(query).remove().catch(callbackWithTryCatch(err => {
313
+ assert(false, { err });
314
+ }, () => {
315
+ resolve();
316
+ }));
317
+ assert(isSuccess(0, res) && res.deleted >= 1, { res });
318
+ } catch (e) {
319
+ catchCallback(e);
320
+ } finally {
321
+ resolve();
322
+ }
323
+ });
324
+ });
325
+
326
+ registerCase('database command: and with preset', async () => {
327
+ return new Promise(async resolve => {
328
+ try {
329
+ let res = await collection.add({ test: 100 }).catch(callbackWithTryCatch(err => {
330
+ assert(false, { err });
331
+ }, () => {
332
+ resolve();
333
+ }));
334
+ assert(isSuccess(0, res) && res.id, { res });
335
+
336
+ const query = {
337
+ test: _.and(_.gt(10), _.lt(1000))
338
+ };
339
+
340
+ res = await collection.where(query).get().catch(callbackWithTryCatch(err => {
341
+ assert(false, { err });
342
+ }, () => {
343
+ resolve();
344
+ }));
345
+ assert(isSuccess(0, res) && res.data.length >= 1, { res });
346
+
347
+ res = await collection.where(query).remove().catch(callbackWithTryCatch(err => {
348
+ assert(false, { err });
349
+ }, () => {
350
+ resolve();
351
+ }));
352
+ assert(isSuccess(0, res) && res.deleted >= 1, { res });
353
+ } catch (e) {
354
+ catchCallback(e);
355
+ } finally {
356
+ resolve();
357
+ }
358
+ });
359
+ });
360
+
361
+ registerCase('database command: or with flow', async () => {
362
+ return new Promise(async resolve => {
363
+ try {
364
+ let res = await collection.add({ test: 100 }).catch(callbackWithTryCatch(err => {
365
+ assert(false, { err });
366
+ }, () => {
367
+ resolve();
368
+ }));
369
+ assert(isSuccess(0, res) && res.id, { res });
370
+
371
+ const query = {
372
+ test: _.gt(1000).or(_.lt(1111))
373
+ };
374
+
375
+ res = await collection.where(query).get().catch(callbackWithTryCatch(err => {
376
+ assert(false, { err });
377
+ }, () => {
378
+ resolve();
379
+ }));
380
+ assert(isSuccess(0, res) && res.data.length >= 1, { res });
381
+
382
+ res = await collection.where(query).remove().catch(callbackWithTryCatch(err => {
383
+ assert(false, { err });
384
+ }, () => {
385
+ resolve();
386
+ }));
387
+ assert(isSuccess(0, res) && res.deleted >= 1, { res });
388
+ } catch (e) {
389
+ catchCallback(e);
390
+ } finally {
391
+ resolve();
392
+ }
393
+ });
394
+ });
395
+
396
+ registerCase('database command: or with preset', async () => {
397
+ return new Promise(async resolve => {
398
+ try {
399
+ let res = await collection.add({ test: 100 }).catch(callbackWithTryCatch(err => {
400
+ assert(false, { err });
401
+ }, () => {
402
+ resolve();
403
+ }));
404
+ assert(isSuccess(0, res) && res.id, { res });
405
+
406
+ const query = {
407
+ test: _.or(_.gt(1000), _.lt(111))
408
+ };
409
+
410
+ res = await collection.where(query).get().catch(callbackWithTryCatch(err => {
411
+ assert(false, { err });
412
+ }, () => {
413
+ resolve();
414
+ }));
415
+ assert(isSuccess(0, res) && res.data.length >= 1, { res });
416
+
417
+ res = await collection.where(query).remove().catch(callbackWithTryCatch(err => {
418
+ assert(false, { err });
419
+ }, () => {
420
+ resolve();
421
+ }));
422
+ assert(isSuccess(0, res) && res.deleted >= 1, { res });
423
+ } catch (e) {
424
+ catchCallback(e);
425
+ } finally {
426
+ resolve();
427
+ }
428
+ });
429
+ });
430
+
431
+ registerCase('database command: set', async () => {
432
+ return new Promise(async resolve => {
433
+ try {
434
+ let res = await collection.add({ data: { a: 1, b: 2, c: 3 }}).catch(callbackWithTryCatch(err => {
435
+ assert(false, { err });
436
+ }, () => {
437
+ resolve();
438
+ }));
439
+ assert(isSuccess(0, res) && res.id, { res });
440
+
441
+ const docId = res.id;
442
+ const update = {
443
+ data: _.set({ a: 1, b: 2 })
444
+ };
445
+
446
+ res = await collection.doc(docId).update(update).catch(callbackWithTryCatch(err => {
447
+ assert(false, { err });
448
+ }, () => {
449
+ resolve();
450
+ }));
451
+ assert(isSuccess(0, res) && res.updated >= 1, { res });
452
+
453
+ res = await collection.doc(docId).remove().catch(callbackWithTryCatch(err => {
454
+ assert(false, { err });
455
+ }, () => {
456
+ resolve();
457
+ }));
458
+ assert(isSuccess(0, res) && res.deleted >= 1, { res });
459
+ } catch (e) {
460
+ catchCallback(e);
461
+ } finally {
462
+ resolve();
463
+ }
464
+ });
465
+ });
466
+
467
+ registerCase('database command: inc', async () => {
468
+ return new Promise(async resolve => {
469
+ try {
470
+ let res = await collection.add({ count: 0 }).catch(callbackWithTryCatch(err => {
471
+ assert(false, { err });
472
+ }, () => {
473
+ resolve();
474
+ }));
475
+ assert(isSuccess(0, res) && res.id, { res });
476
+
477
+ const docId = res.id;
478
+ const update = {
479
+ count: _.inc(2)
480
+ };
481
+
482
+ res = await collection.doc(docId).update(update).catch(callbackWithTryCatch(err => {
483
+ assert(false, { err });
484
+ }, () => {
485
+ resolve();
486
+ }));
487
+ assert(isSuccess(0, res) && res.updated >= 1, { res });
488
+
489
+ res = await collection.doc(docId).get().catch(callbackWithTryCatch(err => {
490
+ assert(false, { err });
491
+ }));
492
+ assert(isSuccess(0, res), { res });
493
+ assert.deepStrictEqual(res.data[0].count, 2, { res });
494
+
495
+ res = await collection.doc(docId).remove().catch(callbackWithTryCatch(err => {
496
+ assert(false, { err });
497
+ }, () => {
498
+ resolve();
499
+ }));
500
+ assert(isSuccess(0, res) && res.deleted >= 1, { res });
501
+ } catch (e) {
502
+ catchCallback(e);
503
+ } finally {
504
+ resolve();
505
+ }
506
+ });
507
+ });
508
+
509
+ registerCase('database command: mul', async () => {
510
+ return new Promise(async resolve => {
511
+ try {
512
+ let res = await collection.add({ count: 3 }).catch(callbackWithTryCatch(err => {
513
+ assert(false, { err });
514
+ }, () => {
515
+ resolve();
516
+ }));
517
+ assert(isSuccess(0, res) && res.id, { res });
518
+
519
+ const docId = res.id;
520
+ const update = {
521
+ count: _.mul(2.5)
522
+ };
523
+
524
+ res = await collection.doc(docId).update(update).catch(callbackWithTryCatch(err => {
525
+ assert(false, { err });
526
+ }, () => {
527
+ resolve();
528
+ }));
529
+ assert(isSuccess(0, res) && res.updated >= 1, { res });
530
+
531
+ res = await collection.doc(docId).get().catch(callbackWithTryCatch(err => {
532
+ assert(false, { err });
533
+ }));
534
+ assert(isSuccess(0, res), { res });
535
+ assert.deepStrictEqual(res.data[0].count, 7.5, { res });
536
+
537
+ res = await collection.doc(docId).remove().catch(callbackWithTryCatch(err => {
538
+ assert(false, { err });
539
+ }, () => {
540
+ resolve();
541
+ }));
542
+ assert(isSuccess(0, res) && res.deleted >= 1, { res });
543
+ } catch (e) {
544
+ catchCallback(e);
545
+ } finally {
546
+ resolve();
547
+ }
548
+ });
549
+ });
550
+
551
+ registerCase('database command: remove', async () => {
552
+ return new Promise(async resolve => {
553
+ try {
554
+ let res = await collection.add({ data: { a: 1, b: 2, c: 3 }}).catch(callbackWithTryCatch(err => {
555
+ assert(false, { err });
556
+ }, () => {
557
+ resolve();
558
+ }));
559
+ assert(isSuccess(0, res) && res.id, { res });
560
+
561
+ const docId = res.id;
562
+ const update = {
563
+ data: { c: _.remove() }
564
+ };
565
+
566
+ res = await collection.doc(docId).update(update).catch(callbackWithTryCatch(err => {
567
+ assert(false, { err });
568
+ }, () => {
569
+ resolve();
570
+ }));
571
+ assert(isSuccess(0, res) && res.updated >= 1, { res });
572
+
573
+ res = await collection.doc(docId).remove().catch(callbackWithTryCatch(err => {
574
+ assert(false, { err });
575
+ }, () => {
576
+ resolve();
577
+ }));
578
+ assert(isSuccess(0, res) && res.deleted >= 1, { res });
579
+ } catch (e) {
580
+ catchCallback(e);
581
+ } finally {
582
+ resolve();
583
+ }
584
+ });
585
+ });
586
+
587
+ registerCase('database command: push', async () => {
588
+ return new Promise(async resolve => {
589
+ try {
590
+ let res = await collection.add({ test: [100, 10000] }).catch(callbackWithTryCatch(err => {
591
+ assert(false, { err });
592
+ }, () => {
593
+ resolve();
594
+ }));
595
+ assert(isSuccess(0, res) && res.id, { res });
596
+
597
+ const docId = res.id;
598
+ const update = {
599
+ test: _.push(1000)
600
+ };
601
+
602
+ res = await collection.doc(docId).update(update).catch(callbackWithTryCatch(err => {
603
+ assert(false, { err });
604
+ }, () => {
605
+ resolve();
606
+ }));
607
+ assert(isSuccess(0, res) && res.updated >= 1, { res });
608
+
609
+ res = await collection.doc(docId).get().catch(callbackWithTryCatch(err => {
610
+ assert(false, { err });
611
+ }));
612
+ assert(isSuccess(0, res), { res });
613
+ assert.deepStrictEqual(res.data[0].test, [100, 10000, 1000], { res });
614
+
615
+ res = await collection.doc(docId).remove().catch(callbackWithTryCatch(err => {
616
+ assert(false, { err });
617
+ }, () => {
618
+ resolve();
619
+ }));
620
+ assert(isSuccess(0, res) && res.deleted >= 1, { res });
621
+ } catch (e) {
622
+ catchCallback(e);
623
+ } finally {
624
+ resolve();
625
+ }
626
+ });
627
+ });
628
+
629
+ registerCase('database command: pop', async () => {
630
+ return new Promise(async resolve => {
631
+ try {
632
+ let res = await collection.add({ test: [100, 10000] }).catch(callbackWithTryCatch(err => {
633
+ assert(false, { err });
634
+ }, () => {
635
+ resolve();
636
+ }));
637
+ assert(isSuccess(0, res) && res.id, { res });
638
+
639
+ const docId = res.id;
640
+ const update = {
641
+ test: _.pop()
642
+ };
643
+
644
+ res = await collection.doc(docId).update(update).catch(callbackWithTryCatch(err => {
645
+ assert(false, { err });
646
+ }, () => {
647
+ resolve();
648
+ }));
649
+ assert(isSuccess(0, res) && res.updated >= 1, { res });
650
+
651
+ res = await collection.doc(docId).get().catch(callbackWithTryCatch(err => {
652
+ assert(false, { err });
653
+ }));
654
+ assert(isSuccess(0, res), { res });
655
+ assert.deepStrictEqual(res.data[0].test, [100], { res });
656
+
657
+ res = await collection.doc(docId).remove().catch(callbackWithTryCatch(err => {
658
+ assert(false, { err });
659
+ }, () => {
660
+ resolve();
661
+ }));
662
+ assert(isSuccess(0, res) && res.deleted >= 1, { res });
663
+ } catch (e) {
664
+ catchCallback(e);
665
+ } finally {
666
+ resolve();
667
+ }
668
+ });
669
+ });
670
+
671
+ registerCase('database command: unshift', async () => {
672
+ return new Promise(async resolve => {
673
+ try {
674
+ let res = await collection.add({ test: [100, 10000] }).catch(callbackWithTryCatch(err => {
675
+ assert(false, { err });
676
+ }, () => {
677
+ resolve();
678
+ }));
679
+ assert(isSuccess(0, res) && res.id, { res });
680
+
681
+ const docId = res.id;
682
+ const update = {
683
+ test: _.unshift(1000)
684
+ };
685
+
686
+ res = await collection.doc(docId).update(update).catch(callbackWithTryCatch(err => {
687
+ assert(false, { err });
688
+ }, () => {
689
+ resolve();
690
+ }));
691
+ assert(isSuccess(0, res) && res.updated >= 1, { res });
692
+
693
+ res = await collection.doc(docId).get().catch(callbackWithTryCatch(err => {
694
+ assert(false, { err });
695
+ }));
696
+ assert(isSuccess(0, res), { res });
697
+ assert.deepStrictEqual(res.data[0].test, [1000, 100, 10000], { res });
698
+
699
+ res = await collection.doc(docId).remove().catch(callbackWithTryCatch(err => {
700
+ assert(false, { err });
701
+ }, () => {
702
+ resolve();
703
+ }));
704
+ assert(isSuccess(0, res) && res.deleted >= 1, { res });
705
+ } catch (e) {
706
+ catchCallback(e);
707
+ } finally {
708
+ resolve();
709
+ }
710
+ });
711
+ });
712
+
713
+ registerCase('database command: shift', async () => {
714
+ return new Promise(async resolve => {
715
+ try {
716
+ let res = await collection.add({ test: [100, 10000] }).catch(callbackWithTryCatch(err => {
717
+ assert(false, { err });
718
+ }, () => {
719
+ resolve();
720
+ }));
721
+ assert(isSuccess(0, res) && res.id, { res });
722
+
723
+ const docId = res.id;
724
+ const update = {
725
+ test: _.shift()
726
+ };
727
+
728
+ res = await collection.doc(docId).update(update).catch(callbackWithTryCatch(err => {
729
+ assert(false, { err });
730
+ }, () => {
731
+ resolve();
732
+ }));
733
+ assert(isSuccess(0, res) && res.updated >= 1, { res });
734
+
735
+ res = await collection.doc(docId).get().catch(callbackWithTryCatch(err => {
736
+ assert(false, { err });
737
+ }));
738
+ assert(isSuccess(0, res), { res });
739
+ assert.deepStrictEqual(res.data[0].test, [10000], { res });
740
+
741
+ res = await collection.doc(docId).remove().catch(callbackWithTryCatch(err => {
742
+ assert(false, { err });
743
+ }, () => {
744
+ resolve();
745
+ }));
746
+ assert(isSuccess(0, res) && res.deleted >= 1, { res });
747
+ } catch (e) {
748
+ catchCallback(e);
749
+ } finally {
750
+ resolve();
751
+ }
752
+ });
753
+ });
754
+ }