You are viewing a plain text version of this content. The canonical link for it is here.
Posted to issues@commons.apache.org by "Uwe Schindler (Jira)" <ji...@apache.org> on 2020/09/23 08:32:00 UTC
[jira] [Created] (IO-689) All new FileUtils method with Java 8 time
break on DST change
Uwe Schindler created IO-689:
--------------------------------
Summary: All new FileUtils method with Java 8 time break on DST change
Key: IO-689
URL: https://issues.apache.org/jira/browse/IO-689
Project: Commons IO
Issue Type: Task
Components: Utilities
Affects Versions: 2.8.0
Reporter: Uwe Schindler
This commit in PR #124 breaks FileUtils with new Java 8 datetime APIs:
https://github.com/apache/commons-io/pull/124/commits/2eb549873470844c88681e92c64631f796002020
Because of this I had to put all of the methods to the list of blacklisted APIs in Apache Lucene / Solr. The reason for this change is that now all depend on local datetime, there's no way to pass an Instant with a UNIX timestamp through the API without it being corrupted due to forwards/backwards transformation.
Background: During DST changes the same local date time exists two times (in autumn, you have in most countries two time the 2:30am time, once before and once after the DST change - because time is rolled back).
With the above commit you first convert an Instant (which is by definition just a UNIX timestamp and can be converted as-is to a long) to a local Datetime and then back to an Instant. By this forward/backward transformation you get off by an hour during that one hour in autumn, when DST switches back to standard time.
Please revert this commit and release a bugfix.
There is no reason to convert an Instant to local and back, the arguments in the PR are plain wrong. Instants are timezoneless and are identical to UNIX timestamps.
--
This message was sent by Atlassian Jira
(v8.3.4#803005)