test/webdav_resource.c

branch
dav-2
changeset 903
457faa53fd7e
parent 902
06fa328989ee
--- a/test/webdav_resource.c	Sat Jan 24 13:56:19 2026 +0100
+++ b/test/webdav_resource.c	Sun Jan 25 17:53:31 2026 +0100
@@ -29,6 +29,16 @@
 #include "webdav.h"
 #include "webdav_resource.h"
 
+CX_TEST_SUBROUTINE(test_default_properties, DavResource *res) {
+    CX_TEST_ASSERT(res->contentlength > 0);
+    CX_TEST_ASSERT(res->creationdate > 0);
+    CX_TEST_ASSERT(res->lastmodified > 0);
+    CX_TEST_ASSERT(res->exists);
+    CX_TEST_ASSERT(res->contenttype);
+    CX_TEST_ASSERT(!res->iscollection);
+    CX_TEST_ASSERT(res->href);
+}
+
 CX_TEST(test_dav_load_webdav) {
     CX_TEST_DO {
         DavSession *sn = get_test_webdav_session();
@@ -36,12 +46,60 @@
         CX_TEST_ASSERT(res);
         int ret = dav_load(res);
         CX_TEST_ASSERT(ret == 0);
-        CX_TEST_ASSERT(res->contentlength > 0);
-        CX_TEST_ASSERT(res->creationdate > 0);
-        CX_TEST_ASSERT(res->lastmodified > 0);
-        CX_TEST_ASSERT(res->exists);
-        CX_TEST_ASSERT(res->contenttype);
-        CX_TEST_ASSERT(!res->iscollection);
-        CX_TEST_ASSERT(res->href);
+        CX_TEST_CALL_SUBROUTINE(test_default_properties, res);
+        dav_session_destroy(sn);
+    }
+}
+
+CX_TEST(test_dav_exists_webdav) {
+    CX_TEST_DO {
+        DavSession *sn = get_test_webdav_session();
+        DavResource *res = dav_resource_new(sn, "/hello.txt");
+        CX_TEST_ASSERT(res);
+        int exists = dav_exists(res);
+        CX_TEST_ASSERT(exists);
+        CX_TEST_CALL_SUBROUTINE(test_default_properties, res);
+        dav_session_destroy(sn);
     }
 }
+
+CX_TEST(test_dav_create_webdav) {
+    CX_TEST_DO {
+        DavSession *sn = get_test_webdav_session();
+        // test1: check if the resource exists and create it after that
+        DavResource *res = dav_resource_new(sn, "/test_create.txt");
+        CX_TEST_ASSERT(res);
+        int exists = dav_exists(res); // the resource should not exist yet
+        CX_TEST_ASSERT(!exists);
+        int ret = dav_create(res); // create the resource
+        CX_TEST_ASSERT(!ret);
+        exists = dav_exists(res); // the resource should exist now
+        CX_TEST_ASSERT(exists);
+        CX_TEST_ASSERT(res->lastmodified > 0); // some properties should be loaded by dav_exists()
+        CX_TEST_ASSERT(res->contenttype);
+        
+        // test2: create a resource without calling dav_exists first
+        DavResource *res2 = dav_resource_new(sn, "/test_create2.txt");
+        ret = dav_create(res2);
+        CX_TEST_ASSERT(!ret);
+        CX_TEST_ASSERT(dav_exists(res2));
+        CX_TEST_ASSERT(res2->lastmodified > 0);
+        CX_TEST_ASSERT(res2->contenttype);
+        
+        dav_session_destroy(sn);
+    }
+}
+
+CX_TEST(test_dav_store_content_webdav) {
+    CX_TEST_DO {
+        DavSession *sn = get_test_webdav_session();
+        DavResource *res = dav_resource_new(sn, "/test_store_content.txt");
+        cxstring content = cx_str("test_store_content test content\n");
+        dav_set_content_data(res, content.ptr, content.length);
+        int ret = dav_store(res);
+        CX_TEST_ASSERT(!ret);
+        CX_TEST_ASSERT(!dav_load(res));
+        CX_TEST_ASSERT(res->contentlength == content.length);
+        dav_session_destroy(sn);
+    }
+}

mercurial