diff options
author | Filip Krzywka <filip.krzywka@nokia.com> | 2019-03-20 14:53:57 +0100 |
---|---|---|
committer | Filip Krzywka <filip.krzywka@nokia.com> | 2019-03-21 13:33:27 +0100 |
commit | 1eed57cfa680a6dcce80f05d57e69d61e947bb69 (patch) | |
tree | 0a32aec375fbb8e6f5c134948098d18c78205cad /sources/hv-collector-configuration/src/test | |
parent | d418dd43e7812ea2cdebf188bf5ab51a997df90c (diff) |
Make security keys optional with SSL disabled
Change-Id: I0b0dd63cb3609cddf6aa5e63cf0a0f147a0aca91
Issue-ID: DCAEGEN2-1340
Signed-off-by: Filip Krzywka <filip.krzywka@nokia.com>
Diffstat (limited to 'sources/hv-collector-configuration/src/test')
2 files changed, 212 insertions, 0 deletions
diff --git a/sources/hv-collector-configuration/src/test/kotlin/org/onap/dcae/collectors/veshv/config/impl/gsonadapters/AddressAdapterTest.kt b/sources/hv-collector-configuration/src/test/kotlin/org/onap/dcae/collectors/veshv/config/impl/gsonadapters/AddressAdapterTest.kt new file mode 100644 index 00000000..f70c4337 --- /dev/null +++ b/sources/hv-collector-configuration/src/test/kotlin/org/onap/dcae/collectors/veshv/config/impl/gsonadapters/AddressAdapterTest.kt @@ -0,0 +1,77 @@ +/* + * ============LICENSE_START======================================================= + * dcaegen2-collectors-veshv + * ================================================================================ + * Copyright (C) 2019 NOKIA + * ================================================================================ + * 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. + * ============LICENSE_END========================================================= + */ +package org.onap.dcae.collectors.veshv.config.impl.gsonadapters + +import com.google.gson.Gson +import com.google.gson.JsonDeserializationContext +import com.google.gson.JsonParseException +import com.google.gson.reflect.TypeToken +import com.nhaarman.mockitokotlin2.mock +import org.assertj.core.api.Assertions.assertThat +import org.jetbrains.spek.api.Spek +import org.jetbrains.spek.api.dsl.describe +import org.jetbrains.spek.api.dsl.given +import org.jetbrains.spek.api.dsl.it +import org.onap.dcae.collectors.veshv.config.impl.gsonadapters.AddressAdapter.InvalidAddressException +import java.lang.NumberFormatException +import kotlin.test.assertFailsWith + + +internal object AddressAdapterTest : Spek({ + + describe("deserialization") { + val gson = Gson() + val context = mock<JsonDeserializationContext>() + val addressAdapterType = TypeToken.get(AddressAdapter::class.java).type + + val cut = AddressAdapter() + + given("valid string") { + val address = "hostname:9000" + val json = gson.toJsonTree(address) + + it("should return address") { + val deserialized = cut.deserialize(json, addressAdapterType, context) + + assertThat(deserialized.hostName).isEqualTo("hostname") + assertThat(deserialized.port).isEqualTo(9000) + } + } + + val invalidAddresses = mapOf( + Pair("missingPort", InvalidAddressException::class), + Pair("NaNPort:Hey", NumberFormatException::class), + Pair(":6036", InvalidAddressException::class)) + + invalidAddresses.forEach { address, exception -> + given("invalid address string: $address") { + + val json = gson.toJsonTree(address) + it("should throw exception") { + assertFailsWith(exception) { + cut.deserialize(json, addressAdapterType, context) + } + } + } + } + } +}) + + diff --git a/sources/hv-collector-configuration/src/test/kotlin/org/onap/dcae/collectors/veshv/config/impl/gsonadapters/SecurityAdapterTest.kt b/sources/hv-collector-configuration/src/test/kotlin/org/onap/dcae/collectors/veshv/config/impl/gsonadapters/SecurityAdapterTest.kt new file mode 100644 index 00000000..a466896b --- /dev/null +++ b/sources/hv-collector-configuration/src/test/kotlin/org/onap/dcae/collectors/veshv/config/impl/gsonadapters/SecurityAdapterTest.kt @@ -0,0 +1,135 @@ +/* + * ============LICENSE_START======================================================= + * dcaegen2-collectors-veshv + * ================================================================================ + * Copyright (C) 2019 NOKIA + * ================================================================================ + * 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. + * ============LICENSE_END========================================================= + */ +package org.onap.dcae.collectors.veshv.config.impl.gsonadapters + +import com.google.gson.JsonDeserializationContext +import com.google.gson.JsonParser +import com.google.gson.reflect.TypeToken +import com.nhaarman.mockitokotlin2.mock +import org.assertj.core.api.Assertions +import org.jetbrains.spek.api.Spek +import org.jetbrains.spek.api.dsl.describe +import org.jetbrains.spek.api.dsl.given +import org.jetbrains.spek.api.dsl.it + +internal object SecurityAdapterTest : Spek({ + + describe("deserialization") { + val gson = JsonParser() + val context = mock<JsonDeserializationContext>() + val someType = TypeToken.get(SecurityAdapter::class.java).type + + val cut = SecurityAdapter() + + given("empty security object") { + val json = gson.parse("{}") + + it("should parse json to security configuration without keys") { + val deserialized = cut.deserialize(json, someType, context) + + Assertions.assertThat(deserialized.keys.isEmpty()).isTrue() + } + } + + given("valid security object with ssl disabled") { + + given("security keys missing") { + val json = gson.parse(SECURITY_WITH_SSL_DISABLED_AND_KEYS_MISSING) + + it("should parse json to security configuration without keys") { + val deserialized = cut.deserialize(json, someType, context) + + Assertions.assertThat(deserialized.keys.isEmpty()).isTrue() + } + } + + given("security keys provided") { + val json = gson.parse(SECURITY_WITH_SSL_DISABLED_AND_KEYS_PROVIDED) + + it("should parse json to security configuration without keys") { + val deserialized = cut.deserialize(json, someType, context) + + Assertions.assertThat(deserialized.keys.isEmpty()).isTrue() + } + } + } + + given("valid security object with missing sslDisable key") { + val json = gson.parse(MISSING_SSL_DISABLE_ENTRY) + + it("should return parse json to security configuration") { + val deserialized = cut.deserialize(json, someType, context) + + Assertions.assertThat(deserialized.keys.isDefined()).isTrue() + } + } + + given("valid security object with ssl enabled") { + val json = gson.parse(VALID_SECURITY_WITH_SSL_ENABLED) + + it("should return parse json to security configuration") { + val deserialized = cut.deserialize(json, someType, context) + + Assertions.assertThat(deserialized.keys.isDefined()).isTrue() + } + } + } +}) + +val SECURITY_WITH_SSL_DISABLED_AND_KEYS_MISSING = """ +{ + "sslDisable": true +} +""" + +val SECURITY_WITH_SSL_DISABLED_AND_KEYS_PROVIDED = """ +{ + "sslDisable": true, + "keys": { + "keyStoreFile": "test.ks.pkcs12", + "keyStorePassword": "changeMe", + "trustStoreFile": "trust.ks.pkcs12", + "trustStorePassword": "changeMeToo" + } +} +""" + +val MISSING_SSL_DISABLE_ENTRY = """ +{ + "keys": { + "keyStoreFile": "test.ks.pkcs12", + "keyStorePassword": "changeMe", + "trustStoreFile": "trust.ks.pkcs12", + "trustStorePassword": "changeMeToo" + } +} +""" + +val VALID_SECURITY_WITH_SSL_ENABLED = """ +{ + "sslDisable": false, + "keys": { + "keyStoreFile": "test.ks.pkcs12", + "keyStorePassword": "changeMe", + "trustStoreFile": "trust.ks.pkcs12", + "trustStorePassword": "changeMeToo" + } +} +""" |