mirror of
https://github.com/Kozea/Radicale.git
synced 2025-08-28 19:40:54 +00:00
Added functionnal tests
This commit is contained in:
parent
3f67ea1e9d
commit
ce59d9ea87
8 changed files with 219 additions and 19 deletions
|
@ -21,10 +21,13 @@ Radicale tests with simple requests.
|
|||
|
||||
"""
|
||||
|
||||
from . import BaseTest
|
||||
from . import (FileSystem, MultiFileSystem, DataBaseSystem,
|
||||
GitFileSystem, GitMultiFileSystem)
|
||||
from .helpers import get_file_content
|
||||
import sys
|
||||
|
||||
|
||||
class TestBaseRequests(BaseTest):
|
||||
class BaseRequests(object):
|
||||
"""Tests with simple requests."""
|
||||
|
||||
def test_root(self):
|
||||
|
@ -32,3 +35,69 @@ class TestBaseRequests(BaseTest):
|
|||
status, headers, answer = self.request("GET", "/")
|
||||
assert status == 200
|
||||
assert "Radicale works!" in answer
|
||||
# Tests the creation of the collection
|
||||
status, headers, answer = self.request("GET", "/calendar.ics/")
|
||||
assert u"BEGIN:VCALENDAR" in answer
|
||||
assert u"VERSION:2.0" in answer
|
||||
assert u"END:VCALENDAR" in answer
|
||||
assert u"PRODID:-//Radicale//NONSGML Radicale Server//EN" in answer
|
||||
|
||||
def test_add_event_todo(self):
|
||||
"""Tests the add of an event and todo."""
|
||||
self.request("GET", "/calendar.ics/")
|
||||
#VEVENT test
|
||||
event = get_file_content("put.ics")
|
||||
path = "/calendar.ics/02805f81-4cc2-4d68-8d39-72768ffa02d9.ics"
|
||||
status, headers, answer = self.request("PUT", path, event)
|
||||
assert status == 201
|
||||
assert u"ETag" in headers.keys()
|
||||
status, headers, answer = self.request("GET", path)
|
||||
assert status == 200
|
||||
assert u"VEVENT" in answer
|
||||
assert u"Nouvel évènement" in answer
|
||||
assert u"UID:02805f81-4cc2-4d68-8d39-72768ffa02d9" in answer
|
||||
# VTODO test
|
||||
todo = get_file_content("putvtodo.ics")
|
||||
path = "/calendar.ics/40f8cf9b-0e62-4624-89a2-24c5e68850f5.ics"
|
||||
status, headers, answer = self.request("PUT", path, todo)
|
||||
assert status == 201
|
||||
assert u"ETag" in headers.keys()
|
||||
status, headers, answer = self.request("GET", path)
|
||||
assert u"VTODO" in answer
|
||||
assert u"Nouvelle tâche" in answer
|
||||
assert u"UID:40f8cf9b-0e62-4624-89a2-24c5e68850f5" in answer
|
||||
|
||||
def test_delete(self):
|
||||
"""Tests the deletion of an event"""
|
||||
self.request("GET", "/calendar.ics/")
|
||||
# Adds a VEVENT to be deleted
|
||||
event = get_file_content("put.ics")
|
||||
path = "/calendar.ics/02805f81-4cc2-4d68-8d39-72768ffa02d9.ics"
|
||||
status, headers, answer = self.request("PUT", path, event)
|
||||
# Then we send a DELETE request
|
||||
status, headers, answer = self.request("DELETE", path)
|
||||
assert status == 200
|
||||
assert u"<href>%s</href>" % path in answer
|
||||
status, headers, answer = self.request("GET", "/calendar.ics/")
|
||||
assert u"VEVENT" not in answer
|
||||
|
||||
|
||||
def test_generator():
|
||||
"""Generates tests for all the system classes"""
|
||||
cl_list = [FileSystem, MultiFileSystem, DataBaseSystem,
|
||||
GitFileSystem, GitMultiFileSystem]
|
||||
for cl in cl_list:
|
||||
classname = "Test%s" % cl.__name__
|
||||
generated_class = type(classname, (BaseRequests,), {})
|
||||
yield generated_class()
|
||||
|
||||
# Generates Classes with different configs
|
||||
cl_list = [FileSystem, MultiFileSystem, DataBaseSystem,
|
||||
GitFileSystem, GitMultiFileSystem]
|
||||
for cl in cl_list:
|
||||
classname = "Test%s" % cl.__name__
|
||||
|
||||
class DummyClass(BaseRequests, cl):
|
||||
"""Test for %s""" % cl.__name__
|
||||
DummyClass.__name__ = classname
|
||||
setattr(sys.modules[__name__], classname, DummyClass)
|
||||
|
|
Loading…
Add table
Add a link
Reference in a new issue