You can not select more than 25 topics Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.

397 lines
16 KiB

8 years ago
8 years ago
8 years ago
8 years ago
8 years ago
8 years ago
8 years ago
8 years ago
8 years ago
8 years ago
  1. # -*- coding: utf-8 -*-
  2. # Author: Julien Coux
  3. # Copyright 2016 Camptocamp SA
  4. # License AGPL-3.0 or later (http://www.gnu.org/licenses/agpl.html).
  5. import time
  6. from . import abstract_test
  7. from openerp.tests.common import TransactionCase
  8. class TestGeneralLedger(abstract_test.AbstractTest):
  9. """
  10. Technical tests for General Ledger Report.
  11. """
  12. def _getReportModel(self):
  13. return self.env['report_general_ledger_qweb']
  14. def _getQwebReportName(self):
  15. return 'account_financial_report_qweb.report_general_ledger_qweb'
  16. def _getXlsxReportName(self):
  17. return 'account_financial_report_qweb.report_general_ledger_xlsx'
  18. def _getXlsxReportActionName(self):
  19. return 'account_financial_report_qweb.' \
  20. 'action_report_general_ledger_xlsx'
  21. def _getReportTitle(self):
  22. return 'General Ledger'
  23. def _getBaseFilters(self):
  24. return {
  25. 'date_from': time.strftime('%Y-01-01'),
  26. 'date_to': time.strftime('%Y-12-31'),
  27. 'company_id': self.env.ref('base.main_company').id,
  28. 'fy_start_date': time.strftime('%Y-01-01'),
  29. }
  30. def _getAdditionalFiltersToBeTested(self):
  31. return [
  32. {'only_posted_moves': True},
  33. {'hide_account_balance_at_0': True},
  34. {'centralize': True},
  35. {'only_posted_moves': True, 'hide_account_balance_at_0': True},
  36. {'only_posted_moves': True, 'centralize': True},
  37. {'hide_account_balance_at_0': True, 'centralize': True},
  38. {
  39. 'only_posted_moves': True,
  40. 'hide_account_balance_at_0': True,
  41. 'centralize': True
  42. },
  43. ]
  44. class TestGeneralLedgerReport(TransactionCase):
  45. def setUp(self):
  46. super(TestGeneralLedgerReport, self).setUp()
  47. self.previous_fy_date_end = '2015-12-31'
  48. self.fy_date_start = '2016-01-01'
  49. self.fy_date_end = '2016-12-31'
  50. self.receivable_account = self.env['account.account'].search([
  51. ('user_type_id.name', '=', 'Receivable')
  52. ], limit=1)
  53. self.income_account = self.env['account.account'].search([
  54. ('user_type_id.name', '=', 'Income')
  55. ], limit=1)
  56. self.unaffected_account = self.env['account.account'].search([
  57. (
  58. 'user_type_id',
  59. '=',
  60. self.env.ref('account.data_unaffected_earnings').id
  61. )], limit=1)
  62. def _add_move(
  63. self,
  64. date,
  65. receivable_debit,
  66. receivable_credit,
  67. income_debit,
  68. income_credit,
  69. unaffected_debit=0,
  70. unaffected_credit=0
  71. ):
  72. move_name = 'expense accrual'
  73. journal = self.env['account.journal'].search([
  74. ('code', '=', 'MISC')])
  75. partner = self.env.ref('base.res_partner_12')
  76. move_vals = {
  77. 'journal_id': journal.id,
  78. 'partner_id': partner.id,
  79. 'name': move_name,
  80. 'date': date,
  81. 'line_ids': [
  82. (0, 0, {
  83. 'name': move_name,
  84. 'debit': receivable_debit,
  85. 'credit': receivable_credit,
  86. 'account_id': self.receivable_account.id}),
  87. (0, 0, {
  88. 'name': move_name,
  89. 'debit': income_debit,
  90. 'credit': income_credit,
  91. 'account_id': self.income_account.id}),
  92. (0, 0, {
  93. 'name': move_name,
  94. 'debit': unaffected_debit,
  95. 'credit': unaffected_credit,
  96. 'account_id': self.unaffected_account.id}),
  97. ]}
  98. move = self.env['account.move'].create(move_vals)
  99. move.post()
  100. def _get_report_lines(self, with_partners=False):
  101. company = self.env.ref('base.main_company')
  102. general_ledger = self.env['report_general_ledger_qweb'].create({
  103. 'date_from': self.fy_date_start,
  104. 'date_to': self.fy_date_end,
  105. 'only_posted_moves': True,
  106. 'hide_account_balance_at_0': False,
  107. 'company_id': company.id,
  108. 'fy_start_date': self.fy_date_start,
  109. })
  110. general_ledger.compute_data_for_report(
  111. with_line_details=True, with_partners=with_partners
  112. )
  113. lines = {}
  114. report_account_model = self.env['report_general_ledger_qweb_account']
  115. lines['receivable'] = report_account_model.search([
  116. ('report_id', '=', general_ledger.id),
  117. ('account_id', '=', self.receivable_account.id),
  118. ])
  119. lines['income'] = report_account_model.search([
  120. ('report_id', '=', general_ledger.id),
  121. ('account_id', '=', self.income_account.id),
  122. ])
  123. lines['unaffected'] = report_account_model.search([
  124. ('report_id', '=', general_ledger.id),
  125. ('account_id', '=', self.unaffected_account.id),
  126. ])
  127. if with_partners:
  128. report_partner_model = self.env[
  129. 'report_general_ledger_qweb_partner'
  130. ]
  131. lines['partner_receivable'] = report_partner_model.search([
  132. ('report_account_id', '=', lines['receivable'].id),
  133. ('partner_id', '=', self.env.ref('base.res_partner_12').id),
  134. ])
  135. return lines
  136. def test_01_account_balance(self):
  137. # Generate the general ledger line
  138. lines = self._get_report_lines()
  139. self.assertEqual(len(lines['receivable']), 0)
  140. self.assertEqual(len(lines['income']), 0)
  141. # Add a move at the previous day of the first day of fiscal year
  142. # to check the initial balance
  143. self._add_move(
  144. date=self.previous_fy_date_end,
  145. receivable_debit=1000,
  146. receivable_credit=0,
  147. income_debit=0,
  148. income_credit=1000
  149. )
  150. # Re Generate the general ledger line
  151. lines = self._get_report_lines()
  152. self.assertEqual(len(lines['receivable']), 1)
  153. self.assertEqual(len(lines['income']), 0)
  154. # Check the initial and final balance
  155. self.assertEqual(lines['receivable'].initial_debit, 1000)
  156. self.assertEqual(lines['receivable'].initial_credit, 0)
  157. self.assertEqual(lines['receivable'].initial_balance, 1000)
  158. self.assertEqual(lines['receivable'].final_debit, 1000)
  159. self.assertEqual(lines['receivable'].final_credit, 0)
  160. self.assertEqual(lines['receivable'].final_balance, 1000)
  161. # Add reversale move of the initial move the first day of fiscal year
  162. # to check the first day of fiscal year is not used
  163. # to compute the initial balance
  164. self._add_move(
  165. date=self.fy_date_start,
  166. receivable_debit=0,
  167. receivable_credit=1000,
  168. income_debit=1000,
  169. income_credit=0
  170. )
  171. # Re Generate the general ledger line
  172. lines = self._get_report_lines()
  173. self.assertEqual(len(lines['receivable']), 1)
  174. self.assertEqual(len(lines['income']), 1)
  175. # Check the initial and final balance
  176. self.assertEqual(lines['receivable'].initial_debit, 1000)
  177. self.assertEqual(lines['receivable'].initial_credit, 0)
  178. self.assertEqual(lines['receivable'].initial_balance, 1000)
  179. self.assertEqual(lines['receivable'].final_debit, 1000)
  180. self.assertEqual(lines['receivable'].final_credit, 1000)
  181. self.assertEqual(lines['receivable'].final_balance, 0)
  182. self.assertEqual(lines['income'].initial_debit, 0)
  183. self.assertEqual(lines['income'].initial_credit, 0)
  184. self.assertEqual(lines['income'].initial_balance, 0)
  185. self.assertEqual(lines['income'].final_debit, 1000)
  186. self.assertEqual(lines['income'].final_credit, 0)
  187. self.assertEqual(lines['income'].final_balance, 1000)
  188. # Add another move at the end day of fiscal year
  189. # to check that it correctly used on report
  190. self._add_move(
  191. date=self.fy_date_end,
  192. receivable_debit=0,
  193. receivable_credit=1000,
  194. income_debit=1000,
  195. income_credit=0
  196. )
  197. # Re Generate the general ledger line
  198. lines = self._get_report_lines()
  199. self.assertEqual(len(lines['receivable']), 1)
  200. self.assertEqual(len(lines['income']), 1)
  201. # Check the initial and final balance
  202. self.assertEqual(lines['receivable'].initial_debit, 1000)
  203. self.assertEqual(lines['receivable'].initial_credit, 0)
  204. self.assertEqual(lines['receivable'].initial_balance, 1000)
  205. self.assertEqual(lines['receivable'].final_debit, 1000)
  206. self.assertEqual(lines['receivable'].final_credit, 2000)
  207. self.assertEqual(lines['receivable'].final_balance, -1000)
  208. self.assertEqual(lines['income'].initial_debit, 0)
  209. self.assertEqual(lines['income'].initial_credit, 0)
  210. self.assertEqual(lines['income'].initial_balance, 0)
  211. self.assertEqual(lines['income'].final_debit, 2000)
  212. self.assertEqual(lines['income'].final_credit, 0)
  213. self.assertEqual(lines['income'].final_balance, 2000)
  214. def test_02_partner_balance(self):
  215. # Generate the general ledger line
  216. lines = self._get_report_lines(with_partners=True)
  217. self.assertEqual(len(lines['partner_receivable']), 0)
  218. # Add a move at the previous day of the first day of fiscal year
  219. # to check the initial balance
  220. self._add_move(
  221. date=self.previous_fy_date_end,
  222. receivable_debit=1000,
  223. receivable_credit=0,
  224. income_debit=0,
  225. income_credit=1000
  226. )
  227. # Re Generate the general ledger line
  228. lines = self._get_report_lines(with_partners=True)
  229. self.assertEqual(len(lines['partner_receivable']), 1)
  230. # Check the initial and final balance
  231. self.assertEqual(lines['partner_receivable'].initial_debit, 1000)
  232. self.assertEqual(lines['partner_receivable'].initial_credit, 0)
  233. self.assertEqual(lines['partner_receivable'].initial_balance, 1000)
  234. self.assertEqual(lines['partner_receivable'].final_debit, 1000)
  235. self.assertEqual(lines['partner_receivable'].final_credit, 0)
  236. self.assertEqual(lines['partner_receivable'].final_balance, 1000)
  237. # Add reversale move of the initial move the first day of fiscal year
  238. # to check the first day of fiscal year is not used
  239. # to compute the initial balance
  240. self._add_move(
  241. date=self.fy_date_start,
  242. receivable_debit=0,
  243. receivable_credit=1000,
  244. income_debit=1000,
  245. income_credit=0
  246. )
  247. # Re Generate the general ledger line
  248. lines = self._get_report_lines(with_partners=True)
  249. self.assertEqual(len(lines['partner_receivable']), 1)
  250. # Check the initial and final balance
  251. self.assertEqual(lines['partner_receivable'].initial_debit, 1000)
  252. self.assertEqual(lines['partner_receivable'].initial_credit, 0)
  253. self.assertEqual(lines['partner_receivable'].initial_balance, 1000)
  254. self.assertEqual(lines['partner_receivable'].final_debit, 1000)
  255. self.assertEqual(lines['partner_receivable'].final_credit, 1000)
  256. self.assertEqual(lines['partner_receivable'].final_balance, 0)
  257. # Add another move at the end day of fiscal year
  258. # to check that it correctly used on report
  259. self._add_move(
  260. date=self.fy_date_end,
  261. receivable_debit=0,
  262. receivable_credit=1000,
  263. income_debit=1000,
  264. income_credit=0
  265. )
  266. # Re Generate the general ledger line
  267. lines = self._get_report_lines(with_partners=True)
  268. self.assertEqual(len(lines['partner_receivable']), 1)
  269. # Check the initial and final balance
  270. self.assertEqual(lines['partner_receivable'].initial_debit, 1000)
  271. self.assertEqual(lines['partner_receivable'].initial_credit, 0)
  272. self.assertEqual(lines['partner_receivable'].initial_balance, 1000)
  273. self.assertEqual(lines['partner_receivable'].final_debit, 1000)
  274. self.assertEqual(lines['partner_receivable'].final_credit, 2000)
  275. self.assertEqual(lines['partner_receivable'].final_balance, -1000)
  276. def test_03_unaffected_account_balance(self):
  277. # Generate the general ledger line
  278. lines = self._get_report_lines()
  279. self.assertEqual(len(lines['unaffected']), 1)
  280. # Check the initial and final balance
  281. self.assertEqual(lines['unaffected'].initial_debit, 0)
  282. self.assertEqual(lines['unaffected'].initial_credit, 0)
  283. self.assertEqual(lines['unaffected'].initial_balance, 0)
  284. self.assertEqual(lines['unaffected'].final_debit, 0)
  285. self.assertEqual(lines['unaffected'].final_credit, 0)
  286. self.assertEqual(lines['unaffected'].final_balance, 0)
  287. # Add a move at the previous day of the first day of fiscal year
  288. # to check the initial balance
  289. self._add_move(
  290. date=self.previous_fy_date_end,
  291. receivable_debit=1000,
  292. receivable_credit=0,
  293. income_debit=0,
  294. income_credit=1000
  295. )
  296. # Re Generate the general ledger line
  297. lines = self._get_report_lines()
  298. self.assertEqual(len(lines['unaffected']), 1)
  299. # Check the initial and final balance
  300. self.assertEqual(lines['unaffected'].initial_debit, 0)
  301. self.assertEqual(lines['unaffected'].initial_credit, 0)
  302. self.assertEqual(lines['unaffected'].initial_balance, -1000)
  303. self.assertEqual(lines['unaffected'].final_debit, -0)
  304. self.assertEqual(lines['unaffected'].final_credit, 0)
  305. self.assertEqual(lines['unaffected'].final_balance, -1000)
  306. # Add reversale move of the initial move the first day of fiscal year
  307. # to check the first day of fiscal year is not used
  308. # to compute the initial balance
  309. self._add_move(
  310. date=self.fy_date_start,
  311. receivable_debit=0,
  312. receivable_credit=0,
  313. income_debit=0,
  314. income_credit=1000,
  315. unaffected_debit=1000,
  316. unaffected_credit=0
  317. )
  318. # Re Generate the general ledger line
  319. lines = self._get_report_lines()
  320. self.assertEqual(len(lines['unaffected']), 1)
  321. # Check the initial and final balance
  322. self.assertEqual(lines['unaffected'].initial_debit, 0)
  323. self.assertEqual(lines['unaffected'].initial_credit, 0)
  324. self.assertEqual(lines['unaffected'].initial_balance, -1000)
  325. self.assertEqual(lines['unaffected'].final_debit, 1000)
  326. self.assertEqual(lines['unaffected'].final_credit, 0)
  327. self.assertEqual(lines['unaffected'].final_balance, 0)
  328. # Add another move at the end day of fiscal year
  329. # to check that it correctly used on report
  330. self._add_move(
  331. date=self.fy_date_end,
  332. receivable_debit=3000,
  333. receivable_credit=0,
  334. income_debit=0,
  335. income_credit=0,
  336. unaffected_debit=0,
  337. unaffected_credit=3000
  338. )
  339. # Re Generate the general ledger line
  340. lines = self._get_report_lines()
  341. self.assertEqual(len(lines['unaffected']), 1)
  342. # Check the initial and final balance
  343. self.assertEqual(lines['unaffected'].initial_debit, 0)
  344. self.assertEqual(lines['unaffected'].initial_credit, 0)
  345. self.assertEqual(lines['unaffected'].initial_balance, -1000)
  346. self.assertEqual(lines['unaffected'].final_debit, 1000)
  347. self.assertEqual(lines['unaffected'].final_credit, 3000)
  348. self.assertEqual(lines['unaffected'].final_balance, -3000)