richardphibel / rpms / librepo

Forked from rpms/librepo 2 years ago
Clone
3ea492
From 3738ee93ebcc3552774b6361fccea2b8ab80e101 Mon Sep 17 00:00:00 2001
3ea492
From: =?UTF-8?q?Ale=C5=A1=20Mat=C4=9Bj?= <amatej@redhat.com>
3ea492
Date: Tue, 22 Jun 2021 10:32:29 +0200
3ea492
Subject: [PATCH] `fail_if` and `fail_unless` are deprecated
3ea492
3ea492
https://libcheck.github.io/check/doc/check_html/check_4.html#Convenience-Test-Functions
3ea492
3ea492
It also fixes a couple of covscan warnings of the following type:
3ea492
```
3ea492
Error: COMPILER_WARNING (CWE-685):
3ea492
librepo-1.12.1/tests/fixtures.h:5: included_from: Included from here.
3ea492
librepo-1.12.1/tests/test_checksum.c:15: included_from: Included from here.
3ea492
librepo-1.12.1/tests/test_checksum.c: scope_hint: In function 'test_checksum'
3ea492
librepo-1.12.1/tests/test_checksum.c:58:9: warning[-Wformat-extra-args]: too many arguments for format
3ea492
\#   58 |         "Checksum is %s instead of %s", checksum, expected);
3ea492
\#      |         ^~~~~~~~~~~~~~~~~~~~~~~~~~~~~~
3ea492
\#   56|       fail_if(tmp_err);
3ea492
\#   57|       fail_if(strcmp(checksum, expected),
3ea492
\#   58|->         "Checksum is %s instead of %s", checksum, expected);
3ea492
\#   59|       lr_free(checksum);
3ea492
\#   60|       close(fd);
3ea492
```
3ea492
---
3ea492
 tests/test_checksum.c           |  88 +++----
3ea492
 tests/test_downloader.c         |  93 +++----
3ea492
 tests/test_gpg.c                |  32 +--
3ea492
 tests/test_handle.c             | 140 +++++-----
3ea492
 tests/test_lrmirrorlist.c       | 114 ++++-----
3ea492
 tests/test_metalink.c           | 438 ++++++++++++++++----------------
3ea492
 tests/test_mirrorlist.c         |  40 +--
3ea492
 tests/test_package_downloader.c |  48 ++--
3ea492
 tests/test_repo_zck.c           |  20 +-
3ea492
 tests/test_repoconf.c           |  24 +-
3ea492
 tests/test_repomd.c             |  38 +--
3ea492
 tests/test_url_substitution.c   |  50 ++--
3ea492
 tests/test_util.c               | 146 +++++------
3ea492
 tests/test_version.c            |  24 +-
3ea492
 14 files changed, 640 insertions(+), 655 deletions(-)
3ea492
3ea492
diff --git a/tests/test_checksum.c b/tests/test_checksum.c
3ea492
index d0aba365..cd28cd17 100644
3ea492
--- a/tests/test_checksum.c
3ea492
+++ b/tests/test_checksum.c
3ea492
@@ -38,8 +38,8 @@ build_test_file(const char *filename, const char *content)
3ea492
 {
3ea492
     FILE *fp = fopen(filename, "w");
3ea492
     size_t len = strlen(content);
3ea492
-    fail_if(fp == NULL);
3ea492
-    fail_unless(fwrite(content, 1, len, fp) == len);
3ea492
+    ck_assert_ptr_nonnull(fp);
3ea492
+    ck_assert(fwrite(content, 1, len, fp) == len);
3ea492
     fclose(fp);
3ea492
 }
3ea492
 
3ea492
@@ -51,11 +51,11 @@ test_checksum(const char *filename, LrChecksumType ch_type, char *expected)
3ea492
     GError *tmp_err = NULL;
3ea492
 
3ea492
     fd = open(filename, O_RDONLY);
3ea492
-    fail_if(fd < 0);
3ea492
+    ck_assert_int_ge(fd, 0);
3ea492
     checksum = lr_checksum_fd(ch_type, fd, &tmp_err);
3ea492
-    fail_if(checksum == NULL);
3ea492
-    fail_if(tmp_err);
3ea492
-    fail_if(strcmp(checksum, expected),
3ea492
+    ck_assert_ptr_nonnull(checksum);
3ea492
+    ck_assert_ptr_null(tmp_err);
3ea492
+    ck_assert_msg(!strcmp(checksum, expected),
3ea492
         "Checksum is %s instead of %s", checksum, expected);
3ea492
     lr_free(checksum);
3ea492
     close(fd);
3ea492
@@ -85,7 +85,7 @@ START_TEST(test_checksum_fd)
3ea492
     test_checksum(file, LR_CHECKSUM_SHA384, CHKS_VAL_01_SHA384);
3ea492
     test_checksum(file, LR_CHECKSUM_SHA512, CHKS_VAL_01_SHA512);
3ea492
 
3ea492
-    fail_if(remove(file) != 0, "Cannot delete temporary test file");
3ea492
+    ck_assert_msg(remove(file) == 0, "Cannot delete temporary test file");
3ea492
     lr_free(file);
3ea492
 }
3ea492
 END_TEST
3ea492
@@ -107,28 +107,28 @@ START_TEST(test_cached_checksum_matches)
3ea492
 
3ea492
     filename = lr_pathconcat(test_globals.tmpdir, "/test_checksum_matches", NULL);
3ea492
     f = fopen(filename, "w");
3ea492
-    fail_if(f == NULL);
3ea492
+    ck_assert_ptr_nonnull(f);
3ea492
     fwrite("foo\nbar\n", 1, 8, f);
3ea492
     fclose(f);
3ea492
 
3ea492
     // Assert no cached checksum exists
3ea492
     attr_ret = GETXATTR(filename, timestamp_key, &buf, sizeof(buf)-1);
3ea492
-    fail_if(attr_ret != -1);  // Cached timestamp should not exists
3ea492
+    ck_assert(attr_ret == -1);  // Cached timestamp should not exists
3ea492
     attr_ret = GETXATTR(filename, checksum_key, &buf, sizeof(buf)-1);
3ea492
-    fail_if(attr_ret != -1);  // Cached checksum should not exists
3ea492
+    ck_assert(attr_ret == -1);  // Cached checksum should not exists
3ea492
 
3ea492
     // Calculate checksum
3ea492
     fd = open(filename, O_RDONLY);
3ea492
-    fail_if(fd < 0);
3ea492
+    ck_assert_int_ge(fd, 0);
3ea492
     checksum_ret = lr_checksum_fd_cmp(LR_CHECKSUM_SHA256,
3ea492
                                       fd,
3ea492
                                       expected,
3ea492
                                       1,
3ea492
                                       &matches,
3ea492
                                       &tmp_err);
3ea492
-    fail_if(tmp_err);
3ea492
-    fail_if(!checksum_ret);
3ea492
-    fail_if(!matches);
3ea492
+    ck_assert_ptr_null(tmp_err);
3ea492
+    ck_assert(checksum_ret);
3ea492
+    ck_assert(matches);
3ea492
     close(fd);
3ea492
 
3ea492
     // Assert cached checksum exists
3ea492
@@ -141,33 +141,33 @@ START_TEST(test_cached_checksum_matches)
3ea492
             goto exit_label;
3ea492
         }
3ea492
         // Any other errno means fail
3ea492
-        fail_if(attr_ret == -1);
3ea492
+        ck_assert(attr_ret != -1);
3ea492
     } else {
3ea492
         buf[attr_ret] = 0;
3ea492
-        fail_if(strcmp(buf, expected));
3ea492
+        ck_assert_str_eq(buf, expected);
3ea492
     }
3ea492
 
3ea492
     // stored timestamp matches the file mtime
3ea492
     ret = stat(filename, &st);
3ea492
-    fail_if(ret != 0);
3ea492
+    ck_assert_int_eq(ret, 0);
3ea492
     mtime_str = g_strdup_printf("%lli", (long long) st.st_mtime);
3ea492
     attr_ret = GETXATTR(filename, timestamp_key, &buf, sizeof(buf)-1);
3ea492
-    fail_if(attr_ret == -1);
3ea492
+    ck_assert(attr_ret != -1);
3ea492
     buf[attr_ret] = 0;
3ea492
-    fail_if(strcmp(buf, mtime_str));
3ea492
+    ck_assert_str_eq(buf, mtime_str);
3ea492
 
3ea492
     // Calculate checksum again (cached shoud be used this time)
3ea492
     fd = open(filename, O_RDONLY);
3ea492
-    fail_if(fd < 0);
3ea492
+    ck_assert_int_ge(fd, 0);
3ea492
     checksum_ret = lr_checksum_fd_cmp(LR_CHECKSUM_SHA256,
3ea492
                                       fd,
3ea492
                                       expected,
3ea492
                                       1,
3ea492
                                       &matches,
3ea492
                                       &tmp_err);
3ea492
-    fail_if(tmp_err);
3ea492
-    fail_if(!checksum_ret);
3ea492
-    fail_if(!matches);
3ea492
+    ck_assert_ptr_null(tmp_err);
3ea492
+    ck_assert(checksum_ret);
3ea492
+    ck_assert(matches);
3ea492
     close(fd);
3ea492
 
3ea492
 exit_label:
3ea492
@@ -195,19 +195,19 @@ START_TEST(test_cached_checksum_value)
3ea492
 
3ea492
     filename = lr_pathconcat(test_globals.tmpdir, "/test_checksum_value", NULL);
3ea492
     f = fopen(filename, "w");
3ea492
-    fail_if(f == NULL);
3ea492
+    ck_assert_ptr_nonnull(f);
3ea492
     fwrite("foo\nbar\n", 1, 8, f);
3ea492
     fclose(f);
3ea492
 
3ea492
     // Assert no cached checksum exists
3ea492
     attr_ret = GETXATTR(filename, timestamp_key, &buf, sizeof(buf)-1);
3ea492
-    fail_if(attr_ret != -1);  // Cached timestamp should not exists
3ea492
+    ck_assert(attr_ret == -1);  // Cached timestamp should not exists
3ea492
     attr_ret = GETXATTR(filename, checksum_key, &buf, sizeof(buf)-1);
3ea492
-    fail_if(attr_ret != -1);  // Cached checksum should not exists
3ea492
+    ck_assert(attr_ret == -1);  // Cached checksum should not exists
3ea492
 
3ea492
     // Calculate checksum
3ea492
     fd = open(filename, O_RDONLY);
3ea492
-    fail_if(fd < 0);
3ea492
+    ck_assert_int_ge(fd, 0);
3ea492
     checksum_ret = lr_checksum_fd_compare(LR_CHECKSUM_SHA256,
3ea492
                                       fd,
3ea492
                                       "",
3ea492
@@ -215,20 +215,20 @@ START_TEST(test_cached_checksum_value)
3ea492
                                       &matches,
3ea492
                                       &calculated,
3ea492
                                       &tmp_err);
3ea492
-    fail_if(tmp_err);
3ea492
-    fail_if(!checksum_ret);
3ea492
+    ck_assert_ptr_null(tmp_err);
3ea492
+    ck_assert(checksum_ret);
3ea492
     // We pass in an empty string for expected, so we must not match.
3ea492
-    fail_if(matches);
3ea492
+    ck_assert(!matches);
3ea492
     close(fd);
3ea492
-    fail_if(strcmp(calculated, expected));
3ea492
+    ck_assert_str_eq(calculated, expected);
3ea492
 
3ea492
     // Assert no cached checksum exists
3ea492
     // This assumes issue #235 is unresolved. Once it is, this code
3ea492
     // should fail and the test will need updated.
3ea492
     attr_ret = GETXATTR(filename, timestamp_key, &buf, sizeof(buf)-1);
3ea492
-    fail_if(attr_ret != -1);  // Cached timestamp should not exists
3ea492
+    ck_assert(attr_ret == -1);  // Cached timestamp should not exists
3ea492
     attr_ret = GETXATTR(filename, checksum_key, &buf, sizeof(buf)-1);
3ea492
-    fail_if(attr_ret != -1);  // Cached checksum should not exists
3ea492
+    ck_assert(attr_ret == -1);  // Cached checksum should not exists
3ea492
 
3ea492
     lr_free(calculated);
3ea492
     lr_free(filename);
3ea492
@@ -252,42 +252,42 @@ START_TEST(test_cached_checksum_clear)
3ea492
 
3ea492
     filename = lr_pathconcat(test_globals.tmpdir, "/test_checksum_clear", NULL);
3ea492
     f = fopen(filename, "w");
3ea492
-    fail_if(f == NULL);
3ea492
+    ck_assert_ptr_nonnull(f);
3ea492
     fclose(f);
3ea492
 
3ea492
     // set extended attributes
3ea492
     fd = open(filename, O_RDONLY);
3ea492
-    fail_if(fd < 0);
3ea492
+    ck_assert_int_ge(fd, 0);
3ea492
     attr_ret = FSETXATTR(fd, timestamp_key, value, strlen(value), 0);
3ea492
     if (attr_ret == -1) {
3ea492
         if (errno == ENOTSUP) {
3ea492
             goto cleanup;
3ea492
         }
3ea492
-        fail_if(attr_ret == -1);
3ea492
+        ck_assert(attr_ret != -1);
3ea492
     }
3ea492
     attr_ret = FSETXATTR(fd, checksum_key, value, strlen(value), 0);
3ea492
-    fail_if(attr_ret == -1);
3ea492
+    ck_assert(attr_ret != -1);
3ea492
     attr_ret = FSETXATTR(fd, other_key, value, strlen(value), 0);
3ea492
-    fail_if(attr_ret == -1);
3ea492
+    ck_assert(attr_ret != -1);
3ea492
 
3ea492
     // verify that xattrs are set
3ea492
     attr_ret = GETXATTR(filename, timestamp_key, &buf, sizeof(buf));
3ea492
-    fail_if(attr_ret == -1);
3ea492
+    ck_assert(attr_ret != -1);
3ea492
     attr_ret = GETXATTR(filename, checksum_key, &buf, sizeof(buf));
3ea492
-    fail_if(attr_ret == -1);
3ea492
+    ck_assert(attr_ret != -1);
3ea492
     attr_ret = GETXATTR(filename, other_key, &buf, sizeof(buf));
3ea492
-    fail_if(attr_ret == -1);
3ea492
+    ck_assert(attr_ret != -1);
3ea492
 
3ea492
     lr_checksum_clear_cache(fd);
3ea492
 
3ea492
     // verify that checksum xattrs are removed
3ea492
     attr_ret = GETXATTR(filename, timestamp_key, &buf, sizeof(buf));
3ea492
-    fail_if(attr_ret != -1);
3ea492
+    ck_assert(attr_ret == -1);
3ea492
     attr_ret = GETXATTR(filename, checksum_key, &buf, sizeof(buf));
3ea492
-    fail_if(attr_ret != -1);
3ea492
+    ck_assert(attr_ret == -1);
3ea492
     // other then checksum related attributes are not removed
3ea492
     attr_ret = GETXATTR(filename, other_key, &buf, sizeof(buf));
3ea492
-    fail_if(attr_ret == -1);
3ea492
+    ck_assert(attr_ret != -1);
3ea492
 cleanup:
3ea492
     close(fd);
3ea492
     lr_free(filename);
3ea492
diff --git a/tests/test_downloader.c b/tests/test_downloader.c
3ea492
index e6155105..34958ab1 100644
3ea492
--- a/tests/test_downloader.c
3ea492
+++ b/tests/test_downloader.c
3ea492
@@ -20,18 +20,14 @@
3ea492
 
3ea492
 START_TEST(test_downloader_no_list)
3ea492
 {
3ea492
-    int ret;
3ea492
     GError *err = NULL;
3ea492
-
3ea492
-    ret = lr_download(NULL, FALSE, &err;;
3ea492
-    fail_if(!ret);
3ea492
-    fail_if(err);
3ea492
+    ck_assert(lr_download(NULL, FALSE, &err));
3ea492
+    ck_assert_ptr_null(err);
3ea492
 }
3ea492
 END_TEST
3ea492
 
3ea492
 START_TEST(test_downloader_single_file)
3ea492
 {
3ea492
-    int ret;
3ea492
     LrHandle *handle;
3ea492
     GSList *list = NULL;
3ea492
     GError *err = NULL;
3ea492
@@ -43,12 +39,12 @@ START_TEST(test_downloader_single_file)
3ea492
     // Prepare handle
3ea492
 
3ea492
     handle = lr_handle_init();
3ea492
-    fail_if(handle == NULL);
3ea492
+    ck_assert_ptr_nonnull(handle);
3ea492
 
3ea492
     char *urls[] = {"http://www.google.com", NULL};
3ea492
-    fail_if(!lr_handle_setopt(handle, NULL, LRO_URLS, urls));
3ea492
+    ck_assert(lr_handle_setopt(handle, NULL, LRO_URLS, urls));
3ea492
     lr_handle_prepare_internal_mirrorlist(handle, FALSE, &tmp_err);
3ea492
-    fail_if(tmp_err);
3ea492
+    ck_assert_ptr_null(tmp_err);
3ea492
 
3ea492
 
3ea492
     // Prepare list of download targets
3ea492
@@ -57,20 +53,19 @@ START_TEST(test_downloader_single_file)
3ea492
 
3ea492
     fd1 = mkstemp(tmpfn1);
3ea492
     lr_free(tmpfn1);
3ea492
-    fail_if(fd1 < 0);
3ea492
+    ck_assert_int_ge(fd1, 0);
3ea492
 
3ea492
     t1 = lr_downloadtarget_new(handle, "index.html", NULL, fd1, NULL, NULL,
3ea492
                                0, 0, NULL, NULL, NULL, NULL, NULL, 0, 0, NULL,
3ea492
                                FALSE, FALSE);
3ea492
-    fail_if(!t1);
3ea492
+    ck_assert_ptr_nonnull(t1);
3ea492
 
3ea492
     list = g_slist_append(list, t1);
3ea492
 
3ea492
     // Download
3ea492
 
3ea492
-    ret = lr_download(list, FALSE, &err;;
3ea492
-    fail_if(!ret);
3ea492
-    fail_if(err);
3ea492
+    ck_assert(lr_download(list, FALSE, &err));
3ea492
+    ck_assert_ptr_null(err);
3ea492
 
3ea492
     lr_handle_free(handle);
3ea492
 
3ea492
@@ -91,7 +86,6 @@ END_TEST
3ea492
 
3ea492
 START_TEST(test_downloader_single_file_2)
3ea492
 {
3ea492
-    int ret;
3ea492
     GSList *list = NULL;
3ea492
     GError *err = NULL;
3ea492
     int fd1;
3ea492
@@ -104,20 +98,19 @@ START_TEST(test_downloader_single_file_2)
3ea492
 
3ea492
     fd1 = mkstemp(tmpfn1);
3ea492
     lr_free(tmpfn1);
3ea492
-    fail_if(fd1 < 0);
3ea492
+    ck_assert_int_ge(fd1, 0);
3ea492
 
3ea492
     t1 = lr_downloadtarget_new(NULL, "http://seznam.cz/index.html", NULL,
3ea492
                                fd1, NULL, NULL, 0, 0, NULL, NULL, NULL,
3ea492
                                NULL, NULL, 0, 0, NULL, FALSE, FALSE);
3ea492
-    fail_if(!t1);
3ea492
+    ck_assert_ptr_nonnull(t1);
3ea492
 
3ea492
     list = g_slist_append(list, t1);
3ea492
 
3ea492
     // Download
3ea492
 
3ea492
-    ret = lr_download(list, FALSE, &err;;
3ea492
-    fail_if(!ret);
3ea492
-    fail_if(err);
3ea492
+    ck_assert(lr_download(list, FALSE, &err));
3ea492
+    ck_assert_ptr_null(err);
3ea492
 
3ea492
     // Check results
3ea492
 
3ea492
@@ -136,7 +129,6 @@ END_TEST
3ea492
 
3ea492
 START_TEST(test_downloader_two_files)
3ea492
 {
3ea492
-    int ret;
3ea492
     LrHandle *handle;
3ea492
     GSList *list = NULL;
3ea492
     GError *err = NULL;
3ea492
@@ -148,12 +140,12 @@ START_TEST(test_downloader_two_files)
3ea492
     // Prepare handle
3ea492
 
3ea492
     handle = lr_handle_init();
3ea492
-    fail_if(handle == NULL);
3ea492
+    ck_assert_ptr_nonnull(handle);
3ea492
 
3ea492
     char *urls[] = {"http://www.google.com", NULL};
3ea492
-    fail_if(!lr_handle_setopt(handle, NULL, LRO_URLS, urls));
3ea492
+    ck_assert(lr_handle_setopt(handle, NULL, LRO_URLS, urls));
3ea492
     lr_handle_prepare_internal_mirrorlist(handle, FALSE, &tmp_err);
3ea492
-    fail_if(tmp_err);
3ea492
+    ck_assert_ptr_null(tmp_err);
3ea492
 
3ea492
     // Prepare list of download targets
3ea492
 
3ea492
@@ -164,26 +156,25 @@ START_TEST(test_downloader_two_files)
3ea492
     fd2 = mkstemp(tmpfn2);
3ea492
     lr_free(tmpfn1);
3ea492
     lr_free(tmpfn2);
3ea492
-    fail_if(fd1 < 0);
3ea492
-    fail_if(fd2 < 0);
3ea492
+    ck_assert_int_ge(fd1, 0);
3ea492
+    ck_assert_int_ge(fd2, 0);
3ea492
 
3ea492
     t1 = lr_downloadtarget_new(handle, "index.html", NULL, fd1, NULL,
3ea492
                                NULL, 0, 0, NULL, NULL, NULL,
3ea492
                                NULL, NULL, 0, 0, NULL, FALSE, FALSE);
3ea492
-    fail_if(!t1);
3ea492
+    ck_assert_ptr_nonnull(t1);
3ea492
     t2 = lr_downloadtarget_new(handle, "index.html", "http://seznam.cz", fd2,
3ea492
                                NULL, NULL, 0, 0, NULL, NULL, NULL,
3ea492
                                NULL, NULL, 0, 0, NULL, FALSE, FALSE);
3ea492
-    fail_if(!t2);
3ea492
+    ck_assert_ptr_nonnull(t2);
3ea492
 
3ea492
     list = g_slist_append(list, t1);
3ea492
     list = g_slist_append(list, t2);
3ea492
 
3ea492
     // Download
3ea492
 
3ea492
-    ret = lr_download(list, FALSE, &err;;
3ea492
-    fail_if(!ret);
3ea492
-    fail_if(err);
3ea492
+    ck_assert(lr_download(list, FALSE, &err));
3ea492
+    ck_assert_ptr_null(err);
3ea492
 
3ea492
     lr_handle_free(handle);
3ea492
 
3ea492
@@ -205,7 +196,6 @@ END_TEST
3ea492
 
3ea492
 START_TEST(test_downloader_three_files_with_error)
3ea492
 {
3ea492
-    int ret;
3ea492
     LrHandle *handle;
3ea492
     GSList *list = NULL;
3ea492
     GError *err = NULL;
3ea492
@@ -217,12 +207,12 @@ START_TEST(test_downloader_three_files_with_error)
3ea492
     // Prepare handle
3ea492
 
3ea492
     handle = lr_handle_init();
3ea492
-    fail_if(handle == NULL);
3ea492
+    ck_assert_ptr_nonnull(handle);
3ea492
 
3ea492
     char *urls[] = {"http://www.google.com", NULL};
3ea492
-    fail_if(!lr_handle_setopt(handle, NULL, LRO_URLS, urls));
3ea492
+    ck_assert(lr_handle_setopt(handle, NULL, LRO_URLS, urls));
3ea492
     lr_handle_prepare_internal_mirrorlist(handle, FALSE, &tmp_err);
3ea492
-    fail_if(tmp_err);
3ea492
+    ck_assert_ptr_null(tmp_err);
3ea492
 
3ea492
     // Prepare list of download targets
3ea492
 
3ea492
@@ -236,25 +226,25 @@ START_TEST(test_downloader_three_files_with_error)
3ea492
     lr_free(tmpfn1);
3ea492
     lr_free(tmpfn2);
3ea492
     lr_free(tmpfn3);
3ea492
-    fail_if(fd1 < 0);
3ea492
-    fail_if(fd2 < 0);
3ea492
-    fail_if(fd3 < 0);
3ea492
+    ck_assert_int_ge(fd1, 0);
3ea492
+    ck_assert_int_ge(fd2, 0);
3ea492
+    ck_assert_int_ge(fd3, 0);
3ea492
 
3ea492
     t1 = lr_downloadtarget_new(handle, "index.html", NULL, fd1, NULL, NULL,
3ea492
                                0, 0, NULL, NULL, NULL, NULL, NULL, 0, 0, NULL,
3ea492
                                FALSE, FALSE);
3ea492
-    fail_if(!t1);
3ea492
+    ck_assert_ptr_nonnull(t1);
3ea492
 
3ea492
     t2 = lr_downloadtarget_new(handle, "index.html", "http://seznam.cz", fd2,
3ea492
                                NULL, NULL, 0, 0, NULL, NULL, NULL, NULL,
3ea492
                                NULL, 0, 0, NULL, FALSE, FALSE);
3ea492
-    fail_if(!t2);
3ea492
+    ck_assert_ptr_nonnull(t2);
3ea492
 
3ea492
     t3 = lr_downloadtarget_new(handle, "i_hope_this_page_doesnt_exists.html",
3ea492
                                "http://google.com", fd3, NULL, NULL,
3ea492
                                0, 0, NULL, NULL, NULL, NULL, NULL, 0, 0, NULL,
3ea492
                                FALSE, FALSE);
3ea492
-    fail_if(!t3);
3ea492
+    ck_assert_ptr_nonnull(t3);
3ea492
 
3ea492
     list = g_slist_append(list, t1);
3ea492
     list = g_slist_append(list, t2);
3ea492
@@ -262,9 +252,8 @@ START_TEST(test_downloader_three_files_with_error)
3ea492
 
3ea492
     // Download
3ea492
 
3ea492
-    ret = lr_download(list, FALSE, &err;;
3ea492
-    fail_if(!ret);
3ea492
-    fail_if(err);
3ea492
+    ck_assert(lr_download(list, FALSE, &err));
3ea492
+    ck_assert_ptr_null(err);
3ea492
 
3ea492
     lr_handle_free(handle);
3ea492
 
3ea492
@@ -314,7 +303,6 @@ START_TEST(test_downloader_checksum)
3ea492
     int i;
3ea492
 
3ea492
     for (i = 0; tests[i].sha512; i++) {
3ea492
-        int ret;
3ea492
         LrHandle *handle;
3ea492
         GSList *list = NULL;
3ea492
         GError *err = NULL;
3ea492
@@ -328,12 +316,12 @@ START_TEST(test_downloader_checksum)
3ea492
         // Prepare handle
3ea492
 
3ea492
         handle = lr_handle_init();
3ea492
-        fail_if(handle == NULL);
3ea492
+        ck_assert_ptr_nonnull(handle);
3ea492
 
3ea492
         char *urls[] = {"file:///", NULL};
3ea492
-        fail_if(!lr_handle_setopt(handle, NULL, LRO_URLS, urls));
3ea492
+        ck_assert(lr_handle_setopt(handle, NULL, LRO_URLS, urls));
3ea492
         lr_handle_prepare_internal_mirrorlist(handle, FALSE, &tmp_err);
3ea492
-        fail_if(tmp_err);
3ea492
+        ck_assert_ptr_null(tmp_err);
3ea492
 
3ea492
 
3ea492
         // Prepare list of download targets
3ea492
@@ -342,7 +330,7 @@ START_TEST(test_downloader_checksum)
3ea492
 
3ea492
         fd1 = mkstemp(tmpfn1);
3ea492
         lr_free(tmpfn1);
3ea492
-        fail_if(fd1 < 0);
3ea492
+        ck_assert_int_ge(fd1, 0);
3ea492
 
3ea492
         checksum = lr_downloadtargetchecksum_new(LR_CHECKSUM_SHA512,
3ea492
                                                  tests[i].sha512);
3ea492
@@ -351,15 +339,14 @@ START_TEST(test_downloader_checksum)
3ea492
         t1 = lr_downloadtarget_new(handle, "dev/null", NULL, fd1, NULL, checksums,
3ea492
                                    0, 0, NULL, NULL, NULL, NULL, NULL, 0, 0, NULL,
3ea492
                                    FALSE, FALSE);
3ea492
-        fail_if(!t1);
3ea492
+        ck_assert_ptr_nonnull(t1);
3ea492
 
3ea492
         list = g_slist_append(list, t1);
3ea492
 
3ea492
         // Download
3ea492
 
3ea492
-        ret = lr_download(list, FALSE, &err;;
3ea492
-        fail_if(!ret);
3ea492
-        fail_if(err);
3ea492
+        ck_assert(lr_download(list, FALSE, &err));
3ea492
+        ck_assert_ptr_null(err);
3ea492
 
3ea492
         lr_handle_free(handle);
3ea492
 
3ea492
diff --git a/tests/test_gpg.c b/tests/test_gpg.c
3ea492
index 1f956d8b..fd322e38 100644
3ea492
--- a/tests/test_gpg.c
3ea492
+++ b/tests/test_gpg.c
3ea492
@@ -39,24 +39,24 @@ START_TEST(test_gpg_check_signature)
3ea492
                              "repo_yum_01/repodata/repomd.xml_bad.asc", NULL);
3ea492
 
3ea492
     ret = lr_gpg_import_key(key_path, tmp_home_path, &tmp_err);
3ea492
-    fail_if(!ret);
3ea492
-    fail_if(tmp_err);
3ea492
+    ck_assert(ret);
3ea492
+    ck_assert_ptr_null(tmp_err);
3ea492
 
3ea492
     // Valid key and data
3ea492
     ret = lr_gpg_check_signature(signature_path,
3ea492
                                  data_path,
3ea492
                                  tmp_home_path,
3ea492
                                  &tmp_err);
3ea492
-    fail_if(!ret);
3ea492
-    fail_if(tmp_err);
3ea492
+    ck_assert(ret);
3ea492
+    ck_assert_ptr_null(tmp_err);
3ea492
 
3ea492
     // Bad signature signed with unknown key
3ea492
     ret = lr_gpg_check_signature(_signature_path,
3ea492
                                  data_path,
3ea492
                                  tmp_home_path,
3ea492
                                  &tmp_err);
3ea492
-    fail_if(ret);
3ea492
-    fail_if(!tmp_err);
3ea492
+    ck_assert(!ret);
3ea492
+    ck_assert_ptr_nonnull(tmp_err);
3ea492
     g_error_free(tmp_err);
3ea492
     tmp_err = NULL;
3ea492
 
3ea492
@@ -65,31 +65,31 @@ START_TEST(test_gpg_check_signature)
3ea492
                                  _data_path,
3ea492
                                  tmp_home_path,
3ea492
                                  &tmp_err);
3ea492
-    fail_if(ret);
3ea492
-    fail_if(!tmp_err);
3ea492
+    ck_assert(!ret);
3ea492
+    ck_assert_ptr_nonnull(tmp_err);
3ea492
     g_error_free(tmp_err);
3ea492
     tmp_err = NULL;
3ea492
 
3ea492
     // Import the 2nd key
3ea492
     ret = lr_gpg_import_key(_key_path, tmp_home_path, &tmp_err);
3ea492
-    fail_if(!ret);
3ea492
-    fail_if(tmp_err);
3ea492
+    ck_assert(ret);
3ea492
+    ck_assert_ptr_null(tmp_err);
3ea492
 
3ea492
     // Valid key and data
3ea492
     ret = lr_gpg_check_signature(_signature_path,
3ea492
                                  _data_path,
3ea492
                                  tmp_home_path,
3ea492
                                  &tmp_err);
3ea492
-    fail_if(!ret);
3ea492
-    fail_if(tmp_err);
3ea492
+    ck_assert(ret);
3ea492
+    ck_assert_ptr_null(tmp_err);
3ea492
 
3ea492
     // Bad signature signed with known key
3ea492
     ret = lr_gpg_check_signature(_signature_path,
3ea492
                                  data_path,
3ea492
                                  tmp_home_path,
3ea492
                                  &tmp_err);
3ea492
-    fail_if(ret);
3ea492
-    fail_if(!tmp_err);
3ea492
+    ck_assert(!ret);
3ea492
+    ck_assert_ptr_nonnull(tmp_err);
3ea492
     g_error_free(tmp_err);
3ea492
     tmp_err = NULL;
3ea492
 
3ea492
@@ -98,8 +98,8 @@ START_TEST(test_gpg_check_signature)
3ea492
                                  data_path,
3ea492
                                  tmp_home_path,
3ea492
                                  &tmp_err);
3ea492
-    fail_if(ret);
3ea492
-    fail_if(!tmp_err);
3ea492
+    ck_assert(!ret);
3ea492
+    ck_assert_ptr_nonnull(tmp_err);
3ea492
     g_error_free(tmp_err);
3ea492
     tmp_err = NULL;
3ea492
 
3ea492
diff --git a/tests/test_handle.c b/tests/test_handle.c
3ea492
index d8b3c3fe..a80df4eb 100644
3ea492
--- a/tests/test_handle.c
3ea492
+++ b/tests/test_handle.c
3ea492
@@ -22,42 +22,42 @@ START_TEST(test_handle)
3ea492
     GError *tmp_err = NULL;
3ea492
 
3ea492
     h = lr_handle_init();
3ea492
-    fail_if(h == NULL);
3ea492
+    ck_assert_ptr_nonnull(h);
3ea492
     lr_handle_free(h);
3ea492
     h = NULL;
3ea492
 
3ea492
     /* This test is meant to check memory leaks. (Use valgrind) */
3ea492
     h = lr_handle_init();
3ea492
     char *urls[] = {"foo", NULL};
3ea492
-    fail_if(!lr_handle_setopt(h, &tmp_err, LRO_URLS, urls));
3ea492
-    fail_if(tmp_err);
3ea492
-    fail_if(!lr_handle_setopt(h, &tmp_err, LRO_URLS, urls));
3ea492
-    fail_if(tmp_err);
3ea492
-    fail_if(!lr_handle_setopt(h, &tmp_err, LRO_MIRRORLIST, "foo"));
3ea492
-    fail_if(tmp_err);
3ea492
-    fail_if(!lr_handle_setopt(h, &tmp_err, LRO_MIRRORLIST, "bar"));
3ea492
-    fail_if(tmp_err);
3ea492
-    fail_if(!lr_handle_setopt(h, NULL, LRO_USERPWD, "user:pwd"));
3ea492
-    fail_if(!lr_handle_setopt(h, NULL, LRO_PROXY, "proxy"));
3ea492
-    fail_if(!lr_handle_setopt(h, NULL, LRO_PROXYUSERPWD, "proxyuser:pwd"));
3ea492
-    fail_if(!lr_handle_setopt(h, NULL, LRO_DESTDIR, "foodir"));
3ea492
-    fail_if(!lr_handle_setopt(h, NULL, LRO_USERAGENT, "librepo/0.0"));
3ea492
+    ck_assert(lr_handle_setopt(h, &tmp_err, LRO_URLS, urls));
3ea492
+    ck_assert_ptr_null(tmp_err);
3ea492
+    ck_assert(lr_handle_setopt(h, &tmp_err, LRO_URLS, urls));
3ea492
+    ck_assert_ptr_null(tmp_err);
3ea492
+    ck_assert(lr_handle_setopt(h, &tmp_err, LRO_MIRRORLIST, "foo"));
3ea492
+    ck_assert_ptr_null(tmp_err);
3ea492
+    ck_assert(lr_handle_setopt(h, &tmp_err, LRO_MIRRORLIST, "bar"));
3ea492
+    ck_assert_ptr_null(tmp_err);
3ea492
+    ck_assert(lr_handle_setopt(h, NULL, LRO_USERPWD, "user:pwd"));
3ea492
+    ck_assert(lr_handle_setopt(h, NULL, LRO_PROXY, "proxy"));
3ea492
+    ck_assert(lr_handle_setopt(h, NULL, LRO_PROXYUSERPWD, "proxyuser:pwd"));
3ea492
+    ck_assert(lr_handle_setopt(h, NULL, LRO_DESTDIR, "foodir"));
3ea492
+    ck_assert(lr_handle_setopt(h, NULL, LRO_USERAGENT, "librepo/0.0"));
3ea492
     char *dlist[] = {"primary", "filelists", NULL};
3ea492
-    fail_if(!lr_handle_setopt(h, NULL, LRO_YUMDLIST, dlist));
3ea492
-    fail_if(!lr_handle_setopt(h, NULL, LRO_YUMBLIST, dlist));
3ea492
+    ck_assert(lr_handle_setopt(h, NULL, LRO_YUMDLIST, dlist));
3ea492
+    ck_assert(lr_handle_setopt(h, NULL, LRO_YUMBLIST, dlist));
3ea492
     LrUrlVars *vars = NULL;
3ea492
     vars = lr_urlvars_set(vars, "foo", "bar");
3ea492
-    fail_if(!lr_handle_setopt(h, NULL, LRO_VARSUB, vars));
3ea492
-    fail_if(!lr_handle_setopt(h, NULL, LRO_FASTESTMIRRORCACHE,
3ea492
+    ck_assert(lr_handle_setopt(h, NULL, LRO_VARSUB, vars));
3ea492
+    ck_assert(lr_handle_setopt(h, NULL, LRO_FASTESTMIRRORCACHE,
3ea492
                               "/var/cache/fastestmirror.librepo"));
3ea492
-    fail_if(!lr_handle_setopt(h, NULL, LRO_SSLCLIENTCERT, "/etc/cert.pem"));
3ea492
-    fail_if(!lr_handle_setopt(h, NULL, LRO_SSLCLIENTKEY, "/etc/cert.key"));
3ea492
-    fail_if(!lr_handle_setopt(h, NULL, LRO_SSLCACERT, "/etc/ca.pem"));
3ea492
-    fail_if(!lr_handle_setopt(h, NULL, LRO_PROXY_SSLCLIENTCERT, "/etc/proxy_cert.pem"));
3ea492
-    fail_if(!lr_handle_setopt(h, NULL, LRO_PROXY_SSLCLIENTKEY, "/etc/proxy_cert.key"));
3ea492
-    fail_if(!lr_handle_setopt(h, NULL, LRO_PROXY_SSLCACERT, "/etc/proxy_ca.pem"));
3ea492
-    fail_if(!lr_handle_setopt(h, NULL, LRO_HTTPAUTHMETHODS, LR_AUTH_NTLM));
3ea492
-    fail_if(!lr_handle_setopt(h, NULL, LRO_PROXYAUTHMETHODS, LR_AUTH_DIGEST));
3ea492
+    ck_assert(lr_handle_setopt(h, NULL, LRO_SSLCLIENTCERT, "/etc/cert.pem"));
3ea492
+    ck_assert(lr_handle_setopt(h, NULL, LRO_SSLCLIENTKEY, "/etc/cert.key"));
3ea492
+    ck_assert(lr_handle_setopt(h, NULL, LRO_SSLCACERT, "/etc/ca.pem"));
3ea492
+    ck_assert(lr_handle_setopt(h, NULL, LRO_PROXY_SSLCLIENTCERT, "/etc/proxy_cert.pem"));
3ea492
+    ck_assert(lr_handle_setopt(h, NULL, LRO_PROXY_SSLCLIENTKEY, "/etc/proxy_cert.key"));
3ea492
+    ck_assert(lr_handle_setopt(h, NULL, LRO_PROXY_SSLCACERT, "/etc/proxy_ca.pem"));
3ea492
+    ck_assert(lr_handle_setopt(h, NULL, LRO_HTTPAUTHMETHODS, LR_AUTH_NTLM));
3ea492
+    ck_assert(lr_handle_setopt(h, NULL, LRO_PROXYAUTHMETHODS, LR_AUTH_DIGEST));
3ea492
     lr_handle_free(h);
3ea492
 }
3ea492
 END_TEST
3ea492
@@ -73,90 +73,90 @@ START_TEST(test_handle_getinfo)
3ea492
     h = lr_handle_init();
3ea492
 
3ea492
     num = -1;
3ea492
-    fail_if(!lr_handle_getinfo(h, &tmp_err, LRI_UPDATE, &num);;
3ea492
-    fail_if(num != 0);
3ea492
-    fail_if(tmp_err);
3ea492
+    ck_assert(lr_handle_getinfo(h, &tmp_err, LRI_UPDATE, &num);;
3ea492
+    ck_assert(num == 0);
3ea492
+    ck_assert_ptr_null(tmp_err);
3ea492
 
3ea492
     strlist = NULL;
3ea492
-    fail_if(!lr_handle_getinfo(h, &tmp_err, LRI_URLS, &strlist));
3ea492
-    fail_if(strlist != NULL);
3ea492
-    fail_if(tmp_err);
3ea492
+    ck_assert(lr_handle_getinfo(h, &tmp_err, LRI_URLS, &strlist));
3ea492
+    ck_assert_ptr_null(strlist);
3ea492
+    ck_assert_ptr_null(tmp_err);
3ea492
 
3ea492
     str = NULL;
3ea492
-    fail_if(!lr_handle_getinfo(h, NULL, LRI_MIRRORLIST, &str);;
3ea492
-    fail_if(str != NULL);
3ea492
+    ck_assert(lr_handle_getinfo(h, NULL, LRI_MIRRORLIST, &str);;
3ea492
+    ck_assert_ptr_null(str);
3ea492
 
3ea492
     num = -1;
3ea492
-    fail_if(!lr_handle_getinfo(h, NULL, LRI_LOCAL, &num);;
3ea492
-    fail_if(num != 0);
3ea492
+    ck_assert(lr_handle_getinfo(h, NULL, LRI_LOCAL, &num);;
3ea492
+    ck_assert(num == 0);
3ea492
 
3ea492
     str = NULL;
3ea492
-    fail_if(!lr_handle_getinfo(h, NULL, LRI_DESTDIR, &str);;
3ea492
-    fail_if(str != NULL);
3ea492
+    ck_assert(lr_handle_getinfo(h, NULL, LRI_DESTDIR, &str);;
3ea492
+    ck_assert_ptr_null(str);
3ea492
 
3ea492
     num = -1;
3ea492
-    fail_if(!lr_handle_getinfo(h, NULL, LRI_REPOTYPE, &num);;
3ea492
-    fail_if(num != 0);
3ea492
+    ck_assert(lr_handle_getinfo(h, NULL, LRI_REPOTYPE, &num);;
3ea492
+    ck_assert(num == 0);
3ea492
 
3ea492
     str = NULL;
3ea492
-    fail_if(!lr_handle_getinfo(h, NULL, LRI_USERAGENT, &str);;
3ea492
-    fail_if(str != NULL);
3ea492
+    ck_assert(lr_handle_getinfo(h, NULL, LRI_USERAGENT, &str);;
3ea492
+    ck_assert_ptr_null(str);
3ea492
 
3ea492
     strlist = NULL;
3ea492
-    fail_if(!lr_handle_getinfo(h, NULL, LRI_YUMDLIST, &strlist));
3ea492
-    fail_if(strlist != NULL);
3ea492
+    ck_assert(lr_handle_getinfo(h, NULL, LRI_YUMDLIST, &strlist));
3ea492
+    ck_assert_ptr_null(strlist);
3ea492
 
3ea492
     strlist = NULL;
3ea492
-    fail_if(!lr_handle_getinfo(h, NULL, LRI_YUMBLIST, &strlist));
3ea492
-    fail_if(strlist != NULL);
3ea492
+    ck_assert(lr_handle_getinfo(h, NULL, LRI_YUMBLIST, &strlist));
3ea492
+    ck_assert_ptr_null(strlist);
3ea492
 
3ea492
     num = -1;
3ea492
-    fail_if(!lr_handle_getinfo(h, NULL, LRI_MAXMIRRORTRIES, &num);;
3ea492
-    fail_if(num != 0);
3ea492
+    ck_assert(lr_handle_getinfo(h, NULL, LRI_MAXMIRRORTRIES, &num);;
3ea492
+    ck_assert(num == 0);
3ea492
 
3ea492
     LrUrlVars *vars = NULL;
3ea492
-    fail_if(!lr_handle_getinfo(h, NULL, LRI_VARSUB, &vars);;
3ea492
-    fail_if(strlist != NULL);
3ea492
+    ck_assert(lr_handle_getinfo(h, NULL, LRI_VARSUB, &vars);;
3ea492
+    ck_assert_ptr_null(strlist);
3ea492
 
3ea492
     str = NULL;
3ea492
-    fail_if(!lr_handle_getinfo(h, NULL, LRI_FASTESTMIRRORCACHE, &str);;
3ea492
-    fail_if(str != NULL);
3ea492
+    ck_assert(lr_handle_getinfo(h, NULL, LRI_FASTESTMIRRORCACHE, &str);;
3ea492
+    ck_assert_ptr_null(str);
3ea492
 
3ea492
     num = -1;
3ea492
-    fail_if(!lr_handle_getinfo(h, NULL, LRI_FASTESTMIRRORMAXAGE, &num);;
3ea492
-    fail_if(num != LRO_FASTESTMIRRORMAXAGE_DEFAULT);
3ea492
+    ck_assert(lr_handle_getinfo(h, NULL, LRI_FASTESTMIRRORMAXAGE, &num);;
3ea492
+    ck_assert(num == LRO_FASTESTMIRRORMAXAGE_DEFAULT);
3ea492
 
3ea492
     str = NULL;
3ea492
-    fail_if(!lr_handle_getinfo(h, NULL, LRI_SSLCLIENTCERT, &str);;
3ea492
-    fail_if(str != NULL);
3ea492
+    ck_assert(lr_handle_getinfo(h, NULL, LRI_SSLCLIENTCERT, &str);;
3ea492
+    ck_assert_ptr_null(str);
3ea492
 
3ea492
     str = NULL;
3ea492
-    fail_if(!lr_handle_getinfo(h, NULL, LRI_SSLCLIENTKEY, &str);;
3ea492
-    fail_if(str != NULL);
3ea492
+    ck_assert(lr_handle_getinfo(h, NULL, LRI_SSLCLIENTKEY, &str);;
3ea492
+    ck_assert_ptr_null(str);
3ea492
 
3ea492
     str = NULL;
3ea492
-    fail_if(!lr_handle_getinfo(h, NULL, LRI_SSLCACERT, &str);;
3ea492
-    fail_if(str != NULL);
3ea492
+    ck_assert(lr_handle_getinfo(h, NULL, LRI_SSLCACERT, &str);;
3ea492
+    ck_assert_ptr_null(str);
3ea492
 
3ea492
     str = NULL;
3ea492
-    fail_if(!lr_handle_getinfo(h, NULL, LRI_PROXY_SSLCLIENTCERT, &str);;
3ea492
-    fail_if(str != NULL);
3ea492
+    ck_assert(lr_handle_getinfo(h, NULL, LRI_PROXY_SSLCLIENTCERT, &str);;
3ea492
+    ck_assert_ptr_null(str);
3ea492
 
3ea492
     str = NULL;
3ea492
-    fail_if(!lr_handle_getinfo(h, NULL, LRI_PROXY_SSLCLIENTKEY, &str);;
3ea492
-    fail_if(str != NULL);
3ea492
+    ck_assert(lr_handle_getinfo(h, NULL, LRI_PROXY_SSLCLIENTKEY, &str);;
3ea492
+    ck_assert_ptr_null(str);
3ea492
 
3ea492
     str = NULL;
3ea492
-    fail_if(!lr_handle_getinfo(h, NULL, LRI_PROXY_SSLCACERT, &str);;
3ea492
-    fail_if(str != NULL);
3ea492
+    ck_assert(lr_handle_getinfo(h, NULL, LRI_PROXY_SSLCACERT, &str);;
3ea492
+    ck_assert_ptr_null(str);
3ea492
 
3ea492
     LrAuth auth = LR_AUTH_NONE;
3ea492
-    fail_if(!lr_handle_getinfo(h, NULL, LRI_HTTPAUTHMETHODS, &auth));
3ea492
-    fail_if(auth != LR_AUTH_BASIC);
3ea492
+    ck_assert(lr_handle_getinfo(h, NULL, LRI_HTTPAUTHMETHODS, &auth));
3ea492
+    ck_assert(auth == LR_AUTH_BASIC);
3ea492
 
3ea492
     auth = LR_AUTH_NONE;
3ea492
-    fail_if(!lr_handle_getinfo(h, NULL, LRI_PROXYAUTHMETHODS, &auth));
3ea492
-    fail_if(auth != LR_AUTH_BASIC);
3ea492
+    ck_assert(lr_handle_getinfo(h, NULL, LRI_PROXYAUTHMETHODS, &auth));
3ea492
+    ck_assert(auth == LR_AUTH_BASIC);
3ea492
 
3ea492
     lr_handle_free(h);
3ea492
 }
3ea492
diff --git a/tests/test_lrmirrorlist.c b/tests/test_lrmirrorlist.c
3ea492
index 9c908026..70c73b2c 100644
3ea492
--- a/tests/test_lrmirrorlist.c
3ea492
+++ b/tests/test_lrmirrorlist.c
3ea492
@@ -29,16 +29,16 @@ START_TEST(test_lrmirrorlist_append_url)
3ea492
     lr_urlvars_free(vars);
3ea492
 
3ea492
     mirror = lr_lrmirrorlist_nth(iml, 0);
3ea492
-    fail_if(!mirror);
3ea492
-    fail_if(strcmp(mirror->url, "ftp://bar"));
3ea492
+    ck_assert_ptr_nonnull(mirror);
3ea492
+    ck_assert_str_eq(mirror->url, "ftp://bar");
3ea492
 
3ea492
     mirror = lr_lrmirrorlist_nth(iml, 1);
3ea492
-    fail_if(!mirror);
3ea492
-    fail_if(strcmp(mirror->url, "http://foo"));
3ea492
+    ck_assert_ptr_nonnull(mirror);
3ea492
+    ck_assert_str_eq(mirror->url, "http://foo");
3ea492
 
3ea492
     mirror = lr_lrmirrorlist_nth(iml, 2);
3ea492
-    fail_if(!mirror);
3ea492
-    fail_if(strcmp(mirror->url, "http://xyz/i386/"));
3ea492
+    ck_assert_ptr_nonnull(mirror);
3ea492
+    ck_assert_str_eq(mirror->url, "http://xyz/i386/");
3ea492
 
3ea492
     lr_lrmirrorlist_free(iml);
3ea492
 }
3ea492
@@ -56,30 +56,30 @@ START_TEST(test_lrmirrorlist_append_mirrorlist)
3ea492
     ml.urls = g_slist_prepend(ml.urls, "ftp://bar");
3ea492
     ml.urls = g_slist_prepend(ml.urls, "http://foo");
3ea492
 
3ea492
-    fail_if(g_slist_length(iml) != 0);
3ea492
+    ck_assert(g_slist_length(iml) == 0);
3ea492
     iml = lr_lrmirrorlist_append_mirrorlist(iml, NULL, NULL);
3ea492
-    fail_if(g_slist_length(iml) != 0);
3ea492
+    ck_assert(g_slist_length(iml) == 0);
3ea492
 
3ea492
     iml = lr_lrmirrorlist_append_mirrorlist(iml, &ml, NULL);
3ea492
-    fail_if(g_slist_length(iml) != 2);
3ea492
+    ck_assert(g_slist_length(iml) == 2);
3ea492
     mirror = lr_lrmirrorlist_nth(iml, 0);
3ea492
-    fail_if(!mirror);
3ea492
-    fail_if(strcmp(mirror->url, "http://foo"));
3ea492
-    fail_if(mirror->preference != 100);
3ea492
-    fail_if(mirror->protocol != LR_PROTOCOL_HTTP);
3ea492
+    ck_assert_ptr_nonnull(mirror);
3ea492
+    ck_assert_str_eq(mirror->url, "http://foo");
3ea492
+    ck_assert(mirror->preference == 100);
3ea492
+    ck_assert(mirror->protocol == LR_PROTOCOL_HTTP);
3ea492
     mirror = lr_lrmirrorlist_nth(iml, 1);
3ea492
-    fail_if(!mirror);
3ea492
-    fail_if(strcmp(mirror->url, "ftp://bar"));
3ea492
-    fail_if(mirror->preference != 100);
3ea492
-    fail_if(mirror->protocol != LR_PROTOCOL_FTP);
3ea492
+    ck_assert_ptr_nonnull(mirror);
3ea492
+    ck_assert_str_eq(mirror->url, "ftp://bar");
3ea492
+    ck_assert(mirror->preference == 100);
3ea492
+    ck_assert(mirror->protocol == LR_PROTOCOL_FTP);
3ea492
 
3ea492
-    fail_if(g_slist_length(iml) != 2);
3ea492
+    ck_assert(g_slist_length(iml) == 2);
3ea492
 
3ea492
     url = lr_lrmirrorlist_nth_url(iml, 0);
3ea492
-    fail_if(strcmp(url, "http://foo"));
3ea492
+    ck_assert_str_eq(url, "http://foo");
3ea492
 
3ea492
     url = lr_lrmirrorlist_nth_url(iml, 1);
3ea492
-    fail_if(strcmp(url, "ftp://bar"));
3ea492
+    ck_assert_str_eq(url, "ftp://bar");
3ea492
 
3ea492
     lr_lrmirrorlist_free(iml);
3ea492
     g_slist_free(ml.urls);
3ea492
@@ -132,46 +132,46 @@ START_TEST(test_lrmirrorlist_append_metalink)
3ea492
     ml.urls = g_slist_prepend(ml.urls, &url2);
3ea492
     ml.urls = g_slist_prepend(ml.urls, &url1);
3ea492
 
3ea492
-    fail_if(g_slist_length(iml) != 0);
3ea492
+    ck_assert(g_slist_length(iml) == 0);
3ea492
     iml = lr_lrmirrorlist_append_metalink(iml, NULL, NULL, NULL);
3ea492
-    fail_if(g_slist_length(iml) != 0);
3ea492
+    ck_assert(g_slist_length(iml) == 0);
3ea492
 
3ea492
     iml = lr_lrmirrorlist_append_metalink(iml, &ml, "/repodata/repomd.xml", NULL);
3ea492
-    fail_if(g_slist_length(iml) != 2);  // 2 because element with empty url shoud be skipped
3ea492
+    ck_assert(g_slist_length(iml) == 2);  // 2 because element with empty url shoud be skipped
3ea492
 
3ea492
     mirror = lr_lrmirrorlist_nth(iml, 0);
3ea492
-    fail_if(strcmp(mirror->url, "http://foo"));
3ea492
-    fail_if(mirror->preference != 100);
3ea492
-    fail_if(mirror->protocol != LR_PROTOCOL_HTTP);
3ea492
+    ck_assert_str_eq(mirror->url, "http://foo");
3ea492
+    ck_assert(mirror->preference == 100);
3ea492
+    ck_assert(mirror->protocol == LR_PROTOCOL_HTTP);
3ea492
 
3ea492
     mirror = lr_lrmirrorlist_nth(iml, 1);
3ea492
-    fail_if(strcmp(mirror->url, "ftp://bar"));
3ea492
-    fail_if(mirror->preference != 95);
3ea492
-    fail_if(mirror->protocol != LR_PROTOCOL_FTP);
3ea492
+    ck_assert_str_eq(mirror->url, "ftp://bar");
3ea492
+    ck_assert(mirror->preference == 95);
3ea492
+    ck_assert(mirror->protocol == LR_PROTOCOL_FTP);
3ea492
 
3ea492
-    fail_if(g_slist_length(iml) != 2);
3ea492
+    ck_assert(g_slist_length(iml) == 2);
3ea492
 
3ea492
     url = lr_lrmirrorlist_nth_url(iml, 0);
3ea492
-    fail_if(strcmp(url, "http://foo"));
3ea492
+    ck_assert_str_eq(url, "http://foo");
3ea492
 
3ea492
     url = lr_lrmirrorlist_nth_url(iml, 1);
3ea492
-    fail_if(strcmp(url, "ftp://bar"));
3ea492
+    ck_assert_str_eq(url, "ftp://bar");
3ea492
 
3ea492
     lr_lrmirrorlist_free(iml);
3ea492
 
3ea492
     // Try append on list with existing element
3ea492
     iml = NULL;
3ea492
-    fail_if(g_slist_length(iml) != 0);
3ea492
+    ck_assert(g_slist_length(iml) == 0);
3ea492
     iml = lr_lrmirrorlist_append_url(iml, "http://abc", NULL);
3ea492
-    fail_if(g_slist_length(iml) != 1);
3ea492
+    ck_assert(g_slist_length(iml) == 1);
3ea492
     iml = lr_lrmirrorlist_append_metalink(iml, &ml, "/repodata/repomd.xml", NULL);
3ea492
-    fail_if(g_slist_length(iml) != 3);
3ea492
+    ck_assert(g_slist_length(iml) == 3);
3ea492
     url = lr_lrmirrorlist_nth_url(iml, 0);
3ea492
-    fail_if(strcmp(url, "http://abc"));
3ea492
+    ck_assert_str_eq(url, "http://abc");
3ea492
     url = lr_lrmirrorlist_nth_url(iml, 1);
3ea492
-    fail_if(strcmp(url, "http://foo"));
3ea492
+    ck_assert_str_eq(url, "http://foo");
3ea492
     url = lr_lrmirrorlist_nth_url(iml, 2);
3ea492
-    fail_if(strcmp(url, "ftp://bar"));
3ea492
+    ck_assert_str_eq(url, "ftp://bar");
3ea492
 
3ea492
     lr_lrmirrorlist_free(iml);
3ea492
     g_slist_free(ml.urls);
3ea492
@@ -189,48 +189,48 @@ START_TEST(test_lrmirrorlist_append_lrmirrorlist)
3ea492
     iml_2 = lr_lrmirrorlist_append_url(iml_2, NULL, NULL);
3ea492
     iml_2 = lr_lrmirrorlist_append_url(iml_2, "ftp://bar", NULL);
3ea492
 
3ea492
-    fail_if(g_slist_length(iml_2) != 2);
3ea492
+    ck_assert(g_slist_length(iml_2) == 2);
3ea492
 
3ea492
-    fail_if(g_slist_length(iml) != 0);
3ea492
+    ck_assert(g_slist_length(iml) == 0);
3ea492
     iml = lr_lrmirrorlist_append_lrmirrorlist(iml, NULL);
3ea492
-    fail_if(g_slist_length(iml) != 0);
3ea492
+    ck_assert(g_slist_length(iml) == 0);
3ea492
 
3ea492
     iml = lr_lrmirrorlist_append_lrmirrorlist(iml, iml_2);
3ea492
-    fail_if(g_slist_length(iml) != 2);  // 2 because element with empty url shoud be skipped
3ea492
+    ck_assert(g_slist_length(iml) == 2);  // 2 because element with empty url shoud be skipped
3ea492
 
3ea492
     mirror = lr_lrmirrorlist_nth(iml, 0);
3ea492
-    fail_if(strcmp(mirror->url, "http://foo"));
3ea492
-    fail_if(mirror->preference != 100);
3ea492
-    fail_if(mirror->protocol != LR_PROTOCOL_HTTP);
3ea492
+    ck_assert_str_eq(mirror->url, "http://foo");
3ea492
+    ck_assert(mirror->preference == 100);
3ea492
+    ck_assert(mirror->protocol == LR_PROTOCOL_HTTP);
3ea492
 
3ea492
     mirror = lr_lrmirrorlist_nth(iml, 1);
3ea492
-    fail_if(strcmp(mirror->url, "ftp://bar"));
3ea492
-    fail_if(mirror->preference != 100);
3ea492
-    fail_if(mirror->protocol != LR_PROTOCOL_FTP);
3ea492
+    ck_assert_str_eq(mirror->url, "ftp://bar");
3ea492
+    ck_assert(mirror->preference == 100);
3ea492
+    ck_assert(mirror->protocol == LR_PROTOCOL_FTP);
3ea492
 
3ea492
-    fail_if(g_slist_length(iml) != 2);
3ea492
+    ck_assert(g_slist_length(iml) == 2);
3ea492
 
3ea492
     url = lr_lrmirrorlist_nth_url(iml, 0);
3ea492
-    fail_if(strcmp(url, "http://foo"));
3ea492
+    ck_assert_str_eq(url, "http://foo");
3ea492
 
3ea492
     url = lr_lrmirrorlist_nth_url(iml, 1);
3ea492
-    fail_if(strcmp(url, "ftp://bar"));
3ea492
+    ck_assert_str_eq(url, "ftp://bar");
3ea492
 
3ea492
     lr_lrmirrorlist_free(iml);
3ea492
 
3ea492
     // Try append on list with existing element
3ea492
     iml = NULL;
3ea492
-    fail_if(g_slist_length(iml) != 0);
3ea492
+    ck_assert(g_slist_length(iml) == 0);
3ea492
     iml = lr_lrmirrorlist_append_url(iml, "http://abc", NULL);
3ea492
-    fail_if(g_slist_length(iml) != 1);
3ea492
+    ck_assert(g_slist_length(iml) == 1);
3ea492
     iml = lr_lrmirrorlist_append_lrmirrorlist(iml, iml_2);
3ea492
-    fail_if(g_slist_length(iml) != 3);
3ea492
+    ck_assert(g_slist_length(iml) == 3);
3ea492
     url = lr_lrmirrorlist_nth_url(iml, 0);
3ea492
-    fail_if(strcmp(url, "http://abc"));
3ea492
+    ck_assert_str_eq(url, "http://abc");
3ea492
     url = lr_lrmirrorlist_nth_url(iml, 1);
3ea492
-    fail_if(strcmp(url, "http://foo"));
3ea492
+    ck_assert_str_eq(url, "http://foo");
3ea492
     url = lr_lrmirrorlist_nth_url(iml, 2);
3ea492
-    fail_if(strcmp(url, "ftp://bar"));
3ea492
+    ck_assert_str_eq(url, "ftp://bar");
3ea492
     lr_lrmirrorlist_free(iml);
3ea492
     lr_lrmirrorlist_free(iml_2);
3ea492
 }
3ea492
diff --git a/tests/test_metalink.c b/tests/test_metalink.c
3ea492
index 69ebc236..e425742c 100644
3ea492
--- a/tests/test_metalink.c
3ea492
+++ b/tests/test_metalink.c
3ea492
@@ -29,7 +29,7 @@ START_TEST(test_metalink_init)
3ea492
     LrMetalink *ml = NULL;
3ea492
 
3ea492
     ml = lr_metalink_init();
3ea492
-    fail_if(ml == NULL);
3ea492
+    ck_assert_ptr_nonnull(ml);
3ea492
     lr_metalink_free(ml);
3ea492
 }
3ea492
 END_TEST
3ea492
@@ -49,101 +49,101 @@ START_TEST(test_metalink_good_01)
3ea492
                          "metalink_good_01", NULL);
3ea492
     fd = open(path, O_RDONLY);
3ea492
     lr_free(path);
3ea492
-    fail_if(fd < 0);
3ea492
+    ck_assert_int_ge(fd, 0);
3ea492
     ml = lr_metalink_init();
3ea492
-    fail_if(ml == NULL);
3ea492
+    ck_assert_ptr_nonnull(ml);
3ea492
     ret = lr_metalink_parse_file(ml, fd, REPOMD, NULL, NULL, &tmp_err);
3ea492
-    fail_if(!ret);
3ea492
-    fail_if(tmp_err);
3ea492
+    ck_assert(ret);
3ea492
+    ck_assert_ptr_null(tmp_err);
3ea492
     close(fd);
3ea492
 
3ea492
-    fail_if(ml->filename == NULL);
3ea492
-    fail_if(strcmp(ml->filename, "repomd.xml"));
3ea492
-    fail_if(ml->timestamp != 1337942396);
3ea492
-    fail_if(ml->size != 4309);
3ea492
-    fail_if(g_slist_length(ml->hashes) != 4);
3ea492
-    fail_if(g_slist_length(ml->urls) != 106);
3ea492
+    ck_assert_ptr_nonnull(ml->filename);
3ea492
+    ck_assert_str_eq(ml->filename, "repomd.xml");
3ea492
+    ck_assert(ml->timestamp == 1337942396);
3ea492
+    ck_assert(ml->size == 4309);
3ea492
+    ck_assert(g_slist_length(ml->hashes) == 4);
3ea492
+    ck_assert(g_slist_length(ml->urls) == 106);
3ea492
 
3ea492
     elem = g_slist_nth(ml->hashes, 0);
3ea492
-    fail_if(!elem);
3ea492
+    ck_assert_ptr_nonnull(elem);
3ea492
     mlhash = elem->data;
3ea492
-    fail_if(!mlhash);
3ea492
-    fail_if(mlhash->type == NULL);
3ea492
-    fail_if(strcmp(mlhash->type, "md5"));
3ea492
-    fail_if(mlhash->value == NULL);
3ea492
-    fail_if(strcmp(mlhash->value, "20b6d77930574ae541108e8e7987ad3f"));
3ea492
+    ck_assert_ptr_nonnull(mlhash);
3ea492
+    ck_assert_ptr_nonnull(mlhash->type);
3ea492
+    ck_assert_str_eq(mlhash->type, "md5");
3ea492
+    ck_assert_ptr_nonnull(mlhash->value);
3ea492
+    ck_assert_str_eq(mlhash->value, "20b6d77930574ae541108e8e7987ad3f");
3ea492
 
3ea492
     elem = g_slist_nth(ml->hashes, 1);
3ea492
-    fail_if(!elem);
3ea492
+    ck_assert_ptr_nonnull(elem);
3ea492
     mlhash = elem->data;
3ea492
-    fail_if(!mlhash);
3ea492
-    fail_if(mlhash->type == NULL);
3ea492
-    fail_if(strcmp(mlhash->type, "sha1"));
3ea492
-    fail_if(mlhash->value == NULL);
3ea492
-    fail_if(strcmp(mlhash->value, "4a5ae1831a567b58e2e0f0de1529ca199d1d8319"));
3ea492
+    ck_assert_ptr_nonnull(mlhash);
3ea492
+    ck_assert_ptr_nonnull(mlhash->type);
3ea492
+    ck_assert_str_eq(mlhash->type, "sha1");
3ea492
+    ck_assert_ptr_nonnull(mlhash->value);
3ea492
+    ck_assert_str_eq(mlhash->value, "4a5ae1831a567b58e2e0f0de1529ca199d1d8319");
3ea492
 
3ea492
     elem = g_slist_nth(ml->hashes, 2);
3ea492
-    fail_if(!elem);
3ea492
+    ck_assert_ptr_nonnull(elem);
3ea492
     mlhash = elem->data;
3ea492
-    fail_if(!mlhash);
3ea492
-    fail_if(mlhash->type == NULL);
3ea492
-    fail_if(strcmp(mlhash->type, "sha256"));
3ea492
-    fail_if(mlhash->value == NULL);
3ea492
-    fail_if(strcmp(mlhash->value, "0076c44aabd352da878d5c4d794901ac87f66afac869488f6a4ef166de018cdf"));
3ea492
+    ck_assert_ptr_nonnull(mlhash);
3ea492
+    ck_assert_ptr_nonnull(mlhash->type);
3ea492
+    ck_assert_str_eq(mlhash->type, "sha256");
3ea492
+    ck_assert_ptr_nonnull(mlhash->value);
3ea492
+    ck_assert_str_eq(mlhash->value, "0076c44aabd352da878d5c4d794901ac87f66afac869488f6a4ef166de018cdf");
3ea492
 
3ea492
     elem = g_slist_nth(ml->hashes, 3);
3ea492
-    fail_if(!elem);
3ea492
+    ck_assert_ptr_nonnull(elem);
3ea492
     mlhash = elem->data;
3ea492
-    fail_if(!mlhash);
3ea492
-    fail_if(mlhash->type == NULL);
3ea492
-    fail_if(strcmp(mlhash->type, "sha512"));
3ea492
-    fail_if(mlhash->value == NULL);
3ea492
-    fail_if(strcmp(mlhash->value, "884dc465da67fee8fe3f11dab321a99d9a13b22ce97f84ceff210e82b6b1a8c635ccd196add1dd738807686714c3a0a048897e2d0650bc05302b3ee26de521fd"));
3ea492
+    ck_assert_ptr_nonnull(mlhash);
3ea492
+    ck_assert_ptr_nonnull(mlhash->type);
3ea492
+    ck_assert_str_eq(mlhash->type, "sha512");
3ea492
+    ck_assert_ptr_nonnull(mlhash->value);
3ea492
+    ck_assert_str_eq(mlhash->value, "884dc465da67fee8fe3f11dab321a99d9a13b22ce97f84ceff210e82b6b1a8c635ccd196add1dd738807686714c3a0a048897e2d0650bc05302b3ee26de521fd");
3ea492
 
3ea492
     elem = g_slist_nth(ml->urls, 0);
3ea492
-    fail_if(!elem);
3ea492
+    ck_assert_ptr_nonnull(elem);
3ea492
     mlurl = elem->data;
3ea492
-    fail_if(!mlurl);
3ea492
-    fail_if(mlurl->protocol == NULL);
3ea492
-    fail_if(strcmp(mlurl->protocol, "http"));
3ea492
-    fail_if(mlurl->type == NULL);
3ea492
-    fail_if(strcmp(mlurl->type, "http"));
3ea492
-    fail_if(mlurl->location == NULL);
3ea492
-    fail_if(strcmp(mlurl->location, "US"));
3ea492
-    fail_if(mlurl->preference != 99);
3ea492
-    fail_if(mlurl->url == NULL);
3ea492
-    fail_if(strcmp(mlurl->url,
3ea492
-                   "http://mirror.pnl.gov/fedora/linux/releases/17/Everything/x86_64/os/repodata/repomd.xml"));
3ea492
+    ck_assert_ptr_nonnull(mlurl);
3ea492
+    ck_assert_ptr_nonnull(mlurl->protocol);
3ea492
+    ck_assert_str_eq(mlurl->protocol, "http");
3ea492
+    ck_assert_ptr_nonnull(mlurl->type);
3ea492
+    ck_assert_str_eq(mlurl->type, "http");
3ea492
+    ck_assert_ptr_nonnull(mlurl->location);
3ea492
+    ck_assert_str_eq(mlurl->location, "US");
3ea492
+    ck_assert(mlurl->preference == 99);
3ea492
+    ck_assert_ptr_nonnull(mlurl->url);
3ea492
+    ck_assert_str_eq(mlurl->url,
3ea492
+                   "http://mirror.pnl.gov/fedora/linux/releases/17/Everything/x86_64/os/repodata/repomd.xml");
3ea492
 
3ea492
     elem = g_slist_nth(ml->urls, 2);
3ea492
-    fail_if(!elem);
3ea492
+    ck_assert_ptr_nonnull(elem);
3ea492
     mlurl = elem->data;
3ea492
-    fail_if(!mlurl);
3ea492
-    fail_if(mlurl->protocol == NULL);
3ea492
-    fail_if(strcmp(mlurl->protocol, "ftp"));
3ea492
-    fail_if(mlurl->type == NULL);
3ea492
-    fail_if(strcmp(mlurl->type, "ftp"));
3ea492
-    fail_if(mlurl->location == NULL);
3ea492
-    fail_if(strcmp(mlurl->location, "US"));
3ea492
-    fail_if(mlurl->preference != 98);
3ea492
-    fail_if(mlurl->url == NULL);
3ea492
-    fail_if(strcmp(mlurl->url,
3ea492
-                   "ftp://mirrors.syringanetworks.net/fedora/releases/17/Everything/x86_64/os/repodata/repomd.xml"));
3ea492
+    ck_assert_ptr_nonnull(mlurl);
3ea492
+    ck_assert_ptr_nonnull(mlurl->protocol);
3ea492
+    ck_assert_str_eq(mlurl->protocol, "ftp");
3ea492
+    ck_assert_ptr_nonnull(mlurl->type);
3ea492
+    ck_assert_str_eq(mlurl->type, "ftp");
3ea492
+    ck_assert_ptr_nonnull(mlurl->location);
3ea492
+    ck_assert_str_eq(mlurl->location, "US");
3ea492
+    ck_assert(mlurl->preference == 98);
3ea492
+    ck_assert_ptr_nonnull(mlurl->url);
3ea492
+    ck_assert_str_eq(mlurl->url,
3ea492
+                   "ftp://mirrors.syringanetworks.net/fedora/releases/17/Everything/x86_64/os/repodata/repomd.xml");
3ea492
 
3ea492
     elem = g_slist_nth(ml->urls, 104);
3ea492
-    fail_if(!elem);
3ea492
+    ck_assert_ptr_nonnull(elem);
3ea492
     mlurl = elem->data;
3ea492
-    fail_if(!mlurl);
3ea492
-    fail_if(mlurl->protocol == NULL);
3ea492
-    fail_if(strcmp(mlurl->protocol, "rsync"));
3ea492
-    fail_if(mlurl->type == NULL);
3ea492
-    fail_if(strcmp(mlurl->type, "rsync"));
3ea492
-    fail_if(mlurl->location == NULL);
3ea492
-    fail_if(strcmp(mlurl->location, "CA"));
3ea492
-    fail_if(mlurl->preference != 48);
3ea492
-    fail_if(mlurl->url == NULL);
3ea492
-    fail_if(strcmp(mlurl->url,
3ea492
-                   "rsync://mirror.csclub.uwaterloo.ca/fedora-enchilada/linux/releases/17/Everything/x86_64/os/repodata/repomd.xml"));
3ea492
+    ck_assert_ptr_nonnull(mlurl);
3ea492
+    ck_assert_ptr_nonnull(mlurl->protocol);
3ea492
+    ck_assert_str_eq(mlurl->protocol, "rsync");
3ea492
+    ck_assert_ptr_nonnull(mlurl->type);
3ea492
+    ck_assert_str_eq(mlurl->type, "rsync");
3ea492
+    ck_assert_ptr_nonnull(mlurl->location);
3ea492
+    ck_assert_str_eq(mlurl->location, "CA");
3ea492
+    ck_assert(mlurl->preference == 48);
3ea492
+    ck_assert_ptr_nonnull(mlurl->url);
3ea492
+    ck_assert_str_eq(mlurl->url,
3ea492
+                   "rsync://mirror.csclub.uwaterloo.ca/fedora-enchilada/linux/releases/17/Everything/x86_64/os/repodata/repomd.xml");
3ea492
 
3ea492
     lr_metalink_free(ml);
3ea492
 }
3ea492
@@ -161,35 +161,35 @@ START_TEST(test_metalink_good_02)
3ea492
                          "metalink_good_02", NULL);
3ea492
     fd = open(path, O_RDONLY);
3ea492
     lr_free(path);
3ea492
-    fail_if(fd < 0);
3ea492
+    ck_assert_int_ge(fd, 0);
3ea492
     ml = lr_metalink_init();
3ea492
-    fail_if(ml == NULL);
3ea492
+    ck_assert_ptr_nonnull(ml);
3ea492
     ret = lr_metalink_parse_file(ml, fd, REPOMD, NULL, NULL, &tmp_err);
3ea492
-    fail_if(!ret);
3ea492
-    fail_if(tmp_err);
3ea492
+    ck_assert(ret);
3ea492
+    ck_assert_ptr_null(tmp_err);
3ea492
     close(fd);
3ea492
 
3ea492
-    fail_if(ml->filename == NULL);
3ea492
-    fail_if(strcmp(ml->filename, "repomd.xml"));
3ea492
-    fail_if(ml->timestamp != 0);
3ea492
-    fail_if(ml->size != 0);
3ea492
-    fail_if(g_slist_length(ml->hashes) != 0);
3ea492
-    fail_if(g_slist_length(ml->urls) != 3);
3ea492
+    ck_assert_ptr_nonnull(ml->filename);
3ea492
+    ck_assert_str_eq(ml->filename, "repomd.xml");
3ea492
+    ck_assert(ml->timestamp == 0);
3ea492
+    ck_assert(ml->size == 0);
3ea492
+    ck_assert(g_slist_length(ml->hashes) == 0);
3ea492
+    ck_assert(g_slist_length(ml->urls) == 3);
3ea492
 
3ea492
     GSList *list = g_slist_nth(ml->urls, 0);
3ea492
-    fail_if(!list);
3ea492
+    ck_assert_ptr_nonnull(list);
3ea492
     LrMetalinkUrl *mlurl = list->data;
3ea492
-    fail_if(!mlurl);
3ea492
-    fail_if(mlurl->protocol == NULL);
3ea492
-    fail_if(strcmp(mlurl->protocol, "http"));
3ea492
-    fail_if(mlurl->type == NULL);
3ea492
-    fail_if(strcmp(mlurl->type, "http"));
3ea492
-    fail_if(mlurl->location == NULL);
3ea492
-    fail_if(strcmp(mlurl->location, "US"));
3ea492
-    fail_if(mlurl->preference != 97);
3ea492
-    fail_if(mlurl->url == NULL);
3ea492
-    fail_if(strcmp(mlurl->url,
3ea492
-                   "http://mirror.pnl.gov/fedora/linux/releases/17/Everything/x86_64/os/repodata/repomd.xml"));
3ea492
+    ck_assert_ptr_nonnull(mlurl);
3ea492
+    ck_assert_ptr_nonnull(mlurl->protocol);
3ea492
+    ck_assert_str_eq(mlurl->protocol, "http");
3ea492
+    ck_assert_ptr_nonnull(mlurl->type);
3ea492
+    ck_assert_str_eq(mlurl->type, "http");
3ea492
+    ck_assert_ptr_nonnull(mlurl->location);
3ea492
+    ck_assert_str_eq(mlurl->location, "US");
3ea492
+    ck_assert(mlurl->preference == 97);
3ea492
+    ck_assert_ptr_nonnull(mlurl->url);
3ea492
+    ck_assert_str_eq(mlurl->url,
3ea492
+                   "http://mirror.pnl.gov/fedora/linux/releases/17/Everything/x86_64/os/repodata/repomd.xml");
3ea492
 
3ea492
     lr_metalink_free(ml);
3ea492
 }
3ea492
@@ -207,20 +207,20 @@ START_TEST(test_metalink_good_03)
3ea492
                          "metalink_good_03", NULL);
3ea492
     fd = open(path, O_RDONLY);
3ea492
     lr_free(path);
3ea492
-    fail_if(fd < 0);
3ea492
+    ck_assert_int_ge(fd, 0);
3ea492
     ml = lr_metalink_init();
3ea492
-    fail_if(ml == NULL);
3ea492
+    ck_assert_ptr_nonnull(ml);
3ea492
     ret = lr_metalink_parse_file(ml, fd, REPOMD, NULL, NULL, &tmp_err);
3ea492
-    fail_if(!ret);
3ea492
-    fail_if(tmp_err);
3ea492
+    ck_assert(ret);
3ea492
+    ck_assert_ptr_null(tmp_err);
3ea492
     close(fd);
3ea492
 
3ea492
-    fail_if(ml->filename == NULL);
3ea492
-    fail_if(strcmp(ml->filename, "repomd.xml"));
3ea492
-    fail_if(ml->timestamp != 0);
3ea492
-    fail_if(ml->size != 0);
3ea492
-    fail_if(g_slist_length(ml->hashes) != 0);
3ea492
-    fail_if(g_slist_length(ml->urls) != 0);
3ea492
+    ck_assert_ptr_nonnull(ml->filename);
3ea492
+    ck_assert_str_eq(ml->filename, "repomd.xml");
3ea492
+    ck_assert(ml->timestamp == 0);
3ea492
+    ck_assert(ml->size == 0);
3ea492
+    ck_assert(g_slist_length(ml->hashes) == 0);
3ea492
+    ck_assert(g_slist_length(ml->urls) == 0);
3ea492
 
3ea492
     lr_metalink_free(ml);
3ea492
 }
3ea492
@@ -251,112 +251,110 @@ START_TEST(test_metalink_bad_01)
3ea492
                          "metalink_bad_01", NULL);
3ea492
     fd = open(path, O_RDONLY);
3ea492
     lr_free(path);
3ea492
-    fail_if(fd < 0);
3ea492
+    ck_assert_int_ge(fd, 0);
3ea492
     ml = lr_metalink_init();
3ea492
-    fail_if(ml == NULL);
3ea492
+    ck_assert_ptr_nonnull(ml);
3ea492
     int call_counter = 0;
3ea492
     ret = lr_metalink_parse_file(ml, fd, REPOMD, warning_cb, &call_counter, &tmp_err);
3ea492
-    fail_if(!ret);
3ea492
-    fail_if(tmp_err);
3ea492
-    fail_if(call_counter <= 0);
3ea492
+    ck_assert(ret);
3ea492
+    ck_assert_ptr_null(tmp_err);
3ea492
+    ck_assert_int_gt(call_counter, 0);
3ea492
     close(fd);
3ea492
 
3ea492
-    fail_if(ml->filename == NULL);
3ea492
-    fail_if(strcmp(ml->filename, "repomd.xml"));
3ea492
-    fail_if(ml->timestamp != 0);
3ea492
-    fail_if(ml->size != 0);
3ea492
-    fail_if(g_slist_length(ml->hashes) != 4);
3ea492
-    fail_if(g_slist_length(ml->urls) != 4);
3ea492
-    fail_if(g_slist_length(ml->alternates) != 0);
3ea492
+    ck_assert_ptr_nonnull(ml->filename);
3ea492
+    ck_assert_str_eq(ml->filename, "repomd.xml");
3ea492
+    ck_assert(ml->timestamp == 0);
3ea492
+    ck_assert(ml->size == 0);
3ea492
+    ck_assert(g_slist_length(ml->hashes) == 4);
3ea492
+    ck_assert(g_slist_length(ml->urls) == 4);
3ea492
+    ck_assert(g_slist_length(ml->alternates) == 0);
3ea492
 
3ea492
     elem = g_slist_nth(ml->hashes, 0);
3ea492
-    fail_if(!elem);
3ea492
+    ck_assert_ptr_nonnull(elem);
3ea492
     mlhash = elem->data;
3ea492
-    fail_if(!mlhash);
3ea492
-    fail_if(mlhash->type == NULL);
3ea492
-    fail_if(strcmp(mlhash->type, "md5"));
3ea492
-    fail_if(mlhash->value == NULL);
3ea492
-    fail_if(strcmp(mlhash->value,
3ea492
-                    "20b6d77930574ae541108e8e7987ad3f"));
3ea492
+    ck_assert_ptr_nonnull(mlhash);
3ea492
+    ck_assert_ptr_nonnull(mlhash->type);
3ea492
+    ck_assert_str_eq(mlhash->type, "md5");
3ea492
+    ck_assert_ptr_nonnull(mlhash->value);
3ea492
+    ck_assert_str_eq(mlhash->value, "20b6d77930574ae541108e8e7987ad3f");
3ea492
 
3ea492
     elem = g_slist_nth(ml->hashes, 1);
3ea492
-    fail_if(!elem);
3ea492
+    ck_assert_ptr_nonnull(elem);
3ea492
     mlhash = elem->data;
3ea492
-    fail_if(!mlhash);
3ea492
-    fail_if(mlhash->type == NULL);
3ea492
-    fail_if(strcmp(mlhash->type, "foo"));
3ea492
-    fail_if(mlhash->value == NULL);
3ea492
-    fail_if(strcmp(mlhash->value, ""));
3ea492
+    ck_assert_ptr_nonnull(mlhash);
3ea492
+    ck_assert_ptr_nonnull(mlhash->type);
3ea492
+    ck_assert_str_eq(mlhash->type, "foo");
3ea492
+    ck_assert_ptr_nonnull(mlhash->value);
3ea492
+    ck_assert_str_eq(mlhash->value, "");
3ea492
 
3ea492
     elem = g_slist_nth(ml->hashes, 2);
3ea492
-    fail_if(!elem);
3ea492
+    ck_assert_ptr_nonnull(elem);
3ea492
     mlhash = elem->data;
3ea492
-    fail_if(!mlhash);
3ea492
-    fail_if(mlhash->type == NULL);
3ea492
-    fail_if(strcmp(mlhash->type, "sha256"));
3ea492
-    fail_if(mlhash->value == NULL);
3ea492
-    fail_if(strcmp(mlhash->value,
3ea492
-                    "0076c44aabd352da878d5c4d794901ac87f66afac869488f6a4ef166de018cdf"));
3ea492
+    ck_assert_ptr_nonnull(mlhash);
3ea492
+    ck_assert_ptr_nonnull(mlhash->type);
3ea492
+    ck_assert_str_eq(mlhash->type, "sha256");
3ea492
+    ck_assert_ptr_nonnull(mlhash->value);
3ea492
+    ck_assert_str_eq(mlhash->value, "0076c44aabd352da878d5c4d794901ac87f66afac869488f6a4ef166de018cdf");
3ea492
 
3ea492
     elem = g_slist_nth(ml->hashes, 3);
3ea492
-    fail_if(!elem);
3ea492
+    ck_assert_ptr_nonnull(elem);
3ea492
     mlhash = elem->data;
3ea492
-    fail_if(!mlhash);
3ea492
-    fail_if(mlhash->type == NULL);
3ea492
-    fail_if(strcmp(mlhash->type, "sha512"));
3ea492
-    fail_if(mlhash->value == NULL);
3ea492
-    fail_if(strcmp(mlhash->value,
3ea492
-                    "884dc465da67fee8fe3f11dab321a99d9a13b22ce97f84ceff210e82b6b1a8c635ccd196add1dd738807686714c3a0a048897e2d0650bc05302b3ee26de521fd"));
3ea492
+    ck_assert_ptr_nonnull(mlhash);
3ea492
+    ck_assert_ptr_nonnull(mlhash->type);
3ea492
+    ck_assert_str_eq(mlhash->type, "sha512");
3ea492
+    ck_assert_ptr_nonnull(mlhash->value);
3ea492
+    ck_assert_str_eq(mlhash->value,
3ea492
+                    "884dc465da67fee8fe3f11dab321a99d9a13b22ce97f84ceff210e82b6b1a8c635ccd196add1dd738807686714c3a0a048897e2d0650bc05302b3ee26de521fd");
3ea492
 
3ea492
     elem = g_slist_nth(ml->urls, 0);
3ea492
-    fail_if(!elem);
3ea492
+    ck_assert_ptr_nonnull(elem);
3ea492
     mlurl = elem->data;
3ea492
-    fail_if(!mlurl);
3ea492
-    fail_if(mlurl->protocol == NULL);
3ea492
-    fail_if(strcmp(mlurl->protocol, "http"));
3ea492
-    fail_if(mlurl->type == NULL);
3ea492
-    fail_if(strcmp(mlurl->type, "http"));
3ea492
-    fail_if(mlurl->location == NULL);
3ea492
-    fail_if(strcmp(mlurl->location, "US"));
3ea492
-    fail_if(mlurl->preference != 0);
3ea492
-    fail_if(mlurl->url == NULL);
3ea492
-    fail_if(strcmp(mlurl->url,
3ea492
-                   "http://mirror.pnl.gov/fedora/linux/releases/17/Everything/x86_64/os/repodata/repomd.xml"));
3ea492
+    ck_assert_ptr_nonnull(mlurl);
3ea492
+    ck_assert_ptr_nonnull(mlurl->protocol);
3ea492
+    ck_assert_str_eq(mlurl->protocol, "http");
3ea492
+    ck_assert_ptr_nonnull(mlurl->type);
3ea492
+    ck_assert_str_eq(mlurl->type, "http");
3ea492
+    ck_assert_ptr_nonnull(mlurl->location);
3ea492
+    ck_assert_str_eq(mlurl->location, "US");
3ea492
+    ck_assert(mlurl->preference == 0);
3ea492
+    ck_assert_ptr_nonnull(mlurl->url);
3ea492
+    ck_assert_str_eq(mlurl->url,
3ea492
+                   "http://mirror.pnl.gov/fedora/linux/releases/17/Everything/x86_64/os/repodata/repomd.xml");
3ea492
 
3ea492
     elem = g_slist_nth(ml->urls, 1);
3ea492
-    fail_if(!elem);
3ea492
+    ck_assert_ptr_nonnull(elem);
3ea492
     mlurl = elem->data;
3ea492
-    fail_if(!mlurl);
3ea492
-    fail_if(mlurl->protocol != NULL);
3ea492
-    fail_if(mlurl->type != NULL);
3ea492
-    fail_if(mlurl->location != NULL);
3ea492
-    fail_if(mlurl->preference < 0 || mlurl->preference > 100);
3ea492
-    fail_if(mlurl->url == NULL);
3ea492
-    fail_if(strcmp(mlurl->url,
3ea492
-                   "ftp://mirrors.syringanetworks.net/fedora/releases/17/Everything/x86_64/os/repodata/repomd.xml"));
3ea492
+    ck_assert_ptr_nonnull(mlurl);
3ea492
+    ck_assert_ptr_null(mlurl->protocol);
3ea492
+    ck_assert_ptr_null(mlurl->type);
3ea492
+    ck_assert_ptr_null(mlurl->location);
3ea492
+    ck_assert(mlurl->preference >= 0 && mlurl->preference <= 100);
3ea492
+    ck_assert_ptr_nonnull(mlurl->url);
3ea492
+    ck_assert_str_eq(mlurl->url,
3ea492
+                   "ftp://mirrors.syringanetworks.net/fedora/releases/17/Everything/x86_64/os/repodata/repomd.xml");
3ea492
 
3ea492
     elem = g_slist_nth(ml->urls, 2);
3ea492
-    fail_if(!elem);
3ea492
+    ck_assert_ptr_nonnull(elem);
3ea492
     mlurl = elem->data;
3ea492
-    fail_if(!mlurl);
3ea492
-    fail_if(mlurl->protocol != NULL);
3ea492
-    fail_if(mlurl->type != NULL);
3ea492
-    fail_if(mlurl->location != NULL);
3ea492
-    fail_if(mlurl->preference != 0);
3ea492
-    fail_if(mlurl->url == NULL);
3ea492
-    fail_if(strcmp(mlurl->url,
3ea492
-                   "rsync://mirrors.syringanetworks.net/fedora/releases/17/Everything/x86_64/os/repodata/repomd.xml"));
3ea492
+    ck_assert_ptr_nonnull(mlurl);
3ea492
+    ck_assert_ptr_null(mlurl->protocol);
3ea492
+    ck_assert_ptr_null(mlurl->type);
3ea492
+    ck_assert_ptr_null(mlurl->location);
3ea492
+    ck_assert(mlurl->preference == 0);
3ea492
+    ck_assert_ptr_nonnull(mlurl->url);
3ea492
+    ck_assert_str_eq(mlurl->url,
3ea492
+                   "rsync://mirrors.syringanetworks.net/fedora/releases/17/Everything/x86_64/os/repodata/repomd.xml");
3ea492
 
3ea492
     elem = g_slist_nth(ml->urls, 3);
3ea492
-    fail_if(!elem);
3ea492
+    ck_assert_ptr_nonnull(elem);
3ea492
     mlurl = elem->data;
3ea492
-    fail_if(!mlurl);
3ea492
-    fail_if(mlurl->protocol != NULL);
3ea492
-    fail_if(mlurl->type != NULL);
3ea492
-    fail_if(mlurl->location != NULL);
3ea492
-    fail_if(mlurl->preference != 0);
3ea492
-    fail_if(mlurl->url == NULL);
3ea492
-    fail_if(strcmp(mlurl->url, ""));
3ea492
+    ck_assert_ptr_nonnull(mlurl);
3ea492
+    ck_assert_ptr_null(mlurl->protocol);
3ea492
+    ck_assert_ptr_null(mlurl->type);
3ea492
+    ck_assert_ptr_null(mlurl->location);
3ea492
+    ck_assert(mlurl->preference == 0);
3ea492
+    ck_assert_ptr_nonnull(mlurl->url);
3ea492
+    ck_assert_str_eq(mlurl->url, "");
3ea492
 
3ea492
     lr_metalink_free(ml);
3ea492
 }
3ea492
@@ -374,14 +372,14 @@ START_TEST(test_metalink_bad_02)
3ea492
                          "metalink_bad_02", NULL);
3ea492
     fd = open(path, O_RDONLY);
3ea492
     lr_free(path);
3ea492
-    fail_if(fd < 0);
3ea492
+    ck_assert_int_ge(fd, 0);
3ea492
     ml = lr_metalink_init();
3ea492
-    fail_if(ml == NULL);
3ea492
+    ck_assert_ptr_nonnull(ml);
3ea492
     ret = lr_metalink_parse_file(ml, fd, REPOMD, NULL, NULL, &tmp_err);
3ea492
-    fail_if(!ret);
3ea492
-    fail_if(tmp_err);
3ea492
+    ck_assert(ret);
3ea492
+    ck_assert_ptr_null(tmp_err);
3ea492
     close(fd);
3ea492
-    fail_if(g_slist_length(ml->urls) != 0);
3ea492
+    ck_assert(g_slist_length(ml->urls) == 0);
3ea492
     lr_metalink_free(ml);
3ea492
 }
3ea492
 END_TEST
3ea492
@@ -398,12 +396,12 @@ START_TEST(test_metalink_really_bad_01)
3ea492
                          "metalink_really_bad_01", NULL);
3ea492
     fd = open(path, O_RDONLY);
3ea492
     lr_free(path);
3ea492
-    fail_if(fd < 0);
3ea492
+    ck_assert_int_ge(fd, 0);
3ea492
     ml = lr_metalink_init();
3ea492
-    fail_if(ml == NULL);
3ea492
+    ck_assert_ptr_nonnull(ml);
3ea492
     ret = lr_metalink_parse_file(ml, fd, REPOMD, NULL, NULL, &tmp_err);
3ea492
-    fail_if(ret);
3ea492
-    fail_if(!tmp_err);
3ea492
+    ck_assert(!ret);
3ea492
+    ck_assert_ptr_nonnull(tmp_err);
3ea492
     g_error_free(tmp_err);
3ea492
     close(fd);
3ea492
     lr_metalink_free(ml);
3ea492
@@ -422,12 +420,12 @@ START_TEST(test_metalink_really_bad_02)
3ea492
                          "metalink_really_bad_02", NULL);
3ea492
     fd = open(path, O_RDONLY);
3ea492
     lr_free(path);
3ea492
-    fail_if(fd < 0);
3ea492
+    ck_assert_int_ge(fd, 0);
3ea492
     ml = lr_metalink_init();
3ea492
-    fail_if(ml == NULL);
3ea492
+    ck_assert_ptr_nonnull(ml);
3ea492
     ret = lr_metalink_parse_file(ml, fd, REPOMD, NULL, NULL, &tmp_err);
3ea492
-    fail_if(ret);
3ea492
-    fail_if(!tmp_err);
3ea492
+    ck_assert(!ret);
3ea492
+    ck_assert_ptr_nonnull(tmp_err);
3ea492
     g_error_free(tmp_err);
3ea492
     close(fd);
3ea492
     lr_metalink_free(ml);
3ea492
@@ -446,12 +444,12 @@ START_TEST(test_metalink_really_bad_03)
3ea492
                          "metalink_really_bad_03", NULL);
3ea492
     fd = open(path, O_RDONLY);
3ea492
     lr_free(path);
3ea492
-    fail_if(fd < 0);
3ea492
+    ck_assert_int_ge(fd, 0);
3ea492
     ml = lr_metalink_init();
3ea492
-    fail_if(ml == NULL);
3ea492
+    ck_assert_ptr_nonnull(ml);
3ea492
     ret = lr_metalink_parse_file(ml, fd, REPOMD, NULL, NULL, &tmp_err);
3ea492
-    fail_if(ret);
3ea492
-    fail_if(!tmp_err);
3ea492
+    ck_assert(!ret);
3ea492
+    ck_assert_ptr_nonnull(tmp_err);
3ea492
     g_error_free(tmp_err);
3ea492
     close(fd);
3ea492
     lr_metalink_free(ml);
3ea492
@@ -473,41 +471,41 @@ START_TEST(test_metalink_with_alternates)
3ea492
                          "metalink_with_alternates", NULL);
3ea492
     fd = open(path, O_RDONLY);
3ea492
     lr_free(path);
3ea492
-    fail_if(fd < 0);
3ea492
+    ck_assert_int_ge(fd, 0);
3ea492
     ml = lr_metalink_init();
3ea492
-    fail_if(ml == NULL);
3ea492
+    ck_assert_ptr_nonnull(ml);
3ea492
     ret = lr_metalink_parse_file(ml, fd, REPOMD, NULL, NULL, &tmp_err);
3ea492
-    fail_if(!ret);
3ea492
-    fail_if(tmp_err);
3ea492
+    ck_assert(ret);
3ea492
+    ck_assert_ptr_null(tmp_err);
3ea492
     close(fd);
3ea492
 
3ea492
-    fail_if(ml->filename == NULL);
3ea492
-    fail_if(strcmp(ml->filename, "repomd.xml"));
3ea492
-    fail_if(g_slist_length(ml->hashes) != 4);
3ea492
-    fail_if(g_slist_length(ml->alternates) != 1);
3ea492
+    ck_assert_ptr_nonnull(ml->filename);
3ea492
+    ck_assert_str_eq(ml->filename, "repomd.xml");
3ea492
+    ck_assert(g_slist_length(ml->hashes) == 4);
3ea492
+    ck_assert(g_slist_length(ml->alternates) == 1);
3ea492
 
3ea492
     elem = g_slist_nth(ml->hashes, 0);
3ea492
-    fail_if(!elem);
3ea492
+    ck_assert_ptr_nonnull(elem);
3ea492
     mlhash = elem->data;
3ea492
-    fail_if(!mlhash);
3ea492
-    fail_if(mlhash->type == NULL);
3ea492
-    fail_if(strcmp(mlhash->type, "md5"));
3ea492
-    fail_if(mlhash->value == NULL);
3ea492
-    fail_if(strcmp(mlhash->value, "0ffcd7798421c9a6760f3e4202cc4675"));
3ea492
+    ck_assert_ptr_nonnull(mlhash);
3ea492
+    ck_assert_ptr_nonnull(mlhash->type);
3ea492
+    ck_assert_str_eq(mlhash->type, "md5");
3ea492
+    ck_assert_ptr_nonnull(mlhash->value);
3ea492
+    ck_assert_str_eq(mlhash->value, "0ffcd7798421c9a6760f3e4202cc4675");
3ea492
 
3ea492
     elem = g_slist_nth(ml->alternates, 0);
3ea492
-    fail_if(!elem);
3ea492
+    ck_assert_ptr_nonnull(elem);
3ea492
     malternate = elem->data;
3ea492
-    fail_if(malternate->timestamp != 1381706941);
3ea492
-    fail_if(malternate->size != 4761);
3ea492
-    fail_if(g_slist_length(malternate->hashes) != 4);
3ea492
+    ck_assert(malternate->timestamp == 1381706941);
3ea492
+    ck_assert(malternate->size == 4761);
3ea492
+    ck_assert(g_slist_length(malternate->hashes) == 4);
3ea492
     elem = g_slist_nth(malternate->hashes, 0);
3ea492
     mlhash = elem->data;
3ea492
-    fail_if(!mlhash);
3ea492
-    fail_if(mlhash->type == NULL);
3ea492
-    fail_if(strcmp(mlhash->type, "md5"));
3ea492
-    fail_if(mlhash->value == NULL);
3ea492
-    fail_if(strcmp(mlhash->value, "0c5b64d395d5364633df7c8e97a07fd6"));
3ea492
+    ck_assert_ptr_nonnull(mlhash);
3ea492
+    ck_assert_ptr_nonnull(mlhash->type);
3ea492
+    ck_assert_str_eq(mlhash->type, "md5");
3ea492
+    ck_assert_ptr_nonnull(mlhash->value);
3ea492
+    ck_assert_str_eq(mlhash->value, "0c5b64d395d5364633df7c8e97a07fd6");
3ea492
 
3ea492
     lr_metalink_free(ml);
3ea492
 }
3ea492
diff --git a/tests/test_mirrorlist.c b/tests/test_mirrorlist.c
3ea492
index 6ccf2537..cc00b7fc 100644
3ea492
--- a/tests/test_mirrorlist.c
3ea492
+++ b/tests/test_mirrorlist.c
3ea492
@@ -18,7 +18,7 @@ START_TEST(test_mirrorlist_init)
3ea492
     LrMirrorlist *ml = NULL;
3ea492
 
3ea492
     ml = lr_mirrorlist_init();
3ea492
-    fail_if(ml == NULL);
3ea492
+    ck_assert_ptr_nonnull(ml);
3ea492
     lr_mirrorlist_free(ml);
3ea492
 }
3ea492
 END_TEST
3ea492
@@ -36,23 +36,23 @@ START_TEST(test_mirrorlist_01)
3ea492
                          "mirrorlist_01", NULL);
3ea492
     fd = open(path, O_RDONLY);
3ea492
     lr_free(path);
3ea492
-    fail_if(fd < 0);
3ea492
+    ck_assert_int_ge(fd, 0);
3ea492
     ml = lr_mirrorlist_init();
3ea492
-    fail_if(ml == NULL);
3ea492
+    ck_assert_ptr_nonnull(ml);
3ea492
     ret = lr_mirrorlist_parse_file(ml, fd, &tmp_err);
3ea492
     close(fd);
3ea492
-    fail_if(!ret);
3ea492
-    fail_if(tmp_err);
3ea492
+    ck_assert(ret);
3ea492
+    ck_assert_ptr_null(tmp_err);
3ea492
 
3ea492
-    fail_if(g_slist_length(ml->urls) != 2);
3ea492
+    ck_assert(g_slist_length(ml->urls) == 2);
3ea492
 
3ea492
     elem = g_slist_nth(ml->urls, 0);
3ea492
-    fail_if(!elem);
3ea492
-    fail_if(g_strcmp0(elem->data, "http://foo.bar/fedora/linux/"));
3ea492
+    ck_assert_ptr_nonnull(elem);
3ea492
+    ck_assert_str_eq(elem->data, "http://foo.bar/fedora/linux/");
3ea492
 
3ea492
     elem = g_slist_nth(ml->urls, 1);
3ea492
-    fail_if(!elem);
3ea492
-    fail_if(g_strcmp0(elem->data, "ftp://ftp.bar.foo/Fedora/17/"));
3ea492
+    ck_assert_ptr_nonnull(elem);
3ea492
+    ck_assert_str_eq(elem->data, "ftp://ftp.bar.foo/Fedora/17/");
3ea492
     lr_mirrorlist_free(ml);
3ea492
 }
3ea492
 END_TEST
3ea492
@@ -69,14 +69,14 @@ START_TEST(test_mirrorlist_02)
3ea492
                          "mirrorlist_02", NULL);
3ea492
     fd = open(path, O_RDONLY);
3ea492
     lr_free(path);
3ea492
-    fail_if(fd < 0);
3ea492
+    ck_assert_int_ge(fd, 0);
3ea492
     ml = lr_mirrorlist_init();
3ea492
-    fail_if(ml == NULL);
3ea492
+    ck_assert_ptr_nonnull(ml);
3ea492
     ret = lr_mirrorlist_parse_file(ml, fd, &tmp_err);
3ea492
     close(fd);
3ea492
-    fail_if(!ret);
3ea492
-    fail_if(tmp_err);
3ea492
-    fail_if(g_slist_length(ml->urls) != 0);
3ea492
+    ck_assert(ret);
3ea492
+    ck_assert_ptr_null(tmp_err);
3ea492
+    ck_assert(g_slist_length(ml->urls) == 0);
3ea492
     lr_mirrorlist_free(ml);
3ea492
 }
3ea492
 END_TEST
3ea492
@@ -93,14 +93,14 @@ START_TEST(test_mirrorlist_03)
3ea492
                          "mirrorlist_03", NULL);
3ea492
     fd = open(path, O_RDONLY);
3ea492
     lr_free(path);
3ea492
-    fail_if(fd < 0);
3ea492
+    ck_assert_int_ge(fd, 0);
3ea492
     ml = lr_mirrorlist_init();
3ea492
-    fail_if(ml == NULL);
3ea492
+    ck_assert_ptr_nonnull(ml);
3ea492
     ret = lr_mirrorlist_parse_file(ml, fd, &tmp_err);
3ea492
     close(fd);
3ea492
-    fail_if(!ret);
3ea492
-    fail_if(tmp_err);
3ea492
-    fail_if(g_slist_length(ml->urls) != 0);
3ea492
+    ck_assert(ret);
3ea492
+    ck_assert_ptr_null(tmp_err);
3ea492
+    ck_assert(g_slist_length(ml->urls) == 0);
3ea492
     lr_mirrorlist_free(ml);
3ea492
 }
3ea492
 END_TEST
3ea492
diff --git a/tests/test_package_downloader.c b/tests/test_package_downloader.c
3ea492
index b384bef8..3263ba02 100644
3ea492
--- a/tests/test_package_downloader.c
3ea492
+++ b/tests/test_package_downloader.c
3ea492
@@ -25,19 +25,19 @@ START_TEST(test_package_downloader_new_and_free)
3ea492
 
3ea492
     target = lr_packagetarget_new(NULL, "url", NULL, 0, NULL, 0, NULL, FALSE,
3ea492
                                   NULL, NULL, &err;;
3ea492
-    fail_if(!target);
3ea492
-    fail_if(err);
3ea492
+    ck_assert_ptr_nonnull(target);
3ea492
+    ck_assert_ptr_null(err);
3ea492
 
3ea492
-    fail_if(strcmp(target->relative_url, "url"));
3ea492
-    fail_if(target->dest);
3ea492
-    fail_if(target->base_url);
3ea492
-    fail_if(target->checksum_type != 0);
3ea492
-    fail_if(target->checksum);
3ea492
-    fail_if(target->resume != FALSE);
3ea492
-    fail_if(target->progresscb);
3ea492
-    fail_if(target->cbdata);
3ea492
-    fail_if(target->local_path);
3ea492
-    fail_if(target->err);
3ea492
+    ck_assert_str_eq(target->relative_url, "url");
3ea492
+    ck_assert_ptr_null(target->dest);
3ea492
+    ck_assert_ptr_null(target->base_url);
3ea492
+    ck_assert(target->checksum_type == 0);
3ea492
+    ck_assert_ptr_null(target->checksum);
3ea492
+    ck_assert(target->resume == FALSE);
3ea492
+    ck_assert(!target->progresscb);
3ea492
+    ck_assert_ptr_null(target->cbdata);
3ea492
+    ck_assert_ptr_null(target->local_path);
3ea492
+    ck_assert_ptr_null(target->err);
3ea492
 
3ea492
     lr_packagetarget_free(target);
3ea492
     target = NULL;
3ea492
@@ -47,19 +47,19 @@ START_TEST(test_package_downloader_new_and_free)
3ea492
     target = lr_packagetarget_new(NULL, "url", "dest", LR_CHECKSUM_SHA384,
3ea492
                                   "xxx", 0, "baseurl", TRUE, (LrProgressCb) 22,
3ea492
                                   (void *) 33, &err;;
3ea492
-    fail_if(!target);
3ea492
-    fail_if(err);
3ea492
+    ck_assert_ptr_nonnull(target);
3ea492
+    ck_assert_ptr_null(err);
3ea492
 
3ea492
-    fail_if(strcmp(target->relative_url, "url"));
3ea492
-    fail_if(strcmp(target->dest, "dest"));
3ea492
-    fail_if(strcmp(target->base_url, "baseurl"));
3ea492
-    fail_if(target->checksum_type != LR_CHECKSUM_SHA384);
3ea492
-    fail_if(strcmp(target->checksum, "xxx"));
3ea492
-    fail_if(target->resume != TRUE);
3ea492
-    fail_if(target->progresscb != (LrProgressCb) 22);
3ea492
-    fail_if(target->cbdata != (void *) 33);
3ea492
-    fail_if(target->local_path);
3ea492
-    fail_if(target->err);
3ea492
+    ck_assert_str_eq(target->relative_url, "url");
3ea492
+    ck_assert_str_eq(target->dest, "dest");
3ea492
+    ck_assert_str_eq(target->base_url, "baseurl");
3ea492
+    ck_assert(target->checksum_type == LR_CHECKSUM_SHA384);
3ea492
+    ck_assert_str_eq(target->checksum, "xxx");
3ea492
+    ck_assert(target->resume == TRUE);
3ea492
+    ck_assert(target->progresscb == (LrProgressCb) 22);
3ea492
+    ck_assert_ptr_eq(target->cbdata, (void *) 33);
3ea492
+    ck_assert_ptr_null(target->local_path);
3ea492
+    ck_assert_ptr_null(target->err);
3ea492
 
3ea492
     lr_packagetarget_free(target);
3ea492
     target = NULL;
3ea492
diff --git a/tests/test_repo_zck.c b/tests/test_repo_zck.c
3ea492
index a2299a8d..e68b1442 100644
3ea492
--- a/tests/test_repo_zck.c
3ea492
+++ b/tests/test_repo_zck.c
3ea492
@@ -23,22 +23,22 @@ START_TEST(test_repo_zck_parsing)
3ea492
                                 "repo_yum_03/repodata/repomd.xml",
3ea492
                                 NULL);
3ea492
     repomd = lr_yum_repomd_init();
3ea492
-    fail_if(!repomd);
3ea492
+    ck_assert_ptr_nonnull(repomd);
3ea492
     fd = open(repomd_path, O_RDONLY);
3ea492
-    fail_if(fd < 0);
3ea492
+    ck_assert_int_ge(fd, 0);
3ea492
 
3ea492
     ret = lr_yum_repomd_parse_file(repomd, fd, NULL, NULL, &tmp_err);
3ea492
     close(fd);
3ea492
 
3ea492
-    fail_if(!ret);
3ea492
-    fail_if(tmp_err);
3ea492
-    fail_if(g_slist_length(repomd->records) != 12);
3ea492
-    fail_if(!lr_yum_repomd_get_record(repomd, "primary"));
3ea492
-    fail_if(!lr_yum_repomd_get_record(repomd, "filelists"));
3ea492
-    fail_if(!lr_yum_repomd_get_record(repomd, "other"));
3ea492
+    ck_assert(ret);
3ea492
+    ck_assert_ptr_null(tmp_err);
3ea492
+    ck_assert(g_slist_length(repomd->records) == 12);
3ea492
+    ck_assert_ptr_nonnull(lr_yum_repomd_get_record(repomd, "primary"));
3ea492
+    ck_assert_ptr_nonnull(lr_yum_repomd_get_record(repomd, "filelists"));
3ea492
+    ck_assert_ptr_nonnull(lr_yum_repomd_get_record(repomd, "other"));
3ea492
 
3ea492
-    fail_if(lr_yum_repomd_get_record(repomd, "foo"));
3ea492
-    fail_if(lr_yum_repomd_get_record(repomd, "bar"));
3ea492
+    ck_assert_ptr_null(lr_yum_repomd_get_record(repomd, "foo"));
3ea492
+    ck_assert_ptr_null(lr_yum_repomd_get_record(repomd, "bar"));
3ea492
 
3ea492
     lr_yum_repomd_free(repomd);
3ea492
     lr_free(repomd_path);
3ea492
diff --git a/tests/test_repoconf.c b/tests/test_repoconf.c
3ea492
index 5c85047e..0036b500 100644
3ea492
--- a/tests/test_repoconf.c
3ea492
+++ b/tests/test_repoconf.c
3ea492
@@ -304,19 +304,19 @@ START_TEST(test_parse_repoconf_minimal)
3ea492
     path = lr_pathconcat(test_globals.testdata_dir, "repo-minimal.repo", NULL);
3ea492
 
3ea492
     confs = lr_yum_repoconfs_init();
3ea492
-    fail_if(!confs);
3ea492
+    ck_assert_ptr_nonnull(confs);
3ea492
 
3ea492
     ret = lr_yum_repoconfs_parse(confs, path, &tmp_err);
3ea492
-    fail_if(!ret);
3ea492
+    ck_assert(ret);
3ea492
 
3ea492
     list = lr_yum_repoconfs_get_list(confs, &tmp_err);
3ea492
-    fail_if(!list);
3ea492
-    fail_if(g_slist_length(list) != 2);
3ea492
+    ck_assert_ptr_nonnull(list);
3ea492
+    ck_assert(g_slist_length(list) == 2);
3ea492
 
3ea492
     // Test content of first repo config
3ea492
 
3ea492
     conf = g_slist_nth_data(list, 0);
3ea492
-    fail_if(!conf);
3ea492
+    ck_assert_ptr_nonnull(conf);
3ea492
 
3ea492
     conf_assert_str_eq(LR_YRC_ID, "minimal-repo-1");
3ea492
     conf_assert_str_eq(LR_YRC_NAME, "Minimal repo 1 - $basearch");
3ea492
@@ -363,7 +363,7 @@ START_TEST(test_parse_repoconf_minimal)
3ea492
     // Test content of second repo config
3ea492
 
3ea492
     conf = g_slist_nth_data(list, 1);
3ea492
-    fail_if(!conf);
3ea492
+    ck_assert_ptr_nonnull(conf);
3ea492
 
3ea492
     conf_assert_str_eq(LR_YRC_ID, "minimal-repo-2");
3ea492
     conf_assert_str_eq(LR_YRC_NAME, "Minimal repo 2 - $basearch");
3ea492
@@ -423,17 +423,17 @@ START_TEST(test_parse_repoconf_big)
3ea492
     path = lr_pathconcat(test_globals.testdata_dir, "repo-big.repo", NULL);
3ea492
 
3ea492
     confs = lr_yum_repoconfs_init();
3ea492
-    fail_if(!confs);
3ea492
+    ck_assert_ptr_nonnull(confs);
3ea492
 
3ea492
     ret = lr_yum_repoconfs_parse(confs, path, &tmp_err);
3ea492
-    fail_if(!ret);
3ea492
+    ck_assert(ret);
3ea492
 
3ea492
     list = lr_yum_repoconfs_get_list(confs, &tmp_err);
3ea492
-    fail_if(!list);
3ea492
-    fail_if(g_slist_length(list) != 1);
3ea492
+    ck_assert_ptr_nonnull(list);
3ea492
+    ck_assert(g_slist_length(list) == 1);
3ea492
 
3ea492
     conf = g_slist_nth_data(list, 0);
3ea492
-    fail_if(!conf);
3ea492
+    ck_assert_ptr_nonnull(conf);
3ea492
 
3ea492
     conf_assert_str_eq(LR_YRC_ID, "big-repo");
3ea492
     conf_assert_str_eq(LR_YRC_NAME, "Maxi repo - $basearch");
3ea492
@@ -504,7 +504,7 @@ START_TEST(test_write_repoconf)
3ea492
 
3ea492
     // Create a temporary file
3ea492
     fd = mkstemp(tmpfn);
3ea492
-    fail_if(fd == -1);
3ea492
+    ck_assert_int_ne(fd, -1);
3ea492
 
3ea492
     // Create reconfs with one repoconf with one id (one section)
3ea492
     confs = lr_yum_repoconfs_init();
3ea492
diff --git a/tests/test_repomd.c b/tests/test_repomd.c
3ea492
index 3dda8337..4c9300d6 100644
3ea492
--- a/tests/test_repomd.c
3ea492
+++ b/tests/test_repomd.c
3ea492
@@ -23,31 +23,31 @@ START_TEST(test_repomd_parsing)
3ea492
                                 "repo_yum_02/repodata/repomd.xml",
3ea492
                                 NULL);
3ea492
     repomd = lr_yum_repomd_init();
3ea492
-    fail_if(!repomd);
3ea492
+    ck_assert_ptr_nonnull(repomd);
3ea492
     fd = open(repomd_path, O_RDONLY);
3ea492
-    fail_if(fd < 0);
3ea492
+    ck_assert_int_ge(fd, 0);
3ea492
 
3ea492
     ret = lr_yum_repomd_parse_file(repomd, fd, NULL, NULL, &tmp_err);
3ea492
     close(fd);
3ea492
 
3ea492
-    fail_if(!ret);
3ea492
-    fail_if(tmp_err);
3ea492
-    fail_if(g_slist_length(repomd->records) != 12);
3ea492
-    fail_if(!lr_yum_repomd_get_record(repomd, "primary"));
3ea492
-    fail_if(!lr_yum_repomd_get_record(repomd, "filelists"));
3ea492
-    fail_if(!lr_yum_repomd_get_record(repomd, "other"));
3ea492
-    fail_if(!lr_yum_repomd_get_record(repomd, "primary_db"));
3ea492
-    fail_if(!lr_yum_repomd_get_record(repomd, "filelists_db"));
3ea492
-    fail_if(!lr_yum_repomd_get_record(repomd, "other_db"));
3ea492
-    fail_if(!lr_yum_repomd_get_record(repomd, "group"));
3ea492
-    fail_if(!lr_yum_repomd_get_record(repomd, "group_gz"));
3ea492
-    fail_if(!lr_yum_repomd_get_record(repomd, "updateinfo"));
3ea492
-    fail_if(!lr_yum_repomd_get_record(repomd, "origin"));
3ea492
-    fail_if(!lr_yum_repomd_get_record(repomd, "prestodelta"));
3ea492
-    fail_if(!lr_yum_repomd_get_record(repomd, "deltainfo"));
3ea492
+    ck_assert(ret);
3ea492
+    ck_assert_ptr_null(tmp_err);
3ea492
+    ck_assert(g_slist_length(repomd->records) == 12);
3ea492
+    ck_assert_ptr_nonnull(lr_yum_repomd_get_record(repomd, "primary"));
3ea492
+    ck_assert_ptr_nonnull(lr_yum_repomd_get_record(repomd, "filelists"));
3ea492
+    ck_assert_ptr_nonnull(lr_yum_repomd_get_record(repomd, "other"));
3ea492
+    ck_assert_ptr_nonnull(lr_yum_repomd_get_record(repomd, "primary_db"));
3ea492
+    ck_assert_ptr_nonnull(lr_yum_repomd_get_record(repomd, "filelists_db"));
3ea492
+    ck_assert_ptr_nonnull(lr_yum_repomd_get_record(repomd, "other_db"));
3ea492
+    ck_assert_ptr_nonnull(lr_yum_repomd_get_record(repomd, "group"));
3ea492
+    ck_assert_ptr_nonnull(lr_yum_repomd_get_record(repomd, "group_gz"));
3ea492
+    ck_assert_ptr_nonnull(lr_yum_repomd_get_record(repomd, "updateinfo"));
3ea492
+    ck_assert_ptr_nonnull(lr_yum_repomd_get_record(repomd, "origin"));
3ea492
+    ck_assert_ptr_nonnull(lr_yum_repomd_get_record(repomd, "prestodelta"));
3ea492
+    ck_assert_ptr_nonnull(lr_yum_repomd_get_record(repomd, "deltainfo"));
3ea492
 
3ea492
-    fail_if(lr_yum_repomd_get_record(repomd, "foo"));
3ea492
-    fail_if(lr_yum_repomd_get_record(repomd, "bar"));
3ea492
+    ck_assert_ptr_null(lr_yum_repomd_get_record(repomd, "foo"));
3ea492
+    ck_assert_ptr_null(lr_yum_repomd_get_record(repomd, "bar"));
3ea492
 
3ea492
     lr_yum_repomd_free(repomd);
3ea492
     lr_free(repomd_path);
3ea492
diff --git a/tests/test_url_substitution.c b/tests/test_url_substitution.c
3ea492
index e3d53a79..b0086a8c 100644
3ea492
--- a/tests/test_url_substitution.c
3ea492
+++ b/tests/test_url_substitution.c
3ea492
@@ -20,22 +20,22 @@ START_TEST(test_urlvars_set)
3ea492
     LrUrlVars *urlvars = NULL;
3ea492
 
3ea492
     urlvars = lr_urlvars_set(urlvars, "foo", "bar");
3ea492
-    fail_if(urlvars == NULL);
3ea492
-    fail_if(strcmp(((LrVar *)urlvars->data)->var, "foo") != 0);
3ea492
+    ck_assert_ptr_nonnull(urlvars);
3ea492
+    ck_assert_str_eq(((LrVar *)urlvars->data)->var, "foo");
3ea492
 
3ea492
     urlvars = lr_urlvars_set(urlvars, "foo1", "bar1");
3ea492
-    fail_if(urlvars == NULL);
3ea492
+    ck_assert_ptr_nonnull(urlvars);
3ea492
 
3ea492
     urlvars = lr_urlvars_set(urlvars, "foo", NULL);
3ea492
-    fail_if(urlvars == NULL);
3ea492
-    fail_if(strcmp(((LrVar *)urlvars->data)->var, "foo1") != 0);
3ea492
+    ck_assert_ptr_nonnull(urlvars);
3ea492
+    ck_assert_str_eq(((LrVar *)urlvars->data)->var, "foo1");
3ea492
 
3ea492
     urlvars = lr_urlvars_set(urlvars, "foo1", NULL);
3ea492
-    fail_if(urlvars != NULL);
3ea492
+    ck_assert_ptr_null(urlvars);
3ea492
 
3ea492
     urlvars = lr_urlvars_set(urlvars, "bar", "foo");
3ea492
-    fail_if(urlvars == NULL);
3ea492
-    fail_if(strcmp(((LrVar *)urlvars->data)->var, "bar") != 0);
3ea492
+    ck_assert_ptr_nonnull(urlvars);
3ea492
+    ck_assert_str_eq(((LrVar *)urlvars->data)->var, "bar");
3ea492
 
3ea492
     lr_urlvars_free(urlvars);
3ea492
 }
3ea492
@@ -49,19 +49,19 @@ START_TEST(test_url_substitute_without_urlvars)
3ea492
     urlvars = lr_urlvars_set(urlvars, "foo", "bar");
3ea492
 
3ea492
     url = lr_url_substitute("", urlvars);
3ea492
-    fail_if(strcmp(url, ""));
3ea492
+    ck_assert_str_eq(url, "");
3ea492
     lr_free(url);
3ea492
 
3ea492
     url = lr_url_substitute("http://foo", urlvars);
3ea492
-    fail_if(strcmp(url, "http://foo"));
3ea492
+    ck_assert_str_eq(url, "http://foo");
3ea492
     lr_free(url);
3ea492
 
3ea492
     url = lr_url_substitute("http://foo?id=$bar", urlvars);
3ea492
-    fail_if(strcmp(url, "http://foo?id=$bar"));
3ea492
+    ck_assert_str_eq(url, "http://foo?id=$bar");
3ea492
     lr_free(url);
3ea492
 
3ea492
     url = lr_url_substitute("http://foo?id=$foox", urlvars);
3ea492
-    fail_if(strcmp(url, "http://foo?id=$foox"));
3ea492
+    ck_assert_str_eq(url, "http://foo?id=$foox");
3ea492
     lr_free(url);
3ea492
 
3ea492
     lr_urlvars_free(urlvars);
3ea492
@@ -78,31 +78,31 @@ START_TEST(test_url_substitute)
3ea492
     urlvars = lr_urlvars_set(urlvars, "bar", "repo");
3ea492
 
3ea492
     url = lr_url_substitute("", urlvars);
3ea492
-    fail_if(strcmp(url, ""));
3ea492
+    ck_assert_str_eq(url, "");
3ea492
     lr_free(url);
3ea492
 
3ea492
     url = lr_url_substitute("http://foo", urlvars);
3ea492
-    fail_if(strcmp(url, "http://foo"));
3ea492
+    ck_assert_str_eq(url, "http://foo");
3ea492
     lr_free(url);
3ea492
 
3ea492
     url = lr_url_substitute("http://foo?id=$bar", urlvars);
3ea492
-    fail_if(strcmp(url, "http://foo?id=repo"));
3ea492
+    ck_assert_str_eq(url, "http://foo?id=repo");
3ea492
     lr_free(url);
3ea492
 
3ea492
     url = lr_url_substitute("http://$foo?id=$bar", urlvars);
3ea492
-    fail_if(strcmp(url, "http://version?id=repo"));
3ea492
+    ck_assert_str_eq(url, "http://version?id=repo");
3ea492
     lr_free(url);
3ea492
 
3ea492
     url = lr_url_substitute("http://$fo?id=$bar", urlvars);
3ea492
-    fail_if(strcmp(url, "http://ver?id=repo"));
3ea492
+    ck_assert_str_eq(url, "http://ver?id=repo");
3ea492
     lr_free(url);
3ea492
 
3ea492
     url = lr_url_substitute("http://$foo$bar", urlvars);
3ea492
-    fail_if(strcmp(url, "http://versionrepo"));
3ea492
+    ck_assert_str_eq(url, "http://versionrepo");
3ea492
     lr_free(url);
3ea492
 
3ea492
     url = lr_url_substitute("http://$foo$bar/", urlvars);
3ea492
-    fail_if(strcmp(url, "http://versionrepo/"));
3ea492
+    ck_assert_str_eq(url, "http://versionrepo/");
3ea492
     lr_free(url);
3ea492
 
3ea492
     lr_urlvars_free(urlvars);
3ea492
@@ -119,27 +119,27 @@ START_TEST(test_url_substitute_braces)
3ea492
     urlvars = lr_urlvars_set(urlvars, "bar", "repo");
3ea492
 
3ea492
     url = lr_url_substitute("http://foo?id=${bar}", urlvars);
3ea492
-    fail_if(strcmp(url, "http://foo?id=repo"));
3ea492
+    ck_assert_str_eq(url, "http://foo?id=repo");
3ea492
     lr_free(url);
3ea492
 
3ea492
     url = lr_url_substitute("http://${foo}?id=${bar}", urlvars);
3ea492
-    fail_if(strcmp(url, "http://version?id=repo"));
3ea492
+    ck_assert_str_eq(url, "http://version?id=repo");
3ea492
     lr_free(url);
3ea492
 
3ea492
     url = lr_url_substitute("http://${fo}?id=$bar", urlvars);
3ea492
-    fail_if(strcmp(url, "http://ver?id=repo"));
3ea492
+    ck_assert_str_eq(url, "http://ver?id=repo");
3ea492
     lr_free(url);
3ea492
 
3ea492
     url = lr_url_substitute("http://${fo?id=$bar", urlvars);
3ea492
-    fail_if(strcmp(url, "http://${fo?id=repo"));
3ea492
+    ck_assert_str_eq(url, "http://${fo?id=repo");
3ea492
     lr_free(url);
3ea492
 
3ea492
     url = lr_url_substitute("http://${foo${bar}", urlvars);
3ea492
-    fail_if(strcmp(url, "http://${foorepo"));
3ea492
+    ck_assert_str_eq(url, "http://${foorepo");
3ea492
     lr_free(url);
3ea492
 
3ea492
     url = lr_url_substitute("http://${foo}${bar}/", urlvars);
3ea492
-    fail_if(strcmp(url, "http://versionrepo/"));
3ea492
+    ck_assert_str_eq(url, "http://versionrepo/");
3ea492
     lr_free(url);
3ea492
 
3ea492
     lr_urlvars_free(urlvars);
3ea492
diff --git a/tests/test_util.c b/tests/test_util.c
3ea492
index b3b2b6dd..595b0fef 100644
3ea492
--- a/tests/test_util.c
3ea492
+++ b/tests/test_util.c
3ea492
@@ -18,7 +18,7 @@ START_TEST(test_malloc)
3ea492
 {
3ea492
     long long *num = NULL;
3ea492
     num = lr_malloc0(sizeof(long long));
3ea492
-    fail_if(num == NULL);
3ea492
+    ck_assert_ptr_nonnull(num);
3ea492
     lr_free(num);
3ea492
 }
3ea492
 END_TEST
3ea492
@@ -27,8 +27,8 @@ START_TEST(test_malloc0)
3ea492
 {
3ea492
     long long *num = NULL;
3ea492
     num = lr_malloc0(sizeof(long long));
3ea492
-    fail_if(num == NULL);
3ea492
-    fail_if(*num != 0LL);
3ea492
+    ck_assert_ptr_nonnull(num);
3ea492
+    ck_assert(*num == 0LL);
3ea492
     lr_free(num);
3ea492
 }
3ea492
 END_TEST
3ea492
@@ -44,7 +44,7 @@ START_TEST(test_gettmpfile)
3ea492
 {
3ea492
     int fd = 0;
3ea492
     fd = lr_gettmpfile();
3ea492
-    fail_if(fd < 0);
3ea492
+    ck_assert_int_ge(fd, 0);
3ea492
     close(fd);
3ea492
 }
3ea492
 END_TEST
3ea492
@@ -52,8 +52,8 @@ END_TEST
3ea492
 START_TEST(test_gettmpdir)
3ea492
 {
3ea492
     char *tmp_dir = lr_gettmpdir();
3ea492
-    fail_if(tmp_dir == NULL);
3ea492
-    fail_if(rmdir(tmp_dir) != 0);
3ea492
+    ck_assert_ptr_nonnull(tmp_dir);
3ea492
+    ck_assert_int_eq(rmdir(tmp_dir), 0);
3ea492
     lr_free(tmp_dir);
3ea492
 }
3ea492
 END_TEST
3ea492
@@ -63,47 +63,47 @@ START_TEST(test_pathconcat)
3ea492
     char *path = NULL;
3ea492
 
3ea492
     path = lr_pathconcat(NULL, NULL);
3ea492
-    fail_if(path != NULL);
3ea492
+    ck_assert_ptr_null(path);
3ea492
 
3ea492
     path = lr_pathconcat("", NULL);
3ea492
-    fail_if(path == NULL);
3ea492
-    fail_if(strcmp(path, ""));
3ea492
+    ck_assert_ptr_nonnull(path);
3ea492
+    ck_assert_str_eq(path, "");
3ea492
     lr_free(path);
3ea492
     path = NULL;
3ea492
 
3ea492
     path = lr_pathconcat("/tmp", "foo///", "bar", NULL);
3ea492
-    fail_if(path == NULL);
3ea492
-    fail_if(strcmp(path, "/tmp/foo/bar"));
3ea492
+    ck_assert_ptr_nonnull(path);
3ea492
+    ck_assert_str_eq(path, "/tmp/foo/bar");
3ea492
     lr_free(path);
3ea492
     path = NULL;
3ea492
 
3ea492
     path = lr_pathconcat("foo", "bar/", NULL);
3ea492
-    fail_if(path == NULL);
3ea492
-    fail_if(strcmp(path, "foo/bar"));
3ea492
+    ck_assert_ptr_nonnull(path);
3ea492
+    ck_assert_str_eq(path, "foo/bar");
3ea492
     lr_free(path);
3ea492
     path = NULL;
3ea492
 
3ea492
     path = lr_pathconcat("foo", "/bar/", NULL);
3ea492
-    fail_if(path == NULL);
3ea492
-    fail_if(strcmp(path, "foo/bar"));
3ea492
+    ck_assert_ptr_nonnull(path);
3ea492
+    ck_assert_str_eq(path, "foo/bar");
3ea492
     lr_free(path);
3ea492
     path = NULL;
3ea492
 
3ea492
     path = lr_pathconcat("foo", "bar", "", NULL);
3ea492
-    fail_if(path == NULL);
3ea492
-    fail_if(strcmp(path, "foo/bar/"));
3ea492
+    ck_assert_ptr_nonnull(path);
3ea492
+    ck_assert_str_eq(path, "foo/bar/");
3ea492
     lr_free(path);
3ea492
     path = NULL;
3ea492
 
3ea492
     path = lr_pathconcat("http://host.net", "path/to/somewhere", NULL);
3ea492
-    fail_if(path == NULL);
3ea492
-    fail_if(strcmp(path, "http://host.net/path/to/somewhere"));
3ea492
+    ck_assert_ptr_nonnull(path);
3ea492
+    ck_assert_str_eq(path, "http://host.net/path/to/somewhere");
3ea492
     lr_free(path);
3ea492
     path = NULL;
3ea492
 
3ea492
     path = lr_pathconcat("http://host.net?hello=1", "path/to/", "somewhere", NULL);
3ea492
-    fail_if(path == NULL);
3ea492
-    fail_if(strcmp(path, "http://host.net/path/to/somewhere?hello=1"));
3ea492
+    ck_assert_ptr_nonnull(path);
3ea492
+    ck_assert_str_eq(path, "http://host.net/path/to/somewhere?hello=1");
3ea492
     lr_free(path);
3ea492
     path = NULL;
3ea492
 }
3ea492
@@ -116,16 +116,16 @@ START_TEST(test_remove_dir)
3ea492
     int fd, rc;
3ea492
 
3ea492
     tmp_dir = lr_gettmpdir();
3ea492
-    fail_if(tmp_dir == NULL);
3ea492
+    ck_assert_ptr_nonnull(tmp_dir);
3ea492
     tmp_file = lr_pathconcat(tmp_dir, "file_a", NULL);
3ea492
     fd = open(tmp_file, O_CREAT|O_TRUNC|O_RDWR, 0660);
3ea492
-    fail_if(fd < 0);
3ea492
+    ck_assert_int_ge(fd, 0);
3ea492
     close(fd);
3ea492
 
3ea492
     rc = lr_remove_dir(tmp_dir);
3ea492
-    fail_if(rc != 0);
3ea492
-    fail_if(unlink(tmp_file) == 0);
3ea492
-    fail_if(rmdir(tmp_dir) == 0);
3ea492
+    ck_assert_int_eq(rc, 0);
3ea492
+    ck_assert_int_ne(unlink(tmp_file), 0);
3ea492
+    ck_assert_int_ne(rmdir(tmp_dir), 0);
3ea492
     lr_free(tmp_dir);
3ea492
     lr_free(tmp_file);
3ea492
 }
3ea492
@@ -136,65 +136,65 @@ START_TEST(test_url_without_path)
3ea492
     char *new_url = NULL;
3ea492
 
3ea492
     new_url = lr_url_without_path(NULL);
3ea492
-    fail_if(new_url != NULL);
3ea492
+    ck_assert_ptr_null(new_url);
3ea492
 
3ea492
     new_url = lr_url_without_path("");
3ea492
-    fail_if(new_url == NULL);
3ea492
-    fail_if(strcmp(new_url, ""));
3ea492
+    ck_assert_ptr_nonnull(new_url);
3ea492
+    ck_assert_str_eq(new_url, "");
3ea492
     lr_free(new_url);
3ea492
     new_url = NULL;
3ea492
 
3ea492
     new_url = lr_url_without_path("hostname");
3ea492
-    fail_if(new_url == NULL);
3ea492
-    fail_if(strcmp(new_url, "hostname"));
3ea492
+    ck_assert_ptr_nonnull(new_url);
3ea492
+    ck_assert_str_eq(new_url, "hostname");
3ea492
     lr_free(new_url);
3ea492
     new_url = NULL;
3ea492
 
3ea492
     new_url = lr_url_without_path("hostname/foo/bar/");
3ea492
-    fail_if(new_url == NULL);
3ea492
-    fail_if(strcmp(new_url, "hostname"));
3ea492
+    ck_assert_ptr_nonnull(new_url);
3ea492
+    ck_assert_str_eq(new_url, "hostname");
3ea492
     lr_free(new_url);
3ea492
     new_url = NULL;
3ea492
 
3ea492
     new_url = lr_url_without_path("hostname:80");
3ea492
-    fail_if(new_url == NULL);
3ea492
-    fail_if(strcmp(new_url, "hostname:80"));
3ea492
+    ck_assert_ptr_nonnull(new_url);
3ea492
+    ck_assert_str_eq(new_url, "hostname:80");
3ea492
     lr_free(new_url);
3ea492
     new_url = NULL;
3ea492
 
3ea492
     new_url = lr_url_without_path("hostname:80/foo/bar");
3ea492
-    fail_if(new_url == NULL);
3ea492
-    fail_if(strcmp(new_url, "hostname:80"));
3ea492
+    ck_assert_ptr_nonnull(new_url);
3ea492
+    ck_assert_str_eq(new_url, "hostname:80");
3ea492
     lr_free(new_url);
3ea492
     new_url = NULL;
3ea492
 
3ea492
     new_url = lr_url_without_path("http://hostname:80/");
3ea492
-    fail_if(new_url == NULL);
3ea492
-    fail_if(strcmp(new_url, "http://hostname:80"));
3ea492
+    ck_assert_ptr_nonnull(new_url);
3ea492
+    ck_assert_str_eq(new_url, "http://hostname:80");
3ea492
     lr_free(new_url);
3ea492
     new_url = NULL;
3ea492
 
3ea492
     new_url = lr_url_without_path("http://hostname:80/foo/bar");
3ea492
-    fail_if(new_url == NULL);
3ea492
-    fail_if(strcmp(new_url, "http://hostname:80"));
3ea492
+    ck_assert_ptr_nonnull(new_url);
3ea492
+    ck_assert_str_eq(new_url, "http://hostname:80");
3ea492
     lr_free(new_url);
3ea492
     new_url = NULL;
3ea492
 
3ea492
     new_url = lr_url_without_path("ftp://foo.hostname:80/foo/bar");
3ea492
-    fail_if(new_url == NULL);
3ea492
-    fail_if(strcmp(new_url, "ftp://foo.hostname:80"));
3ea492
+    ck_assert_ptr_nonnull(new_url);
3ea492
+    ck_assert_str_eq(new_url, "ftp://foo.hostname:80");
3ea492
     lr_free(new_url);
3ea492
     new_url = NULL;
3ea492
 
3ea492
     new_url = lr_url_without_path("file:///home/foobar");
3ea492
-    fail_if(new_url == NULL);
3ea492
-    fail_if(strcmp(new_url, "file://"));
3ea492
+    ck_assert_ptr_nonnull(new_url);
3ea492
+    ck_assert_str_eq(new_url, "file://");
3ea492
     lr_free(new_url);
3ea492
     new_url = NULL;
3ea492
 
3ea492
     new_url = lr_url_without_path("file:/home/foobar");
3ea492
-    fail_if(new_url == NULL);
3ea492
-    fail_if(strcmp(new_url, "file://"));
3ea492
+    ck_assert_ptr_nonnull(new_url);
3ea492
+    ck_assert_str_eq(new_url, "file://");
3ea492
     lr_free(new_url);
3ea492
     new_url = NULL;
3ea492
 }
3ea492
@@ -209,39 +209,39 @@ START_TEST(test_strv_dup)
3ea492
     gchar **copy = NULL;
3ea492
 
3ea492
     copy = lr_strv_dup(in0);
3ea492
-    fail_if(copy != NULL);
3ea492
+    ck_assert_ptr_null(copy);
3ea492
 
3ea492
     copy = lr_strv_dup(in1);
3ea492
-    fail_if(!copy);
3ea492
-    fail_if(copy == in1);
3ea492
-    fail_if(copy[0] != NULL);
3ea492
+    ck_assert(copy);
3ea492
+    ck_assert_ptr_ne(copy, in1);
3ea492
+    ck_assert_ptr_null(copy[0]);
3ea492
     g_strfreev(copy);
3ea492
 
3ea492
     copy = lr_strv_dup(in2);
3ea492
-    fail_if(!copy);
3ea492
-    fail_if(copy == in2);
3ea492
-    fail_if(g_strcmp0(copy[0], "foo"));
3ea492
-    fail_if(copy[0] == in2[0]);
3ea492
-    fail_if(copy[1] != NULL);
3ea492
+    ck_assert(copy);
3ea492
+    ck_assert_ptr_ne(copy, in2);
3ea492
+    ck_assert_str_eq(copy[0], "foo");
3ea492
+    ck_assert_ptr_ne(copy[0], in2[0]);
3ea492
+    ck_assert_ptr_null(copy[1]);
3ea492
     g_strfreev(copy);
3ea492
 }
3ea492
 END_TEST
3ea492
 
3ea492
 START_TEST(test_is_local_path)
3ea492
 {
3ea492
-    fail_if(!lr_is_local_path("/tmp"));
3ea492
-    fail_if(!lr_is_local_path("foo/bar"));
3ea492
-    fail_if(!lr_is_local_path("bar"));
3ea492
-    fail_if(!lr_is_local_path("/"));
3ea492
-    fail_if(!lr_is_local_path("file:///tmp"));
3ea492
-    fail_if(!lr_is_local_path("file:/tmp"));
3ea492
-
3ea492
-    fail_if(lr_is_local_path(NULL));
3ea492
-    fail_if(lr_is_local_path(""));
3ea492
-    fail_if(lr_is_local_path("http://foo.bar"));
3ea492
-    fail_if(lr_is_local_path("https://foo.bar/x"));
3ea492
-    fail_if(lr_is_local_path("ftp://foo.bar/foobar"));
3ea492
-    fail_if(lr_is_local_path("rsync://xyz"));
3ea492
+    ck_assert(lr_is_local_path("/tmp"));
3ea492
+    ck_assert(lr_is_local_path("foo/bar"));
3ea492
+    ck_assert(lr_is_local_path("bar"));
3ea492
+    ck_assert(lr_is_local_path("/"));
3ea492
+    ck_assert(lr_is_local_path("file:///tmp"));
3ea492
+    ck_assert(lr_is_local_path("file:/tmp"));
3ea492
+
3ea492
+    ck_assert(!lr_is_local_path(NULL));
3ea492
+    ck_assert(!lr_is_local_path(""));
3ea492
+    ck_assert(!lr_is_local_path("http://foo.bar"));
3ea492
+    ck_assert(!lr_is_local_path("https://foo.bar/x"));
3ea492
+    ck_assert(!lr_is_local_path("ftp://foo.bar/foobar"));
3ea492
+    ck_assert(!lr_is_local_path("rsync://xyz"));
3ea492
 }
3ea492
 END_TEST
3ea492
 
3ea492
@@ -250,19 +250,19 @@ START_TEST(test_prepend_url_protocol)
3ea492
     gchar *url = NULL;
3ea492
 
3ea492
     url = lr_prepend_url_protocol("/tmp");
3ea492
-    fail_if(g_strcmp0(url, "file:///tmp"));
3ea492
+    ck_assert_str_eq(url, "file:///tmp");
3ea492
     g_free(url);
3ea492
 
3ea492
     url = lr_prepend_url_protocol("file:///tmp");
3ea492
-    fail_if(g_strcmp0(url, "file:///tmp"));
3ea492
+    ck_assert_str_eq(url, "file:///tmp");
3ea492
     g_free(url);
3ea492
 
3ea492
     url = lr_prepend_url_protocol("http://tmp");
3ea492
-    fail_if(g_strcmp0(url, "http://tmp"));
3ea492
+    ck_assert_str_eq(url, "http://tmp");
3ea492
     g_free(url);
3ea492
 
3ea492
     url = lr_prepend_url_protocol("file:/tmp");
3ea492
-    fail_if(g_strcmp0(url, "file:/tmp"));
3ea492
+    ck_assert_str_eq(url, "file:/tmp");
3ea492
     g_free(url);
3ea492
 }
3ea492
 END_TEST
3ea492
diff --git a/tests/test_version.c b/tests/test_version.c
3ea492
index 235b4c6e..96e6ec69 100644
3ea492
--- a/tests/test_version.c
3ea492
+++ b/tests/test_version.c
3ea492
@@ -10,23 +10,23 @@
3ea492
 
3ea492
 START_TEST(test_version_check_macro)
3ea492
 {
3ea492
-    fail_if(!(LR_VERSION_CHECK(LR_VERSION_MAJOR,
3ea492
+    ck_assert(LR_VERSION_CHECK(LR_VERSION_MAJOR,
3ea492
                                LR_VERSION_MINOR,
3ea492
-                               LR_VERSION_PATCH)));
3ea492
+                               LR_VERSION_PATCH));
3ea492
 
3ea492
-    fail_if(!(LR_VERSION_CHECK(0, 0, 0)));
3ea492
+    ck_assert(LR_VERSION_CHECK(0, 0, 0));
3ea492
 
3ea492
-    fail_if(LR_VERSION_CHECK(LR_VERSION_MAJOR,
3ea492
-                             LR_VERSION_MINOR,
3ea492
-                             LR_VERSION_PATCH+1));
3ea492
+    ck_assert(!(LR_VERSION_CHECK(LR_VERSION_MAJOR,
3ea492
+                                 LR_VERSION_MINOR,
3ea492
+                                 LR_VERSION_PATCH+1)));
3ea492
 
3ea492
-    fail_if(LR_VERSION_CHECK(LR_VERSION_MAJOR,
3ea492
-                             LR_VERSION_MINOR+1,
3ea492
-                             LR_VERSION_PATCH));
3ea492
+    ck_assert(!(LR_VERSION_CHECK(LR_VERSION_MAJOR,
3ea492
+                                 LR_VERSION_MINOR+1,
3ea492
+                                 LR_VERSION_PATCH)));
3ea492
 
3ea492
-    fail_if(LR_VERSION_CHECK(LR_VERSION_MAJOR+1,
3ea492
-                             LR_VERSION_MINOR,
3ea492
-                             LR_VERSION_PATCH));
3ea492
+    ck_assert(!(LR_VERSION_CHECK(LR_VERSION_MAJOR+1,
3ea492
+                                 LR_VERSION_MINOR,
3ea492
+                                 LR_VERSION_PATCH)));
3ea492
 }
3ea492
 END_TEST
3ea492