merge_accounting_client 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 (399) hide show
  1. checksums.yaml +7 -0
  2. data/Gemfile +9 -0
  3. data/README.md +251 -0
  4. data/Rakefile +10 -0
  5. data/docs/Account.md +38 -0
  6. data/docs/AccountDetails.md +34 -0
  7. data/docs/AccountDetailsAndActions.md +34 -0
  8. data/docs/AccountDetailsAndActionsIntegration.md +32 -0
  9. data/docs/AccountDetailsAndActionsStatusEnum.md +15 -0
  10. data/docs/AccountDetailsApi.md +79 -0
  11. data/docs/AccountIntegration.md +28 -0
  12. data/docs/AccountStatusEnum.md +15 -0
  13. data/docs/AccountToken.md +20 -0
  14. data/docs/AccountTokenApi.md +79 -0
  15. data/docs/AccountingAttachment.md +26 -0
  16. data/docs/AccountingPhoneNumber.md +20 -0
  17. data/docs/AccountsApi.md +177 -0
  18. data/docs/Address.md +30 -0
  19. data/docs/AddressTypeEnum.md +15 -0
  20. data/docs/AddressesApi.md +85 -0
  21. data/docs/AttachmentsApi.md +177 -0
  22. data/docs/AvailableActions.md +22 -0
  23. data/docs/AvailableActionsApi.md +79 -0
  24. data/docs/BalanceSheet.md +36 -0
  25. data/docs/BalanceSheetsApi.md +177 -0
  26. data/docs/CashFlowStatement.md +40 -0
  27. data/docs/CashFlowStatementsApi.md +177 -0
  28. data/docs/CategoriesEnum.md +15 -0
  29. data/docs/CategoryEnum.md +15 -0
  30. data/docs/ClassificationEnum.md +15 -0
  31. data/docs/CompanyInfo.md +42 -0
  32. data/docs/CompanyInfoApi.md +181 -0
  33. data/docs/Contact.md +42 -0
  34. data/docs/ContactsApi.md +181 -0
  35. data/docs/CountryEnum.md +15 -0
  36. data/docs/CreditNote.md +38 -0
  37. data/docs/CreditNoteStatusEnum.md +15 -0
  38. data/docs/CreditNotesApi.md +181 -0
  39. data/docs/CurrencyEnum.md +15 -0
  40. data/docs/DataPassthroughRequest.md +30 -0
  41. data/docs/DebugModeLog.md +22 -0
  42. data/docs/DebugModelLogSummary.md +22 -0
  43. data/docs/DeleteAccountApi.md +78 -0
  44. data/docs/EncodingEnum.md +15 -0
  45. data/docs/EndUserDetailsRequest.md +28 -0
  46. data/docs/ErrorValidationProblem.md +24 -0
  47. data/docs/Expense.md +38 -0
  48. data/docs/ExpenseLine.md +28 -0
  49. data/docs/ExpensesApi.md +181 -0
  50. data/docs/ForceResyncApi.md +79 -0
  51. data/docs/GenerateKeyApi.md +79 -0
  52. data/docs/GenerateRemoteKeyRequest.md +18 -0
  53. data/docs/IncomeStatement.md +42 -0
  54. data/docs/IncomeStatementsApi.md +177 -0
  55. data/docs/Invoice.md +54 -0
  56. data/docs/InvoiceEndpointRequest.md +18 -0
  57. data/docs/InvoiceLineItem.md +34 -0
  58. data/docs/InvoiceLineItemRequest.md +30 -0
  59. data/docs/InvoiceRequest.md +48 -0
  60. data/docs/InvoiceResponse.md +24 -0
  61. data/docs/InvoiceTypeEnum.md +15 -0
  62. data/docs/InvoicesApi.md +337 -0
  63. data/docs/Issue.md +30 -0
  64. data/docs/IssueStatusEnum.md +15 -0
  65. data/docs/IssuesApi.md +177 -0
  66. data/docs/Item.md +36 -0
  67. data/docs/ItemsApi.md +181 -0
  68. data/docs/JournalEntriesApi.md +333 -0
  69. data/docs/JournalEntry.md +32 -0
  70. data/docs/JournalEntryEndpointRequest.md +18 -0
  71. data/docs/JournalEntryRequest.md +26 -0
  72. data/docs/JournalEntryResponse.md +24 -0
  73. data/docs/JournalLine.md +26 -0
  74. data/docs/JournalLineRequest.md +26 -0
  75. data/docs/LinkToken.md +20 -0
  76. data/docs/LinkTokenApi.md +79 -0
  77. data/docs/LinkedAccountStatus.md +20 -0
  78. data/docs/LinkedAccountsApi.md +103 -0
  79. data/docs/MetaResponse.md +24 -0
  80. data/docs/MethodEnum.md +15 -0
  81. data/docs/ModelOperation.md +24 -0
  82. data/docs/MultipartFormFieldRequest.md +26 -0
  83. data/docs/PaginatedAccountDetailsAndActionsList.md +22 -0
  84. data/docs/PaginatedAccountList.md +22 -0
  85. data/docs/PaginatedAccountingAttachmentList.md +22 -0
  86. data/docs/PaginatedBalanceSheetList.md +22 -0
  87. data/docs/PaginatedCashFlowStatementList.md +22 -0
  88. data/docs/PaginatedCompanyInfoList.md +22 -0
  89. data/docs/PaginatedContactList.md +22 -0
  90. data/docs/PaginatedCreditNoteList.md +22 -0
  91. data/docs/PaginatedExpenseList.md +22 -0
  92. data/docs/PaginatedIncomeStatementList.md +22 -0
  93. data/docs/PaginatedInvoiceList.md +22 -0
  94. data/docs/PaginatedIssueList.md +22 -0
  95. data/docs/PaginatedItemList.md +22 -0
  96. data/docs/PaginatedJournalEntryList.md +22 -0
  97. data/docs/PaginatedPaymentList.md +22 -0
  98. data/docs/PaginatedPurchaseOrderList.md +22 -0
  99. data/docs/PaginatedSyncStatusList.md +22 -0
  100. data/docs/PaginatedTaxRateList.md +22 -0
  101. data/docs/PaginatedTrackingCategoryList.md +22 -0
  102. data/docs/PaginatedWebhookReceiverList.md +22 -0
  103. data/docs/PassthroughApi.md +81 -0
  104. data/docs/Payment.md +32 -0
  105. data/docs/PaymentsApi.md +185 -0
  106. data/docs/PhoneNumbersApi.md +85 -0
  107. data/docs/PurchaseOrder.md +40 -0
  108. data/docs/PurchaseOrderLineItem.md +24 -0
  109. data/docs/PurchaseOrderStatusEnum.md +15 -0
  110. data/docs/PurchaseOrdersApi.md +181 -0
  111. data/docs/RegenerateKeyApi.md +79 -0
  112. data/docs/RemoteData.md +20 -0
  113. data/docs/RemoteDataRequest.md +20 -0
  114. data/docs/RemoteKey.md +20 -0
  115. data/docs/RemoteKeyForRegenerationRequest.md +18 -0
  116. data/docs/RemoteResponse.md +26 -0
  117. data/docs/ReportItem.md +24 -0
  118. data/docs/RequestFormatEnum.md +15 -0
  119. data/docs/StateEnum.md +15 -0
  120. data/docs/Status7d1Enum.md +15 -0
  121. data/docs/SyncStatus.md +28 -0
  122. data/docs/SyncStatusApi.md +85 -0
  123. data/docs/SyncStatusStatusEnum.md +15 -0
  124. data/docs/TaxRate.md +28 -0
  125. data/docs/TaxRatesApi.md +177 -0
  126. data/docs/TrackingCategoriesApi.md +177 -0
  127. data/docs/TrackingCategory.md +26 -0
  128. data/docs/ValidationProblemSource.md +18 -0
  129. data/docs/WarningValidationProblem.md +24 -0
  130. data/docs/WebhookReceiver.md +22 -0
  131. data/docs/WebhookReceiverRequest.md +22 -0
  132. data/docs/WebhookReceiversApi.md +155 -0
  133. data/lib/merge_accounting_client/api/account_details_api.rb +84 -0
  134. data/lib/merge_accounting_client/api/account_token_api.rb +83 -0
  135. data/lib/merge_accounting_client/api/accounts_api.rb +182 -0
  136. data/lib/merge_accounting_client/api/addresses_api.rb +93 -0
  137. data/lib/merge_accounting_client/api/attachments_api.rb +182 -0
  138. data/lib/merge_accounting_client/api/available_actions_api.rb +84 -0
  139. data/lib/merge_accounting_client/api/balance_sheets_api.rb +182 -0
  140. data/lib/merge_accounting_client/api/cash_flow_statements_api.rb +182 -0
  141. data/lib/merge_accounting_client/api/company_info_api.rb +196 -0
  142. data/lib/merge_accounting_client/api/contacts_api.rb +196 -0
  143. data/lib/merge_accounting_client/api/credit_notes_api.rb +196 -0
  144. data/lib/merge_accounting_client/api/delete_account_api.rb +82 -0
  145. data/lib/merge_accounting_client/api/expenses_api.rb +196 -0
  146. data/lib/merge_accounting_client/api/force_resync_api.rb +84 -0
  147. data/lib/merge_accounting_client/api/generate_key_api.rb +85 -0
  148. data/lib/merge_accounting_client/api/income_statements_api.rb +182 -0
  149. data/lib/merge_accounting_client/api/invoices_api.rb +344 -0
  150. data/lib/merge_accounting_client/api/issues_api.rb +181 -0
  151. data/lib/merge_accounting_client/api/items_api.rb +196 -0
  152. data/lib/merge_accounting_client/api/journal_entries_api.rb +334 -0
  153. data/lib/merge_accounting_client/api/link_token_api.rb +85 -0
  154. data/lib/merge_accounting_client/api/linked_accounts_api.rb +117 -0
  155. data/lib/merge_accounting_client/api/passthrough_api.rb +92 -0
  156. data/lib/merge_accounting_client/api/payments_api.rb +202 -0
  157. data/lib/merge_accounting_client/api/phone_numbers_api.rb +93 -0
  158. data/lib/merge_accounting_client/api/purchase_orders_api.rb +196 -0
  159. data/lib/merge_accounting_client/api/regenerate_key_api.rb +85 -0
  160. data/lib/merge_accounting_client/api/sync_status_api.rb +90 -0
  161. data/lib/merge_accounting_client/api/tax_rates_api.rb +182 -0
  162. data/lib/merge_accounting_client/api/tracking_categories_api.rb +182 -0
  163. data/lib/merge_accounting_client/api/webhook_receivers_api.rb +146 -0
  164. data/lib/merge_accounting_client/api_client.rb +390 -0
  165. data/lib/merge_accounting_client/api_error.rb +57 -0
  166. data/lib/merge_accounting_client/configuration.rb +281 -0
  167. data/lib/merge_accounting_client/models/account.rb +330 -0
  168. data/lib/merge_accounting_client/models/account_details.rb +291 -0
  169. data/lib/merge_accounting_client/models/account_details_and_actions.rb +316 -0
  170. data/lib/merge_accounting_client/models/account_details_and_actions_integration.rb +310 -0
  171. data/lib/merge_accounting_client/models/account_details_and_actions_status_enum.rb +38 -0
  172. data/lib/merge_accounting_client/models/account_integration.rb +303 -0
  173. data/lib/merge_accounting_client/models/account_status_enum.rb +38 -0
  174. data/lib/merge_accounting_client/models/account_token.rb +237 -0
  175. data/lib/merge_accounting_client/models/accounting_attachment.rb +279 -0
  176. data/lib/merge_accounting_client/models/accounting_phone_number.rb +232 -0
  177. data/lib/merge_accounting_client/models/address.rb +287 -0
  178. data/lib/merge_accounting_client/models/address_type_enum.rb +37 -0
  179. data/lib/merge_accounting_client/models/available_actions.rb +249 -0
  180. data/lib/merge_accounting_client/models/balance_sheet.rb +319 -0
  181. data/lib/merge_accounting_client/models/cash_flow_statement.rb +341 -0
  182. data/lib/merge_accounting_client/models/categories_enum.rb +39 -0
  183. data/lib/merge_accounting_client/models/category_enum.rb +39 -0
  184. data/lib/merge_accounting_client/models/classification_enum.rb +40 -0
  185. data/lib/merge_accounting_client/models/company_info.rb +402 -0
  186. data/lib/merge_accounting_client/models/contact.rb +354 -0
  187. data/lib/merge_accounting_client/models/country_enum.rb +284 -0
  188. data/lib/merge_accounting_client/models/credit_note.rb +331 -0
  189. data/lib/merge_accounting_client/models/credit_note_status_enum.rb +38 -0
  190. data/lib/merge_accounting_client/models/currency_enum.rb +341 -0
  191. data/lib/merge_accounting_client/models/data_passthrough_request.rb +343 -0
  192. data/lib/merge_accounting_client/models/debug_mode_log.rb +251 -0
  193. data/lib/merge_accounting_client/models/debug_model_log_summary.rb +251 -0
  194. data/lib/merge_accounting_client/models/encoding_enum.rb +37 -0
  195. data/lib/merge_accounting_client/models/end_user_details_request.rb +413 -0
  196. data/lib/merge_accounting_client/models/error_validation_problem.rb +260 -0
  197. data/lib/merge_accounting_client/models/expense.rb +328 -0
  198. data/lib/merge_accounting_client/models/expense_line.rb +274 -0
  199. data/lib/merge_accounting_client/models/generate_remote_key_request.rb +243 -0
  200. data/lib/merge_accounting_client/models/income_statement.rb +352 -0
  201. data/lib/merge_accounting_client/models/invoice.rb +418 -0
  202. data/lib/merge_accounting_client/models/invoice_endpoint_request.rb +223 -0
  203. data/lib/merge_accounting_client/models/invoice_line_item.rb +306 -0
  204. data/lib/merge_accounting_client/models/invoice_line_item_request.rb +285 -0
  205. data/lib/merge_accounting_client/models/invoice_request.rb +386 -0
  206. data/lib/merge_accounting_client/models/invoice_response.rb +266 -0
  207. data/lib/merge_accounting_client/models/invoice_type_enum.rb +37 -0
  208. data/lib/merge_accounting_client/models/issue.rb +281 -0
  209. data/lib/merge_accounting_client/models/issue_status_enum.rb +37 -0
  210. data/lib/merge_accounting_client/models/item.rb +317 -0
  211. data/lib/merge_accounting_client/models/journal_entry.rb +298 -0
  212. data/lib/merge_accounting_client/models/journal_entry_endpoint_request.rb +223 -0
  213. data/lib/merge_accounting_client/models/journal_entry_request.rb +266 -0
  214. data/lib/merge_accounting_client/models/journal_entry_response.rb +266 -0
  215. data/lib/merge_accounting_client/models/journal_line.rb +263 -0
  216. data/lib/merge_accounting_client/models/journal_line_request.rb +263 -0
  217. data/lib/merge_accounting_client/models/link_token.rb +237 -0
  218. data/lib/merge_accounting_client/models/linked_account_status.rb +237 -0
  219. data/lib/merge_accounting_client/models/meta_response.rb +262 -0
  220. data/lib/merge_accounting_client/models/method_enum.rb +42 -0
  221. data/lib/merge_accounting_client/models/model_operation.rb +272 -0
  222. data/lib/merge_accounting_client/models/multipart_form_field_request.rb +341 -0
  223. data/lib/merge_accounting_client/models/paginated_account_details_and_actions_list.rb +240 -0
  224. data/lib/merge_accounting_client/models/paginated_account_list.rb +240 -0
  225. data/lib/merge_accounting_client/models/paginated_accounting_attachment_list.rb +240 -0
  226. data/lib/merge_accounting_client/models/paginated_balance_sheet_list.rb +240 -0
  227. data/lib/merge_accounting_client/models/paginated_cash_flow_statement_list.rb +240 -0
  228. data/lib/merge_accounting_client/models/paginated_company_info_list.rb +240 -0
  229. data/lib/merge_accounting_client/models/paginated_contact_list.rb +240 -0
  230. data/lib/merge_accounting_client/models/paginated_credit_note_list.rb +240 -0
  231. data/lib/merge_accounting_client/models/paginated_expense_list.rb +240 -0
  232. data/lib/merge_accounting_client/models/paginated_income_statement_list.rb +240 -0
  233. data/lib/merge_accounting_client/models/paginated_invoice_list.rb +240 -0
  234. data/lib/merge_accounting_client/models/paginated_issue_list.rb +240 -0
  235. data/lib/merge_accounting_client/models/paginated_item_list.rb +240 -0
  236. data/lib/merge_accounting_client/models/paginated_journal_entry_list.rb +240 -0
  237. data/lib/merge_accounting_client/models/paginated_payment_list.rb +240 -0
  238. data/lib/merge_accounting_client/models/paginated_purchase_order_list.rb +240 -0
  239. data/lib/merge_accounting_client/models/paginated_sync_status_list.rb +240 -0
  240. data/lib/merge_accounting_client/models/paginated_tax_rate_list.rb +240 -0
  241. data/lib/merge_accounting_client/models/paginated_tracking_category_list.rb +240 -0
  242. data/lib/merge_accounting_client/models/paginated_webhook_receiver_list.rb +240 -0
  243. data/lib/merge_accounting_client/models/payment.rb +295 -0
  244. data/lib/merge_accounting_client/models/purchase_order.rb +341 -0
  245. data/lib/merge_accounting_client/models/purchase_order_line_item.rb +253 -0
  246. data/lib/merge_accounting_client/models/purchase_order_status_enum.rb +40 -0
  247. data/lib/merge_accounting_client/models/remote_data.rb +234 -0
  248. data/lib/merge_accounting_client/models/remote_data_request.rb +253 -0
  249. data/lib/merge_accounting_client/models/remote_key.rb +238 -0
  250. data/lib/merge_accounting_client/models/remote_key_for_regeneration_request.rb +243 -0
  251. data/lib/merge_accounting_client/models/remote_response.rb +279 -0
  252. data/lib/merge_accounting_client/models/report_item.rb +254 -0
  253. data/lib/merge_accounting_client/models/request_format_enum.rb +38 -0
  254. data/lib/merge_accounting_client/models/state_enum.rb +94 -0
  255. data/lib/merge_accounting_client/models/status7d1_enum.rb +37 -0
  256. data/lib/merge_accounting_client/models/sync_status.rb +294 -0
  257. data/lib/merge_accounting_client/models/sync_status_status_enum.rb +39 -0
  258. data/lib/merge_accounting_client/models/tax_rate.rb +275 -0
  259. data/lib/merge_accounting_client/models/tracking_category.rb +264 -0
  260. data/lib/merge_accounting_client/models/validation_problem_source.rb +223 -0
  261. data/lib/merge_accounting_client/models/warning_validation_problem.rb +260 -0
  262. data/lib/merge_accounting_client/models/webhook_receiver.rb +246 -0
  263. data/lib/merge_accounting_client/models/webhook_receiver_request.rb +280 -0
  264. data/lib/merge_accounting_client/version.rb +15 -0
  265. data/lib/merge_accounting_client.rb +167 -0
  266. data/merge_accounting_client.gemspec +38 -0
  267. data/pull_request_template.md +19 -0
  268. data/spec/api/account_details_api_spec.rb +46 -0
  269. data/spec/api/account_token_api_spec.rb +46 -0
  270. data/spec/api/accounts_api_spec.rb +68 -0
  271. data/spec/api/addresses_api_spec.rb +48 -0
  272. data/spec/api/attachments_api_spec.rb +68 -0
  273. data/spec/api/available_actions_api_spec.rb +46 -0
  274. data/spec/api/balance_sheets_api_spec.rb +68 -0
  275. data/spec/api/cash_flow_statements_api_spec.rb +68 -0
  276. data/spec/api/company_info_api_spec.rb +70 -0
  277. data/spec/api/contacts_api_spec.rb +70 -0
  278. data/spec/api/credit_notes_api_spec.rb +70 -0
  279. data/spec/api/delete_account_api_spec.rb +46 -0
  280. data/spec/api/expenses_api_spec.rb +70 -0
  281. data/spec/api/force_resync_api_spec.rb +46 -0
  282. data/spec/api/generate_key_api_spec.rb +46 -0
  283. data/spec/api/income_statements_api_spec.rb +68 -0
  284. data/spec/api/invoices_api_spec.rb +97 -0
  285. data/spec/api/issues_api_spec.rb +69 -0
  286. data/spec/api/items_api_spec.rb +70 -0
  287. data/spec/api/journal_entries_api_spec.rb +95 -0
  288. data/spec/api/link_token_api_spec.rb +46 -0
  289. data/spec/api/linked_accounts_api_spec.rb +57 -0
  290. data/spec/api/passthrough_api_spec.rb +47 -0
  291. data/spec/api/payments_api_spec.rb +72 -0
  292. data/spec/api/phone_numbers_api_spec.rb +48 -0
  293. data/spec/api/purchase_orders_api_spec.rb +70 -0
  294. data/spec/api/regenerate_key_api_spec.rb +46 -0
  295. data/spec/api/sync_status_api_spec.rb +48 -0
  296. data/spec/api/tax_rates_api_spec.rb +68 -0
  297. data/spec/api/tracking_categories_api_spec.rb +68 -0
  298. data/spec/api/webhook_receivers_api_spec.rb +58 -0
  299. data/spec/api_client_spec.rb +226 -0
  300. data/spec/configuration_spec.rb +42 -0
  301. data/spec/models/account_details_and_actions_integration_spec.rb +76 -0
  302. data/spec/models/account_details_and_actions_spec.rb +82 -0
  303. data/spec/models/account_details_and_actions_status_enum_spec.rb +28 -0
  304. data/spec/models/account_details_spec.rb +82 -0
  305. data/spec/models/account_integration_spec.rb +64 -0
  306. data/spec/models/account_spec.rb +94 -0
  307. data/spec/models/account_status_enum_spec.rb +28 -0
  308. data/spec/models/account_token_spec.rb +40 -0
  309. data/spec/models/accounting_attachment_spec.rb +58 -0
  310. data/spec/models/accounting_phone_number_spec.rb +40 -0
  311. data/spec/models/address_spec.rb +70 -0
  312. data/spec/models/address_type_enum_spec.rb +28 -0
  313. data/spec/models/available_actions_spec.rb +46 -0
  314. data/spec/models/balance_sheet_spec.rb +88 -0
  315. data/spec/models/cash_flow_statement_spec.rb +100 -0
  316. data/spec/models/categories_enum_spec.rb +28 -0
  317. data/spec/models/category_enum_spec.rb +28 -0
  318. data/spec/models/classification_enum_spec.rb +28 -0
  319. data/spec/models/company_info_spec.rb +106 -0
  320. data/spec/models/contact_spec.rb +106 -0
  321. data/spec/models/country_enum_spec.rb +28 -0
  322. data/spec/models/credit_note_spec.rb +94 -0
  323. data/spec/models/credit_note_status_enum_spec.rb +28 -0
  324. data/spec/models/currency_enum_spec.rb +28 -0
  325. data/spec/models/data_passthrough_request_spec.rb +70 -0
  326. data/spec/models/debug_mode_log_spec.rb +46 -0
  327. data/spec/models/debug_model_log_summary_spec.rb +46 -0
  328. data/spec/models/encoding_enum_spec.rb +28 -0
  329. data/spec/models/end_user_details_request_spec.rb +64 -0
  330. data/spec/models/error_validation_problem_spec.rb +52 -0
  331. data/spec/models/expense_line_spec.rb +64 -0
  332. data/spec/models/expense_spec.rb +94 -0
  333. data/spec/models/generate_remote_key_request_spec.rb +34 -0
  334. data/spec/models/income_statement_spec.rb +106 -0
  335. data/spec/models/invoice_endpoint_request_spec.rb +34 -0
  336. data/spec/models/invoice_line_item_request_spec.rb +70 -0
  337. data/spec/models/invoice_line_item_spec.rb +82 -0
  338. data/spec/models/invoice_request_spec.rb +124 -0
  339. data/spec/models/invoice_response_spec.rb +52 -0
  340. data/spec/models/invoice_spec.rb +142 -0
  341. data/spec/models/invoice_type_enum_spec.rb +28 -0
  342. data/spec/models/issue_spec.rb +70 -0
  343. data/spec/models/issue_status_enum_spec.rb +28 -0
  344. data/spec/models/item_spec.rb +88 -0
  345. data/spec/models/journal_entry_endpoint_request_spec.rb +34 -0
  346. data/spec/models/journal_entry_request_spec.rb +58 -0
  347. data/spec/models/journal_entry_response_spec.rb +52 -0
  348. data/spec/models/journal_entry_spec.rb +76 -0
  349. data/spec/models/journal_line_request_spec.rb +58 -0
  350. data/spec/models/journal_line_spec.rb +58 -0
  351. data/spec/models/link_token_spec.rb +40 -0
  352. data/spec/models/linked_account_status_spec.rb +40 -0
  353. data/spec/models/meta_response_spec.rb +52 -0
  354. data/spec/models/method_enum_spec.rb +28 -0
  355. data/spec/models/model_operation_spec.rb +52 -0
  356. data/spec/models/multipart_form_field_request_spec.rb +58 -0
  357. data/spec/models/paginated_account_details_and_actions_list_spec.rb +46 -0
  358. data/spec/models/paginated_account_list_spec.rb +46 -0
  359. data/spec/models/paginated_accounting_attachment_list_spec.rb +46 -0
  360. data/spec/models/paginated_balance_sheet_list_spec.rb +46 -0
  361. data/spec/models/paginated_cash_flow_statement_list_spec.rb +46 -0
  362. data/spec/models/paginated_company_info_list_spec.rb +46 -0
  363. data/spec/models/paginated_contact_list_spec.rb +46 -0
  364. data/spec/models/paginated_credit_note_list_spec.rb +46 -0
  365. data/spec/models/paginated_expense_list_spec.rb +46 -0
  366. data/spec/models/paginated_income_statement_list_spec.rb +46 -0
  367. data/spec/models/paginated_invoice_list_spec.rb +46 -0
  368. data/spec/models/paginated_issue_list_spec.rb +46 -0
  369. data/spec/models/paginated_item_list_spec.rb +46 -0
  370. data/spec/models/paginated_journal_entry_list_spec.rb +46 -0
  371. data/spec/models/paginated_payment_list_spec.rb +46 -0
  372. data/spec/models/paginated_purchase_order_list_spec.rb +46 -0
  373. data/spec/models/paginated_sync_status_list_spec.rb +46 -0
  374. data/spec/models/paginated_tax_rate_list_spec.rb +46 -0
  375. data/spec/models/paginated_tracking_category_list_spec.rb +46 -0
  376. data/spec/models/paginated_webhook_receiver_list_spec.rb +46 -0
  377. data/spec/models/payment_spec.rb +76 -0
  378. data/spec/models/purchase_order_line_item_spec.rb +52 -0
  379. data/spec/models/purchase_order_spec.rb +100 -0
  380. data/spec/models/purchase_order_status_enum_spec.rb +28 -0
  381. data/spec/models/remote_data_request_spec.rb +40 -0
  382. data/spec/models/remote_data_spec.rb +40 -0
  383. data/spec/models/remote_key_for_regeneration_request_spec.rb +34 -0
  384. data/spec/models/remote_key_spec.rb +40 -0
  385. data/spec/models/remote_response_spec.rb +58 -0
  386. data/spec/models/report_item_spec.rb +52 -0
  387. data/spec/models/request_format_enum_spec.rb +28 -0
  388. data/spec/models/state_enum_spec.rb +28 -0
  389. data/spec/models/status7d1_enum_spec.rb +28 -0
  390. data/spec/models/sync_status_spec.rb +64 -0
  391. data/spec/models/sync_status_status_enum_spec.rb +28 -0
  392. data/spec/models/tax_rate_spec.rb +64 -0
  393. data/spec/models/tracking_category_spec.rb +58 -0
  394. data/spec/models/validation_problem_source_spec.rb +34 -0
  395. data/spec/models/warning_validation_problem_spec.rb +52 -0
  396. data/spec/models/webhook_receiver_request_spec.rb +46 -0
  397. data/spec/models/webhook_receiver_spec.rb +46 -0
  398. data/spec/spec_helper.rb +111 -0
  399. metadata +612 -0
@@ -0,0 +1,48 @@
1
+ =begin
2
+ #Merge Accounting API
3
+
4
+ #The unified API for building rich integrations with multiple Accounting & Finance platforms.
5
+
6
+ The version of the OpenAPI document: 1.0
7
+ Contact: hello@merge.dev
8
+ Generated by: https://openapi-generator.tech
9
+ OpenAPI Generator version: 5.1.1
10
+
11
+ =end
12
+
13
+ require 'spec_helper'
14
+ require 'json'
15
+
16
+ # Unit tests for MergeAccountingClient::PhoneNumbersApi
17
+ # Automatically generated by openapi-generator (https://openapi-generator.tech)
18
+ # Please update as you see appropriate
19
+ describe 'PhoneNumbersApi' do
20
+ before do
21
+ # run before each test
22
+ @api_instance = MergeAccountingClient::PhoneNumbersApi.new
23
+ end
24
+
25
+ after do
26
+ # run after each test
27
+ end
28
+
29
+ describe 'test an instance of PhoneNumbersApi' do
30
+ it 'should create an instance of PhoneNumbersApi' do
31
+ expect(@api_instance).to be_instance_of(MergeAccountingClient::PhoneNumbersApi)
32
+ end
33
+ end
34
+
35
+ # unit tests for phone_numbers_retrieve
36
+ # Returns an `AccountingPhoneNumber` object with the given `id`.
37
+ # @param x_account_token Token identifying the end user.
38
+ # @param id
39
+ # @param [Hash] opts the optional parameters
40
+ # @option opts [Boolean] :include_remote_data Whether to include the original data Merge fetched from the third-party to produce these models.
41
+ # @return [AccountingPhoneNumber]
42
+ describe 'phone_numbers_retrieve test' do
43
+ it 'should work' do
44
+ # assertion here. ref: https://www.relishapp.com/rspec/rspec-expectations/docs/built-in-matchers
45
+ end
46
+ end
47
+
48
+ end
@@ -0,0 +1,70 @@
1
+ =begin
2
+ #Merge Accounting API
3
+
4
+ #The unified API for building rich integrations with multiple Accounting & Finance platforms.
5
+
6
+ The version of the OpenAPI document: 1.0
7
+ Contact: hello@merge.dev
8
+ Generated by: https://openapi-generator.tech
9
+ OpenAPI Generator version: 5.1.1
10
+
11
+ =end
12
+
13
+ require 'spec_helper'
14
+ require 'json'
15
+
16
+ # Unit tests for MergeAccountingClient::PurchaseOrdersApi
17
+ # Automatically generated by openapi-generator (https://openapi-generator.tech)
18
+ # Please update as you see appropriate
19
+ describe 'PurchaseOrdersApi' do
20
+ before do
21
+ # run before each test
22
+ @api_instance = MergeAccountingClient::PurchaseOrdersApi.new
23
+ end
24
+
25
+ after do
26
+ # run after each test
27
+ end
28
+
29
+ describe 'test an instance of PurchaseOrdersApi' do
30
+ it 'should create an instance of PurchaseOrdersApi' do
31
+ expect(@api_instance).to be_instance_of(MergeAccountingClient::PurchaseOrdersApi)
32
+ end
33
+ end
34
+
35
+ # unit tests for purchase_orders_list
36
+ # Returns a list of `PurchaseOrder` objects.
37
+ # @param x_account_token Token identifying the end user.
38
+ # @param [Hash] opts the optional parameters
39
+ # @option opts [Time] :created_after If provided, will only return objects created after this datetime.
40
+ # @option opts [Time] :created_before If provided, will only return objects created before this datetime.
41
+ # @option opts [String] :cursor The pagination cursor value.
42
+ # @option opts [String] :expand Which relations should be returned in expanded form. Multiple relation names should be comma separated without spaces.
43
+ # @option opts [Boolean] :include_deleted_data Whether to include data that was deleted in the third-party service.
44
+ # @option opts [Boolean] :include_remote_data Whether to include the original data Merge fetched from the third-party to produce these models.
45
+ # @option opts [Time] :modified_after If provided, will only return objects modified after this datetime.
46
+ # @option opts [Time] :modified_before If provided, will only return objects modified before this datetime.
47
+ # @option opts [Integer] :page_size Number of results to return per page.
48
+ # @option opts [String] :remote_id The API provider's ID for the given object.
49
+ # @return [PaginatedPurchaseOrderList]
50
+ describe 'purchase_orders_list test' do
51
+ it 'should work' do
52
+ # assertion here. ref: https://www.relishapp.com/rspec/rspec-expectations/docs/built-in-matchers
53
+ end
54
+ end
55
+
56
+ # unit tests for purchase_orders_retrieve
57
+ # Returns a `PurchaseOrder` object with the given `id`.
58
+ # @param x_account_token Token identifying the end user.
59
+ # @param id
60
+ # @param [Hash] opts the optional parameters
61
+ # @option opts [String] :expand Which relations should be returned in expanded form. Multiple relation names should be comma separated without spaces.
62
+ # @option opts [Boolean] :include_remote_data Whether to include the original data Merge fetched from the third-party to produce these models.
63
+ # @return [PurchaseOrder]
64
+ describe 'purchase_orders_retrieve test' do
65
+ it 'should work' do
66
+ # assertion here. ref: https://www.relishapp.com/rspec/rspec-expectations/docs/built-in-matchers
67
+ end
68
+ end
69
+
70
+ end
@@ -0,0 +1,46 @@
1
+ =begin
2
+ #Merge Accounting API
3
+
4
+ #The unified API for building rich integrations with multiple Accounting & Finance platforms.
5
+
6
+ The version of the OpenAPI document: 1.0
7
+ Contact: hello@merge.dev
8
+ Generated by: https://openapi-generator.tech
9
+ OpenAPI Generator version: 5.1.1
10
+
11
+ =end
12
+
13
+ require 'spec_helper'
14
+ require 'json'
15
+
16
+ # Unit tests for MergeAccountingClient::RegenerateKeyApi
17
+ # Automatically generated by openapi-generator (https://openapi-generator.tech)
18
+ # Please update as you see appropriate
19
+ describe 'RegenerateKeyApi' do
20
+ before do
21
+ # run before each test
22
+ @api_instance = MergeAccountingClient::RegenerateKeyApi.new
23
+ end
24
+
25
+ after do
26
+ # run after each test
27
+ end
28
+
29
+ describe 'test an instance of RegenerateKeyApi' do
30
+ it 'should create an instance of RegenerateKeyApi' do
31
+ expect(@api_instance).to be_instance_of(MergeAccountingClient::RegenerateKeyApi)
32
+ end
33
+ end
34
+
35
+ # unit tests for regenerate_key_create
36
+ # Exchange remote keys.
37
+ # @param remote_key_for_regeneration_request
38
+ # @param [Hash] opts the optional parameters
39
+ # @return [RemoteKey]
40
+ describe 'regenerate_key_create test' do
41
+ it 'should work' do
42
+ # assertion here. ref: https://www.relishapp.com/rspec/rspec-expectations/docs/built-in-matchers
43
+ end
44
+ end
45
+
46
+ end
@@ -0,0 +1,48 @@
1
+ =begin
2
+ #Merge Accounting API
3
+
4
+ #The unified API for building rich integrations with multiple Accounting & Finance platforms.
5
+
6
+ The version of the OpenAPI document: 1.0
7
+ Contact: hello@merge.dev
8
+ Generated by: https://openapi-generator.tech
9
+ OpenAPI Generator version: 5.1.1
10
+
11
+ =end
12
+
13
+ require 'spec_helper'
14
+ require 'json'
15
+
16
+ # Unit tests for MergeAccountingClient::SyncStatusApi
17
+ # Automatically generated by openapi-generator (https://openapi-generator.tech)
18
+ # Please update as you see appropriate
19
+ describe 'SyncStatusApi' do
20
+ before do
21
+ # run before each test
22
+ @api_instance = MergeAccountingClient::SyncStatusApi.new
23
+ end
24
+
25
+ after do
26
+ # run after each test
27
+ end
28
+
29
+ describe 'test an instance of SyncStatusApi' do
30
+ it 'should create an instance of SyncStatusApi' do
31
+ expect(@api_instance).to be_instance_of(MergeAccountingClient::SyncStatusApi)
32
+ end
33
+ end
34
+
35
+ # unit tests for sync_status_list
36
+ # Get syncing status. Possible values: `DISABLED`, `DONE`, `FAILED`, `SYNCING`
37
+ # @param x_account_token Token identifying the end user.
38
+ # @param [Hash] opts the optional parameters
39
+ # @option opts [String] :cursor The pagination cursor value.
40
+ # @option opts [Integer] :page_size Number of results to return per page.
41
+ # @return [PaginatedSyncStatusList]
42
+ describe 'sync_status_list test' do
43
+ it 'should work' do
44
+ # assertion here. ref: https://www.relishapp.com/rspec/rspec-expectations/docs/built-in-matchers
45
+ end
46
+ end
47
+
48
+ end
@@ -0,0 +1,68 @@
1
+ =begin
2
+ #Merge Accounting API
3
+
4
+ #The unified API for building rich integrations with multiple Accounting & Finance platforms.
5
+
6
+ The version of the OpenAPI document: 1.0
7
+ Contact: hello@merge.dev
8
+ Generated by: https://openapi-generator.tech
9
+ OpenAPI Generator version: 5.1.1
10
+
11
+ =end
12
+
13
+ require 'spec_helper'
14
+ require 'json'
15
+
16
+ # Unit tests for MergeAccountingClient::TaxRatesApi
17
+ # Automatically generated by openapi-generator (https://openapi-generator.tech)
18
+ # Please update as you see appropriate
19
+ describe 'TaxRatesApi' do
20
+ before do
21
+ # run before each test
22
+ @api_instance = MergeAccountingClient::TaxRatesApi.new
23
+ end
24
+
25
+ after do
26
+ # run after each test
27
+ end
28
+
29
+ describe 'test an instance of TaxRatesApi' do
30
+ it 'should create an instance of TaxRatesApi' do
31
+ expect(@api_instance).to be_instance_of(MergeAccountingClient::TaxRatesApi)
32
+ end
33
+ end
34
+
35
+ # unit tests for tax_rates_list
36
+ # Returns a list of `TaxRate` objects.
37
+ # @param x_account_token Token identifying the end user.
38
+ # @param [Hash] opts the optional parameters
39
+ # @option opts [Time] :created_after If provided, will only return objects created after this datetime.
40
+ # @option opts [Time] :created_before If provided, will only return objects created before this datetime.
41
+ # @option opts [String] :cursor The pagination cursor value.
42
+ # @option opts [Boolean] :include_deleted_data Whether to include data that was deleted in the third-party service.
43
+ # @option opts [Boolean] :include_remote_data Whether to include the original data Merge fetched from the third-party to produce these models.
44
+ # @option opts [Time] :modified_after If provided, will only return objects modified after this datetime.
45
+ # @option opts [Time] :modified_before If provided, will only return objects modified before this datetime.
46
+ # @option opts [Integer] :page_size Number of results to return per page.
47
+ # @option opts [String] :remote_id The API provider's ID for the given object.
48
+ # @return [PaginatedTaxRateList]
49
+ describe 'tax_rates_list test' do
50
+ it 'should work' do
51
+ # assertion here. ref: https://www.relishapp.com/rspec/rspec-expectations/docs/built-in-matchers
52
+ end
53
+ end
54
+
55
+ # unit tests for tax_rates_retrieve
56
+ # Returns a `TaxRate` object with the given `id`.
57
+ # @param x_account_token Token identifying the end user.
58
+ # @param id
59
+ # @param [Hash] opts the optional parameters
60
+ # @option opts [Boolean] :include_remote_data Whether to include the original data Merge fetched from the third-party to produce these models.
61
+ # @return [TaxRate]
62
+ describe 'tax_rates_retrieve test' do
63
+ it 'should work' do
64
+ # assertion here. ref: https://www.relishapp.com/rspec/rspec-expectations/docs/built-in-matchers
65
+ end
66
+ end
67
+
68
+ end
@@ -0,0 +1,68 @@
1
+ =begin
2
+ #Merge Accounting API
3
+
4
+ #The unified API for building rich integrations with multiple Accounting & Finance platforms.
5
+
6
+ The version of the OpenAPI document: 1.0
7
+ Contact: hello@merge.dev
8
+ Generated by: https://openapi-generator.tech
9
+ OpenAPI Generator version: 5.1.1
10
+
11
+ =end
12
+
13
+ require 'spec_helper'
14
+ require 'json'
15
+
16
+ # Unit tests for MergeAccountingClient::TrackingCategoriesApi
17
+ # Automatically generated by openapi-generator (https://openapi-generator.tech)
18
+ # Please update as you see appropriate
19
+ describe 'TrackingCategoriesApi' do
20
+ before do
21
+ # run before each test
22
+ @api_instance = MergeAccountingClient::TrackingCategoriesApi.new
23
+ end
24
+
25
+ after do
26
+ # run after each test
27
+ end
28
+
29
+ describe 'test an instance of TrackingCategoriesApi' do
30
+ it 'should create an instance of TrackingCategoriesApi' do
31
+ expect(@api_instance).to be_instance_of(MergeAccountingClient::TrackingCategoriesApi)
32
+ end
33
+ end
34
+
35
+ # unit tests for tracking_categories_list
36
+ # Returns a list of `TrackingCategory` objects.
37
+ # @param x_account_token Token identifying the end user.
38
+ # @param [Hash] opts the optional parameters
39
+ # @option opts [Time] :created_after If provided, will only return objects created after this datetime.
40
+ # @option opts [Time] :created_before If provided, will only return objects created before this datetime.
41
+ # @option opts [String] :cursor The pagination cursor value.
42
+ # @option opts [Boolean] :include_deleted_data Whether to include data that was deleted in the third-party service.
43
+ # @option opts [Boolean] :include_remote_data Whether to include the original data Merge fetched from the third-party to produce these models.
44
+ # @option opts [Time] :modified_after If provided, will only return objects modified after this datetime.
45
+ # @option opts [Time] :modified_before If provided, will only return objects modified before this datetime.
46
+ # @option opts [Integer] :page_size Number of results to return per page.
47
+ # @option opts [String] :remote_id The API provider's ID for the given object.
48
+ # @return [PaginatedTrackingCategoryList]
49
+ describe 'tracking_categories_list test' do
50
+ it 'should work' do
51
+ # assertion here. ref: https://www.relishapp.com/rspec/rspec-expectations/docs/built-in-matchers
52
+ end
53
+ end
54
+
55
+ # unit tests for tracking_categories_retrieve
56
+ # Returns a `TrackingCategory` object with the given `id`.
57
+ # @param x_account_token Token identifying the end user.
58
+ # @param id
59
+ # @param [Hash] opts the optional parameters
60
+ # @option opts [Boolean] :include_remote_data Whether to include the original data Merge fetched from the third-party to produce these models.
61
+ # @return [TrackingCategory]
62
+ describe 'tracking_categories_retrieve test' do
63
+ it 'should work' do
64
+ # assertion here. ref: https://www.relishapp.com/rspec/rspec-expectations/docs/built-in-matchers
65
+ end
66
+ end
67
+
68
+ end
@@ -0,0 +1,58 @@
1
+ =begin
2
+ #Merge Accounting API
3
+
4
+ #The unified API for building rich integrations with multiple Accounting & Finance platforms.
5
+
6
+ The version of the OpenAPI document: 1.0
7
+ Contact: hello@merge.dev
8
+ Generated by: https://openapi-generator.tech
9
+ OpenAPI Generator version: 5.1.1
10
+
11
+ =end
12
+
13
+ require 'spec_helper'
14
+ require 'json'
15
+
16
+ # Unit tests for MergeAccountingClient::WebhookReceiversApi
17
+ # Automatically generated by openapi-generator (https://openapi-generator.tech)
18
+ # Please update as you see appropriate
19
+ describe 'WebhookReceiversApi' do
20
+ before do
21
+ # run before each test
22
+ @api_instance = MergeAccountingClient::WebhookReceiversApi.new
23
+ end
24
+
25
+ after do
26
+ # run after each test
27
+ end
28
+
29
+ describe 'test an instance of WebhookReceiversApi' do
30
+ it 'should create an instance of WebhookReceiversApi' do
31
+ expect(@api_instance).to be_instance_of(MergeAccountingClient::WebhookReceiversApi)
32
+ end
33
+ end
34
+
35
+ # unit tests for webhook_receivers_create
36
+ # Creates a `WebhookReceiver` object with the given values.
37
+ # @param webhook_receiver_request
38
+ # @param [Hash] opts the optional parameters
39
+ # @return [WebhookReceiver]
40
+ describe 'webhook_receivers_create test' do
41
+ it 'should work' do
42
+ # assertion here. ref: https://www.relishapp.com/rspec/rspec-expectations/docs/built-in-matchers
43
+ end
44
+ end
45
+
46
+ # unit tests for webhook_receivers_list
47
+ # Returns a list of `WebhookReceiver` objects.
48
+ # @param [Hash] opts the optional parameters
49
+ # @option opts [Integer] :cursor The pagination cursor value.
50
+ # @option opts [Integer] :page_size Number of results to return per page.
51
+ # @return [PaginatedWebhookReceiverList]
52
+ describe 'webhook_receivers_list test' do
53
+ it 'should work' do
54
+ # assertion here. ref: https://www.relishapp.com/rspec/rspec-expectations/docs/built-in-matchers
55
+ end
56
+ end
57
+
58
+ end
@@ -0,0 +1,226 @@
1
+ =begin
2
+ #Merge Accounting API
3
+
4
+ #The unified API for building rich integrations with multiple Accounting & Finance platforms.
5
+
6
+ The version of the OpenAPI document: 1.0
7
+ Contact: hello@merge.dev
8
+ Generated by: https://openapi-generator.tech
9
+ OpenAPI Generator version: 5.1.1
10
+
11
+ =end
12
+
13
+ require 'spec_helper'
14
+
15
+ describe MergeAccountingClient::ApiClient do
16
+ context 'initialization' do
17
+ context 'URL stuff' do
18
+ context 'host' do
19
+ it 'removes http from host' do
20
+ MergeAccountingClient.configure { |c| c.host = 'http://example.com' }
21
+ expect(MergeAccountingClient::Configuration.default.host).to eq('example.com')
22
+ end
23
+
24
+ it 'removes https from host' do
25
+ MergeAccountingClient.configure { |c| c.host = 'https://wookiee.com' }
26
+ expect(MergeAccountingClient::ApiClient.default.config.host).to eq('wookiee.com')
27
+ end
28
+
29
+ it 'removes trailing path from host' do
30
+ MergeAccountingClient.configure { |c| c.host = 'hobo.com/v4' }
31
+ expect(MergeAccountingClient::Configuration.default.host).to eq('hobo.com')
32
+ end
33
+ end
34
+
35
+ context 'base_path' do
36
+ it "prepends a slash to base_path" do
37
+ MergeAccountingClient.configure { |c| c.base_path = 'v4/dog' }
38
+ expect(MergeAccountingClient::Configuration.default.base_path).to eq('/v4/dog')
39
+ end
40
+
41
+ it "doesn't prepend a slash if one is already there" do
42
+ MergeAccountingClient.configure { |c| c.base_path = '/v4/dog' }
43
+ expect(MergeAccountingClient::Configuration.default.base_path).to eq('/v4/dog')
44
+ end
45
+
46
+ it "ends up as a blank string if nil" do
47
+ MergeAccountingClient.configure { |c| c.base_path = nil }
48
+ expect(MergeAccountingClient::Configuration.default.base_path).to eq('')
49
+ end
50
+ end
51
+ end
52
+ end
53
+
54
+ describe 'params_encoding in #build_request' do
55
+ let(:config) { MergeAccountingClient::Configuration.new }
56
+ let(:api_client) { MergeAccountingClient::ApiClient.new(config) }
57
+
58
+ it 'defaults to nil' do
59
+ expect(MergeAccountingClient::Configuration.default.params_encoding).to eq(nil)
60
+ expect(config.params_encoding).to eq(nil)
61
+
62
+ request = api_client.build_request(:get, '/test')
63
+ expect(request.options[:params_encoding]).to eq(nil)
64
+ end
65
+
66
+ it 'can be customized' do
67
+ config.params_encoding = :multi
68
+ request = api_client.build_request(:get, '/test')
69
+ expect(request.options[:params_encoding]).to eq(:multi)
70
+ end
71
+ end
72
+
73
+ describe 'timeout in #build_request' do
74
+ let(:config) { MergeAccountingClient::Configuration.new }
75
+ let(:api_client) { MergeAccountingClient::ApiClient.new(config) }
76
+
77
+ it 'defaults to 0' do
78
+ expect(MergeAccountingClient::Configuration.default.timeout).to eq(0)
79
+ expect(config.timeout).to eq(0)
80
+
81
+ request = api_client.build_request(:get, '/test')
82
+ expect(request.options[:timeout]).to eq(0)
83
+ end
84
+
85
+ it 'can be customized' do
86
+ config.timeout = 100
87
+ request = api_client.build_request(:get, '/test')
88
+ expect(request.options[:timeout]).to eq(100)
89
+ end
90
+ end
91
+
92
+ describe '#deserialize' do
93
+ it "handles Array<Integer>" do
94
+ api_client = MergeAccountingClient::ApiClient.new
95
+ headers = { 'Content-Type' => 'application/json' }
96
+ response = double('response', headers: headers, body: '[12, 34]')
97
+ data = api_client.deserialize(response, 'Array<Integer>')
98
+ expect(data).to be_instance_of(Array)
99
+ expect(data).to eq([12, 34])
100
+ end
101
+
102
+ it 'handles Array<Array<Integer>>' do
103
+ api_client = MergeAccountingClient::ApiClient.new
104
+ headers = { 'Content-Type' => 'application/json' }
105
+ response = double('response', headers: headers, body: '[[12, 34], [56]]')
106
+ data = api_client.deserialize(response, 'Array<Array<Integer>>')
107
+ expect(data).to be_instance_of(Array)
108
+ expect(data).to eq([[12, 34], [56]])
109
+ end
110
+
111
+ it 'handles Hash<String, String>' do
112
+ api_client = MergeAccountingClient::ApiClient.new
113
+ headers = { 'Content-Type' => 'application/json' }
114
+ response = double('response', headers: headers, body: '{"message": "Hello"}')
115
+ data = api_client.deserialize(response, 'Hash<String, String>')
116
+ expect(data).to be_instance_of(Hash)
117
+ expect(data).to eq(:message => 'Hello')
118
+ end
119
+ end
120
+
121
+ describe "#object_to_hash" do
122
+ it 'ignores nils and includes empty arrays' do
123
+ # uncomment below to test object_to_hash for model
124
+ # api_client = MergeAccountingClient::ApiClient.new
125
+ # _model = MergeAccountingClient::ModelName.new
126
+ # update the model attribute below
127
+ # _model.id = 1
128
+ # update the expected value (hash) below
129
+ # expected = {id: 1, name: '', tags: []}
130
+ # expect(api_client.object_to_hash(_model)).to eq(expected)
131
+ end
132
+ end
133
+
134
+ describe '#build_collection_param' do
135
+ let(:param) { ['aa', 'bb', 'cc'] }
136
+ let(:api_client) { MergeAccountingClient::ApiClient.new }
137
+
138
+ it 'works for csv' do
139
+ expect(api_client.build_collection_param(param, :csv)).to eq('aa,bb,cc')
140
+ end
141
+
142
+ it 'works for ssv' do
143
+ expect(api_client.build_collection_param(param, :ssv)).to eq('aa bb cc')
144
+ end
145
+
146
+ it 'works for tsv' do
147
+ expect(api_client.build_collection_param(param, :tsv)).to eq("aa\tbb\tcc")
148
+ end
149
+
150
+ it 'works for pipes' do
151
+ expect(api_client.build_collection_param(param, :pipes)).to eq('aa|bb|cc')
152
+ end
153
+
154
+ it 'works for multi' do
155
+ expect(api_client.build_collection_param(param, :multi)).to eq(['aa', 'bb', 'cc'])
156
+ end
157
+
158
+ it 'fails for invalid collection format' do
159
+ expect { api_client.build_collection_param(param, :INVALID) }.to raise_error(RuntimeError, 'unknown collection format: :INVALID')
160
+ end
161
+ end
162
+
163
+ describe '#json_mime?' do
164
+ let(:api_client) { MergeAccountingClient::ApiClient.new }
165
+
166
+ it 'works' do
167
+ expect(api_client.json_mime?(nil)).to eq false
168
+ expect(api_client.json_mime?('')).to eq false
169
+
170
+ expect(api_client.json_mime?('application/json')).to eq true
171
+ expect(api_client.json_mime?('application/json; charset=UTF8')).to eq true
172
+ expect(api_client.json_mime?('APPLICATION/JSON')).to eq true
173
+
174
+ expect(api_client.json_mime?('application/xml')).to eq false
175
+ expect(api_client.json_mime?('text/plain')).to eq false
176
+ expect(api_client.json_mime?('application/jsonp')).to eq false
177
+ end
178
+ end
179
+
180
+ describe '#select_header_accept' do
181
+ let(:api_client) { MergeAccountingClient::ApiClient.new }
182
+
183
+ it 'works' do
184
+ expect(api_client.select_header_accept(nil)).to be_nil
185
+ expect(api_client.select_header_accept([])).to be_nil
186
+
187
+ expect(api_client.select_header_accept(['application/json'])).to eq('application/json')
188
+ expect(api_client.select_header_accept(['application/xml', 'application/json; charset=UTF8'])).to eq('application/json; charset=UTF8')
189
+ expect(api_client.select_header_accept(['APPLICATION/JSON', 'text/html'])).to eq('APPLICATION/JSON')
190
+
191
+ expect(api_client.select_header_accept(['application/xml'])).to eq('application/xml')
192
+ expect(api_client.select_header_accept(['text/html', 'application/xml'])).to eq('text/html,application/xml')
193
+ end
194
+ end
195
+
196
+ describe '#select_header_content_type' do
197
+ let(:api_client) { MergeAccountingClient::ApiClient.new }
198
+
199
+ it 'works' do
200
+ expect(api_client.select_header_content_type(nil)).to eq('application/json')
201
+ expect(api_client.select_header_content_type([])).to eq('application/json')
202
+
203
+ expect(api_client.select_header_content_type(['application/json'])).to eq('application/json')
204
+ expect(api_client.select_header_content_type(['application/xml', 'application/json; charset=UTF8'])).to eq('application/json; charset=UTF8')
205
+ expect(api_client.select_header_content_type(['APPLICATION/JSON', 'text/html'])).to eq('APPLICATION/JSON')
206
+ expect(api_client.select_header_content_type(['application/xml'])).to eq('application/xml')
207
+ expect(api_client.select_header_content_type(['text/plain', 'application/xml'])).to eq('text/plain')
208
+ end
209
+ end
210
+
211
+ describe '#sanitize_filename' do
212
+ let(:api_client) { MergeAccountingClient::ApiClient.new }
213
+
214
+ it 'works' do
215
+ expect(api_client.sanitize_filename('sun')).to eq('sun')
216
+ expect(api_client.sanitize_filename('sun.gif')).to eq('sun.gif')
217
+ expect(api_client.sanitize_filename('../sun.gif')).to eq('sun.gif')
218
+ expect(api_client.sanitize_filename('/var/tmp/sun.gif')).to eq('sun.gif')
219
+ expect(api_client.sanitize_filename('./sun.gif')).to eq('sun.gif')
220
+ expect(api_client.sanitize_filename('..\sun.gif')).to eq('sun.gif')
221
+ expect(api_client.sanitize_filename('\var\tmp\sun.gif')).to eq('sun.gif')
222
+ expect(api_client.sanitize_filename('c:\var\tmp\sun.gif')).to eq('sun.gif')
223
+ expect(api_client.sanitize_filename('.\sun.gif')).to eq('sun.gif')
224
+ end
225
+ end
226
+ end
@@ -0,0 +1,42 @@
1
+ =begin
2
+ #Merge Accounting API
3
+
4
+ #The unified API for building rich integrations with multiple Accounting & Finance platforms.
5
+
6
+ The version of the OpenAPI document: 1.0
7
+ Contact: hello@merge.dev
8
+ Generated by: https://openapi-generator.tech
9
+ OpenAPI Generator version: 5.1.1
10
+
11
+ =end
12
+
13
+ require 'spec_helper'
14
+
15
+ describe MergeAccountingClient::Configuration do
16
+ let(:config) { MergeAccountingClient::Configuration.default }
17
+
18
+ before(:each) do
19
+ # uncomment below to setup host and base_path
20
+ # require 'URI'
21
+ # uri = URI.parse("https://api.merge.dev/api/accounting/v1")
22
+ # MergeAccountingClient.configure do |c|
23
+ # c.host = uri.host
24
+ # c.base_path = uri.path
25
+ # end
26
+ end
27
+
28
+ describe '#base_url' do
29
+ it 'should have the default value' do
30
+ # uncomment below to test default value of the base path
31
+ # expect(config.base_url).to eq("https://api.merge.dev/api/accounting/v1")
32
+ end
33
+
34
+ it 'should remove trailing slashes' do
35
+ [nil, '', '/', '//'].each do |base_path|
36
+ config.base_path = base_path
37
+ # uncomment below to test trailing slashes
38
+ # expect(config.base_url).to eq("https://api.merge.dev/api/accounting/v1")
39
+ end
40
+ end
41
+ end
42
+ end