mirror of
				https://github.com/apache/cloudstack.git
				synced 2025-10-26 08:42:29 +01:00 
			
		
		
		
	CLOUDSTACK-8669: create volume failed due to null charset
Added a new private method getCharSetFromConnection() which checks if the connection charset is null and if it is null, returns StringUtils.getPreferredCharset regression caused by commit f03411ca0436c8b52f5e60b0c8820fd1d1ba2ff6
This commit is contained in:
		
							parent
							
								
									a65339ff1b
								
							
						
					
					
						commit
						c180a6db03
					
				| @ -19,6 +19,7 @@ package com.cloud.hypervisor.vmware.util; | ||||
| import com.cloud.hypervisor.vmware.mo.DatacenterMO; | ||||
| import com.cloud.hypervisor.vmware.mo.DatastoreFile; | ||||
| import com.cloud.utils.ActionDelegate; | ||||
| import com.cloud.utils.StringUtils; | ||||
| import com.vmware.vim25.ManagedObjectReference; | ||||
| import com.vmware.vim25.ObjectContent; | ||||
| import com.vmware.vim25.ObjectSpec; | ||||
| @ -50,6 +51,7 @@ import java.io.UnsupportedEncodingException; | ||||
| import java.net.HttpURLConnection; | ||||
| import java.net.URL; | ||||
| import java.net.URLEncoder; | ||||
| import java.nio.charset.Charset; | ||||
| import java.util.ArrayList; | ||||
| import java.util.HashMap; | ||||
| import java.util.List; | ||||
| @ -357,7 +359,7 @@ public class VmwareContext { | ||||
|             } | ||||
|             out.flush(); | ||||
| 
 | ||||
|             br = new BufferedReader(new InputStreamReader(conn.getInputStream(),conn.getContentEncoding())); | ||||
|             br = new BufferedReader(new InputStreamReader(conn.getInputStream(), getCharSetFromConnection(conn))); | ||||
|             String line; | ||||
|             while ((line = br.readLine()) != null) { | ||||
|                 if (s_logger.isTraceEnabled()) | ||||
| @ -375,6 +377,18 @@ public class VmwareContext { | ||||
|         } | ||||
|     } | ||||
| 
 | ||||
|     private Charset getCharSetFromConnection(HttpURLConnection conn) { | ||||
|         String charsetName = conn.getContentEncoding(); | ||||
|         Charset charset; | ||||
|         try { | ||||
|             charset = Charset.forName(charsetName); | ||||
|         } catch (IllegalArgumentException e) { | ||||
|             s_logger.warn("Illegal/unsupported/null charset name from connection. charsetname from connection is " + charsetName); | ||||
|             charset = StringUtils.getPreferredCharset(); | ||||
|         } | ||||
|         return charset; | ||||
|     } | ||||
| 
 | ||||
|     public void uploadVmdkFile(String httpMethod, String urlString, String localFileName, long totalBytesUpdated, ActionDelegate<Long> progressUpdater) throws Exception { | ||||
| 
 | ||||
|         HttpURLConnection conn = getRawHTTPConnection(urlString); | ||||
| @ -483,9 +497,9 @@ public class VmwareContext { | ||||
|         out.write(content); | ||||
|         out.flush(); | ||||
| 
 | ||||
|         BufferedReader in = new BufferedReader(new InputStreamReader(conn.getInputStream(),conn.getContentEncoding())); | ||||
|         BufferedReader in = new BufferedReader(new InputStreamReader(conn.getInputStream(), getCharSetFromConnection(conn))); | ||||
|         String line; | ||||
|         while ((line = in.readLine()) != null) { | ||||
|         while ((in.ready()) && (line = in.readLine()) != null) { | ||||
|             if (s_logger.isTraceEnabled()) | ||||
|                 s_logger.trace("Upload " + urlString + " response: " + line); | ||||
|         } | ||||
|  | ||||
| @ -0,0 +1,47 @@ | ||||
| /* | ||||
|  * 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 | ||||
|  * | ||||
|  *   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 com.cloud.hypervisor.vmware.util; | ||||
| 
 | ||||
| import java.io.InputStream; | ||||
| import java.io.OutputStream; | ||||
| import java.net.HttpURLConnection; | ||||
| 
 | ||||
| import org.junit.Test; | ||||
| import org.junit.runner.RunWith; | ||||
| import org.mockito.Mockito; | ||||
| import org.mockito.runners.MockitoJUnitRunner; | ||||
| 
 | ||||
| @RunWith(MockitoJUnitRunner.class) | ||||
| public class VmwareContextTest { | ||||
| 
 | ||||
|     @Test | ||||
|     public void testUploadResourceContentCharsetException() throws Exception { | ||||
|         VmwareClient client = Mockito.mock(VmwareClient.class); | ||||
|         String address = "10.1.1.1"; | ||||
|         VmwareContext vmwareContext = Mockito.spy(new VmwareContext(client, address)); | ||||
|         HttpURLConnection conn = Mockito.mock(HttpURLConnection.class); | ||||
|         Mockito.doReturn(Mockito.mock(OutputStream.class)).when(conn).getOutputStream(); | ||||
|         Mockito.doReturn(Mockito.mock(InputStream.class)).when(conn).getInputStream(); | ||||
|         Mockito.doReturn(conn).when(vmwareContext).getHTTPConnection("http://example.com", "PUT"); | ||||
|         //This method should not throw any exception. Ref: CLOUDSTACK-8669 | ||||
|         vmwareContext.uploadResourceContent("http://example.com", "content".getBytes()); | ||||
|     } | ||||
| 
 | ||||
| } | ||||
		Loading…
	
	
			
			x
			
			
		
	
		Reference in New Issue
	
	Block a user