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.

470 lines
18 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 odoo.tests import common
  7. from . import abstract_test_foreign_currency as a_t_f_c
  8. class TestGeneralLedger(a_t_f_c.AbstractTestForeignCurrency):
  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.company.id,
  28. 'fy_start_date': time.strftime('%Y-01-01'),
  29. 'foreign_currency': True,
  30. }
  31. def _getAdditionalFiltersToBeTested(self):
  32. return [
  33. {'only_posted_moves': True},
  34. {'hide_account_balance_at_0': True},
  35. {'centralize': True},
  36. {'only_posted_moves': True, 'hide_account_balance_at_0': True},
  37. {'only_posted_moves': True, 'centralize': True},
  38. {'hide_account_balance_at_0': True, 'centralize': True},
  39. {
  40. 'only_posted_moves': True,
  41. 'hide_account_balance_at_0': True,
  42. 'centralize': True
  43. },
  44. ]
  45. @common.at_install(False)
  46. @common.post_install(True)
  47. class TestGeneralLedgerReport(common.TransactionCase):
  48. def setUp(self):
  49. super(TestGeneralLedgerReport, self).setUp()
  50. self.before_previous_fy_year = '2014-05-05'
  51. self.previous_fy_date_start = '2015-01-01'
  52. self.previous_fy_date_end = '2015-12-31'
  53. self.fy_date_start = '2016-01-01'
  54. self.fy_date_end = '2016-12-31'
  55. self.receivable_account = self.env['account.account'].search([
  56. ('user_type_id.name', '=', 'Receivable')
  57. ], limit=1)
  58. self.income_account = self.env['account.account'].search([
  59. ('user_type_id.name', '=', 'Income')
  60. ], limit=1)
  61. self.unaffected_account = self.env['account.account'].search([
  62. (
  63. 'user_type_id',
  64. '=',
  65. self.env.ref('account.data_unaffected_earnings').id
  66. )], limit=1)
  67. def _add_move(
  68. self,
  69. date,
  70. receivable_debit,
  71. receivable_credit,
  72. income_debit,
  73. income_credit,
  74. unaffected_debit=0,
  75. unaffected_credit=0
  76. ):
  77. move_name = 'expense accrual'
  78. journal = self.env['account.journal'].search([
  79. ('code', '=', 'MISC')])
  80. partner = self.env.ref('base.res_partner_12')
  81. move_vals = {
  82. 'journal_id': journal.id,
  83. 'partner_id': partner.id,
  84. 'name': move_name,
  85. 'date': date,
  86. 'line_ids': [
  87. (0, 0, {
  88. 'name': move_name,
  89. 'debit': receivable_debit,
  90. 'credit': receivable_credit,
  91. 'account_id': self.receivable_account.id}),
  92. (0, 0, {
  93. 'name': move_name,
  94. 'debit': income_debit,
  95. 'credit': income_credit,
  96. 'account_id': self.income_account.id}),
  97. (0, 0, {
  98. 'name': move_name,
  99. 'debit': unaffected_debit,
  100. 'credit': unaffected_credit,
  101. 'account_id': self.unaffected_account.id}),
  102. ]}
  103. move = self.env['account.move'].create(move_vals)
  104. move.post()
  105. def _get_report_lines(self, with_partners=False):
  106. company = self.env.ref('base.main_company')
  107. general_ledger = self.env['report_general_ledger_qweb'].create({
  108. 'date_from': self.fy_date_start,
  109. 'date_to': self.fy_date_end,
  110. 'only_posted_moves': True,
  111. 'hide_account_balance_at_0': False,
  112. 'company_id': company.id,
  113. 'fy_start_date': self.fy_date_start,
  114. })
  115. general_ledger.compute_data_for_report(
  116. with_line_details=True, with_partners=with_partners
  117. )
  118. lines = {}
  119. report_account_model = self.env['report_general_ledger_qweb_account']
  120. lines['receivable'] = report_account_model.search([
  121. ('report_id', '=', general_ledger.id),
  122. ('account_id', '=', self.receivable_account.id),
  123. ])
  124. lines['income'] = report_account_model.search([
  125. ('report_id', '=', general_ledger.id),
  126. ('account_id', '=', self.income_account.id),
  127. ])
  128. lines['unaffected'] = report_account_model.search([
  129. ('report_id', '=', general_ledger.id),
  130. ('account_id', '=', self.unaffected_account.id),
  131. ])
  132. if with_partners:
  133. report_partner_model = self.env[
  134. 'report_general_ledger_qweb_partner'
  135. ]
  136. lines['partner_receivable'] = report_partner_model.search([
  137. ('report_account_id', '=', lines['receivable'].id),
  138. ('partner_id', '=', self.env.ref('base.res_partner_12').id),
  139. ])
  140. return lines
  141. def test_01_account_balance(self):
  142. # Generate the general ledger line
  143. lines = self._get_report_lines()
  144. self.assertEqual(len(lines['receivable']), 0)
  145. self.assertEqual(len(lines['income']), 0)
  146. # Add a move at the previous day of the first day of fiscal year
  147. # to check the initial balance
  148. self._add_move(
  149. date=self.previous_fy_date_end,
  150. receivable_debit=1000,
  151. receivable_credit=0,
  152. income_debit=0,
  153. income_credit=1000
  154. )
  155. # Re Generate the general ledger line
  156. lines = self._get_report_lines()
  157. self.assertEqual(len(lines['receivable']), 1)
  158. self.assertEqual(len(lines['income']), 0)
  159. # Check the initial and final balance
  160. self.assertEqual(lines['receivable'].initial_debit, 1000)
  161. self.assertEqual(lines['receivable'].initial_credit, 0)
  162. self.assertEqual(lines['receivable'].initial_balance, 1000)
  163. self.assertEqual(lines['receivable'].final_debit, 1000)
  164. self.assertEqual(lines['receivable'].final_credit, 0)
  165. self.assertEqual(lines['receivable'].final_balance, 1000)
  166. # Add reversale move of the initial move the first day of fiscal year
  167. # to check the first day of fiscal year is not used
  168. # to compute the initial balance
  169. self._add_move(
  170. date=self.fy_date_start,
  171. receivable_debit=0,
  172. receivable_credit=1000,
  173. income_debit=1000,
  174. income_credit=0
  175. )
  176. # Re Generate the general ledger line
  177. lines = self._get_report_lines()
  178. self.assertEqual(len(lines['receivable']), 1)
  179. self.assertEqual(len(lines['income']), 1)
  180. # Check the initial and final balance
  181. self.assertEqual(lines['receivable'].initial_debit, 1000)
  182. self.assertEqual(lines['receivable'].initial_credit, 0)
  183. self.assertEqual(lines['receivable'].initial_balance, 1000)
  184. self.assertEqual(lines['receivable'].final_debit, 1000)
  185. self.assertEqual(lines['receivable'].final_credit, 1000)
  186. self.assertEqual(lines['receivable'].final_balance, 0)
  187. self.assertEqual(lines['income'].initial_debit, 0)
  188. self.assertEqual(lines['income'].initial_credit, 0)
  189. self.assertEqual(lines['income'].initial_balance, 0)
  190. self.assertEqual(lines['income'].final_debit, 1000)
  191. self.assertEqual(lines['income'].final_credit, 0)
  192. self.assertEqual(lines['income'].final_balance, 1000)
  193. # Add another move at the end day of fiscal year
  194. # to check that it correctly used on report
  195. self._add_move(
  196. date=self.fy_date_end,
  197. receivable_debit=0,
  198. receivable_credit=1000,
  199. income_debit=1000,
  200. income_credit=0
  201. )
  202. # Re Generate the general ledger line
  203. lines = self._get_report_lines()
  204. self.assertEqual(len(lines['receivable']), 1)
  205. self.assertEqual(len(lines['income']), 1)
  206. # Check the initial and final balance
  207. self.assertEqual(lines['receivable'].initial_debit, 1000)
  208. self.assertEqual(lines['receivable'].initial_credit, 0)
  209. self.assertEqual(lines['receivable'].initial_balance, 1000)
  210. self.assertEqual(lines['receivable'].final_debit, 1000)
  211. self.assertEqual(lines['receivable'].final_credit, 2000)
  212. self.assertEqual(lines['receivable'].final_balance, -1000)
  213. self.assertEqual(lines['income'].initial_debit, 0)
  214. self.assertEqual(lines['income'].initial_credit, 0)
  215. self.assertEqual(lines['income'].initial_balance, 0)
  216. self.assertEqual(lines['income'].final_debit, 2000)
  217. self.assertEqual(lines['income'].final_credit, 0)
  218. self.assertEqual(lines['income'].final_balance, 2000)
  219. def test_02_partner_balance(self):
  220. # Generate the general ledger line
  221. lines = self._get_report_lines(with_partners=True)
  222. self.assertEqual(len(lines['partner_receivable']), 0)
  223. # Add a move at the previous day of the first day of fiscal year
  224. # to check the initial balance
  225. self._add_move(
  226. date=self.previous_fy_date_end,
  227. receivable_debit=1000,
  228. receivable_credit=0,
  229. income_debit=0,
  230. income_credit=1000
  231. )
  232. # Re Generate the general ledger line
  233. lines = self._get_report_lines(with_partners=True)
  234. self.assertEqual(len(lines['partner_receivable']), 1)
  235. # Check the initial and final balance
  236. self.assertEqual(lines['partner_receivable'].initial_debit, 1000)
  237. self.assertEqual(lines['partner_receivable'].initial_credit, 0)
  238. self.assertEqual(lines['partner_receivable'].initial_balance, 1000)
  239. self.assertEqual(lines['partner_receivable'].final_debit, 1000)
  240. self.assertEqual(lines['partner_receivable'].final_credit, 0)
  241. self.assertEqual(lines['partner_receivable'].final_balance, 1000)
  242. # Add reversale move of the initial move the first day of fiscal year
  243. # to check the first day of fiscal year is not used
  244. # to compute the initial balance
  245. self._add_move(
  246. date=self.fy_date_start,
  247. receivable_debit=0,
  248. receivable_credit=1000,
  249. income_debit=1000,
  250. income_credit=0
  251. )
  252. # Re Generate the general ledger line
  253. lines = self._get_report_lines(with_partners=True)
  254. self.assertEqual(len(lines['partner_receivable']), 1)
  255. # Check the initial and final balance
  256. self.assertEqual(lines['partner_receivable'].initial_debit, 1000)
  257. self.assertEqual(lines['partner_receivable'].initial_credit, 0)
  258. self.assertEqual(lines['partner_receivable'].initial_balance, 1000)
  259. self.assertEqual(lines['partner_receivable'].final_debit, 1000)
  260. self.assertEqual(lines['partner_receivable'].final_credit, 1000)
  261. self.assertEqual(lines['partner_receivable'].final_balance, 0)
  262. # Add another move at the end day of fiscal year
  263. # to check that it correctly used on report
  264. self._add_move(
  265. date=self.fy_date_end,
  266. receivable_debit=0,
  267. receivable_credit=1000,
  268. income_debit=1000,
  269. income_credit=0
  270. )
  271. # Re Generate the general ledger line
  272. lines = self._get_report_lines(with_partners=True)
  273. self.assertEqual(len(lines['partner_receivable']), 1)
  274. # Check the initial and final balance
  275. self.assertEqual(lines['partner_receivable'].initial_debit, 1000)
  276. self.assertEqual(lines['partner_receivable'].initial_credit, 0)
  277. self.assertEqual(lines['partner_receivable'].initial_balance, 1000)
  278. self.assertEqual(lines['partner_receivable'].final_debit, 1000)
  279. self.assertEqual(lines['partner_receivable'].final_credit, 2000)
  280. self.assertEqual(lines['partner_receivable'].final_balance, -1000)
  281. def test_03_unaffected_account_balance(self):
  282. # Generate the general ledger line
  283. lines = self._get_report_lines()
  284. self.assertEqual(len(lines['unaffected']), 1)
  285. # Check the initial and final balance
  286. self.assertEqual(lines['unaffected'].initial_debit, 0)
  287. self.assertEqual(lines['unaffected'].initial_credit, 0)
  288. self.assertEqual(lines['unaffected'].initial_balance, 0)
  289. self.assertEqual(lines['unaffected'].final_debit, 0)
  290. self.assertEqual(lines['unaffected'].final_credit, 0)
  291. self.assertEqual(lines['unaffected'].final_balance, 0)
  292. # Add a move at the previous day of the first day of fiscal year
  293. # to check the initial balance
  294. self._add_move(
  295. date=self.previous_fy_date_end,
  296. receivable_debit=1000,
  297. receivable_credit=0,
  298. income_debit=0,
  299. income_credit=1000
  300. )
  301. # Re Generate the general ledger line
  302. lines = self._get_report_lines()
  303. self.assertEqual(len(lines['unaffected']), 1)
  304. # Check the initial and final balance
  305. self.assertEqual(lines['unaffected'].initial_debit, 0)
  306. self.assertEqual(lines['unaffected'].initial_credit, 0)
  307. self.assertEqual(lines['unaffected'].initial_balance, -1000)
  308. self.assertEqual(lines['unaffected'].final_debit, -0)
  309. self.assertEqual(lines['unaffected'].final_credit, 0)
  310. self.assertEqual(lines['unaffected'].final_balance, -1000)
  311. # Add reversale move of the initial move the first day of fiscal year
  312. # to check the first day of fiscal year is not used
  313. # to compute the initial balance
  314. self._add_move(
  315. date=self.fy_date_start,
  316. receivable_debit=0,
  317. receivable_credit=0,
  318. income_debit=0,
  319. income_credit=1000,
  320. unaffected_debit=1000,
  321. unaffected_credit=0
  322. )
  323. # Re Generate the general ledger line
  324. lines = self._get_report_lines()
  325. self.assertEqual(len(lines['unaffected']), 1)
  326. # Check the initial and final balance
  327. self.assertEqual(lines['unaffected'].initial_debit, 0)
  328. self.assertEqual(lines['unaffected'].initial_credit, 0)
  329. self.assertEqual(lines['unaffected'].initial_balance, -1000)
  330. self.assertEqual(lines['unaffected'].final_debit, 0)
  331. self.assertEqual(lines['unaffected'].final_credit, 0)
  332. self.assertEqual(lines['unaffected'].final_balance, -1000)
  333. # Add another move at the end day of fiscal year
  334. # to check that it correctly used on report
  335. self._add_move(
  336. date=self.fy_date_end,
  337. receivable_debit=3000,
  338. receivable_credit=0,
  339. income_debit=0,
  340. income_credit=0,
  341. unaffected_debit=0,
  342. unaffected_credit=3000
  343. )
  344. # Re Generate the general ledger line
  345. lines = self._get_report_lines()
  346. self.assertEqual(len(lines['unaffected']), 1)
  347. # Check the initial and final balance
  348. self.assertEqual(lines['unaffected'].initial_debit, 0)
  349. self.assertEqual(lines['unaffected'].initial_credit, 0)
  350. self.assertEqual(lines['unaffected'].initial_balance, -1000)
  351. self.assertEqual(lines['unaffected'].final_debit, 0)
  352. self.assertEqual(lines['unaffected'].final_credit, 0)
  353. self.assertEqual(lines['unaffected'].final_balance, -4000)
  354. def test_04_unaffected_account_balance_2_years(self):
  355. # Generate the general ledger line
  356. lines = self._get_report_lines()
  357. self.assertEqual(len(lines['unaffected']), 1)
  358. # Check the initial and final balance
  359. self.assertEqual(lines['unaffected'].initial_debit, 0)
  360. self.assertEqual(lines['unaffected'].initial_credit, 0)
  361. self.assertEqual(lines['unaffected'].initial_balance, 0)
  362. self.assertEqual(lines['unaffected'].final_debit, 0)
  363. self.assertEqual(lines['unaffected'].final_credit, 0)
  364. self.assertEqual(lines['unaffected'].final_balance, 0)
  365. # Add a move at any date 2 years before the balance
  366. # (to create an historic)
  367. self._add_move(
  368. date=self.before_previous_fy_year,
  369. receivable_debit=0,
  370. receivable_credit=1000,
  371. income_debit=1000,
  372. income_credit=0
  373. )
  374. # Re Generate the general ledger line
  375. lines = self._get_report_lines()
  376. self.assertEqual(len(lines['unaffected']), 1)
  377. # Check the initial and final balance
  378. self.assertEqual(lines['unaffected'].initial_debit, 0)
  379. self.assertEqual(lines['unaffected'].initial_credit, 0)
  380. self.assertEqual(lines['unaffected'].initial_balance, 1000)
  381. self.assertEqual(lines['unaffected'].final_debit, 0)
  382. self.assertEqual(lines['unaffected'].final_credit, 0)
  383. self.assertEqual(lines['unaffected'].final_balance, 1000)
  384. # Affect the company's result last year
  385. self._add_move(
  386. date=self.previous_fy_date_start,
  387. receivable_debit=1000,
  388. receivable_credit=0,
  389. income_debit=0,
  390. income_credit=0,
  391. unaffected_debit=0,
  392. unaffected_credit=1000
  393. )
  394. # Add another move last year to test the initial balance this year
  395. self._add_move(
  396. date=self.previous_fy_date_start,
  397. receivable_debit=0,
  398. receivable_credit=500,
  399. income_debit=500,
  400. income_credit=0,
  401. unaffected_debit=0,
  402. unaffected_credit=0
  403. )
  404. # Re Generate the general ledger line
  405. lines = self._get_report_lines()
  406. self.assertEqual(len(lines['unaffected']), 1)
  407. # Check the initial and final balance
  408. self.assertEqual(lines['unaffected'].initial_debit, 0)
  409. self.assertEqual(lines['unaffected'].initial_credit, 0)
  410. self.assertEqual(lines['unaffected'].initial_balance, 500)
  411. self.assertEqual(lines['unaffected'].final_debit, 0)
  412. self.assertEqual(lines['unaffected'].final_credit, 0)
  413. self.assertEqual(lines['unaffected'].final_balance, 500)