| /** |
| * Licensed to the Apache Software Foundation (ASF) under one |
| * or more contributor license agreements. See the NOTICE file |
| * distributed with this work for additional information |
| * regarding copyright ownership. The ASF licenses this file |
| * to you 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 |
| * <p> |
| * http://www.apache.org/licenses/LICENSE-2.0 |
| * <p> |
| * 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.apache.hadoop.fs.azurebfs; |
| |
| import java.io.IOException; |
| import java.util.Date; |
| |
| import org.junit.Test; |
| |
| import org.apache.commons.lang3.StringUtils; |
| import org.apache.hadoop.fs.azurebfs.oauth2.AccessTokenProvider; |
| import org.apache.hadoop.fs.azurebfs.oauth2.AzureADToken; |
| import org.apache.hadoop.fs.azurebfs.oauth2.MsiTokenProvider; |
| |
| import static org.junit.Assume.assumeThat; |
| import static org.hamcrest.CoreMatchers.is; |
| import static org.hamcrest.CoreMatchers.not; |
| import static org.hamcrest.Matchers.isEmptyOrNullString; |
| import static org.hamcrest.Matchers.isEmptyString; |
| |
| import static org.apache.hadoop.fs.azurebfs.constants.AuthConfigurations.DEFAULT_FS_AZURE_ACCOUNT_OAUTH_MSI_AUTHORITY; |
| import static org.apache.hadoop.fs.azurebfs.constants.AuthConfigurations.DEFAULT_FS_AZURE_ACCOUNT_OAUTH_MSI_ENDPOINT; |
| import static org.apache.hadoop.fs.azurebfs.constants.ConfigurationKeys.FS_AZURE_ACCOUNT_OAUTH_CLIENT_ID; |
| import static org.apache.hadoop.fs.azurebfs.constants.ConfigurationKeys.FS_AZURE_ACCOUNT_OAUTH_MSI_AUTHORITY; |
| import static org.apache.hadoop.fs.azurebfs.constants.ConfigurationKeys.FS_AZURE_ACCOUNT_OAUTH_MSI_ENDPOINT; |
| import static org.apache.hadoop.fs.azurebfs.constants.ConfigurationKeys.FS_AZURE_ACCOUNT_OAUTH_MSI_TENANT; |
| |
| /** |
| * Test MsiTokenProvider. |
| */ |
| public final class ITestAbfsMsiTokenProvider |
| extends AbstractAbfsIntegrationTest { |
| |
| public ITestAbfsMsiTokenProvider() throws Exception { |
| super(); |
| } |
| |
| @Test |
| public void test() throws IOException { |
| AbfsConfiguration conf = getConfiguration(); |
| assumeThat(conf.get(FS_AZURE_ACCOUNT_OAUTH_MSI_ENDPOINT), |
| not(isEmptyOrNullString())); |
| assumeThat(conf.get(FS_AZURE_ACCOUNT_OAUTH_MSI_TENANT), |
| not(isEmptyOrNullString())); |
| assumeThat(conf.get(FS_AZURE_ACCOUNT_OAUTH_CLIENT_ID), |
| not(isEmptyOrNullString())); |
| assumeThat(conf.get(FS_AZURE_ACCOUNT_OAUTH_MSI_AUTHORITY), |
| not(isEmptyOrNullString())); |
| |
| String tenantGuid = conf |
| .getPasswordString(FS_AZURE_ACCOUNT_OAUTH_MSI_TENANT); |
| String clientId = conf.getPasswordString(FS_AZURE_ACCOUNT_OAUTH_CLIENT_ID); |
| String authEndpoint = getTrimmedPasswordString(conf, |
| FS_AZURE_ACCOUNT_OAUTH_MSI_ENDPOINT, |
| DEFAULT_FS_AZURE_ACCOUNT_OAUTH_MSI_ENDPOINT); |
| String authority = getTrimmedPasswordString(conf, |
| FS_AZURE_ACCOUNT_OAUTH_MSI_AUTHORITY, |
| DEFAULT_FS_AZURE_ACCOUNT_OAUTH_MSI_AUTHORITY); |
| AccessTokenProvider tokenProvider = new MsiTokenProvider(authEndpoint, |
| tenantGuid, clientId, authority); |
| |
| AzureADToken token = null; |
| token = tokenProvider.getToken(); |
| assertThat(token.getAccessToken(), not(isEmptyString())); |
| assertThat(token.getExpiry().after(new Date()), is(true)); |
| } |
| |
| private String getTrimmedPasswordString(AbfsConfiguration conf, String key, |
| String defaultValue) throws IOException { |
| String value = conf.getPasswordString(key); |
| if (StringUtils.isBlank(value)) { |
| value = defaultValue; |
| } |
| return value.trim(); |
| } |
| |
| } |