diff options
author | android-build-team Robot <android-build-team-robot@google.com> | 2019-11-11 21:24:43 +0000 |
---|---|---|
committer | android-build-team Robot <android-build-team-robot@google.com> | 2019-11-11 21:24:43 +0000 |
commit | be2e569365fb597b26939bb475e88d99b3da2d63 (patch) | |
tree | b39c3e794945072d38b97c963c5a6f10753514e1 /tests/iketests/src/java/com/android/internal/net/eap/statemachine/CreatedStateTest.java | |
parent | 78052775925ce7e49f6013e2fbea4130779f13cf (diff) | |
parent | eb4c77d7228f956f928c7d3500a220339ee78388 (diff) | |
download | ike-be2e569365fb597b26939bb475e88d99b3da2d63.tar.gz |
Snap for 6001391 from eb4c77d7228f956f928c7d3500a220339ee78388 to qt-aml-networking-releaseandroid-mainline-10.0.0_r6android10-mainline-networking-release
Change-Id: Ifede049eeae909912e9792f87a89bf4ede7e34d9
Diffstat (limited to 'tests/iketests/src/java/com/android/internal/net/eap/statemachine/CreatedStateTest.java')
-rw-r--r-- | tests/iketests/src/java/com/android/internal/net/eap/statemachine/CreatedStateTest.java | 79 |
1 files changed, 79 insertions, 0 deletions
diff --git a/tests/iketests/src/java/com/android/internal/net/eap/statemachine/CreatedStateTest.java b/tests/iketests/src/java/com/android/internal/net/eap/statemachine/CreatedStateTest.java new file mode 100644 index 00000000..a452fa6f --- /dev/null +++ b/tests/iketests/src/java/com/android/internal/net/eap/statemachine/CreatedStateTest.java @@ -0,0 +1,79 @@ +/* + * Copyright (C) 2019 The Android Open Source Project + * + * Licensed 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.android.internal.net.eap.statemachine; + +import static com.android.internal.net.eap.message.EapTestMessageDefinitions.EAP_REQUEST_IDENTITY_PACKET; +import static com.android.internal.net.eap.message.EapTestMessageDefinitions.EAP_REQUEST_NOTIFICATION_PACKET; +import static com.android.internal.net.eap.message.EapTestMessageDefinitions.EAP_REQUEST_SIM_START_PACKET; +import static com.android.internal.net.eap.message.EapTestMessageDefinitions.EAP_RESPONSE_NOTIFICATION_PACKET; + +import static org.junit.Assert.assertArrayEquals; +import static org.junit.Assert.assertTrue; +import static org.mockito.ArgumentMatchers.any; +import static org.mockito.ArgumentMatchers.eq; +import static org.mockito.Mockito.never; +import static org.mockito.Mockito.spy; +import static org.mockito.Mockito.verify; + +import com.android.internal.net.eap.EapResult; +import com.android.internal.net.eap.EapResult.EapResponse; +import com.android.internal.net.eap.statemachine.EapStateMachine.IdentityState; +import com.android.internal.net.eap.statemachine.EapStateMachine.MethodState; + +import org.junit.Before; +import org.junit.Test; + +public class CreatedStateTest extends EapStateTest { + private EapStateMachine mEapStateMachineSpy; + + @Before + @Override + public void setUp() { + super.setUp(); + + mEapStateMachineSpy = spy(mEapStateMachine); + mEapState = mEapStateMachineSpy.new CreatedState(); + } + + @Test + public void testProcessIdentityRequest() { + mEapState.process(EAP_REQUEST_IDENTITY_PACKET); + + verify(mEapStateMachineSpy).transitionAndProcess( + any(IdentityState.class), eq(EAP_REQUEST_IDENTITY_PACKET)); + } + + @Test + public void testProcessNotificationRequest() { + EapResult eapResult = mEapState.process(EAP_REQUEST_NOTIFICATION_PACKET); + + // state shouldn't change after Notification request + assertTrue(eapResult instanceof EapResponse); + EapResponse eapResponse = (EapResponse) eapResult; + assertArrayEquals(EAP_RESPONSE_NOTIFICATION_PACKET, eapResponse.packet); + verify(mEapStateMachineSpy, never()).transitionAndProcess(any(), any()); + } + + @Test + public void testProcessSimStart() { + mEapState.process(EAP_REQUEST_SIM_START_PACKET); + + // EapStateMachine should change to MethodState for method-type packet + verify(mEapStateMachineSpy).transitionAndProcess( + any(MethodState.class), eq(EAP_REQUEST_SIM_START_PACKET)); + } +} |