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