diff options
author | android-build-team Robot <android-build-team-robot@google.com> | 2019-11-11 21:19:18 +0000 |
---|---|---|
committer | android-build-team Robot <android-build-team-robot@google.com> | 2019-11-11 21:19:18 +0000 |
commit | db74d7937f3a9503f0e2590ec24c3bcfbf259ce0 (patch) | |
tree | b39c3e794945072d38b97c963c5a6f10753514e1 /tests/iketests/src/java/com/android/internal/net/eap/message/mschapv2/EapMsChapV2ChallengeResponseTest.java | |
parent | 7ffef5cae6d3c93c93b4055fd22517d44f77acda (diff) | |
parent | eb4c77d7228f956f928c7d3500a220339ee78388 (diff) | |
download | ike-db74d7937f3a9503f0e2590ec24c3bcfbf259ce0.tar.gz |
Snap for 6001391 from eb4c77d7228f956f928c7d3500a220339ee78388 to qt-aml-tzdata-release
Change-Id: Ic6fc3b152696e0096d00036f460262a8b0319394
Diffstat (limited to 'tests/iketests/src/java/com/android/internal/net/eap/message/mschapv2/EapMsChapV2ChallengeResponseTest.java')
-rw-r--r-- | tests/iketests/src/java/com/android/internal/net/eap/message/mschapv2/EapMsChapV2ChallengeResponseTest.java | 109 |
1 files changed, 109 insertions, 0 deletions
diff --git a/tests/iketests/src/java/com/android/internal/net/eap/message/mschapv2/EapMsChapV2ChallengeResponseTest.java b/tests/iketests/src/java/com/android/internal/net/eap/message/mschapv2/EapMsChapV2ChallengeResponseTest.java new file mode 100644 index 00000000..3e243a98 --- /dev/null +++ b/tests/iketests/src/java/com/android/internal/net/eap/message/mschapv2/EapMsChapV2ChallengeResponseTest.java @@ -0,0 +1,109 @@ +/* + * 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.message.mschapv2; + +import static com.android.internal.net.eap.message.mschapv2.EapMsChapV2PacketDefinitions.EAP_MSCHAP_V2_CHALLENGE_RESPONSE; +import static com.android.internal.net.eap.message.mschapv2.EapMsChapV2PacketDefinitions.ID_INT; +import static com.android.internal.net.eap.message.mschapv2.EapMsChapV2PacketDefinitions.NT_RESPONSE_BYTES; +import static com.android.internal.net.eap.message.mschapv2.EapMsChapV2PacketDefinitions.PEER_CHALLENGE_BYTES; +import static com.android.internal.net.eap.message.mschapv2.EapMsChapV2PacketDefinitions.PEER_NAME_BYTES; +import static com.android.internal.net.eap.message.mschapv2.EapMsChapV2PacketDefinitions.SHORT_CHALLENGE_BYTES; +import static com.android.internal.net.eap.message.mschapv2.EapMsChapV2PacketDefinitions.SHORT_NT_RESPONSE; +import static com.android.internal.net.eap.message.mschapv2.EapMsChapV2TypeData.EAP_MSCHAP_V2_RESPONSE; + +import static org.junit.Assert.assertArrayEquals; +import static org.junit.Assert.assertEquals; +import static org.junit.Assert.fail; + +import com.android.internal.net.eap.exceptions.mschapv2.EapMsChapV2ParsingException; +import com.android.internal.net.eap.message.mschapv2.EapMsChapV2TypeData.EapMsChapV2ChallengeResponse; + +import org.junit.Test; + +public class EapMsChapV2ChallengeResponseTest { + private static final int FLAGS = 0; + private static final int INVALID_FLAGS = 0xFF; + + @Test + public void testConstructor() throws Exception { + EapMsChapV2ChallengeResponse challengeResponse = + new EapMsChapV2ChallengeResponse( + ID_INT, PEER_CHALLENGE_BYTES, NT_RESPONSE_BYTES, FLAGS, PEER_NAME_BYTES); + assertEquals(EAP_MSCHAP_V2_RESPONSE, challengeResponse.opCode); + assertEquals(ID_INT, challengeResponse.msChapV2Id); + assertEquals(EAP_MSCHAP_V2_CHALLENGE_RESPONSE.length, challengeResponse.msLength); + assertArrayEquals(PEER_CHALLENGE_BYTES, challengeResponse.peerChallenge); + assertArrayEquals(NT_RESPONSE_BYTES, challengeResponse.ntResponse); + assertEquals(FLAGS, challengeResponse.flags); + assertArrayEquals(PEER_NAME_BYTES, challengeResponse.name); + } + + @Test + public void testConstructorInvalidChallenge() { + try { + EapMsChapV2ChallengeResponse challengeResponse = + new EapMsChapV2ChallengeResponse( + ID_INT, + SHORT_CHALLENGE_BYTES, + NT_RESPONSE_BYTES, + FLAGS, + PEER_NAME_BYTES); + fail("Expected EapMsChapV2ParsingException for invalid Peer Challenge length"); + } catch (EapMsChapV2ParsingException expected) { + } + } + + @Test + public void testConstructorInvalidNtResponse() { + try { + EapMsChapV2ChallengeResponse challengeResponse = + new EapMsChapV2ChallengeResponse( + ID_INT, + PEER_CHALLENGE_BYTES, + SHORT_NT_RESPONSE, + FLAGS, + PEER_NAME_BYTES); + fail("Expected EapMsChapV2ParsingException for invalid NT-Response length"); + } catch (EapMsChapV2ParsingException expected) { + } + } + + @Test + public void testConstructorInvalidFlags() { + try { + EapMsChapV2ChallengeResponse challengeResponse = + new EapMsChapV2ChallengeResponse( + ID_INT, + PEER_CHALLENGE_BYTES, + NT_RESPONSE_BYTES, + INVALID_FLAGS, + PEER_NAME_BYTES); + fail("Expected EapMsChapV2ParsingException for non-zero Flags value"); + } catch (EapMsChapV2ParsingException expected) { + } + } + + @Test + public void testEncode() throws Exception { + EapMsChapV2ChallengeResponse challengeResponse = + new EapMsChapV2ChallengeResponse( + ID_INT, PEER_CHALLENGE_BYTES, NT_RESPONSE_BYTES, FLAGS, PEER_NAME_BYTES); + byte[] encodedChallengeResponse = challengeResponse.encode(); + + assertArrayEquals(EAP_MSCHAP_V2_CHALLENGE_RESPONSE, encodedChallengeResponse); + } +} |