diff options
author | Felix Mulder <felix.mulder@gmail.com> | 2017-04-13 17:38:34 +0200 |
---|---|---|
committer | Felix Mulder <felix.mulder@gmail.com> | 2017-04-13 17:57:14 +0200 |
commit | 623a1d43155823cc7506c3223405bb68f459fd50 (patch) | |
tree | 7fb85efa08e5b2afed7499eddcde73927c081a45 /tests/run/t6253c.scala | |
parent | 0fe56ea73e6775a315f54772dc6bfb40815c7c98 (diff) | |
download | dotty-623a1d43155823cc7506c3223405bb68f459fd50.tar.gz dotty-623a1d43155823cc7506c3223405bb68f459fd50.tar.bz2 dotty-623a1d43155823cc7506c3223405bb68f459fd50.zip |
Fix #2220: disable benchmarks, set run timeout to 30 seconds
Diffstat (limited to 'tests/run/t6253c.scala')
-rw-r--r-- | tests/run/t6253c.scala | 63 |
1 files changed, 0 insertions, 63 deletions
diff --git a/tests/run/t6253c.scala b/tests/run/t6253c.scala deleted file mode 100644 index 39c3a5b17..000000000 --- a/tests/run/t6253c.scala +++ /dev/null @@ -1,63 +0,0 @@ -import scala.collection.immutable.HashSet - -object Test extends dotty.runtime.LegacyApp { - - var hashCount = 0 - - /** - * A key that produces lots of hash collisions, to exercise the part of the code that deals with those - */ - case class Collision(value: Int) { - - override def hashCode = { - hashCount += 1 - value / 5 - } - } - - /** - * A key that is identical to int other than that it counts hashCode invocations - */ - case class HashCounter(value: Int) { - - override def hashCode = { - hashCount += 1 - value - } - } - - def testDiff[T](sizes: Seq[Int], offsets: Seq[Double], keyType: String, mkKey: Int => T): Unit = { - for { - i <- sizes - o <- offsets - } { - val e = HashSet.empty[T] - val j = (i * o).toInt - // create two sets of size i with overlap o - val a = e ++ (0 until i).map(mkKey) - require(a.size == i, s"Building HashSet of size $i failed. Key type $keyType.") - val b = e ++ (j until (i + j)).map(mkKey) - require(b.size == i, s"Building HashSet of size $i failed. Key type $keyType.") - val as = e ++ (0 until j).map(mkKey) - require(as.size == j, s"Building HashSet of size $j failed. Key type $keyType.") - val hashCount0 = hashCount - val u = a diff b - require(hashCount == hashCount0, s"key.hashCode should not be called, but has been called ${hashCount - hashCount0} times. Key type $keyType.") - require(u == (a diff scala.collection.mutable.HashSet(b.toSeq: _*)), s"Operation must still work for other sets!") - require(u.size == j, s"Expected size $j. Real size ${u.size}. Key type $keyType.") - for (x <- 0 until j) - require(u.contains(mkKey(x)), s"Key type $keyType. Set (0 until ${i + j}) should contain $x but does not.") - require((as intersect b).isEmpty) - val b_as = b diff as - val as_b = as diff b - require((b_as eq b) || (b_as eq as), s"No structural sharing in b diff as. Key type $keyType, b=($j until ${i + j}) as=(0 until $j)") - require((as_b eq b) || (as_b eq as), s"No structural sharing in as diff b. Key type $keyType, b=($j until ${i + j}) as=(0 until $j)") - } - } - - val sizes = Seq(1, 10, 100, 1000, 10000, 100000) - val offsets = Seq(0.0, 0.25, 0.5, 0.75, 1.0) - testDiff(sizes, offsets, "int", identity[Int]) - testDiff(sizes, offsets, "hashCounter", HashCounter.apply) - testDiff(sizes, offsets, "collision", Collision.apply) -} |