mirror of
https://github.com/ruby/ruby.git
synced 2022-11-09 12:17:21 -05:00
merge revision(s) 56559,56582,56584,56585: [Backport #12903]
* test/ruby/test_file.rb (TestFile#test_stat): fix noatime case. [ruby-core:77943] [Bug #12903] * ext/-test/file/fs.c (get_atime_p): Updating of file access times is enabled or not. git-svn-id: svn+ssh://ci.ruby-lang.org/ruby/branches/ruby_2_2@56789 b2dd03c8-39d4-4d8f-98ff-823fe69b080e
This commit is contained in:
parent
49e1e456dc
commit
3c61aab98b
5 changed files with 43 additions and 2 deletions
10
ChangeLog
10
ChangeLog
|
|
@ -1,3 +1,13 @@
|
|||
Tue Nov 15 03:55:45 2016 NARUSE, Yui <naruse@ruby-lang.org>
|
||||
|
||||
* ext/-test/file/fs.c (get_atime_p): Updating of file access times
|
||||
is enabled or not.
|
||||
|
||||
Tue Nov 15 03:55:45 2016 Nobuyoshi Nakada <nobu@ruby-lang.org>
|
||||
|
||||
* test/ruby/test_file.rb (TestFile#test_stat): fix noatime case.
|
||||
[ruby-core:77943] [Bug #12903]
|
||||
|
||||
Tue Nov 15 03:54:14 2016 Shugo Maeda <shugo@ruby-lang.org>
|
||||
|
||||
* test/rinda/test_rinda.rb (test_make_socket_ipv6_multicast,
|
||||
|
|
|
|||
|
|
@ -4,6 +4,7 @@ headers = %w[sys/param.h sys/mount.h sys/vfs.h].select {|h| have_header(h)}
|
|||
if have_type("struct statfs", headers)
|
||||
have_struct_member("struct statfs", "f_fstypename", headers)
|
||||
have_struct_member("struct statfs", "f_type", headers)
|
||||
have_struct_member("struct statfs", "f_flags", headers)
|
||||
end
|
||||
|
||||
headers = %w[sys/statvfs.h].select {|h| have_header(h)}
|
||||
|
|
|
|||
|
|
@ -33,6 +33,12 @@ typedef struct statvfs statfs_t;
|
|||
# if defined HAVE_STRUCT_STATVFS_F_TYPE
|
||||
# define HAVE_STRUCT_STATFS_T_F_TYPE 1
|
||||
# endif
|
||||
#elif defined(HAVE_STRUCT_STATFS_F_TYPE) /* Linux */
|
||||
typedef struct statfs statfs_t;
|
||||
# define STATFS(f, s) statfs((f), (s))
|
||||
# if defined HAVE_STRUCT_STATFS_F_TYPE
|
||||
# define HAVE_STRUCT_STATFS_T_F_TYPE 1
|
||||
# endif
|
||||
#endif
|
||||
|
||||
VALUE
|
||||
|
|
@ -69,9 +75,31 @@ get_fsname(VALUE self, VALUE str)
|
|||
return Qnil;
|
||||
}
|
||||
|
||||
VALUE
|
||||
get_noatime_p(VALUE self, VALUE str)
|
||||
{
|
||||
#ifdef STATFS
|
||||
statfs_t st;
|
||||
FilePathValue(str);
|
||||
str = rb_str_encode_ospath(str);
|
||||
if (STATFS(StringValueCStr(str), &st) == -1) {
|
||||
rb_sys_fail_str(str);
|
||||
}
|
||||
# ifdef HAVE_STRUCT_STATFS_F_FLAGS
|
||||
# ifdef MNT_NOATIME
|
||||
return st.f_flags & MNT_NOATIME ? Qtrue : Qfalse;
|
||||
# elif defined(ST_NOATIME)
|
||||
return st.f_flags & ST_NOATIME ? Qtrue : Qfalse;
|
||||
# endif
|
||||
# endif
|
||||
#endif
|
||||
return Qnil;
|
||||
}
|
||||
|
||||
void
|
||||
Init_fs(VALUE module)
|
||||
{
|
||||
VALUE fs = rb_define_module_under(module, "Fs");
|
||||
rb_define_module_function(fs, "fsname", get_fsname, 1);
|
||||
rb_define_module_function(fs, "noatime?", get_noatime_p, 1);
|
||||
}
|
||||
|
|
|
|||
|
|
@ -1,6 +1,7 @@
|
|||
require 'test/unit'
|
||||
require 'tempfile'
|
||||
require "thread"
|
||||
require "-test-/file"
|
||||
require_relative 'ut_eof'
|
||||
|
||||
class TestFile < Test::Unit::TestCase
|
||||
|
|
@ -323,6 +324,7 @@ class TestFile < Test::Unit::TestCase
|
|||
sleep 2
|
||||
File.write(path, "bar")
|
||||
sleep 2
|
||||
File.read(path)
|
||||
File.chmod(0644, path)
|
||||
sleep 2
|
||||
File.read(path)
|
||||
|
|
@ -334,7 +336,7 @@ class TestFile < Test::Unit::TestCase
|
|||
if stat.birthtime != stat.ctime
|
||||
assert_in_delta t0+4, stat.ctime.to_f, delta
|
||||
end
|
||||
unless /mswin|mingw/ =~ RUBY_PLATFORM
|
||||
if /mswin|mingw/ !~ RUBY_PLATFORM && !Bug::File::Fs.noatime?(path)
|
||||
# Windows delays updating atime
|
||||
assert_in_delta t0+6, stat.atime.to_f, delta
|
||||
end
|
||||
|
|
|
|||
|
|
@ -1,6 +1,6 @@
|
|||
#define RUBY_VERSION "2.2.6"
|
||||
#define RUBY_RELEASE_DATE "2016-11-15"
|
||||
#define RUBY_PATCHLEVEL 394
|
||||
#define RUBY_PATCHLEVEL 395
|
||||
|
||||
#define RUBY_RELEASE_YEAR 2016
|
||||
#define RUBY_RELEASE_MONTH 11
|
||||
|
|
|
|||
Loading…
Add table
Add a link
Reference in a new issue