1.1 --- /dev/null Thu Jan 01 00:00:00 1970 +0000 1.2 +++ b/dom/tests/mochitest/sessionstorage/test_cookieSession.html Wed Dec 31 06:09:35 2014 +0100 1.3 @@ -0,0 +1,124 @@ 1.4 +<html xmlns="http://www.w3.org/1999/xhtml"> 1.5 +<head> 1.6 +<title>cookie per-session only test</title> 1.7 + 1.8 +<script type="text/javascript" src="/tests/SimpleTest/SimpleTest.js"></script> 1.9 +<link rel="stylesheet" type="text/css" href="/tests/SimpleTest/test.css" /> 1.10 + 1.11 +<script type="text/javascript"> 1.12 + 1.13 +/* 1.14 + Set cookie access to be just per session and store to the sessionStorage. 1.15 + Content stored must prevail only for session of the browser, so it must 1.16 + be accessible in another window we try to access that key in the same 1.17 + storage. 1.18 + */ 1.19 + 1.20 +function pushCookie(aValue, aNext) { 1.21 + SpecialPowers.pushPermissions([{'type': 'cookie', 'allow': aValue, 'context': document}], pushPermissionAndTest); 1.22 +} 1.23 + 1.24 +function pushPermissionAndTest() { 1.25 + var test = tests.shift(); 1.26 + if (test) { 1.27 + document.getElementById('testframe').onload = test; 1.28 + /* After every permission change, an iframe has to be reloaded, 1.29 + otherwise this test causes failures in b2g (oop) mochitest, because 1.30 + the permission changes don't seem to be always picked up 1.31 + by the code that excercises it */ 1.32 + document.getElementById('testframe').contentWindow.location.reload(); 1.33 + } else { 1.34 + ok(false, 'should not be reached'); 1.35 + SimpleTest.finish(); 1.36 + } 1.37 +} 1.38 + 1.39 +function startTest() { 1.40 + pushCookie(SpecialPowers.Ci.nsICookiePermission.ACCESS_DEFAULT); 1.41 +} 1.42 + 1.43 +var tests = [ 1.44 + function test1() { 1.45 + sessionStorage.setItem("persistent1", "persistent value 1"); 1.46 + sessionStorage.setItem("persistent2", "persistent value 2"); 1.47 + 1.48 + pushCookie(SpecialPowers.Ci.nsICookiePermission.ACCESS_SESSION); 1.49 + }, 1.50 + 1.51 + function test2() { 1.52 + sessionStorage.setItem("session only", "session value"); 1.53 + is(sessionStorage.getItem("session only"), "session value", "Value present when cookies in session-only mode"); 1.54 + is(sessionStorage.getItem("persistent1"), "persistent value 1", "Persistent value present"); 1.55 + is(sessionStorage.getItem("persistent2"), "persistent value 2", "Persistent value present"); 1.56 + 1.57 + sessionStorage.setItem("persistent1", "changed persistent value 1"); 1.58 + sessionStorage.removeItem("persistent2"); 1.59 + 1.60 + is(sessionStorage.getItem("session only"), "session value", "Value present when cookies in session-only mode"); 1.61 + is(sessionStorage.getItem("persistent1"), "changed persistent value 1", "Persistent value present"); 1.62 + is(sessionStorage.getItem("persistent2"), null, "Persistent value removed"); 1.63 + 1.64 + // This clear has to delete only changes made in session only mode 1.65 + sessionStorage.clear(); 1.66 + 1.67 + is(sessionStorage.getItem("session only"), null, "Value not present when cookies in session-only mode after delete"); 1.68 + is(sessionStorage.getItem("persistent1"), null, "Persistent value not present in session only after delete"); 1.69 + is(sessionStorage.getItem("persistent2"), null, "Persistent value not present in session only after delete"); 1.70 + 1.71 + sessionStorage.setItem("session only 2", "must be deleted on drop of session-only cookies permissions"); 1.72 + 1.73 + pushCookie(SpecialPowers.Ci.nsICookiePermission.ACCESS_DEFAULT); 1.74 + }, 1.75 + 1.76 + function test3() { 1.77 + is(sessionStorage.getItem("session only"), null, "No value when cookies are in default mode"); 1.78 + is(sessionStorage.getItem("session only 2"), null, "No value when cookies are in default mode"); 1.79 + is(sessionStorage.getItem("persistent1"), "persistent value 1", "Persistent value present"); 1.80 + is(sessionStorage.getItem("persistent2"), "persistent value 2", "Persistent value present"); 1.81 + 1.82 + pushCookie(SpecialPowers.Ci.nsICookiePermission.ACCESS_SESSION); 1.83 + }, 1.84 + 1.85 + function test4() { 1.86 + is(sessionStorage.getItem("session only"), null, "Value not present when cookies in session-only mode after delete"); 1.87 + is(sessionStorage.getItem("session only 2"), null, "Value not present when cookies in session-only mode after delete"); 1.88 + is(sessionStorage.getItem("persistent1"), "persistent value 1", "Persistent value present again"); 1.89 + is(sessionStorage.getItem("persistent2"), "persistent value 2", "Persistent value present again"); 1.90 + 1.91 + pushCookie(SpecialPowers.Ci.nsICookiePermission.ACCESS_DEFAULT); 1.92 + }, 1.93 + 1.94 + function test5() { 1.95 + sessionStorage.clear(); 1.96 + 1.97 + is(sessionStorage.getItem("session only"), null, "No value when cookies are in default mode"); 1.98 + is(sessionStorage.getItem("persistent1"), null, "Persistent value not present after delete"); 1.99 + is(sessionStorage.getItem("persistent2"), null, "Persistent value not present after delete"); 1.100 + 1.101 + pushCookie(SpecialPowers.Ci.nsICookiePermission.ACCESS_SESSION); 1.102 + }, 1.103 + 1.104 + function test6() { 1.105 + is(sessionStorage.getItem("session only"), null, "Value not present when cookies in session-only mode after delete"); 1.106 + is(sessionStorage.getItem("session only 2"), null, "No value when cookies are in default mode"); 1.107 + is(sessionStorage.getItem("persistent1"), null, "Persistent value not present in session only after delete"); 1.108 + is(sessionStorage.getItem("persistent2"), null, "Persistent value not present in session only after delete"); 1.109 + 1.110 + pushCookie(SpecialPowers.Ci.nsICookiePermission.ACCESS_DEFAULT); 1.111 + }, 1.112 + 1.113 + function test7() { 1.114 + SimpleTest.finish(); 1.115 + } 1.116 +]; 1.117 + 1.118 +SimpleTest.waitForExplicitFinish(); 1.119 + 1.120 +</script> 1.121 + 1.122 +</head> 1.123 + 1.124 +<body onload="startTest();"> 1.125 +<iframe id="testframe" src="data:text/html;charset=utf-8,"></iframe> 1.126 +</body> 1.127 +</html>