/* * #%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(); } }