Fix an oversight in commit 4c70098ff.
authorTom Lane <[email protected]>
Thu, 23 Jan 2020 21:15:32 +0000 (16:15 -0500)
committerTom Lane <[email protected]>
Thu, 23 Jan 2020 21:15:32 +0000 (16:15 -0500)
commit9a3a75cb81d3b060b8e76001d04c78ab4ce0dcef
treee266ac0f2d9d517bf2bec5228b387cda17474245
parent4c70098ffa8cf19e79e7b124ccac05dd338c937b
Fix an oversight in commit 4c70098ff.

I had supposed that the from_char_seq_search() call sites were
all passing the constant arrays you'd expect them to pass ...
but on looking closer, the one for DY format was passing the
days[] array not days_short[].  This accidentally worked because
the day abbreviations in English are all the same as the first
three letters of the full day names.  However, once we took out
the "maximum comparison length" logic, it stopped working.

As penance for that oversight, add regression test cases covering
this, as well as every other switch case in DCH_from_char() that
was not reached according to the code coverage report.

Also, fold the DCH_RM and DCH_rm cases into one --- now that
seq_search is case independent, there's no need to pass different
comparison arrays for those cases.

Back-patch, as the previous commit was.
src/backend/utils/adt/formatting.c
src/test/regress/expected/horology.out
src/test/regress/sql/horology.sql