Small improvements for tests
This commit is contained in:
parent
02575580c6
commit
5b3fbb79a1
@ -43,9 +43,8 @@ class BaseRequestsMixIn:
|
|||||||
assert status == 303
|
assert status == 303
|
||||||
assert answer == "Redirected to .web"
|
assert answer == "Redirected to .web"
|
||||||
# Test the creation of the collection
|
# Test the creation of the collection
|
||||||
self.request("MKCOL", "/calendar.ics/")
|
status, _, _ = self.request("MKCALENDAR", "/calendar.ics/")
|
||||||
self.request(
|
assert status == 201
|
||||||
"PUT", "/calendar.ics/", "BEGIN:VCALENDAR\r\nEND:VCALENDAR")
|
|
||||||
status, headers, answer = self.request("GET", "/calendar.ics/")
|
status, headers, answer = self.request("GET", "/calendar.ics/")
|
||||||
assert "BEGIN:VCALENDAR" in answer
|
assert "BEGIN:VCALENDAR" in answer
|
||||||
assert "END:VCALENDAR" in answer
|
assert "END:VCALENDAR" in answer
|
||||||
@ -63,9 +62,8 @@ class BaseRequestsMixIn:
|
|||||||
|
|
||||||
def test_add_event(self):
|
def test_add_event(self):
|
||||||
"""Add an event."""
|
"""Add an event."""
|
||||||
self.request("MKCOL", "/calendar.ics/")
|
status, _, _ = self.request("MKCALENDAR", "/calendar.ics/")
|
||||||
self.request(
|
assert status == 201
|
||||||
"PUT", "/calendar.ics/", "BEGIN:VCALENDAR\r\nEND:VCALENDAR")
|
|
||||||
event = get_file_content("event1.ics")
|
event = get_file_content("event1.ics")
|
||||||
path = "/calendar.ics/event1.ics"
|
path = "/calendar.ics/event1.ics"
|
||||||
status, headers, answer = self.request("PUT", path, event)
|
status, headers, answer = self.request("PUT", path, event)
|
||||||
@ -79,9 +77,8 @@ class BaseRequestsMixIn:
|
|||||||
|
|
||||||
def test_add_todo(self):
|
def test_add_todo(self):
|
||||||
"""Add a todo."""
|
"""Add a todo."""
|
||||||
self.request("MKCOL", "/calendar.ics/")
|
status, _, _ = self.request("MKCALENDAR", "/calendar.ics/")
|
||||||
self.request(
|
assert status == 201
|
||||||
"PUT", "/calendar.ics/", "BEGIN:VCALENDAR\r\nEND:VCALENDAR")
|
|
||||||
todo = get_file_content("todo1.ics")
|
todo = get_file_content("todo1.ics")
|
||||||
path = "/calendar.ics/todo1.ics"
|
path = "/calendar.ics/todo1.ics"
|
||||||
status, headers, answer = self.request("PUT", path, todo)
|
status, headers, answer = self.request("PUT", path, todo)
|
||||||
@ -126,9 +123,8 @@ class BaseRequestsMixIn:
|
|||||||
|
|
||||||
def test_update(self):
|
def test_update(self):
|
||||||
"""Update an event."""
|
"""Update an event."""
|
||||||
self.request("MKCOL", "/calendar.ics/")
|
status, _, _ = self.request("MKCALENDAR", "/calendar.ics/")
|
||||||
self.request(
|
assert status == 201
|
||||||
"PUT", "/calendar.ics/", "BEGIN:VCALENDAR\r\nEND:VCALENDAR")
|
|
||||||
event = get_file_content("event1.ics")
|
event = get_file_content("event1.ics")
|
||||||
path = "/calendar.ics/event1.ics"
|
path = "/calendar.ics/event1.ics"
|
||||||
status, headers, answer = self.request("PUT", path, event)
|
status, headers, answer = self.request("PUT", path, event)
|
||||||
@ -192,9 +188,8 @@ class BaseRequestsMixIn:
|
|||||||
|
|
||||||
def test_delete(self):
|
def test_delete(self):
|
||||||
"""Delete an event."""
|
"""Delete an event."""
|
||||||
self.request("MKCOL", "/calendar.ics/")
|
status, _, _ = self.request("MKCALENDAR", "/calendar.ics/")
|
||||||
self.request(
|
assert status == 201
|
||||||
"PUT", "/calendar.ics/", "BEGIN:VCALENDAR\r\nEND:VCALENDAR")
|
|
||||||
event = get_file_content("event1.ics")
|
event = get_file_content("event1.ics")
|
||||||
path = "/calendar.ics/event1.ics"
|
path = "/calendar.ics/event1.ics"
|
||||||
status, headers, answer = self.request("PUT", path, event)
|
status, headers, answer = self.request("PUT", path, event)
|
||||||
@ -207,13 +202,15 @@ class BaseRequestsMixIn:
|
|||||||
|
|
||||||
def test_mkcalendar(self):
|
def test_mkcalendar(self):
|
||||||
"""Make a calendar."""
|
"""Make a calendar."""
|
||||||
self.request("MKCALENDAR", "/calendar.ics/")
|
status, _, _ = self.request("MKCALENDAR", "/calendar.ics/")
|
||||||
|
assert status == 201
|
||||||
status, headers, answer = self.request("GET", "/calendar.ics/")
|
status, headers, answer = self.request("GET", "/calendar.ics/")
|
||||||
assert status == 200
|
assert status == 200
|
||||||
|
|
||||||
def test_move(self):
|
def test_move(self):
|
||||||
"""Move a item."""
|
"""Move a item."""
|
||||||
self.request("MKCALENDAR", "/calendar.ics/")
|
status, _, _ = self.request("MKCALENDAR", "/calendar.ics/")
|
||||||
|
assert status == 201
|
||||||
event = get_file_content("event1.ics")
|
event = get_file_content("event1.ics")
|
||||||
path1 = "/calendar.ics/event1.ics"
|
path1 = "/calendar.ics/event1.ics"
|
||||||
path2 = "/calendar.ics/event2.ics"
|
path2 = "/calendar.ics/event2.ics"
|
||||||
@ -237,7 +234,7 @@ class BaseRequestsMixIn:
|
|||||||
|
|
||||||
def test_delete_collection(self):
|
def test_delete_collection(self):
|
||||||
"""Delete a collection."""
|
"""Delete a collection."""
|
||||||
self.request("MKCOL", "/calendar.ics/")
|
self.request("MKCALENDAR", "/calendar.ics/")
|
||||||
event = get_file_content("event1.ics")
|
event = get_file_content("event1.ics")
|
||||||
self.request("PUT", "/calendar.ics/event1.ics", event)
|
self.request("PUT", "/calendar.ics/event1.ics", event)
|
||||||
status, headers, answer = self.request("DELETE", "/calendar.ics/")
|
status, headers, answer = self.request("DELETE", "/calendar.ics/")
|
||||||
@ -248,7 +245,7 @@ class BaseRequestsMixIn:
|
|||||||
|
|
||||||
def test_delete_root_collection(self):
|
def test_delete_root_collection(self):
|
||||||
"""Delete the root collection."""
|
"""Delete the root collection."""
|
||||||
self.request("MKCOL", "/calendar.ics/")
|
self.request("MKCALENDAR", "/calendar.ics/")
|
||||||
event = get_file_content("event1.ics")
|
event = get_file_content("event1.ics")
|
||||||
self.request("PUT", "/event1.ics", event)
|
self.request("PUT", "/event1.ics", event)
|
||||||
self.request("PUT", "/calendar.ics/event1.ics", event)
|
self.request("PUT", "/calendar.ics/event1.ics", event)
|
||||||
@ -278,7 +275,8 @@ class BaseRequestsMixIn:
|
|||||||
|
|
||||||
def test_proppatch(self):
|
def test_proppatch(self):
|
||||||
"""Write a property and read it back."""
|
"""Write a property and read it back."""
|
||||||
self.request("MKCALENDAR", "/calendar.ics/")
|
status, _, _ = self.request("MKCALENDAR", "/calendar.ics/")
|
||||||
|
assert status == 201
|
||||||
proppatch = get_file_content("proppatch1.xml")
|
proppatch = get_file_content("proppatch1.xml")
|
||||||
status, headers, answer = self.request(
|
status, headers, answer = self.request(
|
||||||
"PROPPATCH", "/calendar.ics/", proppatch)
|
"PROPPATCH", "/calendar.ics/", proppatch)
|
||||||
@ -295,7 +293,6 @@ class BaseRequestsMixIn:
|
|||||||
|
|
||||||
def test_put_whole_calendar_multiple_events_with_same_uid(self):
|
def test_put_whole_calendar_multiple_events_with_same_uid(self):
|
||||||
"""Add two events with the same UID."""
|
"""Add two events with the same UID."""
|
||||||
self.request("MKCOL", "/calendar.ics/")
|
|
||||||
self.request("PUT", "/calendar.ics/", get_file_content("event2.ics"))
|
self.request("PUT", "/calendar.ics/", get_file_content("event2.ics"))
|
||||||
status, headers, answer = self.request(
|
status, headers, answer = self.request(
|
||||||
"REPORT", "/calendar.ics/",
|
"REPORT", "/calendar.ics/",
|
||||||
@ -310,9 +307,9 @@ class BaseRequestsMixIn:
|
|||||||
def _test_filter(self, filters, kind="event", items=1):
|
def _test_filter(self, filters, kind="event", items=1):
|
||||||
filters_text = "".join(
|
filters_text = "".join(
|
||||||
"<C:filter>%s</C:filter>" % filter_ for filter_ in filters)
|
"<C:filter>%s</C:filter>" % filter_ for filter_ in filters)
|
||||||
self.request("MKCOL", "/calendar.ics/")
|
status, _, _ = self.request("DELETE", "/calendar.ics/")
|
||||||
status, _, _ = self.request(
|
assert status in (200, 404)
|
||||||
"PUT", "/calendar.ics/", "BEGIN:VCALENDAR\r\nEND:VCALENDAR")
|
status, _, _ = self.request("MKCALENDAR", "/calendar.ics/")
|
||||||
assert status == 201
|
assert status == 201
|
||||||
for i in range(items):
|
for i in range(items):
|
||||||
filename = "{}{}.ics".format(kind, i + 1)
|
filename = "{}{}.ics".format(kind, i + 1)
|
||||||
@ -1047,16 +1044,16 @@ class BaseRequestsMixIn:
|
|||||||
def test_fsync(self):
|
def test_fsync(self):
|
||||||
"""Create a directory and file with syncing enabled."""
|
"""Create a directory and file with syncing enabled."""
|
||||||
self.configuration["storage"]["filesystem_fsync"] = "True"
|
self.configuration["storage"]["filesystem_fsync"] = "True"
|
||||||
status, headers, answer = self.request("MKCALENDAR", "/calendar.ics/")
|
status, _, _ = self.request("MKCALENDAR", "/calendar.ics/")
|
||||||
assert status == 201
|
assert status == 201
|
||||||
|
|
||||||
def test_hook(self):
|
def test_hook(self):
|
||||||
"""Run hook."""
|
"""Run hook."""
|
||||||
self.configuration["storage"]["hook"] = (
|
self.configuration["storage"]["hook"] = (
|
||||||
"mkdir %s" % os.path.join("collection-root", "created_by_hook"))
|
"mkdir %s" % os.path.join("collection-root", "created_by_hook"))
|
||||||
status, headers, answer = self.request("MKCOL", "/calendar.ics/")
|
status, _, _ = self.request("MKCALENDAR", "/calendar.ics/")
|
||||||
assert status == 201
|
assert status == 201
|
||||||
status, headers, answer = self.request("PROPFIND", "/created_by_hook/")
|
status, _, _ = self.request("PROPFIND", "/created_by_hook/")
|
||||||
assert status == 207
|
assert status == 207
|
||||||
|
|
||||||
def test_hook_read_access(self):
|
def test_hook_read_access(self):
|
||||||
@ -1074,7 +1071,7 @@ class BaseRequestsMixIn:
|
|||||||
"""Verify that the storage is locked when the hook runs."""
|
"""Verify that the storage is locked when the hook runs."""
|
||||||
self.configuration["storage"]["hook"] = (
|
self.configuration["storage"]["hook"] = (
|
||||||
"flock -n .Radicale.lock || exit 0; exit 1")
|
"flock -n .Radicale.lock || exit 0; exit 1")
|
||||||
status, headers, answer = self.request("MKCOL", "/calendar.ics/")
|
status, _, _ = self.request("MKCALENDAR", "/calendar.ics/")
|
||||||
assert status == 201
|
assert status == 201
|
||||||
|
|
||||||
def test_hook_principal_collection_creation(self):
|
def test_hook_principal_collection_creation(self):
|
||||||
@ -1091,11 +1088,8 @@ class BaseRequestsMixIn:
|
|||||||
def test_hook_fail(self):
|
def test_hook_fail(self):
|
||||||
"""Verify that a request fails if the hook fails."""
|
"""Verify that a request fails if the hook fails."""
|
||||||
self.configuration["storage"]["hook"] = "exit 1"
|
self.configuration["storage"]["hook"] = "exit 1"
|
||||||
try:
|
status, _, _ = self.request("MKCALENDAR", "/calendar.ics/")
|
||||||
status, headers, answer = self.request("MKCOL", "/calendar.ics/")
|
assert status != 201
|
||||||
assert status != 201
|
|
||||||
except Exception:
|
|
||||||
pass
|
|
||||||
|
|
||||||
def test_custom_headers(self):
|
def test_custom_headers(self):
|
||||||
if not self.configuration.has_section("headers"):
|
if not self.configuration.has_section("headers"):
|
||||||
|
Loading…
x
Reference in New Issue
Block a user