/* * Copyright (C) 2016 TIBCO Jaspersoft Corporation. All rights reserved. * http://community.jaspersoft.com/project/mobile-sdk-android * * Unless you have purchased a commercial license agreement from TIBCO Jaspersoft, * the following license terms apply: * * This program is part of TIBCO Jaspersoft Mobile SDK for Android. * * TIBCO Jaspersoft Mobile SDK is free software: you can redistribute it and/or modify * it under the terms of the GNU Lesser General Public License as published by * the Free Software Foundation, either version 3 of the License, or * (at your option) any later version. * * TIBCO Jaspersoft Mobile SDK is distributed in the hope that it will be useful, * but WITHOUT ANY WARRANTY; without even the implied warranty of * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the * GNU Lesser General Public License for more details. * * You should have received a copy of the GNU Lesser General Public License * along with TIBCO Jaspersoft Mobile SDK for Android. If not, see * <http://www.gnu.org/licenses/lgpl>. */ package com.jaspersoft.android.sdk.network; import com.jaspersoft.android.sdk.network.entity.server.EncryptionKey; import org.junit.Before; import org.junit.Test; import org.junit.runner.RunWith; import org.mockito.Mock; import org.mockito.MockitoAnnotations; import org.powermock.core.classloader.annotations.PrepareForTest; import org.powermock.modules.junit4.PowerMockRunner; import java.util.HashMap; import java.util.Locale; import java.util.Map; import java.util.TimeZone; import static org.mockito.Matchers.anyString; import static org.mockito.Mockito.*; /** * @author Tom Koptel * @since 2.3 */ @RunWith(PowerMockRunner.class) @PrepareForTest({ Locale.class, EncryptionKey.class, JSEncryptionAlgorithm.class, }) public class SpringAuthServiceTest { @Mock AuthRestApi mRestApi; @Mock JSEncryptionAlgorithm mAlgorithm; @Mock EncryptionKey mKey; @Mock TimeZone mTimeZone; private SpringAuthService objectUnderTest; private SpringCredentials credentials; private static final Map<String, String> sOptionals = new HashMap<>(); static { sOptionals.put("userLocale", "en_US"); sOptionals.put("userTimezone", "Europe/Helsinki"); } @Before public void setup() throws Exception { MockitoAnnotations.initMocks(this); objectUnderTest = new SpringAuthService( mRestApi, mAlgorithm ); credentials = SpringCredentials.builder() .withUsername("user") .withPassword("1234") .withOrganization("organization") .withLocale(Locale.US) .withTimeZone(mTimeZone) .build(); when(mRestApi.requestEncryptionMetadata()).thenReturn(mKey); when(mTimeZone.getID()).thenReturn("Europe/Helsinki"); } @Test public void shouldAuthenticateWithHashedPasswordIfEncryptionKeyIsMissing() throws Exception { when(mKey.isAvailable()).thenReturn(true); when(mKey.getExponent()).thenReturn("e"); when(mKey.getModulus()).thenReturn("m"); when(mAlgorithm.encrypt(anyString(), anyString(), anyString())).thenReturn("hashed password"); objectUnderTest.authenticate(credentials); verify(mRestApi, times(1)).springAuth("user", "hashed password", "organization", sOptionals); verify(mRestApi, times(1)).requestEncryptionMetadata(); verify(mAlgorithm, times(1)).encrypt("m", "e", "1234"); } @Test public void shouldAuthenticateWithOpenPasswordIfEncryptionKeyIsMissing() throws Exception { when(mKey.isAvailable()).thenReturn(false); objectUnderTest.authenticate(credentials); verify(mRestApi, times(1)).springAuth("user", "1234", "organization", sOptionals); verify(mRestApi, times(1)).requestEncryptionMetadata(); verifyZeroInteractions(mAlgorithm); } }