mirror of
https://github.com/simonmichael/hledger.git
synced 2024-11-10 14:16:41 +03:00
53 lines
1.1 KiB
Plaintext
53 lines
1.1 KiB
Plaintext
# Testing parse error messages for accuracy and usefulness.
|
|
|
|
# A journal with an incomplete date.
|
|
<
|
|
2018
|
|
|
|
# 1.
|
|
$ hledger -f - print
|
|
>2
|
|
hledger: -:1:5:
|
|
|
|
|
1 | 2018
|
|
| ^
|
|
unexpected newline
|
|
expecting date separator or the rest of year or month
|
|
|
|
>=1
|
|
|
|
# A journal with an unbalanced transaction.
|
|
<
|
|
2018/1/1
|
|
a 1
|
|
|
|
# 2. When read from stdin, this example actually passes because hledger tries all readers.
|
|
# If they all failed, it would show the error from the first (journal reader).
|
|
# But in this case the timedot reader can parse it.
|
|
$ hledger -f - print
|
|
>
|
|
2018/01/01 *
|
|
(a) 1.00
|
|
|
|
>=
|
|
|
|
# 3. So in these tests we must sometimes force the desired format, like so.
|
|
# Now we see the error from the journal reader.
|
|
$ hledger -f journal:- print
|
|
>2 /hledger: could not balance this transaction \(real postings are off by 1\)/
|
|
>=1
|
|
|
|
# A posting without two spaces between account and amount.
|
|
<
|
|
2018/1/1
|
|
(a) 1
|
|
|
|
# 4. hledger doesn't detect this as an error directly, it parses account name "(a) 1" and
|
|
# amount 0 here.
|
|
$ hledger -f - print -x
|
|
2018/01/01
|
|
(a) 1 0
|
|
|
|
>=
|
|
|