3 * Program to test cache path
5 * Eric Bollengier, March 2007
11 Bacula® - The Network Backup Solution
13 Copyright (C) 2001-2006 Free Software Foundation Europe e.V.
15 The main author of Bacula is Kern Sibbald, with contributions from
16 many others, a complete list can be found in the file AUTHORS.
17 This program is Free Software; you can redistribute it and/or
18 modify it under the terms of version two of the GNU General Public
19 License as published by the Free Software Foundation and included
22 This program is distributed in the hope that it will be useful, but
23 WITHOUT ANY WARRANTY; without even the implied warranty of
24 MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU
25 General Public License for more details.
27 You should have received a copy of the GNU General Public License
28 along with this program; if not, write to the Free Software
29 Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA
32 Bacula® is a registered trademark of Kern Sibbald.
33 The licensor of Bacula is the Free Software Foundation Europe
34 (FSFE), Fiduciary Program, Sumatrastrasse 25, 8006 Zürich,
35 Switzerland, email:ftf@fsfeurope.org.
39 #include "cats/cats.h"
40 #include "cats/bvfs.h"
41 #include "findlib/find.h"
46 static const char *db_name = "regress";
47 static const char *db_user = "regress";
48 static const char *db_password = "";
49 static const char *db_host = NULL;
55 "\nVersion: %s (%s)\n"
56 " -d <nn> set debug level to <nn>\n"
57 " -dt print timestamp in debug output\n"
58 " -n <name> specify the database name (default bacula)\n"
59 " -u <user> specify database user name (default bacula)\n"
60 " -P <password specify database password (default none)\n"
61 " -h <host> specify database host (default NULL)\n"
62 " -w <working> specify working directory\n"
63 " -j <jobids> specify jobids\n"
64 " -p <path> specify path\n"
65 //" -f <file> specify file\n"
66 " -T truncate cache table before starting\n"
68 " -? print this message\n\n"), 2001, VERSION, BDATE);
72 static int result_handler(void *ctx, int fields, char **row)
74 Bvfs *vfs = (Bvfs *)ctx;
75 ATTR *attr = vfs->get_attr();
78 if (fields == BVFS_DIR_RECORD || fields == BVFS_FILE_RECORD) {
79 decode_stat((row[BVFS_LStat])?row[BVFS_LStat]:empty,
80 &attr->statp, &attr->LinkFI);
81 if (fields == BVFS_DIR_RECORD) {
82 pm_strcpy(attr->ofname, bvfs_basename_dir(row[BVFS_Name]));
84 pm_strcpy(attr->ofname, row[BVFS_Name]);
86 print_ls_output(vfs->get_jcr(), attr);
89 Pmsg6(0, "%s\t%s\t%s\t%s\t%s\t%s",
90 row[0], row[1], row[2], row[3], row[4], row[5]);
96 /* number of thread started */
98 int main (int argc, char *argv[])
101 char *jobids="1", *path=NULL, *file=NULL;
103 setlocale(LC_ALL, "");
104 bindtextdomain("bacula", LOCALEDIR);
105 textdomain("bacula");
108 Dmsg0(0, "Starting bvfs_test tool\n");
110 my_name_is(argc, argv, "bvfs_test");
111 init_msg(NULL, NULL);
115 while ((ch = getopt(argc, argv, "h:c:d:n:P:Su:vf:w:?j:p:f:T")) != -1) {
117 case 'd': /* debug level */
118 if (*optarg == 't') {
119 dbg_timestamp = true;
121 debug_level = atoi(optarg);
122 if (debug_level <= 0) {
137 working_directory = optarg;
145 db_password = optarg;
178 Pmsg0(0, _("Wrong number of arguments: \n"));
181 JCR *bjcr = new_jcr(sizeof(JCR), NULL);
182 bjcr->JobId = getpid();
183 bjcr->set_JobType(JT_CONSOLE);
184 bjcr->set_JobLevel(L_FULL);
185 bjcr->JobStatus = JS_Running;
186 bjcr->client_name = get_pool_memory(PM_FNAME);
187 pm_strcpy(bjcr->client_name, "Dummy.Client.Name");
188 bstrncpy(bjcr->Job, "bvfs_test", sizeof(bjcr->Job));
190 if ((db=db_init_database(NULL, db_name, db_user, db_password,
191 db_host, 0, NULL, 0)) == NULL) {
192 Emsg0(M_ERROR_TERM, 0, _("Could not init Bacula database\n"));
194 Dmsg1(0, "db_type=%s\n", db_get_type());
196 if (!db_open_database(NULL, db)) {
197 Emsg0(M_ERROR_TERM, 0, db_strerror(db));
199 Dmsg0(200, "Database opened\n");
201 Pmsg2(000, _("Using Database: %s, User: %s\n"), db_name, db_user);
207 Pmsg0(0, "Clean old table\n");
208 db_sql_query(db, "DELETE FROM brestore_pathhierarchy", NULL, NULL);
209 db_sql_query(db, "DELETE FROM brestore_knownjobid", NULL, NULL);
210 db_sql_query(db, "DELETE FROM brestore_pathvisibility", NULL, NULL);
211 bvfs_update_cache(bjcr, db);
215 fs.set_handler(result_handler, &fs);
217 fs.set_jobids(jobids);
222 fs.ls_special_dirs();
229 Pmsg0(0, "list /\n");
231 fs.ls_special_dirs();
235 Pmsg0(0, "list /tmp/\n");
237 fs.ls_special_dirs();
241 Pmsg0(0, "list /tmp/regress/\n");
242 fs.ch_dir("/tmp/regress/");
243 fs.ls_special_dirs();
247 Pmsg0(0, "list /tmp/regress/build/\n");
248 fs.ch_dir("/tmp/regress/build/");
249 fs.ls_special_dirs();
253 fs.get_all_file_versions(1, 347, "zog4-fd");
256 strcpy(p, "/tmp/toto/rep/");
258 if(strcmp(p, "/tmp/toto/")) {
259 Pmsg0(000, "Error in bvfs_parent_dir\n");
262 if(strcmp(p, "/tmp/")) {
263 Pmsg0(000, "Error in bvfs_parent_dir\n");
267 Pmsg0(000, "Error in bvfs_parent_dir\n");
271 Pmsg0(000, "Error in bvfs_parent_dir\n");
275 Pmsg0(000, "Error in bvfs_parent_dir\n");