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"
67 " -? print this message\n\n"), 2001, VERSION, BDATE);
71 static int result_handler(void *ctx, int fields, char **row)
73 Bvfs *vfs = (Bvfs *)ctx;
74 ATTR *attr = vfs->get_attr();
77 if (fields == BVFS_DIR_RECORD || fields == BVFS_FILE_RECORD) {
78 decode_stat((row[BVFS_LStat])?row[BVFS_LStat]:empty,
79 &attr->statp, &attr->LinkFI);
80 if (fields == BVFS_DIR_RECORD) {
81 pm_strcpy(attr->ofname, bvfs_basename_dir(row[BVFS_Name]));
83 pm_strcpy(attr->ofname, row[BVFS_Name]);
85 print_ls_output(vfs->get_jcr(), attr);
88 Pmsg6(0, "%s\t%s\t%s\t%s\t%s\t%s",
89 row[0], row[1], row[2], row[3], row[4], row[5]);
95 /* number of thread started */
97 int main (int argc, char *argv[])
100 char *jobids="1", *path=NULL, *file=NULL;
101 setlocale(LC_ALL, "");
102 bindtextdomain("bacula", LOCALEDIR);
103 textdomain("bacula");
106 Dmsg0(0, "Starting bvfs_test tool\n");
108 my_name_is(argc, argv, "bvfs_test");
109 init_msg(NULL, NULL);
113 while ((ch = getopt(argc, argv, "h:c:d:n:P:Su:vf:w:?j:p:f:")) != -1) {
115 case 'd': /* debug level */
116 if (*optarg == 't') {
117 dbg_timestamp = true;
119 debug_level = atoi(optarg);
120 if (debug_level <= 0) {
135 working_directory = optarg;
143 db_password = optarg;
172 Pmsg0(0, _("Wrong number of arguments: \n"));
175 JCR *bjcr = new_jcr(sizeof(JCR), NULL);
176 bjcr->JobId = getpid();
177 bjcr->set_JobType(JT_CONSOLE);
178 bjcr->set_JobLevel(L_FULL);
179 bjcr->JobStatus = JS_Running;
180 bjcr->client_name = get_pool_memory(PM_FNAME);
181 pm_strcpy(bjcr->client_name, "Dummy.Client.Name");
182 bstrncpy(bjcr->Job, "bvfs_test", sizeof(bjcr->Job));
184 if ((db=db_init_database(NULL, db_name, db_user, db_password,
185 db_host, 0, NULL, 0)) == NULL) {
186 Emsg0(M_ERROR_TERM, 0, _("Could not init Bacula database\n"));
188 Dmsg1(0, "db_type=%s\n", db_get_type());
190 if (!db_open_database(NULL, db)) {
191 Emsg0(M_ERROR_TERM, 0, db_strerror(db));
193 Dmsg0(200, "Database opened\n");
195 Pmsg2(000, _("Using Database: %s, User: %s\n"), db_name, db_user);
200 db_sql_query(db, "DELETE FROM brestore_pathhierarchy", NULL, NULL);
201 db_sql_query(db, "DELETE FROM brestore_knownjobid", NULL, NULL);
202 db_sql_query(db, "DELETE FROM brestore_pathvisibility", NULL, NULL);
204 bvfs_update_cache(bjcr, db);
206 fs.set_handler(result_handler, &fs);
208 fs.set_jobids(jobids);
213 fs.ls_special_dirs();
220 Pmsg0(0, "list /\n");
222 fs.ls_special_dirs();
226 Pmsg0(0, "list /tmp/\n");
228 fs.ls_special_dirs();
232 Pmsg0(0, "list /tmp/regress/\n");
233 fs.ch_dir("/tmp/regress/");
234 fs.ls_special_dirs();
238 Pmsg0(0, "list /tmp/regress/build/\n");
239 fs.ch_dir("/tmp/regress/build/");
240 fs.ls_special_dirs();
244 fs.get_all_file_versions(1, 347, "zog4-fd");
247 strcpy(p, "/tmp/toto/rep/");
249 if(strcmp(p, "/tmp/toto/")) {
250 Pmsg0(000, "Error in bvfs_parent_dir\n");
253 if(strcmp(p, "/tmp/")) {
254 Pmsg0(000, "Error in bvfs_parent_dir\n");
258 Pmsg0(000, "Error in bvfs_parent_dir\n");
262 Pmsg0(000, "Error in bvfs_parent_dir\n");
266 Pmsg0(000, "Error in bvfs_parent_dir\n");