1052 lines
34 KiB
C
1052 lines
34 KiB
C
/*
|
|
* Unit test for tree.h
|
|
*/
|
|
|
|
#include "libisofs.h"
|
|
#include "tree.h"
|
|
#include "test.h"
|
|
|
|
#include <assert.h>
|
|
#include <stdio.h>
|
|
#include <sys/types.h>
|
|
#include <sys/stat.h>
|
|
#include <unistd.h>
|
|
#include <string.h>
|
|
|
|
|
|
static void test_new_root() {
|
|
struct iso_tree_node_dir *root;
|
|
root = iso_tree_new_root();
|
|
CU_ASSERT_PTR_NOT_NULL(root);
|
|
CU_ASSERT_EQUAL(root->nchildren, 0);
|
|
CU_ASSERT_PTR_NULL(root->children);
|
|
CU_ASSERT_PTR_NULL(root->node.parent);
|
|
CU_ASSERT_PTR_NULL(root->node.name);
|
|
CU_ASSERT(S_ISDIR(root->node.attrib.st_mode) );
|
|
}
|
|
|
|
static void test_add_dir() {
|
|
struct iso_tree_node_dir *root;
|
|
struct iso_tree_node_dir *dir;
|
|
|
|
root = iso_tree_new_root();
|
|
CU_ASSERT_PTR_NOT_NULL(root);
|
|
dir = iso_tree_add_dir(root, "New dir name");
|
|
CU_ASSERT_PTR_NOT_NULL(root);
|
|
CU_ASSERT_PTR_NOT_NULL(dir);
|
|
CU_ASSERT_PTR_EQUAL(dir->node.parent, root);
|
|
CU_ASSERT_EQUAL(root->nchildren, 1);
|
|
CU_ASSERT_PTR_EQUAL(root->children[0], (struct iso_tree_node *)dir);
|
|
CU_ASSERT_STRING_EQUAL( dir->node.name, "New dir name");
|
|
CU_ASSERT( S_ISDIR(dir->node.attrib.st_mode) );
|
|
iso_tree_free((struct iso_tree_node *)root);
|
|
}
|
|
|
|
static void test_add_file() {
|
|
struct iso_tree_node_dir *root;
|
|
struct iso_tree_node_file *file;
|
|
|
|
root = iso_tree_new_root();
|
|
file = (struct iso_tree_node_file *)
|
|
iso_tree_add_file(root, "/tmp/libisofs_test/README");
|
|
CU_ASSERT_PTR_NOT_NULL(root);
|
|
CU_ASSERT_PTR_NOT_NULL(file);
|
|
CU_ASSERT_PTR_EQUAL(file->node.parent, root);
|
|
CU_ASSERT_EQUAL(root->nchildren, 1);
|
|
CU_ASSERT_PTR_EQUAL(root->children[0], (struct iso_tree_node *)file);
|
|
CU_ASSERT_STRING_EQUAL( file->node.name, "README" );
|
|
CU_ASSERT_STRING_EQUAL( file->loc.path, "/tmp/libisofs_test/README" );
|
|
CU_ASSERT( S_ISREG(file->node.attrib.st_mode) );
|
|
iso_tree_free((struct iso_tree_node *)root);
|
|
}
|
|
|
|
static void test_add_symlink() {
|
|
struct iso_tree_node_dir *root;
|
|
struct iso_tree_node *lnk;
|
|
|
|
root = iso_tree_new_root();
|
|
lnk = iso_tree_add_symlink(root, "read", "/tmp/libisofs_test/README");
|
|
CU_ASSERT_PTR_NOT_NULL(root);
|
|
CU_ASSERT_PTR_NOT_NULL(lnk);
|
|
CU_ASSERT_PTR_EQUAL(lnk->parent, root);
|
|
CU_ASSERT_EQUAL(root->nchildren, 1);
|
|
CU_ASSERT_PTR_EQUAL(root->children[0], (struct iso_tree_node *)lnk);
|
|
CU_ASSERT_STRING_EQUAL( lnk->name, "read");
|
|
CU_ASSERT_STRING_EQUAL( ((struct iso_tree_node_symlink*)lnk)->dest,
|
|
"/tmp/libisofs_test/README" );
|
|
CU_ASSERT( S_ISLNK(lnk->attrib.st_mode) );
|
|
iso_tree_free((struct iso_tree_node *)root);
|
|
}
|
|
|
|
static void test_add_node() {
|
|
struct iso_tree_node_dir *root;
|
|
struct iso_tree_node *node;
|
|
|
|
root = iso_tree_new_root();
|
|
|
|
/* test addition of a dir */
|
|
node = iso_tree_add_node(root, "/tmp/libisofs_test/dir1");
|
|
CU_ASSERT_PTR_NOT_NULL(node);
|
|
CU_ASSERT_PTR_EQUAL(node->parent, root);
|
|
CU_ASSERT_EQUAL(root->nchildren, 1);
|
|
CU_ASSERT_PTR_EQUAL(root->children[0], node);
|
|
CU_ASSERT_STRING_EQUAL( node->name, "dir1");
|
|
CU_ASSERT( ISO_ISDIR(node) );
|
|
CU_ASSERT( S_ISDIR(node->attrib.st_mode) );
|
|
|
|
/* test addition of a link */
|
|
node = iso_tree_add_node(root, "/tmp/libisofs_test/link to readme");
|
|
CU_ASSERT_PTR_NOT_NULL(node);
|
|
CU_ASSERT_PTR_EQUAL(node->parent, root);
|
|
CU_ASSERT_EQUAL(root->nchildren, 2);
|
|
CU_ASSERT_PTR_EQUAL(root->children[1], node);
|
|
CU_ASSERT( ISO_ISLNK(node) );
|
|
CU_ASSERT( S_ISLNK(node->attrib.st_mode) );
|
|
CU_ASSERT_STRING_EQUAL( node->name, "link to readme");
|
|
CU_ASSERT_STRING_EQUAL( ((struct iso_tree_node_symlink*)node)->dest,
|
|
"/tmp/libisofs_test/README" );
|
|
|
|
/* test addition of a file */
|
|
node = iso_tree_add_node(root, "/tmp/libisofs_test/README");
|
|
CU_ASSERT_PTR_NOT_NULL(node);
|
|
CU_ASSERT_PTR_EQUAL(node->parent, root);
|
|
CU_ASSERT_EQUAL(root->nchildren, 3);
|
|
CU_ASSERT_PTR_EQUAL(root->children[2], node);
|
|
CU_ASSERT( S_ISREG(node->attrib.st_mode) );
|
|
CU_ASSERT( ISO_ISREG(node) );
|
|
CU_ASSERT_STRING_EQUAL( node->name, "README" );
|
|
CU_ASSERT_STRING_EQUAL( ((struct iso_tree_node_file *) node)->loc.path,
|
|
"/tmp/libisofs_test/README" );
|
|
|
|
/* test no exiting file */
|
|
node = iso_tree_add_node(root, "/tmp/libisofs_test/THISNOTEXIST");
|
|
CU_ASSERT_PTR_NULL(node);
|
|
CU_ASSERT_EQUAL(libisofs_errno, NO_FILE);
|
|
CU_ASSERT_EQUAL(root->nchildren, 3);
|
|
|
|
/* test no valid file */
|
|
node = iso_tree_add_node(root, "/dev/zero");
|
|
CU_ASSERT_PTR_NULL(node);
|
|
CU_ASSERT_EQUAL(libisofs_errno, UNEXPECTED_FILE_TYPE);
|
|
CU_ASSERT_EQUAL(root->nchildren, 3);
|
|
|
|
/* test no read perm file */
|
|
node = iso_tree_add_node(root, "/tmp/libisofs_test/no_read");
|
|
CU_ASSERT_PTR_NULL(node);
|
|
CU_ASSERT_EQUAL(libisofs_errno, NO_READ_ACCESS);
|
|
CU_ASSERT_EQUAL(root->nchildren, 3);
|
|
|
|
iso_tree_free((struct iso_tree_node *)root);
|
|
}
|
|
|
|
static void test_set_name() {
|
|
struct iso_tree_node_dir *root;
|
|
struct iso_tree_node *node;
|
|
|
|
root = iso_tree_new_root();
|
|
|
|
/* test on a dir */
|
|
node = iso_tree_add_node(root, "/tmp/libisofs_test/dir1");
|
|
CU_ASSERT_PTR_NOT_NULL(node);
|
|
CU_ASSERT_STRING_EQUAL( node->name, "dir1");
|
|
iso_tree_node_set_name(node, "newname");
|
|
CU_ASSERT_STRING_EQUAL( node->name, "newname");
|
|
|
|
/* test on a link */
|
|
node = iso_tree_add_node(root, "/tmp/libisofs_test/link to readme");
|
|
CU_ASSERT_PTR_NOT_NULL(node);
|
|
CU_ASSERT_STRING_EQUAL( node->name, "link to readme");
|
|
iso_tree_node_set_name(node, "new link name");
|
|
CU_ASSERT_STRING_EQUAL( node->name, "new link name");
|
|
|
|
/* test on a file */
|
|
node = iso_tree_add_node(root, "/tmp/libisofs_test/README");
|
|
CU_ASSERT_PTR_NOT_NULL(node);
|
|
CU_ASSERT_STRING_EQUAL( node->name, "README" );
|
|
iso_tree_node_set_name(node, "new file name");
|
|
CU_ASSERT_STRING_EQUAL( node->name, "new file name");
|
|
|
|
iso_tree_free((struct iso_tree_node *)root);
|
|
}
|
|
|
|
static void test_get_name() {
|
|
struct iso_tree_node_dir *root;
|
|
struct iso_tree_node *node;
|
|
|
|
root = iso_tree_new_root();
|
|
|
|
/* test on a dir */
|
|
node = iso_tree_add_node(root, "/tmp/libisofs_test/dir1");
|
|
CU_ASSERT_STRING_EQUAL( iso_tree_node_get_name(node), "dir1");
|
|
iso_tree_node_set_name(node, "newname");
|
|
CU_ASSERT_STRING_EQUAL( iso_tree_node_get_name(node), "newname");
|
|
|
|
/* test on a link */
|
|
node = iso_tree_add_node(root, "/tmp/libisofs_test/link to readme");
|
|
CU_ASSERT_STRING_EQUAL( iso_tree_node_get_name(node), "link to readme");
|
|
iso_tree_node_set_name(node, "new link name");
|
|
CU_ASSERT_STRING_EQUAL( iso_tree_node_get_name(node), "new link name");
|
|
|
|
/* test on a file */
|
|
node = iso_tree_add_node(root, "/tmp/libisofs_test/README");
|
|
CU_ASSERT_STRING_EQUAL( iso_tree_node_get_name(node), "README" );
|
|
iso_tree_node_set_name(node, "new file name");
|
|
CU_ASSERT_STRING_EQUAL( iso_tree_node_get_name(node), "new file name");
|
|
|
|
iso_tree_free((struct iso_tree_node *)root);
|
|
}
|
|
|
|
static void test_set_hidden() {
|
|
struct iso_tree_node_dir *root;
|
|
struct iso_tree_node *node;
|
|
|
|
root = iso_tree_new_root();
|
|
|
|
/* test on a dir */
|
|
node = iso_tree_add_node(root, "/tmp/libisofs_test/dir1");
|
|
CU_ASSERT_PTR_NOT_NULL(node);
|
|
CU_ASSERT_EQUAL(node->hide_flags, 0);
|
|
iso_tree_node_set_hidden(node, LIBISO_HIDE_ON_RR);
|
|
CU_ASSERT_EQUAL(node->hide_flags, LIBISO_HIDE_ON_RR);
|
|
iso_tree_node_set_hidden(node, LIBISO_HIDE_ON_JOLIET);
|
|
CU_ASSERT_EQUAL(node->hide_flags, LIBISO_HIDE_ON_JOLIET);
|
|
iso_tree_node_set_hidden(node, LIBISO_HIDE_ON_RR|LIBISO_HIDE_ON_JOLIET);
|
|
CU_ASSERT_EQUAL(node->hide_flags, LIBISO_HIDE_ON_RR|LIBISO_HIDE_ON_JOLIET);
|
|
|
|
/* test on a link */
|
|
node = iso_tree_add_node(root, "/tmp/libisofs_test/link to readme");
|
|
CU_ASSERT_PTR_NOT_NULL(node);
|
|
CU_ASSERT_EQUAL(node->hide_flags, 0);
|
|
iso_tree_node_set_hidden(node, LIBISO_HIDE_ON_RR);
|
|
CU_ASSERT_EQUAL(node->hide_flags, LIBISO_HIDE_ON_RR);
|
|
iso_tree_node_set_hidden(node, LIBISO_HIDE_ON_JOLIET);
|
|
CU_ASSERT_EQUAL(node->hide_flags, LIBISO_HIDE_ON_JOLIET);
|
|
iso_tree_node_set_hidden(node, LIBISO_HIDE_ON_RR|LIBISO_HIDE_ON_JOLIET);
|
|
CU_ASSERT_EQUAL(node->hide_flags, LIBISO_HIDE_ON_RR|LIBISO_HIDE_ON_JOLIET);
|
|
|
|
/* test on a file */
|
|
node = iso_tree_add_node(root, "/tmp/libisofs_test/README");
|
|
CU_ASSERT_PTR_NOT_NULL(node);
|
|
CU_ASSERT_EQUAL(node->hide_flags, 0);
|
|
iso_tree_node_set_hidden(node, LIBISO_HIDE_ON_RR);
|
|
CU_ASSERT_EQUAL(node->hide_flags, LIBISO_HIDE_ON_RR);
|
|
iso_tree_node_set_hidden(node, LIBISO_HIDE_ON_JOLIET);
|
|
CU_ASSERT_EQUAL(node->hide_flags, LIBISO_HIDE_ON_JOLIET);
|
|
iso_tree_node_set_hidden(node, LIBISO_HIDE_ON_RR|LIBISO_HIDE_ON_JOLIET);
|
|
CU_ASSERT_EQUAL(node->hide_flags, LIBISO_HIDE_ON_RR|LIBISO_HIDE_ON_JOLIET);
|
|
|
|
iso_tree_free((struct iso_tree_node *)root);
|
|
}
|
|
|
|
static void test_is_hidden() {
|
|
struct iso_tree_node_dir *root;
|
|
struct iso_tree_node *node;
|
|
|
|
root = iso_tree_new_root();
|
|
|
|
/* test on a dir */
|
|
node = iso_tree_add_node(root, "/tmp/libisofs_test/dir1");
|
|
CU_ASSERT_FALSE(iso_tree_node_is_hidden(node));
|
|
iso_tree_node_set_hidden(node, LIBISO_HIDE_ON_RR);
|
|
CU_ASSERT_EQUAL(iso_tree_node_is_hidden(node), LIBISO_HIDE_ON_RR);
|
|
iso_tree_node_set_hidden(node, LIBISO_HIDE_ON_JOLIET);
|
|
CU_ASSERT_EQUAL(iso_tree_node_is_hidden(node), LIBISO_HIDE_ON_JOLIET);
|
|
iso_tree_node_set_hidden(node, LIBISO_HIDE_ON_RR|LIBISO_HIDE_ON_JOLIET);
|
|
CU_ASSERT_EQUAL(iso_tree_node_is_hidden(node), LIBISO_HIDE_ON_RR|LIBISO_HIDE_ON_JOLIET);
|
|
|
|
/* test on a link */
|
|
node = iso_tree_add_node(root, "/tmp/libisofs_test/link to readme");
|
|
CU_ASSERT_FALSE(iso_tree_node_is_hidden(node));
|
|
iso_tree_node_set_hidden(node, LIBISO_HIDE_ON_RR);
|
|
CU_ASSERT_EQUAL(iso_tree_node_is_hidden(node), LIBISO_HIDE_ON_RR);
|
|
iso_tree_node_set_hidden(node, LIBISO_HIDE_ON_JOLIET);
|
|
CU_ASSERT_EQUAL(iso_tree_node_is_hidden(node), LIBISO_HIDE_ON_JOLIET);
|
|
iso_tree_node_set_hidden(node, LIBISO_HIDE_ON_RR|LIBISO_HIDE_ON_JOLIET);
|
|
CU_ASSERT_EQUAL(iso_tree_node_is_hidden(node), LIBISO_HIDE_ON_RR|LIBISO_HIDE_ON_JOLIET);
|
|
|
|
/* test on a file */
|
|
node = iso_tree_add_node(root, "/tmp/libisofs_test/README");
|
|
CU_ASSERT_FALSE(iso_tree_node_is_hidden(node));
|
|
iso_tree_node_set_hidden(node, LIBISO_HIDE_ON_RR);
|
|
CU_ASSERT_EQUAL(iso_tree_node_is_hidden(node), LIBISO_HIDE_ON_RR);
|
|
iso_tree_node_set_hidden(node, LIBISO_HIDE_ON_JOLIET);
|
|
CU_ASSERT_EQUAL(iso_tree_node_is_hidden(node), LIBISO_HIDE_ON_JOLIET);
|
|
iso_tree_node_set_hidden(node, LIBISO_HIDE_ON_RR|LIBISO_HIDE_ON_JOLIET);
|
|
CU_ASSERT_EQUAL(iso_tree_node_is_hidden(node), LIBISO_HIDE_ON_RR|LIBISO_HIDE_ON_JOLIET);
|
|
|
|
iso_tree_free((struct iso_tree_node *)root);
|
|
}
|
|
|
|
static void test_set_gid() {
|
|
struct iso_tree_node_dir *root;
|
|
struct iso_tree_node *node;
|
|
gid_t mygid = getgid();
|
|
|
|
root = iso_tree_new_root();
|
|
|
|
/* test on a dir */
|
|
node = iso_tree_add_node(root, "/tmp/libisofs_test/dir1");
|
|
CU_ASSERT_PTR_NOT_NULL(node);
|
|
CU_ASSERT_EQUAL(node->attrib.st_gid, mygid);
|
|
iso_tree_node_set_gid(node, 1234);
|
|
CU_ASSERT_EQUAL(node->attrib.st_gid, 1234);
|
|
|
|
/* test on a link */
|
|
node = iso_tree_add_node(root, "/tmp/libisofs_test/link to readme");
|
|
CU_ASSERT_PTR_NOT_NULL(node);
|
|
CU_ASSERT_EQUAL(node->attrib.st_gid, mygid);
|
|
iso_tree_node_set_gid(node, 1234);
|
|
CU_ASSERT_EQUAL(node->attrib.st_gid, 1234);
|
|
|
|
/* test on a file */
|
|
node = iso_tree_add_node(root, "/tmp/libisofs_test/README");
|
|
CU_ASSERT_PTR_NOT_NULL(node);
|
|
CU_ASSERT_EQUAL(node->attrib.st_gid, mygid);
|
|
iso_tree_node_set_gid(node, 1234);
|
|
CU_ASSERT_EQUAL(node->attrib.st_gid, 1234);
|
|
|
|
iso_tree_free((struct iso_tree_node *)root);
|
|
}
|
|
|
|
static void test_get_gid() {
|
|
struct iso_tree_node_dir *root;
|
|
struct iso_tree_node *node;
|
|
gid_t mygid = getgid();
|
|
|
|
root = iso_tree_new_root();
|
|
|
|
/* test on a dir */
|
|
node = iso_tree_add_node(root, "/tmp/libisofs_test/dir1");
|
|
CU_ASSERT_EQUAL(iso_tree_node_get_gid(node), mygid);
|
|
iso_tree_node_set_gid(node, 1234);
|
|
CU_ASSERT_EQUAL(iso_tree_node_get_gid(node), 1234);
|
|
|
|
/* test on a link */
|
|
node = iso_tree_add_node(root, "/tmp/libisofs_test/link to readme");
|
|
CU_ASSERT_EQUAL(iso_tree_node_get_gid(node), mygid);
|
|
iso_tree_node_set_gid(node, 1234);
|
|
CU_ASSERT_EQUAL(iso_tree_node_get_gid(node), 1234);
|
|
|
|
/* test on a file */
|
|
node = iso_tree_add_node(root, "/tmp/libisofs_test/README");
|
|
CU_ASSERT_EQUAL(iso_tree_node_get_gid(node), mygid);
|
|
iso_tree_node_set_gid(node, 1234);
|
|
CU_ASSERT_EQUAL(iso_tree_node_get_gid(node), 1234);
|
|
|
|
iso_tree_free((struct iso_tree_node *)root);
|
|
}
|
|
|
|
static void test_set_uid() {
|
|
struct iso_tree_node_dir *root;
|
|
struct iso_tree_node *node;
|
|
uid_t myuid = getuid();
|
|
|
|
root = iso_tree_new_root();
|
|
|
|
/* test on a dir */
|
|
node = iso_tree_add_node(root, "/tmp/libisofs_test/dir1");
|
|
CU_ASSERT_PTR_NOT_NULL(node);
|
|
CU_ASSERT_EQUAL(node->attrib.st_uid, myuid);
|
|
iso_tree_node_set_uid(node, 1234);
|
|
CU_ASSERT_EQUAL(node->attrib.st_uid, 1234);
|
|
|
|
/* test on a link */
|
|
node = iso_tree_add_node(root, "/tmp/libisofs_test/link to readme");
|
|
CU_ASSERT_PTR_NOT_NULL(node);
|
|
CU_ASSERT_EQUAL(node->attrib.st_uid, myuid);
|
|
iso_tree_node_set_uid(node, 1234);
|
|
CU_ASSERT_EQUAL(node->attrib.st_uid, 1234);
|
|
|
|
/* test on a file */
|
|
node = iso_tree_add_node(root, "/tmp/libisofs_test/README");
|
|
CU_ASSERT_PTR_NOT_NULL(node);
|
|
CU_ASSERT_EQUAL(node->attrib.st_uid, myuid);
|
|
iso_tree_node_set_uid(node, 1234);
|
|
CU_ASSERT_EQUAL(node->attrib.st_uid, 1234);
|
|
|
|
//TODO
|
|
|
|
iso_tree_free((struct iso_tree_node *)root);
|
|
}
|
|
|
|
static void test_get_uid() {
|
|
struct iso_tree_node_dir *root;
|
|
struct iso_tree_node *node;
|
|
uid_t myuid = getuid();
|
|
|
|
root = iso_tree_new_root();
|
|
|
|
/* test on a dir */
|
|
node = iso_tree_add_node(root, "/tmp/libisofs_test/dir1");
|
|
CU_ASSERT_EQUAL(iso_tree_node_get_uid(node), myuid);
|
|
iso_tree_node_set_uid(node, 1234);
|
|
CU_ASSERT_EQUAL(iso_tree_node_get_uid(node), 1234);
|
|
|
|
/* test on a link */
|
|
node = iso_tree_add_node(root, "/tmp/libisofs_test/link to readme");
|
|
CU_ASSERT_EQUAL(iso_tree_node_get_uid(node), myuid);
|
|
iso_tree_node_set_uid(node, 1234);
|
|
CU_ASSERT_EQUAL(iso_tree_node_get_uid(node), 1234);
|
|
|
|
/* test on a file */
|
|
node = iso_tree_add_node(root, "/tmp/libisofs_test/README");
|
|
CU_ASSERT_EQUAL(iso_tree_node_get_uid(node), myuid);
|
|
iso_tree_node_set_uid(node, 1234);
|
|
CU_ASSERT_EQUAL(iso_tree_node_get_uid(node), 1234);
|
|
|
|
iso_tree_free((struct iso_tree_node *)root);
|
|
}
|
|
|
|
static void test_set_permissions() {
|
|
struct iso_tree_node_dir *root;
|
|
struct iso_tree_node *node;
|
|
|
|
root = iso_tree_new_root();
|
|
|
|
/* test on a dir */
|
|
node = iso_tree_add_node(root, "/tmp/libisofs_test/dir1");
|
|
CU_ASSERT_PTR_NOT_NULL(node);
|
|
CU_ASSERT_EQUAL(node->attrib.st_mode, S_IFDIR | 0755);
|
|
iso_tree_node_set_permissions(node, 0777);
|
|
CU_ASSERT_EQUAL(node->attrib.st_mode, S_IFDIR | 0777);
|
|
iso_tree_node_set_permissions(node, 0744);
|
|
CU_ASSERT_EQUAL(node->attrib.st_mode, S_IFDIR | 0744);
|
|
iso_tree_node_set_permissions(node, 0411);
|
|
CU_ASSERT_EQUAL(node->attrib.st_mode, S_IFDIR | 0411);
|
|
|
|
/* test on a link */
|
|
node = iso_tree_add_node(root, "/tmp/libisofs_test/link to readme");
|
|
CU_ASSERT_PTR_NOT_NULL(node);
|
|
CU_ASSERT_EQUAL(node->attrib.st_mode, S_IFLNK | 0777);
|
|
iso_tree_node_set_permissions(node, 0555);
|
|
CU_ASSERT_EQUAL(node->attrib.st_mode, S_IFLNK | 0555);
|
|
iso_tree_node_set_permissions(node, 0744);
|
|
CU_ASSERT_EQUAL(node->attrib.st_mode, S_IFLNK | 0744);
|
|
iso_tree_node_set_permissions(node, 0411);
|
|
CU_ASSERT_EQUAL(node->attrib.st_mode, S_IFLNK | 0411);
|
|
|
|
/* test on a file */
|
|
node = iso_tree_add_node(root, "/tmp/libisofs_test/README");
|
|
CU_ASSERT_PTR_NOT_NULL(node);
|
|
CU_ASSERT_EQUAL(node->attrib.st_mode, S_IFREG | 0555);
|
|
iso_tree_node_set_permissions(node, 0777);
|
|
CU_ASSERT_EQUAL(node->attrib.st_mode, S_IFREG | 0777);
|
|
iso_tree_node_set_permissions(node, 0744);
|
|
CU_ASSERT_EQUAL(node->attrib.st_mode, S_IFREG | 0744);
|
|
iso_tree_node_set_permissions(node, 0411);
|
|
CU_ASSERT_EQUAL(node->attrib.st_mode, S_IFREG | 0411);
|
|
|
|
iso_tree_free((struct iso_tree_node *)root);
|
|
}
|
|
|
|
static void test_get_permissions() {
|
|
struct iso_tree_node_dir *root;
|
|
struct iso_tree_node *node;
|
|
|
|
root = iso_tree_new_root();
|
|
|
|
/* test on a dir */
|
|
node = iso_tree_add_node(root, "/tmp/libisofs_test/dir1");
|
|
CU_ASSERT_EQUAL(iso_tree_node_get_permissions(node), 0755);
|
|
iso_tree_node_set_permissions(node, 0777);
|
|
CU_ASSERT_EQUAL(iso_tree_node_get_permissions(node), 0777);
|
|
iso_tree_node_set_permissions(node, 0744);
|
|
CU_ASSERT_EQUAL(iso_tree_node_get_permissions(node), 0744);
|
|
iso_tree_node_set_permissions(node, 0411);
|
|
CU_ASSERT_EQUAL(iso_tree_node_get_permissions(node), 0411);
|
|
|
|
/* test on a link */
|
|
node = iso_tree_add_node(root, "/tmp/libisofs_test/link to readme");
|
|
CU_ASSERT_EQUAL(iso_tree_node_get_permissions(node), 0777);
|
|
iso_tree_node_set_permissions(node, 0555);
|
|
CU_ASSERT_EQUAL(iso_tree_node_get_permissions(node), 0555);
|
|
iso_tree_node_set_permissions(node, 0744);
|
|
CU_ASSERT_EQUAL(iso_tree_node_get_permissions(node), 0744);
|
|
iso_tree_node_set_permissions(node, 0411);
|
|
CU_ASSERT_EQUAL(iso_tree_node_get_permissions(node), 0411);
|
|
|
|
/* test on a file */
|
|
node = iso_tree_add_node(root, "/tmp/libisofs_test/README");
|
|
CU_ASSERT_EQUAL(iso_tree_node_get_permissions(node), 0555);
|
|
iso_tree_node_set_permissions(node, 0777);
|
|
CU_ASSERT_EQUAL(iso_tree_node_get_permissions(node), 0777);
|
|
iso_tree_node_set_permissions(node, 0744);
|
|
CU_ASSERT_EQUAL(iso_tree_node_get_permissions(node), 0744);
|
|
iso_tree_node_set_permissions(node, 0411);
|
|
CU_ASSERT_EQUAL(iso_tree_node_get_permissions(node), 0411);
|
|
|
|
iso_tree_free((struct iso_tree_node *)root);
|
|
}
|
|
|
|
static void test_set_sort_weight() {
|
|
struct iso_tree_node_dir *root;
|
|
struct iso_tree_node_dir *dir;
|
|
struct iso_tree_node_file *file;
|
|
|
|
root = iso_tree_new_root();
|
|
|
|
dir = iso_tree_add_dir(root, "New dir name");
|
|
CU_ASSERT_PTR_NOT_NULL(dir);
|
|
|
|
file = (struct iso_tree_node_file *)
|
|
iso_tree_add_file(dir, "/tmp/libisofs_test/README");
|
|
CU_ASSERT_EQUAL(file->sort_weight, 0);
|
|
iso_tree_node_set_sort_weight((struct iso_tree_node *) file, 15);
|
|
CU_ASSERT_EQUAL(file->sort_weight, 15);
|
|
iso_tree_node_set_sort_weight((struct iso_tree_node *) file, -15);
|
|
CU_ASSERT_EQUAL(file->sort_weight, -15);
|
|
|
|
/* changes to dir involve update files inside it */
|
|
iso_tree_node_set_sort_weight((struct iso_tree_node *) dir, 28);
|
|
CU_ASSERT_EQUAL(file->sort_weight, 28);
|
|
|
|
iso_tree_free((struct iso_tree_node *)root);
|
|
}
|
|
|
|
static void test_set_dest() {
|
|
struct iso_tree_node_dir *root;
|
|
struct iso_tree_node *node;
|
|
struct iso_tree_node_symlink *link;
|
|
|
|
root = iso_tree_new_root();
|
|
|
|
node = iso_tree_add_node(root, "/tmp/libisofs_test/link to readme");
|
|
link = (struct iso_tree_node_symlink *) node;
|
|
CU_ASSERT_STRING_EQUAL( link->dest, "/tmp/libisofs_test/README");
|
|
iso_tree_node_symlink_set_dest(link, "/tmp/inexistent");
|
|
CU_ASSERT_STRING_EQUAL( link->dest, "/tmp/inexistent");
|
|
|
|
iso_tree_free((struct iso_tree_node *)root);
|
|
}
|
|
|
|
static void test_get_dest() {
|
|
struct iso_tree_node_dir *root;
|
|
struct iso_tree_node *node;
|
|
struct iso_tree_node_symlink *link;
|
|
|
|
root = iso_tree_new_root();
|
|
|
|
node = iso_tree_add_node(root, "/tmp/libisofs_test/link to readme");
|
|
link = (struct iso_tree_node_symlink *) node;
|
|
CU_ASSERT_STRING_EQUAL( iso_tree_node_symlink_get_dest(link), "/tmp/libisofs_test/README");
|
|
iso_tree_node_symlink_set_dest(link, "/tmp/inexistent");
|
|
CU_ASSERT_STRING_EQUAL( iso_tree_node_symlink_get_dest(link), "/tmp/inexistent");
|
|
|
|
iso_tree_free((struct iso_tree_node *)root);
|
|
}
|
|
|
|
static void test_get_node_type() {
|
|
struct iso_tree_node_dir *root;
|
|
struct iso_tree_node *node;
|
|
|
|
root = iso_tree_new_root();
|
|
|
|
/* test on a dir */
|
|
node = iso_tree_add_node(root, "/tmp/libisofs_test/dir1");
|
|
CU_ASSERT_EQUAL(iso_tree_node_get_type(node), LIBISO_NODE_DIR);
|
|
|
|
/* test on a link */
|
|
node = iso_tree_add_node(root, "/tmp/libisofs_test/link to readme");
|
|
CU_ASSERT_EQUAL(iso_tree_node_get_type(node), LIBISO_NODE_SYMLINK);
|
|
|
|
/* test on a file */
|
|
node = iso_tree_add_node(root, "/tmp/libisofs_test/README");
|
|
CU_ASSERT_EQUAL(iso_tree_node_get_type(node), LIBISO_NODE_FILE);
|
|
|
|
iso_tree_free((struct iso_tree_node *)root);
|
|
}
|
|
|
|
static void test_children_iter() {
|
|
struct iso_tree_node_dir *root;
|
|
struct iso_tree_iter *iter;
|
|
struct iso_tree_node *child;
|
|
struct iso_tree_node *node1, *node2, *node3;
|
|
|
|
root = iso_tree_new_root();
|
|
|
|
node1 = iso_tree_add_node(root, "/tmp/libisofs_test/dir1");
|
|
node2 = iso_tree_add_node(root, "/tmp/libisofs_test/link to readme");
|
|
node3 = iso_tree_add_node(root, "/tmp/libisofs_test/README");
|
|
|
|
/* get the iterator */
|
|
iter = iso_tree_node_children(root);
|
|
CU_ASSERT_PTR_NOT_NULL(iter);
|
|
|
|
/* test correct iteration */
|
|
child = iso_tree_iter_next(iter);
|
|
CU_ASSERT_PTR_NOT_NULL(child);
|
|
CU_ASSERT_PTR_EQUAL(child, node1);
|
|
|
|
child = iso_tree_iter_next(iter);
|
|
CU_ASSERT_PTR_NOT_NULL(child);
|
|
CU_ASSERT_PTR_EQUAL(child, node2);
|
|
|
|
child = iso_tree_iter_next(iter);
|
|
CU_ASSERT_PTR_NOT_NULL(child);
|
|
CU_ASSERT_PTR_EQUAL(child, node3);
|
|
|
|
/* and NULL when no more children */
|
|
child = iso_tree_iter_next(iter);
|
|
CU_ASSERT_PTR_NULL(child);
|
|
|
|
iso_tree_iter_free(iter);
|
|
|
|
/* now an iter on a empty dir */
|
|
iter = iso_tree_node_children((struct iso_tree_node_dir *)node1);
|
|
CU_ASSERT_PTR_NOT_NULL(iter);
|
|
|
|
child = iso_tree_iter_next(iter);
|
|
CU_ASSERT_PTR_NULL(child);
|
|
|
|
iso_tree_free((struct iso_tree_node *)root);
|
|
}
|
|
|
|
static void test_tree_node_take() {
|
|
int res;
|
|
struct iso_tree_node_dir *root;
|
|
struct iso_tree_iter *iter;
|
|
struct iso_tree_node *child;
|
|
struct iso_tree_node *node1, *node2, *node3;
|
|
|
|
root = iso_tree_new_root();
|
|
|
|
node1 = iso_tree_add_node(root, "/tmp/libisofs_test/dir1");
|
|
node2 = iso_tree_add_node(root, "/tmp/libisofs_test/link to readme");
|
|
node3 = iso_tree_add_node(root, "/tmp/libisofs_test/README");
|
|
|
|
/* we take a ref to each node to test current reference behavior */
|
|
iso_tree_node_ref(node1);
|
|
iso_tree_node_ref(node2);
|
|
iso_tree_node_ref(node3);
|
|
|
|
/* remove node2 */
|
|
res = iso_tree_node_take(root, node2);
|
|
CU_ASSERT_EQUAL(res, 0);
|
|
CU_ASSERT_EQUAL(root->nchildren, 2);
|
|
CU_ASSERT_PTR_NULL(node2->parent);
|
|
|
|
/* node2 should keep both refs */
|
|
CU_ASSERT_EQUAL(node2->refcount, 2);
|
|
|
|
/* test iteration */
|
|
iter = iso_tree_node_children(root);
|
|
CU_ASSERT_PTR_NOT_NULL(iter);
|
|
child = iso_tree_iter_next(iter);
|
|
CU_ASSERT_PTR_NOT_NULL(child);
|
|
CU_ASSERT_PTR_EQUAL(child, node1);
|
|
child = iso_tree_iter_next(iter);
|
|
CU_ASSERT_PTR_NOT_NULL(child);
|
|
CU_ASSERT_PTR_EQUAL(child, node3);
|
|
child = iso_tree_iter_next(iter);
|
|
CU_ASSERT_PTR_NULL(child);
|
|
iso_tree_iter_free(iter);
|
|
|
|
/* try to remove again node2 */
|
|
res = iso_tree_node_take(root, node2);
|
|
CU_ASSERT_EQUAL(res, -1);
|
|
CU_ASSERT_EQUAL(root->nchildren, 2);
|
|
iso_tree_free(node2);
|
|
|
|
/* ok, now remove node1, and then node3 */
|
|
res = iso_tree_node_take(root, node1);
|
|
CU_ASSERT_EQUAL(res, 0);
|
|
CU_ASSERT_EQUAL(root->nchildren, 1);
|
|
CU_ASSERT_EQUAL(node1->refcount, 2);
|
|
CU_ASSERT_PTR_NULL(node1->parent);
|
|
|
|
iter = iso_tree_node_children(root);
|
|
CU_ASSERT_PTR_NOT_NULL(iter);
|
|
child = iso_tree_iter_next(iter);
|
|
CU_ASSERT_PTR_NOT_NULL(child);
|
|
CU_ASSERT_PTR_EQUAL(child, node3);
|
|
child = iso_tree_iter_next(iter);
|
|
CU_ASSERT_PTR_NULL(child);
|
|
iso_tree_iter_free(iter);
|
|
|
|
res = iso_tree_node_take(root, node3);
|
|
CU_ASSERT_EQUAL(res, 0);
|
|
CU_ASSERT_EQUAL(root->nchildren, 0);
|
|
CU_ASSERT_EQUAL(node3->refcount, 2);
|
|
CU_ASSERT_PTR_NULL(node3->parent);
|
|
|
|
iter = iso_tree_node_children(root);
|
|
CU_ASSERT_PTR_NOT_NULL(iter);
|
|
child = iso_tree_iter_next(iter);
|
|
CU_ASSERT_PTR_NULL(child);
|
|
iso_tree_iter_free(iter);
|
|
|
|
/* and try to remove on an empty dir */
|
|
res = iso_tree_node_take(root, node3);
|
|
CU_ASSERT_EQUAL(res, -1);
|
|
|
|
iso_tree_free(node1);
|
|
iso_tree_free(node3);
|
|
|
|
iso_tree_free((struct iso_tree_node *)root);
|
|
iso_tree_free(node1);
|
|
iso_tree_free(node2);
|
|
iso_tree_free(node3);
|
|
}
|
|
|
|
static void test_tree_node_remove() {
|
|
int res;
|
|
struct iso_tree_node_dir *root;
|
|
struct iso_tree_iter *iter;
|
|
struct iso_tree_node *child;
|
|
struct iso_tree_node *node1, *node2, *node3;
|
|
|
|
root = iso_tree_new_root();
|
|
|
|
node1 = iso_tree_add_node(root, "/tmp/libisofs_test/dir1");
|
|
node2 = iso_tree_add_node(root, "/tmp/libisofs_test/link to readme");
|
|
node3 = iso_tree_add_node(root, "/tmp/libisofs_test/README");
|
|
|
|
/* we take a ref to each node to test current reference behavior */
|
|
iso_tree_node_ref(node1);
|
|
iso_tree_node_ref(node2);
|
|
iso_tree_node_ref(node3);
|
|
|
|
/* remove node2 */
|
|
res = iso_tree_node_remove(root, node2);
|
|
CU_ASSERT_EQUAL(res, 0);
|
|
CU_ASSERT_EQUAL(root->nchildren, 2);
|
|
CU_ASSERT_PTR_NULL(node2->parent);
|
|
|
|
/* node2 should be unref */
|
|
CU_ASSERT_EQUAL(node2->refcount, 1);
|
|
|
|
/* test iteration */
|
|
iter = iso_tree_node_children(root);
|
|
CU_ASSERT_PTR_NOT_NULL(iter);
|
|
child = iso_tree_iter_next(iter);
|
|
CU_ASSERT_PTR_NOT_NULL(child);
|
|
CU_ASSERT_PTR_EQUAL(child, node1);
|
|
child = iso_tree_iter_next(iter);
|
|
CU_ASSERT_PTR_NOT_NULL(child);
|
|
CU_ASSERT_PTR_EQUAL(child, node3);
|
|
child = iso_tree_iter_next(iter);
|
|
CU_ASSERT_PTR_NULL(child);
|
|
iso_tree_iter_free(iter);
|
|
|
|
/* try to remove again node2 */
|
|
res = iso_tree_node_remove(root, node2);
|
|
CU_ASSERT_EQUAL(res, -1);
|
|
CU_ASSERT_EQUAL(root->nchildren, 2);
|
|
CU_ASSERT_EQUAL(node2->refcount, 1);
|
|
|
|
/* ok, now remove node1, and then node3 */
|
|
res = iso_tree_node_remove(root, node1);
|
|
CU_ASSERT_EQUAL(res, 0);
|
|
CU_ASSERT_EQUAL(root->nchildren, 1);
|
|
CU_ASSERT_EQUAL(node1->refcount, 1);
|
|
CU_ASSERT_PTR_NULL(node1->parent);
|
|
|
|
iter = iso_tree_node_children(root);
|
|
CU_ASSERT_PTR_NOT_NULL(iter);
|
|
child = iso_tree_iter_next(iter);
|
|
CU_ASSERT_PTR_NOT_NULL(child);
|
|
CU_ASSERT_PTR_EQUAL(child, node3);
|
|
child = iso_tree_iter_next(iter);
|
|
CU_ASSERT_PTR_NULL(child);
|
|
iso_tree_iter_free(iter);
|
|
|
|
res = iso_tree_node_remove(root, node3);
|
|
CU_ASSERT_EQUAL(res, 0);
|
|
CU_ASSERT_EQUAL(root->nchildren, 0);
|
|
CU_ASSERT_EQUAL(node3->refcount, 1);
|
|
CU_ASSERT_PTR_NULL(node3->parent);
|
|
|
|
iter = iso_tree_node_children(root);
|
|
CU_ASSERT_PTR_NOT_NULL(iter);
|
|
child = iso_tree_iter_next(iter);
|
|
CU_ASSERT_PTR_NULL(child);
|
|
iso_tree_iter_free(iter);
|
|
|
|
/* and try to remove on an empty dir */
|
|
res = iso_tree_node_remove(root, node3);
|
|
CU_ASSERT_EQUAL(res, -1);
|
|
CU_ASSERT_EQUAL(node3->refcount, 1);
|
|
|
|
iso_tree_free((struct iso_tree_node *)root);
|
|
iso_tree_free(node1);
|
|
iso_tree_free(node2);
|
|
iso_tree_free(node3);
|
|
}
|
|
|
|
static void test_tree_node_take_iter() {
|
|
int res;
|
|
struct iso_tree_node_dir *root;
|
|
struct iso_tree_iter *iter;
|
|
struct iso_tree_node *child;
|
|
struct iso_tree_node *node1, *node2, *node3;
|
|
|
|
root = iso_tree_new_root();
|
|
|
|
node1 = iso_tree_add_node(root, "/tmp/libisofs_test/dir1");
|
|
node2 = iso_tree_add_node(root, "/tmp/libisofs_test/link to readme");
|
|
node3 = iso_tree_add_node(root, "/tmp/libisofs_test/README");
|
|
|
|
/* we take a ref to each node to test current reference behavior */
|
|
iso_tree_node_ref(node1);
|
|
iso_tree_node_ref(node2);
|
|
iso_tree_node_ref(node3);
|
|
|
|
/* begin iteration */
|
|
iter = iso_tree_node_children(root);
|
|
CU_ASSERT_PTR_NOT_NULL(iter);
|
|
|
|
child = iso_tree_iter_next(iter);
|
|
CU_ASSERT_PTR_NOT_NULL(child);
|
|
CU_ASSERT_PTR_EQUAL(child, node1);
|
|
|
|
child = iso_tree_iter_next(iter);
|
|
CU_ASSERT_PTR_NOT_NULL(child);
|
|
CU_ASSERT_PTR_EQUAL(child, node2);
|
|
|
|
/* ok, take node 2 */
|
|
res = iso_tree_node_take_iter(iter);
|
|
CU_ASSERT_EQUAL(res, 0);
|
|
CU_ASSERT_EQUAL(root->nchildren, 2);
|
|
CU_ASSERT_EQUAL(node2->refcount, 2);
|
|
CU_ASSERT_PTR_NULL(node2->parent);
|
|
|
|
/* the iter have to work after remove */
|
|
child = iso_tree_iter_next(iter);
|
|
CU_ASSERT_PTR_NOT_NULL(child);
|
|
CU_ASSERT_PTR_EQUAL(child, node3);
|
|
|
|
child = iso_tree_iter_next(iter);
|
|
CU_ASSERT_PTR_NULL(child);
|
|
iso_tree_iter_free(iter);
|
|
|
|
/* ok, now remove before the begining */
|
|
iter = iso_tree_node_children(root);
|
|
CU_ASSERT_PTR_NOT_NULL(iter);
|
|
|
|
res = iso_tree_node_take_iter(iter);
|
|
CU_ASSERT_TRUE(res < 0);
|
|
|
|
/* and the iter still works */
|
|
child = iso_tree_iter_next(iter);
|
|
CU_ASSERT_PTR_NOT_NULL(child);
|
|
CU_ASSERT_PTR_EQUAL(child, node1);
|
|
child = iso_tree_iter_next(iter);
|
|
CU_ASSERT_PTR_NOT_NULL(child);
|
|
CU_ASSERT_PTR_EQUAL(child, node3);
|
|
child = iso_tree_iter_next(iter);
|
|
CU_ASSERT_PTR_NULL(child);
|
|
|
|
/* and now try to remove at the end */
|
|
res = iso_tree_node_take_iter(iter);
|
|
CU_ASSERT_TRUE(res < 0);
|
|
iso_tree_iter_free(iter);
|
|
|
|
/* ok, now remove all during iteration */
|
|
iter = iso_tree_node_children(root);
|
|
CU_ASSERT_PTR_NOT_NULL(iter);
|
|
|
|
child = iso_tree_iter_next(iter);
|
|
CU_ASSERT_PTR_NOT_NULL(child);
|
|
CU_ASSERT_PTR_EQUAL(child, node1);
|
|
|
|
res = iso_tree_node_take_iter(iter);
|
|
CU_ASSERT_EQUAL(res, 0);
|
|
CU_ASSERT_EQUAL(root->nchildren, 1);
|
|
CU_ASSERT_EQUAL(node1->refcount, 2);
|
|
CU_ASSERT_PTR_NULL(node1->parent);
|
|
|
|
child = iso_tree_iter_next(iter);
|
|
CU_ASSERT_PTR_NOT_NULL(child);
|
|
CU_ASSERT_PTR_EQUAL(child, node3);
|
|
|
|
res = iso_tree_node_take_iter(iter);
|
|
CU_ASSERT_EQUAL(res, 0);
|
|
CU_ASSERT_EQUAL(root->nchildren, 0);
|
|
CU_ASSERT_EQUAL(node3->refcount, 2);
|
|
CU_ASSERT_PTR_NULL(node3->parent);
|
|
|
|
child = iso_tree_iter_next(iter);
|
|
CU_ASSERT_PTR_NULL(child);
|
|
iso_tree_iter_free(iter);
|
|
|
|
iso_tree_free(node1);
|
|
iso_tree_free(node2);
|
|
iso_tree_free(node3);
|
|
|
|
iso_tree_free((struct iso_tree_node *)root);
|
|
iso_tree_free(node1);
|
|
iso_tree_free(node2);
|
|
iso_tree_free(node3);
|
|
}
|
|
|
|
static void test_tree_node_remove_iter() {
|
|
int res;
|
|
struct iso_tree_node_dir *root;
|
|
struct iso_tree_iter *iter;
|
|
struct iso_tree_node *child;
|
|
struct iso_tree_node *node1, *node2, *node3;
|
|
|
|
root = iso_tree_new_root();
|
|
|
|
node1 = iso_tree_add_node(root, "/tmp/libisofs_test/dir1");
|
|
node2 = iso_tree_add_node(root, "/tmp/libisofs_test/link to readme");
|
|
node3 = iso_tree_add_node(root, "/tmp/libisofs_test/README");
|
|
|
|
/* we take a ref to each node to test current reference behavior */
|
|
iso_tree_node_ref(node1);
|
|
iso_tree_node_ref(node2);
|
|
iso_tree_node_ref(node3);
|
|
|
|
/* begin iteration */
|
|
iter = iso_tree_node_children(root);
|
|
CU_ASSERT_PTR_NOT_NULL(iter);
|
|
|
|
child = iso_tree_iter_next(iter);
|
|
CU_ASSERT_PTR_NOT_NULL(child);
|
|
CU_ASSERT_PTR_EQUAL(child, node1);
|
|
|
|
child = iso_tree_iter_next(iter);
|
|
CU_ASSERT_PTR_NOT_NULL(child);
|
|
CU_ASSERT_PTR_EQUAL(child, node2);
|
|
|
|
/* ok, remove node 2 */
|
|
res = iso_tree_node_remove_iter(iter);
|
|
CU_ASSERT_EQUAL(res, 0);
|
|
CU_ASSERT_EQUAL(root->nchildren, 2);
|
|
CU_ASSERT_EQUAL(node2->refcount, 1);
|
|
CU_ASSERT_PTR_NULL(node2->parent);
|
|
|
|
/* the iter have to work after remove */
|
|
child = iso_tree_iter_next(iter);
|
|
CU_ASSERT_PTR_NOT_NULL(child);
|
|
CU_ASSERT_PTR_EQUAL(child, node3);
|
|
|
|
child = iso_tree_iter_next(iter);
|
|
CU_ASSERT_PTR_NULL(child);
|
|
iso_tree_iter_free(iter);
|
|
|
|
/* ok, now remove before the begining */
|
|
iter = iso_tree_node_children(root);
|
|
CU_ASSERT_PTR_NOT_NULL(iter);
|
|
|
|
res = iso_tree_node_remove_iter(iter);
|
|
CU_ASSERT_TRUE(res < 0);
|
|
|
|
/* and the iter still works */
|
|
child = iso_tree_iter_next(iter);
|
|
CU_ASSERT_PTR_NOT_NULL(child);
|
|
CU_ASSERT_PTR_EQUAL(child, node1);
|
|
child = iso_tree_iter_next(iter);
|
|
CU_ASSERT_PTR_NOT_NULL(child);
|
|
CU_ASSERT_PTR_EQUAL(child, node3);
|
|
child = iso_tree_iter_next(iter);
|
|
CU_ASSERT_PTR_NULL(child);
|
|
|
|
/* and now try to remove at the end */
|
|
res = iso_tree_node_remove_iter(iter);
|
|
CU_ASSERT_TRUE(res < 0);
|
|
iso_tree_iter_free(iter);
|
|
|
|
/* ok, now remove all during iteration */
|
|
iter = iso_tree_node_children(root);
|
|
CU_ASSERT_PTR_NOT_NULL(iter);
|
|
|
|
child = iso_tree_iter_next(iter);
|
|
CU_ASSERT_PTR_NOT_NULL(child);
|
|
CU_ASSERT_PTR_EQUAL(child, node1);
|
|
|
|
res = iso_tree_node_remove_iter(iter);
|
|
CU_ASSERT_EQUAL(res, 0);
|
|
CU_ASSERT_EQUAL(root->nchildren, 1);
|
|
CU_ASSERT_EQUAL(node1->refcount, 1);
|
|
CU_ASSERT_PTR_NULL(node1->parent);
|
|
|
|
child = iso_tree_iter_next(iter);
|
|
CU_ASSERT_PTR_NOT_NULL(child);
|
|
CU_ASSERT_PTR_EQUAL(child, node3);
|
|
|
|
res = iso_tree_node_remove_iter(iter);
|
|
CU_ASSERT_EQUAL(res, 0);
|
|
CU_ASSERT_EQUAL(root->nchildren, 0);
|
|
CU_ASSERT_EQUAL(node3->refcount, 1);
|
|
CU_ASSERT_PTR_NULL(node3->parent);
|
|
|
|
child = iso_tree_iter_next(iter);
|
|
CU_ASSERT_PTR_NULL(child);
|
|
iso_tree_iter_free(iter);
|
|
|
|
iso_tree_free((struct iso_tree_node *)root);
|
|
iso_tree_free(node1);
|
|
iso_tree_free(node2);
|
|
iso_tree_free(node3);
|
|
}
|
|
|
|
static void test_tree_node_get_parent() {
|
|
struct iso_tree_node_dir *root;
|
|
struct iso_tree_node_dir *parent;
|
|
struct iso_tree_node *node1, *node2, *node3;
|
|
|
|
root = iso_tree_new_root();
|
|
|
|
node1 = iso_tree_add_node(root, "/tmp/libisofs_test/dir1");
|
|
node2 = iso_tree_add_node(root, "/tmp/libisofs_test/link to readme");
|
|
node3 = iso_tree_add_node( (struct iso_tree_node_dir*)node1,
|
|
"/tmp/libisofs_test/README");
|
|
|
|
parent = iso_tree_node_get_parent((struct iso_tree_node *)root);
|
|
CU_ASSERT_PTR_NULL(parent);
|
|
|
|
parent = iso_tree_node_get_parent(node1);
|
|
CU_ASSERT_PTR_NOT_NULL(parent);
|
|
CU_ASSERT_PTR_EQUAL(parent, root);
|
|
|
|
parent = iso_tree_node_get_parent(node2);
|
|
CU_ASSERT_PTR_NOT_NULL(parent);
|
|
CU_ASSERT_PTR_EQUAL(parent, root);
|
|
|
|
parent = iso_tree_node_get_parent(node3);
|
|
CU_ASSERT_PTR_NOT_NULL(parent);
|
|
CU_ASSERT_PTR_EQUAL(parent, node1);
|
|
|
|
iso_tree_node_take(root, node1);
|
|
parent = iso_tree_node_get_parent(node1);
|
|
CU_ASSERT_PTR_NULL(parent);
|
|
|
|
iso_tree_free((struct iso_tree_node *)root);
|
|
iso_tree_free(node1);
|
|
}
|
|
|
|
void add_tree_suite()
|
|
{
|
|
CU_pSuite pSuite = CU_add_suite("TreeSuite", NULL, NULL);
|
|
|
|
CU_add_test(pSuite, "test of iso_tree_new_root()", test_new_root);
|
|
CU_add_test(pSuite, "test of iso_tree_add_dir()", test_add_dir);
|
|
CU_add_test(pSuite, "test of iso_tree_add_file()", test_add_file);
|
|
CU_add_test(pSuite, "test of iso_tree_add_symlink()", test_add_symlink);
|
|
CU_add_test(pSuite, "test of iso_tree_add_node()", test_add_node);
|
|
|
|
CU_add_test(pSuite, "test of iso_tree_node_set_name()", test_set_name);
|
|
CU_add_test(pSuite, "test of iso_tree_node_get_name()", test_get_name);
|
|
CU_add_test(pSuite, "test of iso_tree_node_set_hidden()", test_set_hidden);
|
|
CU_add_test(pSuite, "test of iso_tree_node_is_hidden()", test_is_hidden);
|
|
CU_add_test(pSuite, "test of iso_tree_node_set_gid()", test_set_gid);
|
|
CU_add_test(pSuite, "test of iso_tree_node_get_gid()", test_get_gid);
|
|
CU_add_test(pSuite, "test of iso_tree_node_set_uid()", test_set_uid);
|
|
CU_add_test(pSuite, "test of iso_tree_node_get_uid()", test_get_uid);
|
|
CU_add_test(pSuite, "test of iso_tree_node_set_permissions()", test_set_permissions);
|
|
CU_add_test(pSuite, "test of iso_tree_node_get_permissions()", test_get_permissions);
|
|
CU_add_test(pSuite, "test of iso_tree_node_set_sort_weight()", test_set_sort_weight);
|
|
CU_add_test(pSuite, "test of iso_tree_node_symlink_set_dest()", test_set_dest);
|
|
CU_add_test(pSuite, "test of iso_tree_node_symlink_get_dest()", test_get_dest);
|
|
CU_add_test(pSuite, "test of iso_tree_node_get_type()", test_get_node_type);
|
|
|
|
CU_add_test(pSuite, "test of children iteration", test_children_iter);
|
|
CU_add_test(pSuite, "test of iso_tree_node_take()", test_tree_node_take);
|
|
CU_add_test(pSuite, "test of iso_tree_node_remove()", test_tree_node_remove);
|
|
CU_add_test(pSuite, "test of iso_tree_node_take_iter()", test_tree_node_take_iter);
|
|
CU_add_test(pSuite, "test of iso_tree_node_remove_iter()", test_tree_node_remove_iter);
|
|
|
|
CU_add_test(pSuite, "test of iso_tree_node_get_parent()", test_tree_node_get_parent);
|
|
}
|