File tree Expand file tree Collapse file tree 2 files changed +41
-9
lines changed Expand file tree Collapse file tree 2 files changed +41
-9
lines changed Original file line number Diff line number Diff line change @@ -1383,18 +1383,21 @@ def copy(dest)
13831383 end
13841384 when symlink?
13851385 File . symlink File . readlink ( path ( ) ) , dest
1386- when chardev?
1387- raise "cannot handle device file" unless File . respond_to? ( :mknod )
1388- mknod dest , ?c, 0666 , lstat ( ) . rdev
1389- when blockdev?
1390- raise "cannot handle device file" unless File . respond_to? ( :mknod )
1391- mknod dest , ?b, 0666 , lstat ( ) . rdev
1386+ when chardev? , blockdev?
1387+ raise "cannot handle device file"
13921388 when socket?
1393- raise "cannot handle socket" unless File . respond_to? ( :mknod )
1394- mknod dest , nil , lstat ( ) . mode , 0
1389+ begin
1390+ require 'socket'
1391+ rescue LoadError
1392+ raise "cannot handle socket"
1393+ else
1394+ raise "cannot handle socket" unless defined? ( UNIXServer )
1395+ end
1396+ UNIXServer . new ( dest ) . close
1397+ File . chmod lstat ( ) . mode , dest
13951398 when pipe?
13961399 raise "cannot handle FIFO" unless File . respond_to? ( :mkfifo )
1397- mkfifo dest , 0666
1400+ File . mkfifo dest , lstat ( ) . mode
13981401 when door?
13991402 raise "cannot handle door: #{ path ( ) } "
14001403 else
Original file line number Diff line number Diff line change @@ -430,6 +430,35 @@ def test_cp_r_symlink_preserve
430430 }
431431 end if have_symlink? and !no_broken_symlink?
432432
433+ def test_cp_r_fifo
434+ Dir . mkdir ( 'tmp/cpr_src' )
435+ File . mkfifo 'tmp/cpr_src/fifo' , 0600
436+ cp_r 'tmp/cpr_src' , 'tmp/cpr_dest'
437+ assert_equal ( true , File . pipe? ( 'tmp/cpr_dest/fifo' ) )
438+ end if File . respond_to? ( :mkfifo )
439+
440+ def test_cp_r_dev
441+ devs = Dir [ '/dev/*' ]
442+ chardev = Dir [ '/dev/*' ] . find { |f | File . chardev? ( f ) }
443+ blockdev = Dir [ '/dev/*' ] . find { |f | File . blockdev? ( f ) }
444+ Dir . mkdir ( 'tmp/cpr_dest' )
445+ assert_raise ( RuntimeError ) { cp_r chardev , 'tmp/cpr_dest/cd' }
446+ assert_raise ( RuntimeError ) { cp_r blockdev , 'tmp/cpr_dest/bd' }
447+ end
448+
449+ begin
450+ require 'socket'
451+ rescue LoadError
452+ else
453+ def test_cp_r_socket
454+ skip "Skipping socket test on JRuby" if RUBY_ENGINE == 'jruby'
455+ Dir . mkdir ( 'tmp/cpr_src' )
456+ UNIXServer . new ( 'tmp/cpr_src/socket' ) . close
457+ cp_r 'tmp/cpr_src' , 'tmp/cpr_dest'
458+ assert_equal ( true , File . socket? ( 'tmp/cpr_dest/socket' ) )
459+ end if defined? ( UNIXServer )
460+ end
461+
433462 def test_cp_r_pathname
434463 # pathname
435464 touch 'tmp/cprtmp'
You can’t perform that action at this time.
0 commit comments