NIFI-10971: improved edge case handling while fetching objects using Azure Key Vault Client and added unit tests

Signed-off-by: Pierre Villard <pierre.villard.fr@gmail.com>

This closes #6780.
This commit is contained in:
Emilio Setiadarma 2022-12-12 19:07:21 -08:00 committed by Pierre Villard
parent beb90ba8a6
commit bf24d575b3
No known key found for this signature in database
GPG Key ID: F92A93B30C07C6D5
2 changed files with 64 additions and 3 deletions

View File

@ -132,9 +132,11 @@ public class AzureKeyVaultSecretsParameterProvider extends AbstractParameterProv
final List<KeyVaultSecret> secrets = new ArrayList<>();
for (final SecretProperties secretProperties : secretClient.listPropertiesOfSecrets()) {
if (secretProperties.isEnabled()) {
KeyVaultSecret secretWithValue = secretClient.getSecret(secretProperties.getName(), secretProperties.getVersion());
secrets.add(secretWithValue);
}
}
return secrets;
}
@ -145,7 +147,12 @@ public class AzureKeyVaultSecretsParameterProvider extends AbstractParameterProv
final String parameterName = secret.getName();
final String parameterValue = secret.getValue();
final String parameterGroupName = secret.getProperties().getTags().get(GROUP_NAME_TAG);
final Map<String, String> tags = secret.getProperties().getTags();
if (tags == null) {
getLogger().debug("Secret with parameter name [{}] not recognized as a valid parameter since it does not have tags");
continue;
}
final String parameterGroupName = tags.get(GROUP_NAME_TAG);
if (parameterGroupName == null) {
getLogger().debug("Secret with parameter name [{}] not recognized as a valid parameter since it " +
"does not have the [{}] tag", parameterName, GROUP_NAME_TAG);

View File

@ -96,6 +96,59 @@ public class TestAzureKeyVaultSecretsParameterProvider {
runProviderTest( 8, ConfigVerificationResult.Outcome.SUCCESSFUL);
}
@Test
public void testFetchDisabledParameters() throws IOException, InitializationException {
final List<SecretProperties> secretPropertiesList = new ArrayList<>();
for (final ParameterGroup group : mockParameterGroups) {
for (final Parameter parameter : group.getParameters()) {
final SecretProperties secretProperties = mock(SecretProperties.class);
when(secretProperties.isEnabled()).thenReturn(false);
secretPropertiesList.add(secretProperties);
}
}
final PagedIterable<SecretProperties> mockIterable = mock(PagedIterable.class);
when(secretClient.listPropertiesOfSecrets()).thenReturn(mockIterable);
when(mockIterable.iterator()).thenReturn(secretPropertiesList.iterator());
runProviderTest( 0, ConfigVerificationResult.Outcome.SUCCESSFUL);
}
@Test
public void testFetchParametersWithNullTagsShouldNotThrowError() throws IOException, InitializationException {
final List<SecretProperties> secretPropertiesList = new ArrayList<>();
for (final ParameterGroup group : mockParameterGroups) {
for (final Parameter parameter : group.getParameters()) {
final String parameterName = parameter.getDescriptor().getName();
final String parameterValue = parameter.getValue();
final KeyVaultSecret secret = mock(KeyVaultSecret.class);
when(secret.getName()).thenReturn(parameterName);
when(secret.getValue()).thenReturn(parameterValue);
final SecretProperties secretProperties = mock(SecretProperties.class);
when(secret.getProperties()).thenReturn(secretProperties);
final Map<String, String> tags = null;
when(secretProperties.getTags()).thenReturn(tags);
when(secretProperties.getName()).thenReturn(parameterName);
when(secretProperties.getVersion()).thenReturn(null);
when(secretProperties.isEnabled()).thenReturn(true);
when(secretClient.getSecret(eq(parameterName), any())).thenReturn(secret);
secretPropertiesList.add(secretProperties);
}
}
final PagedIterable<SecretProperties> mockIterable = mock(PagedIterable.class);
when(secretClient.listPropertiesOfSecrets()).thenReturn(mockIterable);
when(mockIterable.iterator()).thenReturn(secretPropertiesList.iterator());
runProviderTest( 0, ConfigVerificationResult.Outcome.SUCCESSFUL);
}
@Test
public void testFetchParametersListFailure() throws IOException, InitializationException {
when(secretClient.listPropertiesOfSecrets()).thenThrow(new RuntimeException("Fake RuntimeException"));
@ -129,6 +182,7 @@ public class TestAzureKeyVaultSecretsParameterProvider {
when(secretProperties.getName()).thenReturn(parameterName);
when(secretProperties.getVersion()).thenReturn(null);
when(secretProperties.isEnabled()).thenReturn(true);
when(secretClient.getSecret(eq(parameterName), any())).thenReturn(secret);
secretPropertiesList.add(secretProperties);