aboutsummaryrefslogtreecommitdiffstats
path: root/test/test_set.rb
diff options
context:
space:
mode:
authorknu <knu@b2dd03c8-39d4-4d8f-98ff-823fe69b080e>2015-11-16 06:43:43 +0000
committerknu <knu@b2dd03c8-39d4-4d8f-98ff-823fe69b080e>2015-11-16 06:43:43 +0000
commitd736eded9d4cb7ab5ddc693059d55f8d1e369c98 (patch)
treece1ca9beb8c7219979490076e1f025c360df3cf7 /test/test_set.rb
parent8fef6aa20bd658d90036287caa96b9ca17ef3fc5 (diff)
downloadruby-d736eded9d4cb7ab5ddc693059d55f8d1e369c98.tar.gz
* lib/set.rb (#>=, #>, #<=, #<): Make use of Hash#>=, #>, #<, and
#<= when comparing against an instance of the same kind. git-svn-id: svn+ssh://ci.ruby-lang.org/ruby/trunk@52586 b2dd03c8-39d4-4d8f-98ff-823fe69b080e
Diffstat (limited to 'test/test_set.rb')
-rw-r--r--test/test_set.rb73
1 files changed, 42 insertions, 31 deletions
diff --git a/test/test_set.rb b/test/test_set.rb
index 854bcc637b..66944f576f 100644
--- a/test/test_set.rb
+++ b/test/test_set.rb
@@ -2,6 +2,9 @@ require 'test/unit'
require 'set'
class TC_Set < Test::Unit::TestCase
+ class Set2 < Set
+ end
+
def test_aref
assert_nothing_raised {
Set[]
@@ -211,16 +214,18 @@ class TC_Set < Test::Unit::TestCase
set.superset?([2])
}
- assert_equal(true, set.superset?(Set[]))
- assert_equal(true, set.superset?(Set[1,2]))
- assert_equal(true, set.superset?(Set[1,2,3]))
- assert_equal(false, set.superset?(Set[1,2,3,4]))
- assert_equal(false, set.superset?(Set[1,4]))
+ [Set, Set2].each { |klass|
+ assert_equal(true, set.superset?(klass[]), klass.name)
+ assert_equal(true, set.superset?(klass[1,2]), klass.name)
+ assert_equal(true, set.superset?(klass[1,2,3]), klass.name)
+ assert_equal(false, set.superset?(klass[1,2,3,4]), klass.name)
+ assert_equal(false, set.superset?(klass[1,4]), klass.name)
- assert_equal(true, set >= Set[1,2,3])
- assert_equal(true, set >= Set[1,2])
+ assert_equal(true, set >= klass[1,2,3], klass.name)
+ assert_equal(true, set >= klass[1,2], klass.name)
- assert_equal(true, Set[].superset?(Set[]))
+ assert_equal(true, Set[].superset?(klass[]), klass.name)
+ }
end
def test_proper_superset?
@@ -238,16 +243,18 @@ class TC_Set < Test::Unit::TestCase
set.proper_superset?([2])
}
- assert_equal(true, set.proper_superset?(Set[]))
- assert_equal(true, set.proper_superset?(Set[1,2]))
- assert_equal(false, set.proper_superset?(Set[1,2,3]))
- assert_equal(false, set.proper_superset?(Set[1,2,3,4]))
- assert_equal(false, set.proper_superset?(Set[1,4]))
+ [Set, Set2].each { |klass|
+ assert_equal(true, set.proper_superset?(klass[]), klass.name)
+ assert_equal(true, set.proper_superset?(klass[1,2]), klass.name)
+ assert_equal(false, set.proper_superset?(klass[1,2,3]), klass.name)
+ assert_equal(false, set.proper_superset?(klass[1,2,3,4]), klass.name)
+ assert_equal(false, set.proper_superset?(klass[1,4]), klass.name)
- assert_equal(false, set > Set[1,2,3])
- assert_equal(true, set > Set[1,2])
+ assert_equal(false, set > klass[1,2,3], klass.name)
+ assert_equal(true, set > klass[1,2], klass.name)
- assert_equal(false, Set[].proper_superset?(Set[]))
+ assert_equal(false, Set[].proper_superset?(klass[]), klass.name)
+ }
end
def test_subset?
@@ -265,16 +272,18 @@ class TC_Set < Test::Unit::TestCase
set.subset?([2])
}
- assert_equal(true, set.subset?(Set[1,2,3,4]))
- assert_equal(true, set.subset?(Set[1,2,3]))
- assert_equal(false, set.subset?(Set[1,2]))
- assert_equal(false, set.subset?(Set[]))
+ [Set, Set2].each { |klass|
+ assert_equal(true, set.subset?(klass[1,2,3,4]), klass.name)
+ assert_equal(true, set.subset?(klass[1,2,3]), klass.name)
+ assert_equal(false, set.subset?(klass[1,2]), klass.name)
+ assert_equal(false, set.subset?(klass[]), klass.name)
- assert_equal(true, set <= Set[1,2,3])
- assert_equal(true, set <= Set[1,2,3,4])
+ assert_equal(true, set <= klass[1,2,3], klass.name)
+ assert_equal(true, set <= klass[1,2,3,4], klass.name)
- assert_equal(true, Set[].subset?(Set[1]))
- assert_equal(true, Set[].subset?(Set[]))
+ assert_equal(true, Set[].subset?(klass[1]), klass.name)
+ assert_equal(true, Set[].subset?(klass[]), klass.name)
+ }
end
def test_proper_subset?
@@ -292,15 +301,17 @@ class TC_Set < Test::Unit::TestCase
set.proper_subset?([2])
}
- assert_equal(true, set.proper_subset?(Set[1,2,3,4]))
- assert_equal(false, set.proper_subset?(Set[1,2,3]))
- assert_equal(false, set.proper_subset?(Set[1,2]))
- assert_equal(false, set.proper_subset?(Set[]))
+ [Set, Set2].each { |klass|
+ assert_equal(true, set.proper_subset?(klass[1,2,3,4]), klass.name)
+ assert_equal(false, set.proper_subset?(klass[1,2,3]), klass.name)
+ assert_equal(false, set.proper_subset?(klass[1,2]), klass.name)
+ assert_equal(false, set.proper_subset?(klass[]), klass.name)
- assert_equal(false, set < Set[1,2,3])
- assert_equal(true, set < Set[1,2,3,4])
+ assert_equal(false, set < klass[1,2,3], klass.name)
+ assert_equal(true, set < klass[1,2,3,4], klass.name)
- assert_equal(false, Set[].proper_subset?(Set[]))
+ assert_equal(false, Set[].proper_subset?(klass[]), klass.name)
+ }
end
def assert_intersect(expected, set, other)