blob: 8d8bcab3cf16d7a8aaf815602f74e0b77a085049 [file] [log] [blame]
/**
* Licensed to the Apache Software Foundation (ASF) under one
* or more contributor license agreements. See the NOTICE file
* distributed with this work for additional information
* regarding copyright ownership. The ASF licenses this file
* to you 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 org.apache.hadoop.gateway.provider.federation;
import java.util.ArrayList;
import junit.framework.TestCase;
import org.apache.hadoop.gateway.services.security.token.impl.JWTToken;
import org.junit.Test;
public class JWTTokenTest extends TestCase {
private static final String JWT_TOKEN = "eyJhbGciOiJIUzI1NiIsInR5cCI6IkpXVCJ9.eyJpYXQiOjE0MTY5MjkxMDksImp0aSI6ImFhN2Y4ZDBhOTVjIiwic2NvcGVzIjpbInJlcG8iLCJwdWJsaWNfcmVwbyJdfQ.XCEwpBGvOLma4TCoh36FU7XhUbcskygS81HE1uHLf0E";
private static final String HEADER = "{\"alg\":\"RS256\", \"type\":\"JWT\"}";
private static final String CLAIMS = "{\"iss\": \"gateway\", \"prn\": \"john.doe@example.com\", \"aud\": \"https://login.example.com\", \"exp\": \"1363360913\"}";
// public void testTokenParsing() throws Exception {
// try {
// JWTToken token = JWTToken.parseToken(JWT_TOKEN);
// assertEquals(token.getHeader(), HEADER);
// assertEquals(token.getClaims(), CLAIMS);
//
// assertEquals(token.getIssuer(), "gateway");
// assertEquals(token.getPrincipal(), "john.doe@example.com");
// assertEquals(token.getAudience(), "https://login.example.com");
// assertEquals(token.getExpires(), "1363360913");
// }
// catch (ParseException pe) {
// fail("ParseException encountered.");
// }
// }
@Test
public void testTokenCreation() throws Exception {
String[] claims = new String[4];
claims[0] = "KNOXSSO";
claims[1] = "john.doe@example.com";
claims[2] = "https://login.example.com";
claims[3] = Long.toString( ( System.currentTimeMillis()/1000 ) + 300);
JWTToken token = new JWTToken("RS256", claims);
assertEquals("KNOXSSO", token.getIssuer());
assertEquals("john.doe@example.com", token.getSubject());
assertEquals("https://login.example.com", token.getAudience());
}
@Test
public void testTokenCreationWithAudienceListSingle() throws Exception {
String[] claims = new String[4];
claims[0] = "KNOXSSO";
claims[1] = "john.doe@example.com";
claims[2] = null;
claims[3] = Long.toString( ( System.currentTimeMillis()/1000 ) + 300);
ArrayList<String> audiences = new ArrayList<String>();
audiences.add("https://login.example.com");
JWTToken token = new JWTToken("RS256", claims, audiences);
assertEquals("KNOXSSO", token.getIssuer());
assertEquals("john.doe@example.com", token.getSubject());
assertEquals("https://login.example.com", token.getAudience());
assertEquals(1, token.getAudienceClaims().length);
}
@Test
public void testTokenCreationWithAudienceListMultiple() throws Exception {
String[] claims = new String[4];
claims[0] = "KNOXSSO";
claims[1] = "john.doe@example.com";
claims[2] = null;
claims[3] = Long.toString( ( System.currentTimeMillis()/1000 ) + 300);
ArrayList<String> audiences = new ArrayList<String>();
audiences.add("https://login.example.com");
audiences.add("KNOXSSO");
JWTToken token = new JWTToken("RS256", claims, audiences);
assertEquals("KNOXSSO", token.getIssuer());
assertEquals("john.doe@example.com", token.getSubject());
assertEquals("https://login.example.com", token.getAudience());
assertEquals(2, token.getAudienceClaims().length);
}
@Test
public void testTokenCreationWithAudienceListCombined() throws Exception {
String[] claims = new String[4];
claims[0] = "KNOXSSO";
claims[1] = "john.doe@example.com";
claims[2] = "LJM";
claims[3] = Long.toString( ( System.currentTimeMillis()/1000 ) + 300);
ArrayList<String> audiences = new ArrayList<String>();
audiences.add("https://login.example.com");
audiences.add("KNOXSSO");
JWTToken token = new JWTToken("RS256", claims, audiences);
assertEquals("KNOXSSO", token.getIssuer());
assertEquals("john.doe@example.com", token.getSubject());
assertEquals("https://login.example.com", token.getAudience());
assertEquals(3, token.getAudienceClaims().length);
}
@Test
public void testTokenCreationWithNullAudienceList() throws Exception {
String[] claims = new String[4];
claims[0] = "KNOXSSO";
claims[1] = "john.doe@example.com";
claims[2] = null;
claims[3] = Long.toString( ( System.currentTimeMillis()/1000 ) + 300);
ArrayList<String> audiences = null;
JWTToken token = new JWTToken("RS256", claims, audiences);
assertEquals("KNOXSSO", token.getIssuer());
assertEquals("john.doe@example.com", token.getSubject());
assertEquals(null, token.getAudience());
assertEquals(null, token.getAudienceClaims());
}
}