/* * Copyright 2016 LinkedIn Corp. * * 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 azkaban.restli; import azkaban.fixture.MockResourceContext; import org.junit.Test; import static org.junit.Assert.assertEquals; import static org.junit.Assert.assertNotNull; public class ResourceUtilsTest { @Test public void testWhenNoXForwardedForHeaderUseClientIp(){ String clientIp = "127.0.0.1:10000"; MockResourceContext ctx = MockResourceContext.getResourceContext(clientIp); assertNotNull(ctx); String ip = ResourceUtils.getRealClientIpAddr(ctx); assertEquals(ip, "127.0.0.1"); } @Test public void testWhenClientIpNoPort(){ String clientIp = "192.168.1.1"; MockResourceContext ctx = MockResourceContext.getResourceContext(clientIp); assertNotNull(ctx); String ip = ResourceUtils.getRealClientIpAddr(ctx); assertEquals(ip, "192.168.1.1"); } @Test public void testWhenXForwardedForHeaderUseHeader(){ String clientIp = "127.0.0.1:10000"; String upstreamIp = "192.168.1.1:10000"; MockResourceContext ctx = MockResourceContext.getResourceContextWithUpstream(clientIp, upstreamIp); assertNotNull(ctx); String ip = ResourceUtils.getRealClientIpAddr(ctx); assertEquals(ip, "192.168.1.1"); } @Test public void testWhenXForwardedForHeaderMultipleUpstreamsUseHeader(){ String clientIp = "127.0.0.1:10000"; String upstreamIp = "192.168.1.1:10000"; MockResourceContext ctx = MockResourceContext.getResourceContextWithMultipleUpstreams(clientIp, upstreamIp); assertNotNull(ctx); String ip = ResourceUtils.getRealClientIpAddr(ctx); assertEquals(ip, "192.168.1.1"); } }