summaryrefslogtreecommitdiff
path: root/test/dbm/test_dbm.rb
diff options
context:
space:
mode:
authorakr <akr@b2dd03c8-39d4-4d8f-98ff-823fe69b080e>2005-08-12 15:53:06 +0000
committerakr <akr@b2dd03c8-39d4-4d8f-98ff-823fe69b080e>2005-08-12 15:53:06 +0000
commit2b5bb9ad00ac8205cda18a3a35e6bd906ba5223d (patch)
tree42206a5436185839fd028d91292b9da375c5c7cf /test/dbm/test_dbm.rb
parent66323da355837efbf7abc31e6770b1ae20753b27 (diff)
dbm/test_dbm.rb: specify pid for Process.wait.
gdbm/test_gdbm.rb: ditto. sdbm/test_sdbm.rb: ditto. dbm/test_dbm.rb: add tests for open when db is not exist. gdbm/test_gdbm.rb: ditto. git-svn-id: svn+ssh://ci.ruby-lang.org/ruby/trunk@8977 b2dd03c8-39d4-4d8f-98ff-823fe69b080e
Diffstat (limited to 'test/dbm/test_dbm.rb')
-rw-r--r--test/dbm/test_dbm.rb38
1 files changed, 31 insertions, 7 deletions
diff --git a/test/dbm/test_dbm.rb b/test/dbm/test_dbm.rb
index 9d63bdf5b3..c7ca50cd09 100644
--- a/test/dbm/test_dbm.rb
+++ b/test/dbm/test_dbm.rb
@@ -87,7 +87,7 @@ if defined? DBM
end
def test_s_open_lock
return unless have_fork? # snip this test
- fork() {
+ pid = fork() {
assert_instance_of(DBM, dbm = DBM.open("tmptest_dbm", 0644))
sleep 2
}
@@ -101,7 +101,7 @@ if defined? DBM
end
}
ensure
- Process.wait
+ Process.wait pid
end
end
@@ -127,7 +127,7 @@ if defined? DBM
end
return unless have_fork? # snip this test
- fork() {
+ pid = fork() {
assert_instance_of(DBM, dbm = DBM.open("tmptest_dbm", 0644,
DBM::NOLOCK))
sleep 2
@@ -139,13 +139,13 @@ if defined? DBM
assert_instance_of(DBM, dbm2 = DBM.open("tmptest_dbm", 0644))
}
ensure
- Process.wait
+ Process.wait pid
dbm2.close if dbm2
end
p Dir.glob("tmptest_dbm*") if $DEBUG
- fork() {
+ pid = fork() {
assert_instance_of(DBM, dbm = DBM.open("tmptest_dbm", 0644))
sleep 2
}
@@ -158,7 +158,7 @@ if defined? DBM
DBM::NOLOCK))
}
ensure
- Process.wait
+ Process.wait pid
dbm2.close if dbm2
end
end
@@ -590,8 +590,32 @@ if defined? DBM
FileUtils.rm_rf TMPROOT if File.directory?(TMPROOT)
end
+ def test_reader_open_notexist
+ assert_raise(Errno::ENOENT) {
+ DBM.open("#{TMPROOT}/a", 0666, DBM::READER)
+ }
+ end
+
+ def test_writer_open_notexist
+ assert_raise(Errno::ENOENT) {
+ DBM.open("#{TMPROOT}/a", 0666, DBM::WRITER)
+ }
+ end
+
+ def test_wrcreat_open_notexist
+ v = DBM.open("#{TMPROOT}/a", 0666, DBM::WRCREAT)
+ assert_instance_of(DBM, v)
+ v.close
+ end
+
+ def test_newdb_open_notexist
+ v = DBM.open("#{TMPROOT}/a", 0666, DBM::NEWDB)
+ assert_instance_of(DBM, v)
+ v.close
+ end
+
def test_reader_open
- DBM.open("#{TMPROOT}/a") {}
+ DBM.open("#{TMPROOT}/a") {} # create a db.
v = DBM.open("#{TMPROOT}/a", nil, DBM::READER) {|d|
# Errno::EPERM is raised on Solaris which use ndbm.
# DBMError is raised on Debian which use gdbm.