Fred Hansen created PDFBOX-1633:
-----------------------------------

             Summary: DateConverter needs to work
                 Key: PDFBOX-1633
                 URL: https://issues.apache.org/jira/browse/PDFBOX-1633
             Project: PDFBox
          Issue Type: Bug
          Components: Utilities
    Affects Versions: 1.8.2
         Environment: all os and java platforms
            Reporter: Fred Hansen
             Fix For: 1.8.3, 2.0.0


Most of the tests for org/apache/pdfbox/util/DateConverter.java in 
src/test/java/org/apache/pdfbox/util/TestDateUtil.java have been commented out. 
 DateConverter was broken.

The attached patch fixes the problems.  Extensive comments document the 
problems. Here's a copy:

/* the former version of DateConverter had these bugs:
 *   -  In toISO8601 the conversion from millis to minutes was with 1000/1000;
 *      should have been 1000/60.
 *   -  PDFBox-402 was not completely implemented. The calendar fields in the
 *      POTENTIAL_FORMATS are shared among threads. Hence we must create new
 *      SimpleThreadFormats for each test.  (Or synchronize somehow).
 *   -  Some formats with hh did not have an a field. I changed them to HH.
 * 
 *  these questionable features:
 *   -  A timezone with neither plus sign nor minus is assumed to be minus.
 *      This seems wrong, but I have not changed it.
 *   -  toCalendar() returned a value in the default Locale.
 *      PDF files do not have locales (I think) and even if they do
 *      there is no reason to assume the Java default.
 *      I have switched to Locale.ENGLISH which was already assumed 
 *      in the date formats and toString.
 * 
 * and these infelicities:
 *   -  Constants 60 and 1000 appeared.
 *   -  zeroAppend was not used where applicable.
 *      In one case it was inapplicable only because TimeZone.getOffset 
 *      was suspected of returning a long. It does not.
 *   -  Manually computed constants were used to in date.substring
 *      thus reducing flexibility and maintainability. 
 *   -  The TimeZone name reported by toCalendar was always "Unknown"
 *      It is easy enough to compute a name.
 *   -  Time zones were not accepted with most of the alternate parsing formats.
 *      The new code allows a timezone after any format.
 */

--
This message is automatically generated by JIRA.
If you think it was sent incorrectly, please contact your JIRA administrators
For more information on JIRA, see: http://www.atlassian.com/software/jira

Reply via email to