未验证 提交 548bd509 编写于 作者: R Rafael França 提交者: GitHub

Merge pull request #34037 from reitermarkus/atomic_write-permissions

`atomic_write`: Ensure correct permission when `tmpdir` is the same as `dirname`.
......@@ -29,7 +29,7 @@ def self.atomic_write(file_name, temp_dir = dirname(file_name))
old_stat = if exist?(file_name)
# Get original file permissions
stat(file_name)
elsif temp_dir != dirname(file_name)
else
# If not possible, probe which are the default permissions in the
# destination directory.
probe_stat_in(dirname(file_name))
......
......@@ -59,6 +59,20 @@ def test_atomic_write_preserves_default_file_permissions
File.unlink(file_name) rescue nil
end
def test_atomic_write_preserves_file_permissions_same_directory
Dir.mktmpdir do |temp_dir|
File.chmod 0700, temp_dir
probed_permissions = File.probe_stat_in(temp_dir).mode.to_s(8)
File.atomic_write(File.join(temp_dir, file_name), &:close)
actual_permissions = File.stat(File.join(temp_dir, file_name)).mode.to_s(8)
assert_equal actual_permissions, probed_permissions
end
end
def test_atomic_write_returns_result_from_yielded_block
block_return_value = File.atomic_write(file_name, Dir.pwd) do |file|
"Hello world!"
......
Markdown is supported
0% .
You are about to add 0 people to the discussion. Proceed with caution.
先完成此消息的编辑!
想要评论请 注册