Difference between revisions of "User:Christopherlam"
(→Generating Coverage Reports: fix syntaxhighlight error) |
(→Project 2 Creating test-transaction.scm: update to latest test-transaction.scm) |
||
Line 12: | Line 12: | ||
(system vm vm)) | (system vm vm)) | ||
− | + | (define (run-test) | |
− | ( | + | (coverage-test run-tests-proper)) |
− | + | (define (run-tests-proper) | |
− | |||
− | |||
− | (define (run- | ||
(test-runner-factory my-runner) | (test-runner-factory my-runner) | ||
(test-begin "transaction.scm") | (test-begin "transaction.scm") | ||
+ | (trep-tests) | ||
+ | (test-end "transaction.scm")) | ||
− | ;; | + | (define (coverage-test test-function) |
− | (call-with-values (lambda () | + | ;; we need to add location of transaction.scm otherwise it's not included in report |
− | + | (add-to-load-path "/home/chris/sources/gnucash/gnucash/report/standard-reports") | |
− | + | (call-with-values | |
− | + | (lambda () | |
− | + | (with-code-coverage (make-vm) ;; for guile-2.0. I think for guile-2.2 just remove (make-vm) | |
− | + | test-function)) | |
(lambda (data result) | (lambda (data result) | ||
;; and we save the result into tempdir | ;; and we save the result into tempdir | ||
(let ((port (open-output-file "/tmp/lcov.info"))) | (let ((port (open-output-file "/tmp/lcov.info"))) | ||
(coverage-data->lcov data port) | (coverage-data->lcov data port) | ||
− | (close port))) | + | (close port))))) |
− | |||
</syntaxhighlight> | </syntaxhighlight> | ||
Revision as of 12:08, 5 June 2018
Project 2 Creating test-transaction.scm
I will document some thoughts about development of implementation/mock testing for transaction.scm. Without a framework, creating test-transaction.scm is an awkward hierarchy of function calls as follows:(and (test-1) (test-2) (test-3))
I have tried yawaramin's ggspec and guile-2.0's SRFI-64 and I think the latter is a much simpler tool. I've created test-transaction.scm based on it, and is still in progress.
Generating Coverage Reports
Scheme has an inbuilt coverage report generator. Here's relevant excerpt from test-transaction.scm to illustrate coverage report generator.
(use-modules (system vm coverage)
(system vm vm))
(define (run-test)
(coverage-test run-tests-proper))
(define (run-tests-proper)
(test-runner-factory my-runner)
(test-begin "transaction.scm")
(trep-tests)
(test-end "transaction.scm"))
(define (coverage-test test-function)
;; we need to add location of transaction.scm otherwise it's not included in report
(add-to-load-path "/home/chris/sources/gnucash/gnucash/report/standard-reports")
(call-with-values
(lambda ()
(with-code-coverage (make-vm) ;; for guile-2.0. I think for guile-2.2 just remove (make-vm)
test-function))
(lambda (data result)
;; and we save the result into tempdir
(let ((port (open-output-file "/tmp/lcov.info")))
(coverage-data->lcov data port)
(close port)))))
The result of all this hard work is a coverage log.
We can download lcov from http://ltp.sourceforge.net/coverage/lcov.php
git clone https://github.com/linux-test-project/lcov.git
mkdir html
cd html
../lcov/bin/genhtml /tmp/lcov.info
And the coverage log is converted to an html report. Example report output. Excerpt as follows.
Project 1 Completed Dec 2017
When I was offered opportunity to completely overhaul, I have sought to fix Transaction Report as much as possible, and add options to derive as much value as possible with the underlying data presentable as a customized TR.
This document will serve as useful summary for users, and also as a roadmap for rewriting the git history.
1. General thoughts
The original TR was a complete mess, grown and hacked together by years of accumulated crud. Many functions were created for single use, numerous lists of splits, options, and sortkeys being passed around for no particular reason. I have flattened the TR to a reasonable level; and I haven't quite finalized it yet. There are further flattening/abstracting refinements that can need to take place. e.g. the generic and versatile TR can be massaged to produce a report suitable for reconciliation, just by setting the right options. I can formalise it by creating another report initialized with the above options. I can also rewrite the Income GST Statement to also exist within transaction.scm (or ideally another file) that will just call the options-generator and the renderer with new values. These may require refactoring to allow modification of calculated-cells
2. Bugs were fixed
a) bug for pre-1970 dates whereby the wrong weekday was selected b) bug for 'register-order sortkey being classed as a date-subtotal-type c) fixing debit/credit amount columns - sign reversal strategy was flawed d) fixing date sorting to understand periodic sorting, rather than strict daily sorting
3. Additional features were added
a) proper debit/credit subtotals in the appropriate columns b) multicolumn values and subtotals c) friendly headers for debit/credit d) optionally render Account Description in the subheading e) add 'daily subtotal strategy - useful for "daily report" types f) optionally hide the transactional data - but only a subtotals are enabled g) new filters - transaction/account substring/regex filters, reconciled-status h) new sortkey - reconciled status unreconciled->cleared->reconciled with subtotals i) new infobox - summarise options used and optionally render at the top of report j) sign reversal strategy - will default to follow the global pref k) optionally indent left columns according to grouping strategy
4. Unsure how to fix
a) debit/credit signs are wrong if the sortkeys are 'other-account types