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