[#44776] [ruby-trunk - Bug #6385][Open] mtime vie File.stat(filename).utime vs File.open(filename, 'r').mtime in Windows — "kolmanv (Kolman Vornovitsky)" <kolmanv@...>

9 messages 2012/05/01

[#44782] [ruby-trunk - Bug #6387][Open] 1.9.3p194 crashed on require in ubuntu — "ywen (Yi Wen)" <hayafirst@...>

12 messages 2012/05/01

[#44795] [ruby-trunk - Bug #6391][Open] Segment Fault while execute make_encmake.rb for Ruby 1.9.3 P194 ( MinGW64) — "raylinn@... (ray linn)" <raylinn@...>

13 messages 2012/05/02

[#44911] [ruby-trunk - Bug #6408][Open] DelegateClass#eql? and <=> don't work as expected — "tenderlovemaking (Aaron Patterson)" <aaron@...>

11 messages 2012/05/06

[#44951] [ruby-trunk - Feature #6414][Open] Destructuring Assignment — "edtsech (Edward Tsech)" <edtsech@...>

14 messages 2012/05/08

[#44958] [ruby-trunk - Feature #6418][Assigned] Supporing a subset of ANSI escape code on Windows — "usa (Usaku NAKAMURA)" <usa@...>

11 messages 2012/05/09

[#45035] [ruby-trunk - Bug #6433][Open] rb_thread_blocking_region(): ubf() function is executed with GVL — ibc (Iñaki Baz Castillo) <ibc@...>

12 messages 2012/05/14

[#45180] [ruby-trunk - Feature #6478][Open] BasicObject#__class__ — "trans (Thomas Sawyer)" <transfire@...>

14 messages 2012/05/22

[#45193] [ruby-trunk - Feature #6482][Open] Add URI requested to Net::HTTP request and response objects — "drbrain (Eric Hodel)" <drbrain@...7.net>

16 messages 2012/05/23

[#45198] [ruby-trunk - Feature #6483][Open] parametric map — "prijutme4ty (Ilya Vorontsov)" <prijutme4ty@...>

14 messages 2012/05/23

[#45222] [ruby-trunk - Feature #6492][Open] Inflate all HTTP Content-Encoding: deflate, gzip, x-gzip responses by default — "drbrain (Eric Hodel)" <drbrain@...7.net>

23 messages 2012/05/24

[#45252] [ruby-trunk - Feature #6499][Open] Array::zip — "prijutme4ty (Ilya Vorontsov)" <prijutme4ty@...>

14 messages 2012/05/26

[#45272] [ruby-trunk - Feature #6503][Open] Support for the NPN extension to TLS/SSL — "igrigorik (Ilya Grigorik)" <ilya@...>

13 messages 2012/05/27

[#45316] [ruby-trunk - Feature #6515][Open] array.c: added method that verifies if an Array is part of another — "lellisga (Li Ellis Galardo)" <lellisga@...>

14 messages 2012/05/30

[ruby-core:44837] [ruby-trunk - Bug #6385][Assigned] mtime vie File.stat(filename).utime vs File.open(filename, 'r').mtime in Windows

From: "mame (Yusuke Endoh)" <mame@...>
Date: 2012-05-03 04:30:46 UTC
List: ruby-core #44837
Issue #6385 has been updated by mame (Yusuke Endoh).

Status changed from Open to Assigned
Assignee set to usa (Usaku NAKAMURA)


----------------------------------------
Bug #6385: mtime vie File.stat(filename).utime vs File.open(filename, 'r').mtime in Windows
https://bugs.ruby-lang.org/issues/6385#change-26412

Author: kolmanv (Kolman Vornovitsky)
Status: Assigned
Priority: Normal
Assignee: usa (Usaku NAKAMURA)
Category: 
Target version: 
ruby -v: ruby 1.9.3p194 (2012-04-20) [i386-mingw32]


Seems that File.stat is not working well under Windows, specifically the mtime member.
This thing maybe related to local time (timezones) which should not because time which is used is unixtime.
On Mac works fine.

Windows: ruby 1.9.3p194 (2012-04-20) [i386-mingw32]
Mac: ruby 1.9.3p202 (2012-04-27 revision 35484) [x86_64-darwin11.3.0]

To reproduce:
RESOURCES_DIR = File.expand_path(File.dirname(__FILE__) + "/test")
MOD_TIME_CONTENTS = Time.at 1306527039

def test_local_os
  Dir.mkdir(RESOURCES_DIR) unless (File.exists?(RESOURCES_DIR))
  file_path = "#{RESOURCES_DIR}/local_os_test.test"
  file = File.open(file_path, "w", 0777) do |file|
    file.puts("kuku")
  end
  file_stats = File.stat(file_path)
  p "MOD_TIME_CONTENTS: #{MOD_TIME_CONTENTS}."
  p "MOD_TIME_CONTENTS: #{MOD_TIME_CONTENTS.to_i}."
  p "file_stat.mtime: #{file_stats.mtime}."
  p "file_stat.mtime: #{file_stats.mtime.to_i}."
  p "File.mtime: #{File.mtime(file_path)}."
  p "File.mtime: #{File.mtime(file_path).to_i}."
  File.utime File.atime(file_path), MOD_TIME_CONTENTS, file_path
  file_stats = File.stat(file_path)
  p "file_stat.mtime: #{file_stats.mtime}."
  p "file_stat.mtime: #{file_stats.mtime.to_i}."
  p "File.mtime: #{File.mtime(file_path)}."
  p "File.mtime: #{File.mtime(file_path).to_i}."
		  
  file_mtime = nil
  file = File.open(file_path, 'r') do |file|
    p "file.open.mtime = #{file.mtime}"
    p "file.open.mtime = #{file.mtime.to_i}"
    file_mtime = file.mtime
  end
		  
  assert_equal(MOD_TIME_CONTENTS, file_mtime)
		  
  # !!! This fails on windows with different timezone
  assert_equal(MOD_TIME_CONTENTS, file_stats.mtime)
end

Second assertion fails:
  1) Failure:
test_local_os(BBFS::FileUtils::Test::TestTimeModification) [test/file_utils/time_modification_test.rb:89]:
<2011-05-27 20:10:39 +0000> expected but was
<2011-05-27 18:10:39 +0000>.


-- 
http://bugs.ruby-lang.org/

In This Thread