ResourceUtilsTest.java

78 lines | 2.254 kB Blame History Raw Download
/*
 * 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");
    }
}