org.gradle.util.GUtilTest.groovy Maven / Gradle / Ivy
Go to download
Show more of this group Show more artifacts with this name
Show all versions of gradle-api Show documentation
Show all versions of gradle-api Show documentation
Gradle 6.9.1 API redistribution.
/*
* Copyright 2009 the original author or authors.
*
* Licensed under the Apache License, Version 2.0 (the "License");
* you may not use this file except in compliance with the License.
* You may obtain a copy of the License at
*
* http://www.apache.org/licenses/LICENSE-2.0
*
* Unless required by applicable law or agreed to in writing, software
* distributed under the License is distributed on an "AS IS" BASIS,
* WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
* See the License for the specific language governing permissions and
* limitations under the License.
*/
package org.gradle.util
import com.google.common.base.Charsets
import static org.gradle.util.GUtil.*
public class GUtilTest extends spock.lang.Specification {
static sep = File.pathSeparator
def convertStringToCamelCase() {
expect:
toCamelCase(null) == null
toCamelCase("") == ""
toCamelCase("word") == "Word"
toCamelCase("twoWords") == "TwoWords"
toCamelCase("TwoWords") == "TwoWords"
toCamelCase("two-words") == "TwoWords"
toCamelCase("two.words") == "TwoWords"
toCamelCase("two words") == "TwoWords"
toCamelCase("two Words") == "TwoWords"
toCamelCase("Two Words") == "TwoWords"
toCamelCase(" Two \t words\n") == "TwoWords"
toCamelCase("four or so Words") == "FourOrSoWords"
toCamelCase("123-project") == "123Project"
toCamelCase("i18n-admin") == "I18nAdmin"
toCamelCase("trailing-") == "Trailing"
toCamelCase("ABC") == "ABC"
toCamelCase(".") == ""
toCamelCase("-") == ""
}
def convertStringToLowerCamelCase() {
expect:
toLowerCamelCase(null) == null
toLowerCamelCase("") == ""
toLowerCamelCase("word") == "word"
toLowerCamelCase("twoWords") == "twoWords"
toLowerCamelCase("TwoWords") == "twoWords"
toLowerCamelCase("two-words") == "twoWords"
toLowerCamelCase("two.words") == "twoWords"
toLowerCamelCase("two words") == "twoWords"
toLowerCamelCase("two Words") == "twoWords"
toLowerCamelCase("Two Words") == "twoWords"
toLowerCamelCase(" Two \t words\n") == "twoWords"
toLowerCamelCase("four or so Words") == "fourOrSoWords"
toLowerCamelCase("123-project") == "123Project"
toLowerCamelCase("i18n-admin") == "i18nAdmin"
toLowerCamelCase("trailing-") == "trailing"
toLowerCamelCase("ABC") == "aBC"
toLowerCamelCase(".") == ""
toLowerCamelCase("-") == ""
}
def convertStringToConstantName() {
expect:
toConstant(null) == null
toConstant("") == ""
toConstant("word") == "WORD"
toConstant("twoWords") == "TWO_WORDS"
toConstant("TwoWords") == "TWO_WORDS"
toConstant("two-words") == "TWO_WORDS"
toConstant("TWO_WORDS") == "TWO_WORDS"
toConstant("two.words") == "TWO_WORDS"
toConstant("two words") == "TWO_WORDS"
toConstant("two Words") == "TWO_WORDS"
toConstant("Two Words") == "TWO_WORDS"
toConstant(" Two \t words\n") == "TWO_WORDS"
toConstant("four or so Words") == "FOUR_OR_SO_WORDS"
toConstant("trailing-") == "TRAILING"
toConstant("a") == "A"
toConstant("A") == "A"
toConstant("aB") == "A_B"
toConstant("ABC") == "ABC"
toConstant("ABCThing") == "ABC_THING"
toConstant("ABC Thing") == "ABC_THING"
toConstant("123-project") == "123_PROJECT"
toConstant("123abc-project") == "123ABC_PROJECT"
toConstant("i18n-admin") == "I18N_ADMIN"
toConstant(".") == ""
toConstant("-") == ""
}
def convertStringToWords() {
expect:
toWords(null) == null
toWords("") == ""
toWords("word") == "word"
toWords("twoWords") == "two words"
toWords("TwoWords") == "two words"
toWords("two words") == "two words"
toWords("Two Words") == "two words"
toWords(" Two \t words\n") == "two words"
toWords("two_words") == "two words"
toWords("two.words") == "two words"
toWords("two,words") == "two words"
toWords("trailing-") == "trailing"
toWords("a") == "a"
toWords("aB") == "a b"
toWords("ABC") == "abc"
toWords("ABCThing") == "abc thing"
toWords("ABC Thing") == "abc thing"
toWords("123Thing") == "123 thing"
toWords(".") == ""
toWords("_") == ""
}
def "flattens maps and arrays"() {
expect:
flatten([[1], [foo: 'bar']]) == [1, 'bar']
Object[] array = [1]
flatten([array, [foo: 'bar']]) == [1, 'bar']
}
def "flattening of maps controls flatting of arrays"() {
//documenting current functionality, not sure if the functionality is a good one
when:
def out = []
Object[] array = [1]
then:
flatten([array, [foo: 'bar']], out, true) == [1, 'bar']
when:
out = []
array = [1]
then:
flatten([array, [foo: 'bar']], out, false) == [[1], [foo: 'bar']]
}
def "normalizes to collection"() {
expect:
collectionize(null) == []
collectionize(10) == [10]
collectionize("a") == ["a"]
List list = [2, 2, "three"] as List
collectionize(list) == [2, 2, "three"]
Object[] array = [1, 1, "three"]
collectionize(array) == [1, 1, "three"]
collectionize([list, array]) == [2, 2, "three", 1, 1, "three"]
collectionize([[1], [hey: 'man']]) == [1, [hey: 'man']]
}
def "flattens"() {
expect:
flattenElements(1, [2, 3]) == [1, 2, 3]
}
def "convert to path notation"() {
expect:
asPath(["lib1.jar", "lib2.jar", new File("lib3.jar")]) == "lib1.jar${sep}lib2.jar${sep}lib3.jar"
}
def "adds to collection"() {
def list = [0]
when:
addToCollection(list, [1, 2], [2, 3])
then:
list == [0, 1, 2, 2, 3]
}
def "adds empty list to collection"() {
expect:
addToCollection([], [], []) == []
addToCollection([1], [], [2]) == [1, 2]
}
def "adds to collection preventing nulls"() {
when:
addToCollection([], true, [1, 2], [null, 3])
then:
def ex = thrown(IllegalArgumentException)
ex.message.contains([null, 3].toString())
}
def "write properties file without date comment"() {
def out = new ByteArrayOutputStream()
def props = new Properties()
props.setProperty("foo", "bar")
when:
saveProperties(props, out)
then:
out.toString(Charsets.ISO_8859_1.name()).startsWith("#")
when:
out.reset()
savePropertiesNoDateComment(props, out)
then:
out.toString(Charsets.ISO_8859_1.name()).trim() == "foo=bar"
}
def "properties file without comment is encoding correctly and is round trippable"() {
def out = new ByteArrayOutputStream()
def props = new Properties()
props.setProperty("foo\u03A9=FOO", "bar\u2202")
when:
savePropertiesNoDateComment(props, out)
then:
out.toString(Charsets.ISO_8859_1.name()).trim() == "foo\\u03A9\\=FOO=bar\\u2202"
when:
def properties = loadProperties(new ByteArrayInputStream(out.toByteArray()))
then:
properties.getProperty("fooΩ=FOO") == "bar∂"
}
def "can write empty properties with no date comment"() {
def out = new ByteArrayOutputStream()
def props = new Properties()
when:
savePropertiesNoDateComment(props, out)
then:
out.size() == 0
}
def "can convert strings to enums using the enum value names"() {
expect:
TestEnum.ENUM1 == toEnum(TestEnum, "ENUM1")
TestEnum.ENUM1 == toEnum(TestEnum, "enum1")
TestEnum.ENUM1 == toEnum(TestEnum, "EnUm1")
TestEnum.ENUM2 == toEnum(TestEnum, "enum2")
TestEnum.ENUM3 == toEnum(TestEnum, "enum3")
TestEnum.ENUM_4_1 == toEnum(TestEnum, "enum_4_1")
TestEnum.STANDARD_OUT == toEnum(TestEnum, "Standard_Out")
TestEnum.STANDARD_OUT == toEnum(TestEnum, "standardOut")
}
def "converts enum constants to themselves"() {
expect:
TestEnum.ENUM1 == toEnum(TestEnum, TestEnum.ENUM1)
}
def "fails when trying to convert incompatible types to enums"() {
when:
toEnum(TestEnum, 2)
then:
def e = thrown(IllegalArgumentException)
e.message == "Cannot convert value '2' of type 'java.lang.Integer' to enum type 'org.gradle.util.GUtilTest\$TestEnum'"
}
def "can convert multiple strings to an enum set"() {
expect:
[TestEnum.ENUM1, TestEnum.ENUM2, TestEnum.ENUM3] as Set == toEnumSet(TestEnum, "Enum1", "EnUm2", TestEnum.ENUM3)
}
def "reports available enum values for non convertible strings"() {
when:
toEnum(TestEnum, value)
then:
def e = thrown(IllegalArgumentException)
e.message == "Cannot convert string value '$value' to an enum value of type 'org.gradle.util.GUtilTest\$TestEnum' (valid case insensitive values: ENUM1, ENUM2, ENUM3, ENUM_4_1, STANDARD_OUT)"
where:
value | _
"notKnown" | _
"3" | _
"3" | _
}
static enum TestEnum {
ENUM1,
ENUM2,
ENUM3(){
@Override
String toString() {
return "3"
}
},
ENUM_4_1,
STANDARD_OUT
}
}
© 2015 - 2025 Weber Informatics LLC | Privacy Policy