org.zaproxy.zap.network.ZapCookieSpecUnitTest.java Source code

Java tutorial

Introduction

Here is the source code for org.zaproxy.zap.network.ZapCookieSpecUnitTest.java

Source

/*
 * Zed Attack Proxy (ZAP) and its related class files.
 * 
 * ZAP is an HTTP/HTTPS proxy for assessing web application security.
 * 
 * Copyright 2017 The ZAP Development Team
 * 
 * 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 org.zaproxy.zap.network;

import org.apache.commons.httpclient.Cookie;
import org.apache.commons.httpclient.cookie.CookieSpec;
import org.apache.commons.httpclient.cookie.MalformedCookieException;
import org.junit.Test;

/**
 * Unit test for {@link ZapCookieSpec}.
 */
public class ZapCookieSpecUnitTest {

    private static final String HOST = "example.com";
    private static final int PORT = 8443;
    private static final String PATH = "/path/file";
    private static final boolean SECURE = true;

    @Test(expected = IllegalArgumentException.class)
    public void shouldThrowWhenValidatingWithNullHost() throws MalformedCookieException {
        // Given
        CookieSpec cookieSpec = createCookieSpec();
        String host = null;
        // When
        cookieSpec.validate(host, PORT, PATH, SECURE, new Cookie());
        // Then = IllegalArgumentException.
    }

    @Test(expected = IllegalArgumentException.class)
    public void shouldThrowWhenValidatingWithEmptyHost() throws MalformedCookieException {
        // Given
        CookieSpec cookieSpec = createCookieSpec();
        String host = "";
        // When
        cookieSpec.validate(host, PORT, PATH, SECURE, new Cookie());
        // Then = IllegalArgumentException.
    }

    @Test(expected = IllegalArgumentException.class)
    public void shouldThrowWhenValidatingWithNegativePort() throws MalformedCookieException {
        // Given
        CookieSpec cookieSpec = createCookieSpec();
        int port = -1;
        // When
        cookieSpec.validate(HOST, port, PATH, SECURE, new Cookie());
        // Then = IllegalArgumentException.
    }

    @Test(expected = IllegalArgumentException.class)
    public void shouldThrowWhenValidatingWithNullPath() throws MalformedCookieException {
        // Given
        CookieSpec cookieSpec = createCookieSpec();
        String path = null;
        // When
        cookieSpec.validate(HOST, PORT, path, SECURE, new Cookie());
        // Then = IllegalArgumentException.
    }

    @Test(expected = NullPointerException.class)
    public void shouldThrowWhenValidatingWithNullCookie() throws MalformedCookieException {
        // Given
        CookieSpec cookieSpec = createCookieSpec();
        Cookie cookie = null;
        // When
        cookieSpec.validate(HOST, PORT, PATH, SECURE, cookie);
        // Then = NullPointerException.
    }

    @Test(expected = NullPointerException.class)
    public void shouldThrowWhenValidatingWithNullCookieDomain() throws MalformedCookieException {
        // Given
        CookieSpec cookieSpec = createCookieSpec();
        Cookie cookie = new Cookie(null, "name", "value");
        // When
        cookieSpec.validate(HOST, PORT, PATH, SECURE, cookie);
        // Then = NullPointerException.
    }

    @Test(expected = MalformedCookieException.class)
    public void shouldBeMalformedWhenValidatingWithNegativeCookieVersion() throws MalformedCookieException {
        // Given
        CookieSpec cookieSpec = createCookieSpec();
        Cookie cookie = new Cookie(HOST, "name", "value");
        cookie.setVersion(-1);
        // When
        cookieSpec.validate(HOST, PORT, PATH, SECURE, cookie);
        // Then = MalformedCookieException.
    }

    @Test
    public void shouldBeValidEvenIfCookiePathIsDifferentThanOrigin() throws MalformedCookieException {
        // Given
        CookieSpec cookieSpec = createCookieSpec();
        Cookie cookie = new Cookie(HOST, "name", "value");
        cookie.setPath("/other/path/");
        // When
        cookieSpec.validate(HOST, PORT, PATH, SECURE, cookie);
        // Then = No exception.
    }

    private static CookieSpec createCookieSpec() {
        return new ZapCookieSpec();
    }
}