Moved a static variable here, that should be here, added more tests
This commit is contained in:
@@ -1,8 +1,13 @@
|
|||||||
#!/usr/bin/env python
|
#!/usr/bin/env python
|
||||||
|
|
||||||
|
import time
|
||||||
|
|
||||||
from saml2.cache import Cache
|
from saml2.cache import Cache
|
||||||
from saml2.time_util import in_a_while, str_to_time
|
from saml2.time_util import in_a_while, str_to_time
|
||||||
from saml2.client import SESSION_INFO
|
|
||||||
|
SESSION_INFO_PATTERN = {"ava":{}, "came from":"", "not_on_or_after":0,
|
||||||
|
"issuer":"", "session_id":-1}
|
||||||
|
|
||||||
|
|
||||||
def _eq(l1,l2):
|
def _eq(l1,l2):
|
||||||
return set(l1) == set(l2)
|
return set(l1) == set(l2)
|
||||||
@@ -15,7 +20,7 @@ class TestClass:
|
|||||||
|
|
||||||
def test_0(self):
|
def test_0(self):
|
||||||
not_on_or_after = str_to_time(in_a_while(days=1))
|
not_on_or_after = str_to_time(in_a_while(days=1))
|
||||||
session_info = SESSION_INFO.copy()
|
session_info = SESSION_INFO_PATTERN.copy()
|
||||||
session_info["ava"] = {"givenName":["Derek"]}
|
session_info["ava"] = {"givenName":["Derek"]}
|
||||||
self.cache.set("1234", "abcd", session_info,
|
self.cache.set("1234", "abcd", session_info,
|
||||||
not_on_or_after)
|
not_on_or_after)
|
||||||
@@ -25,9 +30,9 @@ class TestClass:
|
|||||||
assert ava.keys() == ["givenName"]
|
assert ava.keys() == ["givenName"]
|
||||||
assert ava["givenName"] == ["Derek"]
|
assert ava["givenName"] == ["Derek"]
|
||||||
|
|
||||||
def test_1(self):
|
def test_add_ava_info(self):
|
||||||
not_on_or_after = str_to_time(in_a_while(days=1))
|
not_on_or_after = str_to_time(in_a_while(days=1))
|
||||||
session_info = SESSION_INFO.copy()
|
session_info = SESSION_INFO_PATTERN.copy()
|
||||||
session_info["ava"] = {"surName":["Jeter"]}
|
session_info["ava"] = {"surName":["Jeter"]}
|
||||||
self.cache.set("1234", "bcde", session_info,
|
self.cache.set("1234", "bcde", session_info,
|
||||||
not_on_or_after)
|
not_on_or_after)
|
||||||
@@ -38,16 +43,20 @@ class TestClass:
|
|||||||
assert ava["givenName"] == ["Derek"]
|
assert ava["givenName"] == ["Derek"]
|
||||||
assert ava["surName"] == ["Jeter"]
|
assert ava["surName"] == ["Jeter"]
|
||||||
|
|
||||||
def test_2(self):
|
def test_from_one_target_source(self):
|
||||||
session_info = self.cache.get("1234","bcde")
|
session_info = self.cache.get("1234","bcde")
|
||||||
ava = session_info["ava"]
|
ava = session_info["ava"]
|
||||||
assert _eq(ava.keys(), ["surName"])
|
assert _eq(ava.keys(), ["surName"])
|
||||||
assert ava["surName"] == ["Jeter"]
|
assert ava["surName"] == ["Jeter"]
|
||||||
|
session_info = self.cache.get("1234","abcd")
|
||||||
|
ava = session_info["ava"]
|
||||||
|
assert _eq(ava.keys(), ["givenName"])
|
||||||
|
assert ava["givenName"] == ["Derek"]
|
||||||
|
|
||||||
def test_entities(self):
|
def test_entities(self):
|
||||||
assert _eq(self.cache.entities("1234"), ["abcd", "bcde"])
|
assert _eq(self.cache.entities("1234"), ["abcd", "bcde"])
|
||||||
|
|
||||||
def test_4(self):
|
def test_remove_info(self):
|
||||||
self.cache.reset("1234", "bcde")
|
self.cache.reset("1234", "bcde")
|
||||||
assert self.cache.active("1234","bcde") == False
|
assert self.cache.active("1234","bcde") == False
|
||||||
assert self.cache.active("1234","abcd")
|
assert self.cache.active("1234","abcd")
|
||||||
@@ -62,7 +71,7 @@ class TestClass:
|
|||||||
|
|
||||||
def test_second_subject(self):
|
def test_second_subject(self):
|
||||||
not_on_or_after = str_to_time(in_a_while(days=1))
|
not_on_or_after = str_to_time(in_a_while(days=1))
|
||||||
session_info = SESSION_INFO.copy()
|
session_info = SESSION_INFO_PATTERN.copy()
|
||||||
session_info["ava"] = {"givenName":["Ichiro"],
|
session_info["ava"] = {"givenName":["Ichiro"],
|
||||||
"surName":["Suzuki"]}
|
"surName":["Suzuki"]}
|
||||||
self.cache.set("9876", "abcd", session_info,
|
self.cache.set("9876", "abcd", session_info,
|
||||||
@@ -75,3 +84,30 @@ class TestClass:
|
|||||||
assert ava["surName"] == ["Suzuki"]
|
assert ava["surName"] == ["Suzuki"]
|
||||||
assert _eq(self.cache.subjects(), ["1234","9876"])
|
assert _eq(self.cache.subjects(), ["1234","9876"])
|
||||||
|
|
||||||
|
def test_receivers(self):
|
||||||
|
assert _eq(self.cache.receivers("9876"), ["abcd"])
|
||||||
|
|
||||||
|
not_on_or_after = str_to_time(in_a_while(days=1))
|
||||||
|
session_info = SESSION_INFO_PATTERN.copy()
|
||||||
|
session_info["ava"] = {"givenName":["Ichiro"],
|
||||||
|
"surName":["Suzuki"]}
|
||||||
|
self.cache.set("9876", "bcde", session_info,
|
||||||
|
not_on_or_after)
|
||||||
|
|
||||||
|
assert _eq(self.cache.receivers("9876"), ["abcd", "bcde"])
|
||||||
|
assert _eq(self.cache.subjects(), ["1234","9876"])
|
||||||
|
|
||||||
|
def test_timeout(self):
|
||||||
|
not_on_or_after = str_to_time(in_a_while(seconds=1))
|
||||||
|
session_info = SESSION_INFO_PATTERN.copy()
|
||||||
|
session_info["ava"] = {"givenName":["Alex"],
|
||||||
|
"surName":["Rodriguez"]}
|
||||||
|
self.cache.set("1000", "bcde", session_info,
|
||||||
|
not_on_or_after)
|
||||||
|
|
||||||
|
time.sleep(2)
|
||||||
|
(ava, inactive) = self.cache.get_identity("1000")
|
||||||
|
assert inactive == ["bcde"]
|
||||||
|
assert ava == {}
|
||||||
|
|
||||||
|
|
||||||
Reference in New Issue
Block a user