django-ledger 0.7.1__py3-none-any.whl → 0.7.3__py3-none-any.whl
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.
Potentially problematic release.
This version of django-ledger might be problematic. Click here for more details.
- django_ledger/__init__.py +1 -1
- django_ledger/forms/account.py +4 -1
- django_ledger/io/io_core.py +3 -1
- django_ledger/models/customer.py +1 -1
- django_ledger/models/data_import.py +22 -3
- django_ledger/models/invoice.py +1 -1
- django_ledger/models/mixins.py +5 -5
- django_ledger/static/django_ledger/bundle/djetler.bundle.js +1 -1
- django_ledger/static/django_ledger/bundle/styles.bundle.js +1 -1
- django_ledger/templates/django_ledger/account/tags/account_txs_table.html +1 -1
- django_ledger/templates/django_ledger/bills/bill_update.html +1 -1
- django_ledger/templates/django_ledger/components/icon.html +1 -1
- django_ledger/templates/django_ledger/data_import/tags/data_import_job_list_table.html +8 -0
- django_ledger/templates/django_ledger/data_import/tags/data_import_job_txs_imported.html +8 -1
- django_ledger/templates/django_ledger/financial_statements/balance_sheet.html +1 -0
- django_ledger/templates/django_ledger/financial_statements/tags/balance_sheet_statement.html +4 -4
- django_ledger/templates/django_ledger/financial_statements/tags/income_statement.html +118 -0
- django_ledger/templates/django_ledger/includes/nav.html +9 -5
- django_ledger/templates/django_ledger/invoice/includes/card_invoice.html +69 -69
- django_ledger/templatetags/django_ledger.py +11 -3
- django_ledger/views/account.py +1 -1
- django_ledger/views/mixins.py +6 -18
- {django_ledger-0.7.1.dist-info → django_ledger-0.7.3.dist-info}/METADATA +1 -1
- {django_ledger-0.7.1.dist-info → django_ledger-0.7.3.dist-info}/RECORD +28 -78
- assets/node_modules/node-gyp/gyp/gyp_main.py +0 -45
- assets/node_modules/node-gyp/gyp/pylib/gyp/MSVSNew.py +0 -367
- assets/node_modules/node-gyp/gyp/pylib/gyp/MSVSProject.py +0 -206
- assets/node_modules/node-gyp/gyp/pylib/gyp/MSVSSettings.py +0 -1270
- assets/node_modules/node-gyp/gyp/pylib/gyp/MSVSSettings_test.py +0 -1547
- assets/node_modules/node-gyp/gyp/pylib/gyp/MSVSToolFile.py +0 -59
- assets/node_modules/node-gyp/gyp/pylib/gyp/MSVSUserFile.py +0 -153
- assets/node_modules/node-gyp/gyp/pylib/gyp/MSVSUtil.py +0 -271
- assets/node_modules/node-gyp/gyp/pylib/gyp/MSVSVersion.py +0 -574
- assets/node_modules/node-gyp/gyp/pylib/gyp/__init__.py +0 -666
- assets/node_modules/node-gyp/gyp/pylib/gyp/common.py +0 -654
- assets/node_modules/node-gyp/gyp/pylib/gyp/common_test.py +0 -78
- assets/node_modules/node-gyp/gyp/pylib/gyp/easy_xml.py +0 -165
- assets/node_modules/node-gyp/gyp/pylib/gyp/easy_xml_test.py +0 -109
- assets/node_modules/node-gyp/gyp/pylib/gyp/flock_tool.py +0 -55
- assets/node_modules/node-gyp/gyp/pylib/gyp/generator/__init__.py +0 -0
- assets/node_modules/node-gyp/gyp/pylib/gyp/generator/analyzer.py +0 -808
- assets/node_modules/node-gyp/gyp/pylib/gyp/generator/android.py +0 -1173
- assets/node_modules/node-gyp/gyp/pylib/gyp/generator/cmake.py +0 -1321
- assets/node_modules/node-gyp/gyp/pylib/gyp/generator/compile_commands_json.py +0 -120
- assets/node_modules/node-gyp/gyp/pylib/gyp/generator/dump_dependency_json.py +0 -103
- assets/node_modules/node-gyp/gyp/pylib/gyp/generator/eclipse.py +0 -464
- assets/node_modules/node-gyp/gyp/pylib/gyp/generator/gypd.py +0 -89
- assets/node_modules/node-gyp/gyp/pylib/gyp/generator/gypsh.py +0 -58
- assets/node_modules/node-gyp/gyp/pylib/gyp/generator/make.py +0 -2518
- assets/node_modules/node-gyp/gyp/pylib/gyp/generator/msvs.py +0 -3978
- assets/node_modules/node-gyp/gyp/pylib/gyp/generator/msvs_test.py +0 -44
- assets/node_modules/node-gyp/gyp/pylib/gyp/generator/ninja.py +0 -2936
- assets/node_modules/node-gyp/gyp/pylib/gyp/generator/ninja_test.py +0 -55
- assets/node_modules/node-gyp/gyp/pylib/gyp/generator/xcode.py +0 -1394
- assets/node_modules/node-gyp/gyp/pylib/gyp/generator/xcode_test.py +0 -25
- assets/node_modules/node-gyp/gyp/pylib/gyp/input.py +0 -3137
- assets/node_modules/node-gyp/gyp/pylib/gyp/input_test.py +0 -98
- assets/node_modules/node-gyp/gyp/pylib/gyp/mac_tool.py +0 -771
- assets/node_modules/node-gyp/gyp/pylib/gyp/msvs_emulation.py +0 -1271
- assets/node_modules/node-gyp/gyp/pylib/gyp/ninja_syntax.py +0 -174
- assets/node_modules/node-gyp/gyp/pylib/gyp/simple_copy.py +0 -61
- assets/node_modules/node-gyp/gyp/pylib/gyp/win_tool.py +0 -374
- assets/node_modules/node-gyp/gyp/pylib/gyp/xcode_emulation.py +0 -1939
- assets/node_modules/node-gyp/gyp/pylib/gyp/xcode_ninja.py +0 -302
- assets/node_modules/node-gyp/gyp/pylib/gyp/xcodeproj_file.py +0 -3197
- assets/node_modules/node-gyp/gyp/pylib/gyp/xml_fix.py +0 -65
- assets/node_modules/node-gyp/gyp/setup.py +0 -42
- assets/node_modules/node-gyp/gyp/test_gyp.py +0 -260
- assets/node_modules/node-gyp/gyp/tools/graphviz.py +0 -102
- assets/node_modules/node-gyp/gyp/tools/pretty_gyp.py +0 -156
- assets/node_modules/node-gyp/gyp/tools/pretty_sln.py +0 -181
- assets/node_modules/node-gyp/gyp/tools/pretty_vcproj.py +0 -339
- assets/node_modules/node-gyp/test/fixtures/test-charmap.py +0 -31
- assets/node_modules/node-gyp/update-gyp.py +0 -46
- {django_ledger-0.7.1.dist-info → django_ledger-0.7.3.dist-info}/AUTHORS.md +0 -0
- {django_ledger-0.7.1.dist-info → django_ledger-0.7.3.dist-info}/LICENSE +0 -0
- {django_ledger-0.7.1.dist-info → django_ledger-0.7.3.dist-info}/WHEEL +0 -0
- {django_ledger-0.7.1.dist-info → django_ledger-0.7.3.dist-info}/top_level.txt +0 -0
|
@@ -1,98 +0,0 @@
|
|
|
1
|
-
#!/usr/bin/env python3
|
|
2
|
-
|
|
3
|
-
# Copyright 2013 Google Inc. All rights reserved.
|
|
4
|
-
# Use of this source code is governed by a BSD-style license that can be
|
|
5
|
-
# found in the LICENSE file.
|
|
6
|
-
|
|
7
|
-
"""Unit tests for the input.py file."""
|
|
8
|
-
|
|
9
|
-
import gyp.input
|
|
10
|
-
import unittest
|
|
11
|
-
|
|
12
|
-
|
|
13
|
-
class TestFindCycles(unittest.TestCase):
|
|
14
|
-
def setUp(self):
|
|
15
|
-
self.nodes = {}
|
|
16
|
-
for x in ("a", "b", "c", "d", "e"):
|
|
17
|
-
self.nodes[x] = gyp.input.DependencyGraphNode(x)
|
|
18
|
-
|
|
19
|
-
def _create_dependency(self, dependent, dependency):
|
|
20
|
-
dependent.dependencies.append(dependency)
|
|
21
|
-
dependency.dependents.append(dependent)
|
|
22
|
-
|
|
23
|
-
def test_no_cycle_empty_graph(self):
|
|
24
|
-
for label, node in self.nodes.items():
|
|
25
|
-
self.assertEqual([], node.FindCycles())
|
|
26
|
-
|
|
27
|
-
def test_no_cycle_line(self):
|
|
28
|
-
self._create_dependency(self.nodes["a"], self.nodes["b"])
|
|
29
|
-
self._create_dependency(self.nodes["b"], self.nodes["c"])
|
|
30
|
-
self._create_dependency(self.nodes["c"], self.nodes["d"])
|
|
31
|
-
|
|
32
|
-
for label, node in self.nodes.items():
|
|
33
|
-
self.assertEqual([], node.FindCycles())
|
|
34
|
-
|
|
35
|
-
def test_no_cycle_dag(self):
|
|
36
|
-
self._create_dependency(self.nodes["a"], self.nodes["b"])
|
|
37
|
-
self._create_dependency(self.nodes["a"], self.nodes["c"])
|
|
38
|
-
self._create_dependency(self.nodes["b"], self.nodes["c"])
|
|
39
|
-
|
|
40
|
-
for label, node in self.nodes.items():
|
|
41
|
-
self.assertEqual([], node.FindCycles())
|
|
42
|
-
|
|
43
|
-
def test_cycle_self_reference(self):
|
|
44
|
-
self._create_dependency(self.nodes["a"], self.nodes["a"])
|
|
45
|
-
|
|
46
|
-
self.assertEqual(
|
|
47
|
-
[[self.nodes["a"], self.nodes["a"]]], self.nodes["a"].FindCycles()
|
|
48
|
-
)
|
|
49
|
-
|
|
50
|
-
def test_cycle_two_nodes(self):
|
|
51
|
-
self._create_dependency(self.nodes["a"], self.nodes["b"])
|
|
52
|
-
self._create_dependency(self.nodes["b"], self.nodes["a"])
|
|
53
|
-
|
|
54
|
-
self.assertEqual(
|
|
55
|
-
[[self.nodes["a"], self.nodes["b"], self.nodes["a"]]],
|
|
56
|
-
self.nodes["a"].FindCycles(),
|
|
57
|
-
)
|
|
58
|
-
self.assertEqual(
|
|
59
|
-
[[self.nodes["b"], self.nodes["a"], self.nodes["b"]]],
|
|
60
|
-
self.nodes["b"].FindCycles(),
|
|
61
|
-
)
|
|
62
|
-
|
|
63
|
-
def test_two_cycles(self):
|
|
64
|
-
self._create_dependency(self.nodes["a"], self.nodes["b"])
|
|
65
|
-
self._create_dependency(self.nodes["b"], self.nodes["a"])
|
|
66
|
-
|
|
67
|
-
self._create_dependency(self.nodes["b"], self.nodes["c"])
|
|
68
|
-
self._create_dependency(self.nodes["c"], self.nodes["b"])
|
|
69
|
-
|
|
70
|
-
cycles = self.nodes["a"].FindCycles()
|
|
71
|
-
self.assertTrue([self.nodes["a"], self.nodes["b"], self.nodes["a"]] in cycles)
|
|
72
|
-
self.assertTrue([self.nodes["b"], self.nodes["c"], self.nodes["b"]] in cycles)
|
|
73
|
-
self.assertEqual(2, len(cycles))
|
|
74
|
-
|
|
75
|
-
def test_big_cycle(self):
|
|
76
|
-
self._create_dependency(self.nodes["a"], self.nodes["b"])
|
|
77
|
-
self._create_dependency(self.nodes["b"], self.nodes["c"])
|
|
78
|
-
self._create_dependency(self.nodes["c"], self.nodes["d"])
|
|
79
|
-
self._create_dependency(self.nodes["d"], self.nodes["e"])
|
|
80
|
-
self._create_dependency(self.nodes["e"], self.nodes["a"])
|
|
81
|
-
|
|
82
|
-
self.assertEqual(
|
|
83
|
-
[
|
|
84
|
-
[
|
|
85
|
-
self.nodes["a"],
|
|
86
|
-
self.nodes["b"],
|
|
87
|
-
self.nodes["c"],
|
|
88
|
-
self.nodes["d"],
|
|
89
|
-
self.nodes["e"],
|
|
90
|
-
self.nodes["a"],
|
|
91
|
-
]
|
|
92
|
-
],
|
|
93
|
-
self.nodes["a"].FindCycles(),
|
|
94
|
-
)
|
|
95
|
-
|
|
96
|
-
|
|
97
|
-
if __name__ == "__main__":
|
|
98
|
-
unittest.main()
|