Set avatar to null on Account when request is false (#78)
This commit is contained in:
		
							parent
							
								
									a68d91b54c
								
							
						
					
					
						commit
						25a5a8db68
					
				|  | @ -2,6 +2,7 @@ package org.whispersystems.textsecuregcm.controllers; | |||
| 
 | ||||
| import com.amazonaws.services.s3.AmazonS3; | ||||
| import com.codahale.metrics.annotation.Timed; | ||||
| import io.dropwizard.auth.Auth; | ||||
| import org.apache.commons.codec.DecoderException; | ||||
| import org.apache.commons.codec.binary.Base64; | ||||
| import org.apache.commons.codec.binary.Hex; | ||||
|  | @ -51,8 +52,6 @@ import java.time.ZonedDateTime; | |||
| import java.util.Optional; | ||||
| import java.util.UUID; | ||||
| 
 | ||||
| import io.dropwizard.auth.Auth; | ||||
| 
 | ||||
| @SuppressWarnings("OptionalUsedAsFieldOrParameterType") | ||||
| @Path("/v1/profile") | ||||
| public class ProfileController { | ||||
|  | @ -125,7 +124,7 @@ public class ProfileController { | |||
|     } | ||||
| 
 | ||||
|     account.setProfileName(request.getName()); | ||||
|     if (avatar != null) account.setAvatar(avatar); | ||||
|     account.setAvatar(avatar); | ||||
|     accountsManager.update(account); | ||||
| 
 | ||||
|     if (response.isPresent()) return Response.ok(response).build(); | ||||
|  |  | |||
|  | @ -1,22 +1,21 @@ | |||
| package org.whispersystems.textsecuregcm.tests.controllers; | ||||
| 
 | ||||
| import com.amazonaws.services.s3.AmazonS3; | ||||
| import com.amazonaws.services.s3.AmazonS3Client; | ||||
| import com.google.common.collect.ImmutableSet; | ||||
| import io.dropwizard.auth.PolymorphicAuthValueFactoryProvider; | ||||
| import io.dropwizard.testing.junit.ResourceTestRule; | ||||
| import org.glassfish.jersey.test.grizzly.GrizzlyWebTestContainerFactory; | ||||
| import org.junit.Before; | ||||
| import org.junit.ClassRule; | ||||
| import org.junit.Test; | ||||
| import org.mockito.ArgumentCaptor; | ||||
| import org.mockito.ArgumentMatcher; | ||||
| import org.mockito.Mockito; | ||||
| import org.signal.zkgroup.InvalidInputException; | ||||
| import org.signal.zkgroup.profiles.ProfileKey; | ||||
| import org.signal.zkgroup.profiles.ProfileKeyCommitment; | ||||
| import org.signal.zkgroup.profiles.ServerZkProfileOperations; | ||||
| import org.whispersystems.textsecuregcm.auth.AmbiguousIdentifier; | ||||
| import org.whispersystems.textsecuregcm.auth.DisabledPermittedAccount; | ||||
| import org.whispersystems.textsecuregcm.configuration.CdnConfiguration; | ||||
| import org.whispersystems.textsecuregcm.controllers.ProfileController; | ||||
| import org.whispersystems.textsecuregcm.controllers.RateLimitExceededException; | ||||
| import org.whispersystems.textsecuregcm.entities.CreateProfileRequest; | ||||
|  | @ -41,10 +40,16 @@ import javax.ws.rs.core.Response; | |||
| import java.util.List; | ||||
| import java.util.Optional; | ||||
| 
 | ||||
| import io.dropwizard.auth.PolymorphicAuthValueFactoryProvider; | ||||
| import io.dropwizard.testing.junit.ResourceTestRule; | ||||
| import static org.assertj.core.api.Java6Assertions.assertThat; | ||||
| import static org.mockito.Mockito.*; | ||||
| import static org.mockito.Mockito.any; | ||||
| import static org.mockito.Mockito.argThat; | ||||
| import static org.mockito.Mockito.clearInvocations; | ||||
| import static org.mockito.Mockito.eq; | ||||
| import static org.mockito.Mockito.mock; | ||||
| import static org.mockito.Mockito.times; | ||||
| import static org.mockito.Mockito.verify; | ||||
| import static org.mockito.Mockito.verifyNoMoreInteractions; | ||||
| import static org.mockito.Mockito.when; | ||||
| 
 | ||||
| public class ProfileControllerTest { | ||||
| 
 | ||||
|  | @ -320,6 +325,8 @@ public class ProfileControllerTest { | |||
|   public void testSetProfileWithoutAvatarUpload() throws InvalidInputException { | ||||
|     ProfileKeyCommitment commitment = new ProfileKey(new byte[32]).getCommitment(AuthHelper.VALID_UUID); | ||||
| 
 | ||||
|     clearInvocations(AuthHelper.VALID_ACCOUNT_TWO); | ||||
| 
 | ||||
|     Response response = resources.getJerseyTest() | ||||
|                                  .target("/v1/profile/") | ||||
|                                  .request() | ||||
|  | @ -334,6 +341,9 @@ public class ProfileControllerTest { | |||
|     verify(profilesManager, times(1)).get(eq(AuthHelper.VALID_UUID_TWO), eq("anotherversion")); | ||||
|     verify(profilesManager, times(1)).set(eq(AuthHelper.VALID_UUID_TWO), profileArgumentCaptor.capture()); | ||||
| 
 | ||||
|     verify(AuthHelper.VALID_ACCOUNT_TWO).setProfileName("123456789012345678901234567890123456789012345678901234567890123456789012345678901234567890123456789012345678"); | ||||
|     verify(AuthHelper.VALID_ACCOUNT_TWO).setAvatar(null); | ||||
| 
 | ||||
|     verifyNoMoreInteractions(s3client); | ||||
| 
 | ||||
|     assertThat(profileArgumentCaptor.getValue().getCommitment()).isEqualTo(commitment.serialize()); | ||||
|  |  | |||
		Loading…
	
		Reference in New Issue
	
	 Ehren Kret
						Ehren Kret