Fix the tests now that you can have multiple sockets open at once
This commit is contained in:
@@ -1,10 +1,6 @@
|
|||||||
require File.expand_path( File.join(File.dirname(__FILE__), 'test_helper') )
|
require File.expand_path( File.join(File.dirname(__FILE__), 'test_helper') )
|
||||||
require 'linux/netlink/route'
|
require 'linux/netlink/route'
|
||||||
|
|
||||||
# Note: multiple sockets bound to the same PID seem to cause timeout problems.
|
|
||||||
# (Should we use different algorithm for generating the PID? PID + seq?)
|
|
||||||
$ip ||= Linux::Netlink::Route::Socket.new
|
|
||||||
|
|
||||||
#
|
#
|
||||||
# Ruby 1.8.7 appears to lack the KeyError constant.
|
# Ruby 1.8.7 appears to lack the KeyError constant.
|
||||||
#
|
#
|
||||||
@@ -15,7 +11,7 @@ end
|
|||||||
class TestAddr < Test::Unit::TestCase
|
class TestAddr < Test::Unit::TestCase
|
||||||
context "With netlink route socket" do
|
context "With netlink route socket" do
|
||||||
setup do
|
setup do
|
||||||
@ip = $ip
|
@ip = Linux::Netlink::Route::Socket.new
|
||||||
@ifname = nil
|
@ifname = nil
|
||||||
end
|
end
|
||||||
|
|
||||||
@@ -25,12 +21,25 @@ class TestAddr < Test::Unit::TestCase
|
|||||||
rescue KeyError, IndexError
|
rescue KeyError, IndexError
|
||||||
# Do nothing
|
# Do nothing
|
||||||
end
|
end
|
||||||
|
|
||||||
|
@ip.close
|
||||||
end
|
end
|
||||||
|
|
||||||
test "Read link type" do
|
test "Read link type" do
|
||||||
assert_equal Linux::ARPHRD_LOOPBACK, @ip.link["lo"].type
|
assert_equal Linux::ARPHRD_LOOPBACK, @ip.link["lo"].type
|
||||||
end
|
end
|
||||||
|
|
||||||
|
test "Both sockets work if two are open at the same time" do
|
||||||
|
begin
|
||||||
|
@ip2 = Linux::Netlink::Route::Socket.new
|
||||||
|
|
||||||
|
assert_kind_of Enumerable, @ip.route.list
|
||||||
|
assert_kind_of Enumerable, @ip2.route.list
|
||||||
|
ensure
|
||||||
|
@ip2.close
|
||||||
|
end
|
||||||
|
end
|
||||||
|
|
||||||
def create_test_interface(ifname = "test_#{$$}")
|
def create_test_interface(ifname = "test_#{$$}")
|
||||||
begin
|
begin
|
||||||
@ip.link.add(
|
@ip.link.add(
|
||||||
|
Reference in New Issue
Block a user