cookies.SessionIT.java Source code

Java tutorial

Introduction

Here is the source code for cookies.SessionIT.java

Source

/*
 * #%L
 * Wisdom-Framework
 * %%
 * Copyright (C) 2013 - 2014 Wisdom Framework
 * %%
 * 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.
 * #L%
 */
package cookies;

import org.apache.http.cookie.Cookie;
import org.junit.Test;
import org.wisdom.test.http.HttpResponse;
import org.wisdom.test.parents.WisdomBlackBoxTest;

import java.io.InputStream;

import static org.assertj.core.api.Assertions.assertThat;

public class SessionIT extends WisdomBlackBoxTest {

    @Test
    public void testSessionManipulation() throws Exception {
        HttpResponse<String> response = get("/session").asString();
        Cookie session = response.cookie("wisdom_SESSION");
        assertThat(session).isNotNull();
        assertThat(session.getPath()).isEqualTo("/");
        assertThat(session.getValue()).contains("foo=bar").contains("baz=bah").contains("blah=42");

        response = get("/session").asString();
        session = response.cookie("wisdom_SESSION");
        // blah removed
        assertThat(session.getValue()).contains("foo=bar").contains("baz=bah").doesNotContain("blah");

        response = get("/session/clear").asString();
        session = response.cookie("wisdom_SESSION");
        // Session cleared... no more cookie.
        assertThat(session).isNull();
    }

    @Test
    public void testSessionWithAnotherCookie() throws Exception {
        HttpResponse<String> response = get("/session/cookie").asString();
        Cookie session = response.cookie("wisdom_SESSION");
        Cookie cookie = response.cookie("toto");

        assertThat(session).isNotNull();
        assertThat(cookie).isNotNull();
        assertThat(session.getPath()).isEqualTo("/");
        assertThat(cookie.getPath()).isEqualTo("/");
        assertThat(session.getValue()).contains("foo=bar");
        assertThat(cookie.getValue()).contains("titi");

        // Clear the cookie
        response = get("/session/cookie/clear").asString();
        session = response.cookie("wisdom_SESSION");
        cookie = response.cookie("toto");
        assertThat(session).isNotNull();
        assertThat(cookie).isNull();

        response = get("/session/clear").asString();
        session = response.cookie("wisdom_SESSION");
        assertThat(session).isNull();
    }

    @Test
    public void noCookiesOnAsset() throws Exception {
        HttpResponse<String> response = get("/session").asString();
        Cookie session = response.cookie("wisdom_SESSION");
        assertThat(session).isNotNull();
        assertThat(session.getPath()).isEqualTo("/");
        assertThat(session.getValue()).contains("foo=bar").contains("baz=bah").contains("blah=42");

        HttpResponse<InputStream> resp = get("/assets/empty.txt").asBinary();
        assertThat(resp.code()).isEqualTo(OK);
        assertThat(resp.header(SET_COOKIE)).isNull();

        response = get("/session/clear").asString();
        session = response.cookie("wisdom_SESSION");
        // Session cleared... no more cookie.
        assertThat(session).isNull();
    }
}