diff options
Diffstat (limited to 'plugins/tests/test_disk.c')
-rw-r--r-- | plugins/tests/test_disk.c | 115 |
1 files changed, 77 insertions, 38 deletions
diff --git a/plugins/tests/test_disk.c b/plugins/tests/test_disk.c index 19cc3ac..8940236 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 | ||