diff options
Diffstat (limited to 'test')
-rw-r--r-- | test/files/neg/t5666.check | 36 | ||||
-rw-r--r-- | test/files/run/caseClassHash.scala | 4 | ||||
-rw-r--r-- | test/files/run/repl-colon-type.check | 16 | ||||
-rw-r--r-- | test/files/run/repl-type-verbose.check | 32 | ||||
-rw-r--r-- | test/files/run/t5867.check | 1 | ||||
-rw-r--r-- | test/files/run/t5867.scala | 14 | ||||
-rw-r--r-- | test/files/run/t5879.check | 16 | ||||
-rw-r--r-- | test/files/run/t5879.scala | 74 | ||||
-rw-r--r-- | test/files/run/t5880.scala | 41 | ||||
-rw-r--r-- | test/pending/specialized/SI-5005.check (renamed from test/files/specialized/SI-5005.check) | 0 | ||||
-rw-r--r-- | test/pending/specialized/SI-5005.scala (renamed from test/files/specialized/SI-5005.scala) | 9 |
11 files changed, 204 insertions, 39 deletions
diff --git a/test/files/neg/t5666.check b/test/files/neg/t5666.check index 4289b00ade..1c714796ba 100644 --- a/test/files/neg/t5666.check +++ b/test/files/neg/t5666.check @@ -4,33 +4,33 @@ t5666.scala:2: error: class Any is abstract; cannot be instantiated t5666.scala:3: error: class AnyVal is abstract; cannot be instantiated new AnyVal ^ -t5666.scala:4: error: Double does not have a constructor +t5666.scala:4: error: class Double is abstract; cannot be instantiated new Double - ^ -t5666.scala:5: error: Float does not have a constructor + ^ +t5666.scala:5: error: class Float is abstract; cannot be instantiated new Float - ^ -t5666.scala:6: error: Long does not have a constructor + ^ +t5666.scala:6: error: class Long is abstract; cannot be instantiated new Long - ^ -t5666.scala:7: error: Int does not have a constructor + ^ +t5666.scala:7: error: class Int is abstract; cannot be instantiated new Int - ^ -t5666.scala:8: error: Char does not have a constructor + ^ +t5666.scala:8: error: class Char is abstract; cannot be instantiated new Char - ^ -t5666.scala:9: error: Short does not have a constructor + ^ +t5666.scala:9: error: class Short is abstract; cannot be instantiated new Short - ^ -t5666.scala:10: error: Byte does not have a constructor + ^ +t5666.scala:10: error: class Byte is abstract; cannot be instantiated new Byte - ^ -t5666.scala:11: error: Boolean does not have a constructor + ^ +t5666.scala:11: error: class Boolean is abstract; cannot be instantiated new Boolean - ^ -t5666.scala:12: error: Unit does not have a constructor + ^ +t5666.scala:12: error: class Unit is abstract; cannot be instantiated new Unit - ^ + ^ t5666.scala:13: error: class Nothing is abstract; cannot be instantiated new Nothing ^ diff --git a/test/files/run/caseClassHash.scala b/test/files/run/caseClassHash.scala index 7adfddedf8..c5cb09c355 100644 --- a/test/files/run/caseClassHash.scala +++ b/test/files/run/caseClassHash.scala @@ -11,8 +11,8 @@ object Test { println("## method 1: " + foo1.##) println("## method 2: " + foo2.##) - println(" Murmur 1: " + scala.util.MurmurHash3.productHash(foo1)) - println(" Murmur 2: " + scala.util.MurmurHash3.productHash(foo2)) + println(" Murmur 1: " + scala.util.hashing.MurmurHash3.productHash(foo1)) + println(" Murmur 2: " + scala.util.hashing.MurmurHash3.productHash(foo2)) } } diff --git a/test/files/run/repl-colon-type.check b/test/files/run/repl-colon-type.check index cb0b9a6c8b..35cd04ba87 100644 --- a/test/files/run/repl-colon-type.check +++ b/test/files/run/repl-colon-type.check @@ -82,8 +82,10 @@ TypeRef( TypeRef( TypeSymbol(abstract trait Function1[-T1, +R] extends Object) args = List( - TypeRef(TypeSymbol(final class Int extends AnyVal)) - TypeRef(TypeSymbol(final class Boolean extends AnyVal)) + TypeRef(TypeSymbol(final abstract class Int extends AnyVal)) + TypeRef( + TypeSymbol(final abstract class Boolean extends AnyVal) + ) ) ) TypeRef( @@ -92,7 +94,7 @@ TypeRef( ) args = List( - TypeRef(TypeSymbol(final class Int extends AnyVal)) + TypeRef(TypeSymbol(final abstract class Int extends AnyVal)) ) ) ) @@ -125,14 +127,14 @@ scala> :type -v def x = 1 ; def bar[T >: Null <: AnyRef](xyz: T) = 5 OverloadedType( alts = List( NullaryMethodType( - TypeRef(TypeSymbol(final class Int extends AnyVal)) + TypeRef(TypeSymbol(final abstract class Int extends AnyVal)) ) PolyType( typeParams = List(TypeParam(T >: Null <: AnyRef)) resultType = MethodType( params = List(TermSymbol(xyz: T)) resultType = TypeRef( - TypeSymbol(final class Int extends AnyVal) + TypeSymbol(final abstract class Int extends AnyVal) ) ) ) @@ -147,7 +149,7 @@ Int => Iterator[List[Nothing]] TypeRef( TypeSymbol(abstract trait Function1[-T1, +R] extends Object) args = List( - TypeRef(TypeSymbol(final class Int extends AnyVal)) + TypeRef(TypeSymbol(final abstract class Int extends AnyVal)) TypeRef( TypeSymbol( abstract trait Iterator[+A] extends TraversableOnce[A] @@ -180,7 +182,7 @@ PolyType( TypeRef( TypeSymbol(abstract trait Function1[-T1, +R] extends Object) args = List( - TypeRef(TypeSymbol(final class Int extends AnyVal)) + TypeRef(TypeSymbol(final abstract class Int extends AnyVal)) TypeRef( TypeSymbol( abstract trait Iterator[+A] extends TraversableOnce[A] diff --git a/test/files/run/repl-type-verbose.check b/test/files/run/repl-type-verbose.check index 103ac3e64d..989c0735b0 100644 --- a/test/files/run/repl-type-verbose.check +++ b/test/files/run/repl-type-verbose.check @@ -11,7 +11,7 @@ scala> :type -v def f = 5 // Internal Type structure NullaryMethodType( - TypeRef(TypeSymbol(final class Int extends AnyVal)) + TypeRef(TypeSymbol(final abstract class Int extends AnyVal)) ) scala> :type -v def f() = 5 @@ -20,7 +20,9 @@ scala> :type -v def f() = 5 // Internal Type structure NullaryMethodType( - resultType = TypeRef(TypeSymbol(final class Int extends AnyVal)) + resultType = TypeRef( + TypeSymbol(final abstract class Int extends AnyVal) + ) ) scala> :type -v def f[T] = 5 @@ -31,7 +33,7 @@ scala> :type -v def f[T] = 5 PolyType( typeParams = List(TypeParam(T)) resultType = NullaryMethodType( - TypeRef(TypeSymbol(final class Int extends AnyVal)) + TypeRef(TypeSymbol(final abstract class Int extends AnyVal)) ) ) @@ -43,7 +45,7 @@ scala> :type -v def f[T >: Null] = 5 PolyType( typeParams = List(TypeParam(T >: Null)) resultType = NullaryMethodType( - TypeRef(TypeSymbol(final class Int extends AnyVal)) + TypeRef(TypeSymbol(final abstract class Int extends AnyVal)) ) ) @@ -55,7 +57,7 @@ scala> :type -v def f[T <: String] = 5 PolyType( typeParams = List(TypeParam(T <: String)) resultType = NullaryMethodType( - TypeRef(TypeSymbol(final class Int extends AnyVal)) + TypeRef(TypeSymbol(final abstract class Int extends AnyVal)) ) ) @@ -67,7 +69,9 @@ scala> :type -v def f[T]() = 5 PolyType( typeParams = List(TypeParam(T)) resultType = NullaryMethodType( - resultType = TypeRef(TypeSymbol(final class Int extends AnyVal)) + resultType = TypeRef( + TypeSymbol(final abstract class Int extends AnyVal) + ) ) ) @@ -79,7 +83,9 @@ scala> :type -v def f[T, U]() = 5 PolyType( typeParams = List(TypeParam(T), TypeParam(U)) resultType = NullaryMethodType( - resultType = TypeRef(TypeSymbol(final class Int extends AnyVal)) + resultType = TypeRef( + TypeSymbol(final abstract class Int extends AnyVal) + ) ) ) @@ -93,7 +99,7 @@ PolyType( resultType = NullaryMethodType( resultType = NullaryMethodType( resultType = TypeRef( - TypeSymbol(final class Int extends AnyVal) + TypeSymbol(final abstract class Int extends AnyVal) ) ) ) @@ -107,7 +113,7 @@ scala> :type -v def f[T, U <: T] = 5 PolyType( typeParams = List(TypeParam(T), TypeParam(U <: T)) resultType = NullaryMethodType( - TypeRef(TypeSymbol(final class Int extends AnyVal)) + TypeRef(TypeSymbol(final abstract class Int extends AnyVal)) ) ) @@ -123,7 +129,7 @@ PolyType( resultType = MethodType( params = List(TermSymbol(y: U)) resultType = TypeRef( - TypeSymbol(final class Int extends AnyVal) + TypeSymbol(final abstract class Int extends AnyVal) ) ) ) @@ -138,7 +144,9 @@ PolyType( typeParams = List(TypeParam(T)) resultType = MethodType( params = List(TermSymbol(implicit evidence$1: Ordering[T])) - resultType = TypeRef(TypeSymbol(final class Int extends AnyVal)) + resultType = TypeRef( + TypeSymbol(final abstract class Int extends AnyVal) + ) ) ) @@ -177,7 +185,7 @@ PolyType( ) ) resultType = NullaryMethodType( - TypeRef(TypeSymbol(final class Int extends AnyVal)) + TypeRef(TypeSymbol(final abstract class Int extends AnyVal)) ) ) diff --git a/test/files/run/t5867.check b/test/files/run/t5867.check new file mode 100644 index 0000000000..e1811eeefa --- /dev/null +++ b/test/files/run/t5867.check @@ -0,0 +1 @@ +UnrolledBuffer(1, 2, 3, 4, 5, 6, 7, 8, 9, 10, 11, 12, 13, 14, 15, 16, 17, 18, 19, 20, 21, 22, 23, 24, 25, 26, 27, 28, 29, 30, 31, 32, 33, 34, 35, 36, 37, 38, 39, 40, 41, 42, 43, 44, 45, 46, 47, 48, 49, 50, 1, 2, 3, 4, 5, 6, 7, 8, 9, 10, 11, 12, 13, 14, 15, 16, 17, 18, 19, 20, 21, 22, 23, 24, 25, 26, 27, 28, 29, 30, 31, 32, 33, 34, 35, 36, 37, 38, 39, 40, 41, 42, 43, 44, 45, 46, 47, 48, 49, 50)
\ No newline at end of file diff --git a/test/files/run/t5867.scala b/test/files/run/t5867.scala new file mode 100644 index 0000000000..6a86ac3e6d --- /dev/null +++ b/test/files/run/t5867.scala @@ -0,0 +1,14 @@ +import collection.mutable.UnrolledBuffer + + + +object Test { + + def main(args: Array[String]) { + val buf = UnrolledBuffer(1 to 50: _*) + val dub = buf ++ buf + + println(dub) + } + +} diff --git a/test/files/run/t5879.check b/test/files/run/t5879.check new file mode 100644 index 0000000000..b6cbda35a7 --- /dev/null +++ b/test/files/run/t5879.check @@ -0,0 +1,16 @@ +Map(1 -> 1) +1 +Map(1 -> 1) +1 +(1,1) +Map(1 -> 1) +1 +(1,1) +Map(1 -> 1) +1 +(1,2) +Map(1 -> 2) +2 +(1,2) +Map(1 -> 2) +2
\ No newline at end of file diff --git a/test/files/run/t5879.scala b/test/files/run/t5879.scala new file mode 100644 index 0000000000..e1c07fc4c2 --- /dev/null +++ b/test/files/run/t5879.scala @@ -0,0 +1,74 @@ +import collection.immutable.HashMap + + +object Test { + + def main(args: Array[String]) { + resolveDefault() + resolveFirst() + resolveSecond() + resolveMany() + } + + def resolveDefault() { + val a = HashMap(1 -> "1") + val b = HashMap(1 -> "2") + + val r = a.merged(b)(null) + println(r) + println(r(1)) + + val rold = a.merge(b) + println(rold) + println(rold(1)) + } + + def resolveFirst() { + val a = HashMap(1 -> "1") + val b = HashMap(1 -> "2") + def collision(a: (Int, String), b: (Int, String)) = { + println(a) + a + } + + val r = a.merged(b) { collision } + println(r) + println(r(1)) + + val rold = a.merge(b, collision) + println(rold) + println(rold(1)) + } + + def resolveSecond() { + val a = HashMap(1 -> "1") + val b = HashMap(1 -> "2") + def collision(a: (Int, String), b: (Int, String)) = { + println(b) + b + } + + val r = a.merged(b) { collision } + println(r) + println(r(1)) + + val rold = a.merge(b, collision) + println(rold) + println(rold(1)) + } + + def resolveMany() { + val a = HashMap((0 until 100) zip (0 until 100): _*) + val b = HashMap((0 until 100) zip (100 until 200): _*) + def collision(a: (Int, Int), b: (Int, Int)) = { + (a._1, a._2 + b._2) + } + + val r = a.merged(b) { collision } + for ((k, v) <- r) assert(v == 100 + 2 * k, (k, v)) + + val rold = a.merge(b, collision) + for ((k, v) <- r) assert(v == 100 + 2 * k, (k, v)) + } + +} diff --git a/test/files/run/t5880.scala b/test/files/run/t5880.scala new file mode 100644 index 0000000000..4cda599f79 --- /dev/null +++ b/test/files/run/t5880.scala @@ -0,0 +1,41 @@ + + +import scala.collection.JavaConversions._ + + + +object Test { + + def main(args:Array[String]) = { + val tests = 5000 + val jm: java.util.Map[Int, Int] = scala.collection.mutable.Map((0 until tests) zip (0 until tests).reverse: _*) + val es = jm.entrySet() + val it = es.iterator + + // chi square test + val groups = 10 + val hits = new Array[Int](groups) + def hit(hc: Int) { + val bucket = math.abs(hc) / (Int.MaxValue / groups) + hits(bucket) += 1 + } + def expected = tests / groups + def Dstat = { + val diffs = for (i <- 0 until groups) yield math.abs(hits(i) - expected) + diffs.sum.toDouble / expected + } + def ChiSquare = { + val diffs = for (i <- 0 until groups) yield (hits(i) - expected) * (hits(i) - expected) + diffs.sum.toDouble / expected + } + + while (it.hasNext) { + val x = it.next() + hit(x.##) + } + // println(hits.toBuffer) + // println(ChiSquare) + assert(ChiSquare < 4.0, ChiSquare + " -> " + hits.mkString(", ")) + } + +} diff --git a/test/files/specialized/SI-5005.check b/test/pending/specialized/SI-5005.check index 81e8342dad..81e8342dad 100644 --- a/test/files/specialized/SI-5005.check +++ b/test/pending/specialized/SI-5005.check diff --git a/test/files/specialized/SI-5005.scala b/test/pending/specialized/SI-5005.scala index 3d1ada49e2..280bf0aa2d 100644 --- a/test/files/specialized/SI-5005.scala +++ b/test/pending/specialized/SI-5005.scala @@ -1,6 +1,15 @@ import scala.tools.partest._ import java.io._ + + +// I think this may be due to a bug in partest where it uses some other version +// of the scala-library.jar - _hashCode is in line 202 currently, not 212! +// +// [partest] testing: [...]/files/specialized/SI-5005.scala [FAILED] +// [partest] java.lang.NoClassDefFoundError: scala/util/MurmurHash3$ +// [partest] java.lang.NoClassDefFoundError: scala/util/MurmurHash3$ +// [partest] at scala.runtime.ScalaRunTime$._hashCode(ScalaRunTime.scala:212) object Test extends DirectTest { override def extraSettings: String = "-usejavacp -Xprint:spec -optimize -Ylog:inliner -d " + testOutput.path |