Move some tests from boxWithStdlib/ to box/
Move those tests which do not require neither stdlib nor reflect
This commit is contained in:
committed by
Alexander Udalov
parent
54a615fcd3
commit
20e36438e2
@@ -1,10 +0,0 @@
|
||||
data class A(val x: Array<Int>, val y: IntArray)
|
||||
|
||||
fun foo(x: Array<Int>, y: IntArray) = A(x, y)
|
||||
|
||||
fun box(): String {
|
||||
val a = Array<Int>(0, {0})
|
||||
val b = IntArray(0)
|
||||
val (x, y) = foo(a, b)
|
||||
return if (a == x && b == y) "OK" else "Fail"
|
||||
}
|
||||
@@ -1,8 +0,0 @@
|
||||
data class A(var string: String)
|
||||
|
||||
fun box(): String {
|
||||
val a = A("Fail")
|
||||
a.string = "OK"
|
||||
val (result) = a
|
||||
return result
|
||||
}
|
||||
-29
@@ -1,29 +0,0 @@
|
||||
data class A(val a: Int = 1, val b: String = "$a") {}
|
||||
|
||||
fun box() : String {
|
||||
var result = ""
|
||||
val a = A()
|
||||
val b = a.copy()
|
||||
if (b.a == 1 && b.b == "1") {
|
||||
result += "1"
|
||||
}
|
||||
|
||||
val c = a.copy(a = 2)
|
||||
if (c.a == 2 && c.b == "1") {
|
||||
result += "2"
|
||||
}
|
||||
|
||||
val d = a.copy(b = "2")
|
||||
if (d.a == 1 && d.b == "2") {
|
||||
result += "3"
|
||||
}
|
||||
|
||||
val e = a.copy(a = 2, b = "2")
|
||||
if (e.a == 2 && e.b == "2") {
|
||||
result += "4"
|
||||
}
|
||||
if (result == "1234") {
|
||||
return "OK"
|
||||
}
|
||||
return "fail"
|
||||
}
|
||||
-17
@@ -1,17 +0,0 @@
|
||||
class Bar(val name: String)
|
||||
|
||||
abstract class Foo {
|
||||
public abstract fun foo(): String
|
||||
}
|
||||
|
||||
fun box(): String {
|
||||
return object: Foo() {
|
||||
inner class NestedFoo(val bar: Bar) {
|
||||
fun copy(bar: Bar) = NestedFoo(bar)
|
||||
}
|
||||
|
||||
override fun foo(): String {
|
||||
return NestedFoo(Bar("Fail")).copy(bar = Bar("OK")).bar.name
|
||||
}
|
||||
}.foo()
|
||||
}
|
||||
@@ -1,10 +0,0 @@
|
||||
data class A(val a: Double, val b: Double)
|
||||
|
||||
fun box() : String {
|
||||
val a = A(1.0, 1.0)
|
||||
val b = a.copy()
|
||||
if (b.a == 1.0 && b.b == 1.0) {
|
||||
return "OK"
|
||||
}
|
||||
return "fail"
|
||||
}
|
||||
-29
@@ -1,29 +0,0 @@
|
||||
data class A(val a: Int, val b: String) {}
|
||||
|
||||
fun box() : String {
|
||||
var result = ""
|
||||
val a = A(1, "a")
|
||||
val b = a.copy()
|
||||
if (b.a == 1 && b.b == "a") {
|
||||
result += "1"
|
||||
}
|
||||
|
||||
val c = a.copy(a = 2)
|
||||
if (c.a == 2 && c.b == "a") {
|
||||
result += "2"
|
||||
}
|
||||
|
||||
val d = a.copy(b = "b")
|
||||
if (d.a == 1 && d.b == "b") {
|
||||
result += "3"
|
||||
}
|
||||
|
||||
val e = a.copy(a = 2, b = "b")
|
||||
if (e.a == 2 && e.b == "b") {
|
||||
result += "4"
|
||||
}
|
||||
if (result == "1234") {
|
||||
return "OK"
|
||||
}
|
||||
return "fail"
|
||||
}
|
||||
-29
@@ -1,29 +0,0 @@
|
||||
data class A(var a: Int, var b: String) {}
|
||||
|
||||
fun box() : String {
|
||||
var result = ""
|
||||
val a = A(1, "a")
|
||||
val b = a.copy()
|
||||
if (b.a == 1 && b.b == "a") {
|
||||
result += "1"
|
||||
}
|
||||
|
||||
val c = a.copy(a = 2)
|
||||
if (c.a == 2 && c.b == "a") {
|
||||
result += "2"
|
||||
}
|
||||
|
||||
val d = a.copy(b = "b")
|
||||
if (d.a == 1 && d.b == "b") {
|
||||
result += "3"
|
||||
}
|
||||
|
||||
val e = a.copy(a = 2, b = "b")
|
||||
if (e.a == 2 && e.b == "b") {
|
||||
result += "4"
|
||||
}
|
||||
if (result == "1234") {
|
||||
return "OK"
|
||||
}
|
||||
return "fail"
|
||||
}
|
||||
-14
@@ -1,14 +0,0 @@
|
||||
data class A(val a: Foo<String>) {}
|
||||
|
||||
class Foo<T>(val a: T) { }
|
||||
|
||||
fun box() : String {
|
||||
val f1 = Foo("a")
|
||||
val f2 = Foo("b")
|
||||
val a = A(f1)
|
||||
val b = a.copy(f2)
|
||||
if (b.a.a == "b") {
|
||||
return "OK"
|
||||
}
|
||||
return "fail"
|
||||
}
|
||||
@@ -1,30 +0,0 @@
|
||||
import java.util.HashSet
|
||||
|
||||
val NAN = java.lang.Double.NaN
|
||||
|
||||
data class A(val x: Double)
|
||||
|
||||
fun box(): String {
|
||||
if (A(+0.0) == A(-0.0)) return "Fail: +0.0 == -0.0"
|
||||
if (A(+0.0).hashCode() == A(-0.0).hashCode()) return "Fail: hash(+0.0) == hash(-0.0)"
|
||||
|
||||
if (A(NAN) != A(NAN)) return "Fail: NaN != NaN"
|
||||
if (A(NAN).hashCode() != A(NAN).hashCode()) return "Fail: hash(NaN) != hash(NaN)"
|
||||
|
||||
val s = HashSet<A>()
|
||||
for (times in 1..5) {
|
||||
s.add(A(3.14))
|
||||
s.add(A(+0.0))
|
||||
s.add(A(-0.0))
|
||||
s.add(A(-2.72))
|
||||
s.add(A(NAN))
|
||||
}
|
||||
|
||||
if (A(3.14) !in s) return "Fail: 3.14 not found"
|
||||
if (A(+0.0) !in s) return "Fail: +0.0 not found"
|
||||
if (A(-0.0) !in s) return "Fail: -0.0 not found"
|
||||
if (A(-2.72) !in s) return "Fail: -2.72 not found"
|
||||
if (A(NAN) !in s) return "Fail: NaN not found"
|
||||
|
||||
return if (s.size == 5) "OK" else "Fail $s"
|
||||
}
|
||||
@@ -1,8 +0,0 @@
|
||||
data class A(val x: Int) {
|
||||
override fun equals(other: Any?): Boolean = false
|
||||
}
|
||||
|
||||
fun box(): String {
|
||||
val a = A(0)
|
||||
return if (a.equals(a)) "fail" else "OK"
|
||||
}
|
||||
@@ -1,8 +0,0 @@
|
||||
data class A(val v: Array<Int>)
|
||||
|
||||
fun box() : String {
|
||||
val myArray = arrayOf(0, 1, 2)
|
||||
if(A(myArray) == A(arrayOf(0, 1, 2))) return "fail"
|
||||
if(A(myArray) != A(myArray)) return "fail 2"
|
||||
return "OK"
|
||||
}
|
||||
@@ -1,8 +0,0 @@
|
||||
data class A(val v: IntArray)
|
||||
|
||||
fun box() : String {
|
||||
val myArray = intArrayOf(0, 1, 2)
|
||||
if(A(myArray) == A(intArrayOf(0, 1, 2))) return "fail"
|
||||
if(A(myArray) != A(myArray)) return "fail 2"
|
||||
return "OK"
|
||||
}
|
||||
@@ -1,11 +0,0 @@
|
||||
class Dummy {
|
||||
override fun equals(other: Any?) = true
|
||||
}
|
||||
|
||||
data class A(val v: Any?)
|
||||
|
||||
fun box() : String {
|
||||
val a = A(Dummy())
|
||||
val b: A? = null
|
||||
return if(a != b && b != a) "OK" else "fail"
|
||||
}
|
||||
@@ -1,7 +0,0 @@
|
||||
data class A(val arg: Any? = null)
|
||||
|
||||
fun box() : String {
|
||||
val a = A()
|
||||
val b = a
|
||||
return if(b == a) "OK" else "fail"
|
||||
}
|
||||
@@ -1,30 +0,0 @@
|
||||
import java.util.HashSet
|
||||
|
||||
val NAN = java.lang.Float.NaN
|
||||
|
||||
data class A(val x: Float)
|
||||
|
||||
fun box(): String {
|
||||
if (A(+0f) == A(-0f)) return "Fail: +0 == -0"
|
||||
if (A(+0f).hashCode() == A(-0f).hashCode()) return "Fail: hash(+0) == hash(-0)"
|
||||
|
||||
if (A(NAN) != A(NAN)) return "Fail: NaN != NaN"
|
||||
if (A(NAN).hashCode() != A(NAN).hashCode()) return "Fail: hash(NaN) != hash(NaN)"
|
||||
|
||||
val s = HashSet<A>()
|
||||
for (times in 1..5) {
|
||||
s.add(A(3.14f))
|
||||
s.add(A(+0f))
|
||||
s.add(A(-0f))
|
||||
s.add(A(-2.72f))
|
||||
s.add(A(NAN))
|
||||
}
|
||||
|
||||
if (A(3.14f) !in s) return "Fail: 3.14 not found"
|
||||
if (A(+0f) !in s) return "Fail: +0 not found"
|
||||
if (A(-0f) !in s) return "Fail: -0 not found"
|
||||
if (A(-2.72f) !in s) return "Fail: -2.72 not found"
|
||||
if (A(NAN) !in s) return "Fail: NaN not found"
|
||||
|
||||
return if (s.size == 5) "OK" else "Fail $s"
|
||||
}
|
||||
@@ -1,12 +0,0 @@
|
||||
data class A<T>(val x: T)
|
||||
|
||||
fun box(): String {
|
||||
val a = A(42)
|
||||
if (a.component1() != 42) return "Fail a: ${a.component1()}"
|
||||
|
||||
val b = A(239.toLong())
|
||||
if (b.component1() != 239.toLong()) return "Fail b: ${b.component1()}"
|
||||
|
||||
val c = A("OK")
|
||||
return c.component1()
|
||||
}
|
||||
-7
@@ -1,7 +0,0 @@
|
||||
data class A(val x: Int) {
|
||||
override fun hashCode(): Int = -3
|
||||
}
|
||||
|
||||
fun box(): String {
|
||||
return if (A(0).hashCode() == -3) "OK" else "fail"
|
||||
}
|
||||
@@ -1,6 +0,0 @@
|
||||
data class A(val a: IntArray, var b: Array<String>)
|
||||
|
||||
fun box() : String {
|
||||
if( A(intArrayOf(1,2,3),arrayOf("239")).hashCode() != 31*java.util.Arrays.hashCode(intArrayOf(0,1,2)) + "239".hashCode()) "fail"
|
||||
return "OK"
|
||||
}
|
||||
@@ -1,5 +0,0 @@
|
||||
data class A(val a: Boolean)
|
||||
|
||||
fun box() : String {
|
||||
return if( A(true).hashCode()==1 && A(false).hashCode()==0 ) "OK" else "fail"
|
||||
}
|
||||
@@ -1,7 +0,0 @@
|
||||
data class A(val a: Byte)
|
||||
|
||||
fun box() : String {
|
||||
val v1 = A(10.toByte()).hashCode()
|
||||
val v2 = (10.toByte() as Byte?)!!.hashCode()
|
||||
return if( v1 == v2 ) "OK" else "$v1 $v2"
|
||||
}
|
||||
@@ -1,7 +0,0 @@
|
||||
data class A(val a: Char)
|
||||
|
||||
fun box() : String {
|
||||
val v1 = A('a').hashCode()
|
||||
val v2 = ('a' as Char?)!!.hashCode()
|
||||
return if( v1 == v2 ) "OK" else "$v1 $v2"
|
||||
}
|
||||
@@ -1,7 +0,0 @@
|
||||
data class A(val a: Double)
|
||||
|
||||
fun box() : String {
|
||||
val v1 = A(-10.toDouble()).hashCode()
|
||||
val v2 = (-10.toDouble() as Double?)!!.hashCode()
|
||||
return if( v1 == v2 ) "OK" else "$v1 $v2"
|
||||
}
|
||||
@@ -1,7 +0,0 @@
|
||||
data class A(val a: Float)
|
||||
|
||||
fun box() : String {
|
||||
val v1 = A(-10.toFloat()).hashCode()
|
||||
val v2 = (-10.toFloat() as Float?)!!.hashCode()
|
||||
return if( v1 == v2 ) "OK" else "$v1 $v2"
|
||||
}
|
||||
@@ -1,7 +0,0 @@
|
||||
data class A<T>(val t: T)
|
||||
|
||||
fun box(): String {
|
||||
val h = A<String?>(null).hashCode()
|
||||
if (h != 0) return "Fail $h"
|
||||
return "OK"
|
||||
}
|
||||
@@ -1,7 +0,0 @@
|
||||
data class A(val a: Int)
|
||||
|
||||
fun box() : String {
|
||||
val v1 = A(-10.toInt()).hashCode()
|
||||
val v2 = (-10.toInt() as Int?)!!.hashCode()
|
||||
return if( v1 == v2 ) "OK" else "$v1 $v2"
|
||||
}
|
||||
@@ -1,7 +0,0 @@
|
||||
data class A(val a: Long)
|
||||
|
||||
fun box() : String {
|
||||
val v1 = A(-10.toLong()).hashCode()
|
||||
val v2 = (-10.toLong() as Long?)!!.hashCode()
|
||||
return if( v1 == v2 ) "OK" else "$v1 $v2"
|
||||
}
|
||||
@@ -1,16 +0,0 @@
|
||||
data class A(val a: Any?, var x: Int)
|
||||
data class B(val a: Any?)
|
||||
data class C(val a: Int, var x: Int?)
|
||||
data class D(val a: Int?)
|
||||
|
||||
fun box() : String {
|
||||
if( A(null,19).hashCode() != 19) "fail"
|
||||
if( A(239,19).hashCode() != (239*31+19)) "fail"
|
||||
if( B(null).hashCode() != 0) "fail"
|
||||
if( B(239).hashCode() != 239) "fail"
|
||||
if( C(239,19).hashCode() != (239*31+19)) "fail"
|
||||
if( C(239,null).hashCode() != 239*31) "fail"
|
||||
if( D(239).hashCode() != (239)) "fail"
|
||||
if( D(null).hashCode() != 0) "fail"
|
||||
return "OK"
|
||||
}
|
||||
@@ -1,7 +0,0 @@
|
||||
data class A(val a: Short)
|
||||
|
||||
fun box() : String {
|
||||
val v1 = A(10.toShort()).hashCode()
|
||||
val v2 = (10.toShort() as Short?)!!.hashCode()
|
||||
return if( v1 == v2 ) "OK" else "$v1 $v2"
|
||||
}
|
||||
@@ -1,15 +0,0 @@
|
||||
import java.io.Serializable
|
||||
|
||||
public data class Pair<out A, out B> (
|
||||
public val first: A,
|
||||
public val second: B
|
||||
) : Serializable
|
||||
|
||||
fun box(): String {
|
||||
val p = Pair(42, "OK")
|
||||
val q = Pair(42, "OK")
|
||||
if (p != q) return "Fail equals"
|
||||
if (p.hashCode() != q.hashCode()) return "Fail hashCode"
|
||||
if (p.toString() != q.toString()) return "Fail toString"
|
||||
return p.second
|
||||
}
|
||||
@@ -1,8 +0,0 @@
|
||||
data class A(var x: Int, val z: Int)
|
||||
|
||||
fun box(): String {
|
||||
val a = A(1, 3)
|
||||
if (a.component1() != 1) return "Fail: ${a.component1()}"
|
||||
if (a.component2() != 3) return "Fail: ${a.component2()}"
|
||||
return "OK"
|
||||
}
|
||||
@@ -1,7 +0,0 @@
|
||||
data class A(val x: Int, val y: Any?, val z: String)
|
||||
|
||||
fun box(): String {
|
||||
val a = A(42, null, "OK")
|
||||
val (x, y, z) = a
|
||||
return if (x == 42 && y == null) z else "Fail"
|
||||
}
|
||||
@@ -1,17 +0,0 @@
|
||||
data class A(val x: Int, val y: String)
|
||||
|
||||
fun box(): String {
|
||||
val arr = Array<A>(5) {
|
||||
i -> A(i, i.toString())
|
||||
}
|
||||
|
||||
var sum = 0
|
||||
var str = ""
|
||||
|
||||
for ((x, y) in arr) {
|
||||
sum += x
|
||||
str += y
|
||||
}
|
||||
|
||||
return if (sum == 0+1+2+3+4 && str == "01234") "OK" else "Fail ${sum} ${str}"
|
||||
}
|
||||
@@ -1,13 +0,0 @@
|
||||
data class D(private val x: Long, private val y: Char) {
|
||||
fun foo() = "${component1()}${component2()}"
|
||||
}
|
||||
|
||||
fun box(): String {
|
||||
val d1 = D(42L, 'a')
|
||||
val d2 = D(42L, 'a')
|
||||
if (d1 != d2) return "Fail equals"
|
||||
if (d1.hashCode() != d2.hashCode()) return "Fail hashCode"
|
||||
if (d1.toString() != d2.toString()) return "Fail toString"
|
||||
if (d1.foo() != d2.foo()) return "Fail foo"
|
||||
return "OK"
|
||||
}
|
||||
-7
@@ -1,7 +0,0 @@
|
||||
data class A(val x: Int) {
|
||||
override fun toString(): String = "!"
|
||||
}
|
||||
|
||||
fun box(): String {
|
||||
return if (A(0).toString() == "!") "OK" else "fail"
|
||||
}
|
||||
@@ -1,14 +0,0 @@
|
||||
data class A(val x: Array<Int>?, val y: IntArray?)
|
||||
|
||||
fun box(): String {
|
||||
var ts = A(Array<Int>(2, {it}), IntArray(3)).toString()
|
||||
if(ts != "A(x=[0, 1], y=[0, 0, 0])") return ts
|
||||
|
||||
ts = A(null, IntArray(3)).toString()
|
||||
if(ts != "A(x=null, y=[0, 0, 0])") return ts
|
||||
|
||||
ts = A(null, null).toString()
|
||||
if(ts != "A(x=null, y=null)") return ts
|
||||
|
||||
return "OK"
|
||||
}
|
||||
-11
@@ -1,11 +0,0 @@
|
||||
data class A(var string: String)
|
||||
|
||||
fun box(): String {
|
||||
val a = A("Fail")
|
||||
if(a.toString() != "A(string=Fail)") return "fail"
|
||||
|
||||
a.string = "OK"
|
||||
if("$a" != "A(string=OK)") return a.toString()
|
||||
|
||||
return "OK"
|
||||
}
|
||||
@@ -1,11 +0,0 @@
|
||||
data class A<T>(val x: T)
|
||||
|
||||
fun box(): String {
|
||||
val a = A(42)
|
||||
if ("$a" != "A(x=42)") return "$a"
|
||||
|
||||
val b = A(239.toLong())
|
||||
if ("$b" != "A(x=239)") return "$b"
|
||||
|
||||
return "OK"
|
||||
}
|
||||
@@ -1,7 +0,0 @@
|
||||
data class A(var x: Int, val z: Int?)
|
||||
|
||||
fun box(): String {
|
||||
val a = A(1, null)
|
||||
if("$a" != "A(x=1, z=null)") return "$a"
|
||||
return "OK"
|
||||
}
|
||||
@@ -1,6 +0,0 @@
|
||||
data class A(val x: Unit)
|
||||
|
||||
fun box(): String {
|
||||
val a = A(Unit)
|
||||
return if ("$a" == "A(x=kotlin.Unit)") "OK" else "$a"
|
||||
}
|
||||
@@ -1,6 +0,0 @@
|
||||
data class A(val x: Int, val y: String)
|
||||
|
||||
fun box(): String {
|
||||
val a = A(42, "OK")
|
||||
return if (a.component1() == 42) a.component2() else a.component1().toString()
|
||||
}
|
||||
@@ -1,9 +0,0 @@
|
||||
data class A(var x: Int, var y: String)
|
||||
|
||||
fun box(): String {
|
||||
val a = A(21, "K")
|
||||
if (a.component1() != 21 || a.component2() != "K") return "Fail"
|
||||
a.x *= 2
|
||||
a.y = "O" + a.component2()
|
||||
return if (a.component1() == 42) a.component2() else a.component1().toString()
|
||||
}
|
||||
@@ -1,6 +0,0 @@
|
||||
data class A(val x: Unit)
|
||||
|
||||
fun box(): String {
|
||||
val a = A(Unit)
|
||||
return if (a.component1() is Unit) "OK" else "Fail ${a.component1()}"
|
||||
}
|
||||
Reference in New Issue
Block a user