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
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
|
package scala.collection.immutable
import org.junit.Assert._
import org.junit.Test
import org.junit.runner.RunWith
import org.junit.runners.JUnit4
import scala.tools.testing.AssertUtil
import scala.util.Random
/* Test for SI-8988 */
@RunWith(classOf[JUnit4])
class StringLikeTest {
@Test
def testStringSplitWithChar: Unit = {
val chars = (0 to 255).map(_.toChar)
def randString = Random.nextString(30)
for (c <- chars) {
val s = randString
val jString = new java.lang.String(s)
// make sure we can match a literal character done by Java's split
val jSplit = jString.split("\\Q" + c.toString + "\\E")
val sSplit = s.split(c)
AssertUtil.assertSameElements(jSplit, sSplit, s"Not same result as Java split for char $c in string $s")
}
}
@Test
def testSplitEdgeCases: Unit = {
val high = 0xD852.toChar
val low = 0xDF62.toChar
val surrogatepair = List(high, low).mkString
val twopairs = surrogatepair + "_" + surrogatepair
AssertUtil.assertSameElements("abcd".split('d'), Array("abc")) // not Array("abc", "")
AssertUtil.assertSameElements("abccc".split('c'), Array("ab")) // not Array("ab", "", "", "")
AssertUtil.assertSameElements("xxx".split('x'), Array[String]()) // not Array("", "", "", "")
AssertUtil.assertSameElements("".split('x'), Array("")) // not Array()
AssertUtil.assertSameElements("--ch--omp--".split("-"), Array("", "", "ch", "", "omp")) // All the cases!
AssertUtil.assertSameElements(twopairs.split(high), Array(twopairs)) //don't split on characters that are half a surrogate pair
}
/* Test for SI-9767 */
@Test
def testNumericConversion: Unit = {
val sOne = " \t\n 1 \n\r\t "
val sOk = "2"
val sNull:String = null
AssertUtil.assertThrows[java.lang.NumberFormatException](sOne.toInt)
AssertUtil.assertThrows[java.lang.NumberFormatException](sOne.toLong)
AssertUtil.assertThrows[java.lang.NumberFormatException](sOne.toShort)
AssertUtil.assertThrows[java.lang.NumberFormatException](sOne.toByte)
assertTrue("trim toDouble", sOne.toDouble == 1.0d)
assertTrue("trim toFloat", sOne.toFloat == 1.0f)
assertTrue("no trim toInt", sOk.toInt == 2)
assertTrue("no trim toLong", sOk.toLong == 2L)
assertTrue("no trim toShort", sOk.toShort == 2.toShort)
assertTrue("no trim toByte", sOk.toByte == 2.toByte)
assertTrue("no trim toDouble", sOk.toDouble == 2.0d)
assertTrue("no trim toFloat", sOk.toFloat == 2.0f)
AssertUtil.assertThrows[java.lang.NumberFormatException](sNull.toInt, {s => s == "null"})
AssertUtil.assertThrows[java.lang.NumberFormatException](sNull.toLong, {s => s == "null"})
AssertUtil.assertThrows[java.lang.NumberFormatException](sNull.toShort, {s => s == "null"})
AssertUtil.assertThrows[java.lang.NumberFormatException](sNull.toByte, {s => s == "null"})
AssertUtil.assertThrows[java.lang.NullPointerException](sNull.toDouble)
AssertUtil.assertThrows[java.lang.NullPointerException](sNull.toFloat)
}
}
|