diff --git a/conservancy_beancount/reports/ledger.py b/conservancy_beancount/reports/ledger.py index 02306da..bf2fbf9 100644 --- a/conservancy_beancount/reports/ledger.py +++ b/conservancy_beancount/reports/ledger.py @@ -92,6 +92,7 @@ class LedgerODS(core.BaseODS[data.Posting, None]): ] ACCOUNT_COLUMNS: Dict[str, Sequence[str]] = collections.OrderedDict([ ('Income', ['project', 'rt-id', 'receipt', 'income-type', 'memo']), + ('Expenses:Payroll', ['project', 'rt-id', 'payroll-type', 'expense-type', 'receipt', 'approval']), ('Expenses', ['project', 'rt-id', 'receipt', 'approval', 'expense-type']), ('Equity', ['project', 'rt-id']), ('Assets:Receivable', ['project', 'rt-id', 'invoice', 'approval', 'contract', 'purchase-order']), diff --git a/setup.py b/setup.py index f052290..e7bb3fd 100755 --- a/setup.py +++ b/setup.py @@ -5,7 +5,7 @@ from setuptools import setup setup( name='conservancy_beancount', description="Plugin, library, and reports for reading Conservancy's books", - version='1.15.4', + version='1.15.5', author='Software Freedom Conservancy', author_email='info@sfconservancy.org', license='GNU AGPLv3+', diff --git a/tests/books/ledger.beancount b/tests/books/ledger.beancount index 13619b1..629035a 100644 --- a/tests/books/ledger.beancount +++ b/tests/books/ledger.beancount @@ -9,6 +9,8 @@ classification: "Accounts receivable" 2018-01-01 open Expenses:Other classification: "Other expenses" +2018-01-01 open Expenses:Payroll + classification: "Payroll expenses" 2018-01-01 open Income:Other classification: "Other income" 2018-01-01 open Liabilities:CreditCard diff --git a/tests/test_reports_ledger.py b/tests/test_reports_ledger.py index 6139a25..34b09a3 100644 --- a/tests/test_reports_ledger.py +++ b/tests/test_reports_ledger.py @@ -34,6 +34,7 @@ _ledger_load = bc_loader.load_file(testutil.test_path('books/ledger.beancount')) DEFAULT_REPORT_SHEETS = [ 'Balance', 'Income', + 'Expenses:Payroll', 'Expenses', 'Equity', 'Assets:Receivable', @@ -42,7 +43,9 @@ DEFAULT_REPORT_SHEETS = [ 'Assets', 'Liabilities', ] -PROJECT_REPORT_SHEETS = DEFAULT_REPORT_SHEETS[:5] + [ +PROJECT_REPORT_SHEETS = [ + *DEFAULT_REPORT_SHEETS[:2], + *DEFAULT_REPORT_SHEETS[3:6], 'Assets:Prepaid', 'Liabilities:UnearnedIncome', 'Liabilities:Payable', @@ -402,6 +405,11 @@ def test_account_names_report(ledger_entries, accounts, report_kwargs): for account in iter_accounts(ledger_entries): if not account.startswith(accounts): ExpectedPostings.check_not_in_report(report.document, account) + # This account is reportable but has no postings + elif account == 'Expenses:Payroll': + ExpectedPostings.check_in_report( + report.document, account, START_DATE, STOP_DATE, txn_filter, + ) elif txn_filter is None: expected[account].check_report(report.document, START_DATE, STOP_DATE) else: