diff options
Diffstat (limited to 'plugins/tests')
| -rw-r--r-- | plugins/tests/.cvsignore | 1 | ||||
| -rw-r--r-- | plugins/tests/test_disk.c | 115 |
2 files changed, 78 insertions, 38 deletions
diff --git a/plugins/tests/.cvsignore b/plugins/tests/.cvsignore index 94b5122a..6dc692f5 100644 --- a/plugins/tests/.cvsignore +++ b/plugins/tests/.cvsignore | |||
| @@ -1,4 +1,5 @@ | |||
| 1 | Makefile | 1 | Makefile |
| 2 | Makefile.in | 2 | Makefile.in |
| 3 | test_utils | 3 | test_utils |
| 4 | test_disk | ||
| 4 | .deps | 5 | .deps |
diff --git a/plugins/tests/test_disk.c b/plugins/tests/test_disk.c index 19cc3acd..8940236b 100644 --- a/plugins/tests/test_disk.c +++ b/plugins/tests/test_disk.c | |||
| @@ -27,16 +27,24 @@ main (int argc, char **argv) | |||
| 27 | { | 27 | { |
| 28 | struct name_list *exclude_filesystem=NULL; | 28 | struct name_list *exclude_filesystem=NULL; |
| 29 | struct name_list *exclude_fstype=NULL; | 29 | struct name_list *exclude_fstype=NULL; |
| 30 | struct name_list *dummy_mountlist = NULL; | ||
| 31 | struct name_list *temp_name; | ||
| 32 | struct parameter_list *paths = NULL; | ||
| 33 | struct parameter_list *p; | ||
| 30 | 34 | ||
| 31 | plan_tests(8); | 35 | struct mount_entry *dummy_mount_list; |
| 36 | struct mount_entry *me; | ||
| 37 | struct mount_entry **mtail = &dummy_mount_list; | ||
| 32 | 38 | ||
| 33 | ok( np_find_name(exclude_filesystem, "/var") == FALSE, "/var not in list"); | 39 | plan_tests(17); |
| 34 | np_add_name(&exclude_filesystem, "/var"); | 40 | |
| 35 | ok( np_find_name(exclude_filesystem, "/var") == TRUE, "is in list now"); | 41 | ok( np_find_name(exclude_filesystem, "/var/log") == FALSE, "/var/log not in list"); |
| 42 | np_add_name(&exclude_filesystem, "/var/log"); | ||
| 43 | ok( np_find_name(exclude_filesystem, "/var/log") == TRUE, "is in list now"); | ||
| 36 | ok( np_find_name(exclude_filesystem, "/home") == FALSE, "/home not in list"); | 44 | ok( np_find_name(exclude_filesystem, "/home") == FALSE, "/home not in list"); |
| 37 | np_add_name(&exclude_filesystem, "/home"); | 45 | np_add_name(&exclude_filesystem, "/home"); |
| 38 | ok( np_find_name(exclude_filesystem, "/home") == TRUE, "is in list now"); | 46 | ok( np_find_name(exclude_filesystem, "/home") == TRUE, "is in list now"); |
| 39 | ok( np_find_name(exclude_filesystem, "/var") == TRUE, "/var still in list"); | 47 | ok( np_find_name(exclude_filesystem, "/var/log") == TRUE, "/var/log still in list"); |
| 40 | 48 | ||
| 41 | ok( np_find_name(exclude_fstype, "iso9660") == FALSE, "iso9660 not in list"); | 49 | ok( np_find_name(exclude_fstype, "iso9660") == FALSE, "iso9660 not in list"); |
| 42 | np_add_name(&exclude_fstype, "iso9660"); | 50 | np_add_name(&exclude_fstype, "iso9660"); |
| @@ -44,42 +52,73 @@ main (int argc, char **argv) | |||
| 44 | 52 | ||
| 45 | ok( np_find_name(exclude_filesystem, "iso9660") == FALSE, "Make sure no clashing in variables"); | 53 | ok( np_find_name(exclude_filesystem, "iso9660") == FALSE, "Make sure no clashing in variables"); |
| 46 | 54 | ||
| 47 | |||
| 48 | |||
| 49 | |||
| 50 | /* | 55 | /* |
| 51 | range = parse_range_string("6"); | 56 | for (temp_name = exclude_filesystem; temp_name; temp_name = temp_name->next) { |
| 52 | ok( range != NULL, "'6' is valid range"); | 57 | printf("Name: %s\n", temp_name->name); |
| 53 | ok( range->start == 0, "Start correct"); | 58 | } |
| 54 | ok( range->start_infinity == FALSE, "Not using negative infinity"); | ||
| 55 | ok( range->end == 6, "End correct"); | ||
| 56 | ok( range->end_infinity == FALSE, "Not using infinity"); | ||
| 57 | free(range); | ||
| 58 | |||
| 59 | range = parse_range_string("-7:23"); | ||
| 60 | ok( range != NULL, "'-7:23' is valid range"); | ||
| 61 | ok( range->start == -7, "Start correct"); | ||
| 62 | ok( range->start_infinity == FALSE, "Not using negative infinity"); | ||
| 63 | ok( range->end == 23, "End correct"); | ||
| 64 | ok( range->end_infinity == FALSE, "Not using infinity"); | ||
| 65 | free(range); | ||
| 66 | |||
| 67 | range = parse_range_string(":5.75"); | ||
| 68 | ok( range != NULL, "':5.75' is valid range"); | ||
| 69 | ok( range->start == 0, "Start correct"); | ||
| 70 | ok( range->start_infinity == FALSE, "Not using negative infinity"); | ||
| 71 | ok( range->end == 5.75, "End correct"); | ||
| 72 | ok( range->end_infinity == FALSE, "Not using infinity"); | ||
| 73 | free(range); | ||
| 74 | |||
| 75 | range = parse_range_string("~:-95.99"); | ||
| 76 | ok( range != NULL, "~:-95.99' is valid range"); | ||
| 77 | ok( range->start_infinity == TRUE, "Using negative infinity"); | ||
| 78 | ok( range->end == -95.99, "End correct (with rounding errors)"); | ||
| 79 | ok( range->end_infinity == FALSE, "Not using infinity"); | ||
| 80 | free(range); | ||
| 81 | */ | 59 | */ |
| 82 | 60 | ||
| 61 | me = (struct mount_entry *) malloc(sizeof *me); | ||
| 62 | me->me_devname = strdup("/dev/c0t0d0s0"); | ||
| 63 | me->me_mountdir = strdup("/"); | ||
| 64 | *mtail = me; | ||
| 65 | mtail = &me->me_next; | ||
| 66 | |||
| 67 | me = (struct mount_entry *) malloc(sizeof *me); | ||
| 68 | me->me_devname = strdup("/dev/c1t0d1s0"); | ||
| 69 | me->me_mountdir = strdup("/var"); | ||
| 70 | *mtail = me; | ||
| 71 | mtail = &me->me_next; | ||
| 72 | |||
| 73 | me = (struct mount_entry *) malloc(sizeof *me); | ||
| 74 | me->me_devname = strdup("/dev/c2t0d0s0"); | ||
| 75 | me->me_mountdir = strdup("/home"); | ||
| 76 | *mtail = me; | ||
| 77 | mtail = &me->me_next; | ||
| 78 | |||
| 79 | |||
| 80 | np_add_parameter(&paths, "/home/groups"); | ||
| 81 | np_add_parameter(&paths, "/var"); | ||
| 82 | np_add_parameter(&paths, "/tmp"); | ||
| 83 | np_add_parameter(&paths, "/home/tonvoon"); | ||
| 84 | np_add_parameter(&paths, "/dev/c2t0d0s0"); | ||
| 85 | |||
| 86 | np_set_best_match(paths, dummy_mount_list, FALSE); | ||
| 87 | for (p = paths; p; p = p->name_next) { | ||
| 88 | struct mount_entry *temp_me; | ||
| 89 | temp_me = p->best_match; | ||
| 90 | if (! strcmp(p->name, "/home/groups")) { | ||
| 91 | ok( temp_me && !strcmp(temp_me->me_mountdir, "/home"), "/home/groups got right best match: /home"); | ||
| 92 | } else if (! strcmp(p->name, "/var")) { | ||
| 93 | ok( temp_me && !strcmp(temp_me->me_mountdir, "/var"), "/var got right best match: /var"); | ||
| 94 | } else if (! strcmp(p->name, "/tmp")) { | ||
| 95 | ok( temp_me && !strcmp(temp_me->me_mountdir, "/"), "/tmp got right best match: /"); | ||
| 96 | } else if (! strcmp(p->name, "/home/tonvoon")) { | ||
| 97 | ok( temp_me && !strcmp(temp_me->me_mountdir, "/home"), "/home/tonvoon got right best match: /home"); | ||
| 98 | } else if (! strcmp(p->name, "/dev/c2t0d0s0")) { | ||
| 99 | ok( temp_me && !strcmp(temp_me->me_devname, "/dev/c2t0d0s0"), "/dev/c2t0d0s0 got right best match: /dev/c2t0d0s0"); | ||
| 100 | } | ||
| 101 | } | ||
| 102 | |||
| 103 | paths = NULL; /* Bad boy - should free, but this is a test suite */ | ||
| 104 | np_add_parameter(&paths, "/home/groups"); | ||
| 105 | np_add_parameter(&paths, "/var"); | ||
| 106 | np_add_parameter(&paths, "/tmp"); | ||
| 107 | np_add_parameter(&paths, "/home/tonvoon"); | ||
| 108 | |||
| 109 | np_set_best_match(paths, dummy_mount_list, TRUE); | ||
| 110 | for (p = paths; p; p = p->name_next) { | ||
| 111 | if (! strcmp(p->name, "/home/groups")) { | ||
| 112 | ok( p->found == 0, "/home/groups correctly not found"); | ||
| 113 | } else if (! strcmp(p->name, "/var")) { | ||
| 114 | ok( p->found == 1, "/var found"); | ||
| 115 | } else if (! strcmp(p->name, "/tmp")) { | ||
| 116 | ok( p->found == 0, "/tmp correctly not found"); | ||
| 117 | } else if (! strcmp(p->name, "/home/tonvoon")) { | ||
| 118 | ok( p->found == 0, "/home/tonvoon not found"); | ||
| 119 | } | ||
| 120 | } | ||
| 121 | |||
| 83 | return exit_status(); | 122 | return exit_status(); |
| 84 | } | 123 | } |
| 85 | 124 | ||
