test-logger.cc

Go to the documentation of this file.
00001 #include "config.h"
00002 
00003 #include <iostream>
00004 #include <fstream>
00005 #include <string>
00006 #include <cassert>
00007 
00008 #ifdef HAVE_UNISTD_H
00009 #include <unistd.h>
00010 #endif
00011 
00012 #include <errno.h>
00013 
00014 #include "asserts.h"
00015 #include "types.h"
00016 #include "error.h"
00017 #include "estring.h"
00018 #include "fs.h"
00019 #include "tstamp.h"
00020 #include "rconfig.h"
00021 #include "timer.h"
00022 
00023 #include "logger.h"
00024 
00025 // #define ERR_OUT(e)   std::cerr << e
00026 #define ERR_OUT(e)
00027 
00028 #define TEST(code,test) \
00029         thrown = false; \
00030         try { \
00031                 code; \
00032         } \
00033         catch(error e) { \
00034                 ERR_OUT(e); \
00035                 thrown = true; \
00036         } \
00037         catch(...) { \
00038                 assert(0); \
00039         }
00040 
00041 
00042 bool make_dir(const std::string& path)
00043 {
00044         bool thrown;
00045 
00046         thrown = false;
00047         try {
00048                 mk_dir(path);
00049         }
00050         catch(...) {
00051                 thrown = true;
00052         }
00053 
00054         return(thrown == false);
00055 }
00056 
00057 void cleanup(void)
00058 {
00059         assert(system("rm -fr ./test-logger.dir") == 0);
00060 }
00061 
00062 void setup(void)
00063 {
00064         std::ofstream out;
00065 
00066         assert(make_dir("./test-logger.dir"));
00067         assert(make_dir("./test-logger.dir/log.dir"));
00068         assert(make_dir("./test-logger.dir/vault.dir"));
00069 
00070         out.open("./test-logger.dir/rvm.conf");
00071         assert(out.is_open());
00072         out << "log-dir ./test-logger.dir/log.dir" << std::endl;
00073         out << "vault ./test-logger.dir/vault.dir" << std::endl;
00074         out << "<job>" << std::endl;
00075         out << "        archive-path pathname" << std::endl;
00076         out << "        rsync-connection-type local" << std::endl;
00077         out << "        path /var/spool" << std::endl;
00078         out << "</job>" << std::endl;
00079         out.close();
00080 }
00081 
00082 const bool same(std::string s1, std::string s2)
00083 {
00084         s1[11] = 'x'; s2[11] = 'x';
00085         s1[12] = 'x'; s2[12] = 'x';
00086         s1[14] = 'x'; s2[14] = 'x';
00087         s1[15] = 'x'; s2[15] = 'x';
00088         s1[17] = 'x'; s2[17] = 'x';
00089         s1[18] = 'x'; s2[18] = 'x';
00090 
00091         if (s1 == s2) {
00092                 return(true);
00093         }
00094         return(false);
00095 }
00096 
00097 void test(void)
00098 {
00099         char *argv[256] = { 0 };
00100         int argc = 0;
00101         bool thrown;
00102 
00103         thrown = false;
00104         TEST(
00105                 logger.init(),
00106                 assert(e.num() == 0);
00107                 assert(!e.internal());
00108                 assert(e.size() == 1);
00109                 assert(e[0].what() == "Configuration manager is not initialized");
00110                 );
00111         assert(thrown);
00112 
00113         argv[argc++] = "<program>";
00114         argv[argc++] = "--archive";
00115         config.default_file("./test-logger.dir/rvm.conf");
00116         config.init(argc, argv);
00117 
00118         logger.clear();
00119         TEST(logger.init(),);
00120         assert(!thrown);
00121 
00122         logger.write("Testing... ");
00123         logger.write("1... ");
00124         logger.write("2... ");
00125         logger.write("3... ");
00126         logger.write("\n");
00127         logger.write("Testing...\n");
00128         logger.write("1...\n",1);
00129         logger.write("2...\n",2);
00130         logger.write("3...\n",3);
00131         logger.write("Testing...\n1...\n2...\n3...\n",1);
00132         logger.write("PID is ");
00133         logger.write(estring(static_cast<unsigned long>(pid())));
00134         logger.write("\n");
00135         logger.clear();
00136 
00137         std::ifstream in;
00138         std::string filename;
00139         std::string str;
00140         char line[1024];
00141 
00142         filename = "./test-logger.dir/log.dir/";
00143         filename += config.timestamp().str();
00144         filename += ".log";
00145         in.open(filename.c_str());
00146         assert(in.is_open());
00147         
00148         in.get(line,1024);
00149         str = stamp(pid());
00150         str += "Rsync Vault Manager - ";
00151         str += estring(VERSION);
00152         assert(same(str,line));
00153 
00154         in.ignore();
00155 
00156         in.get(line,1024);
00157         str = stamp(pid());
00158         str += "Testing... 1... 2... 3... ";
00159         assert(same(str,line));
00160 
00161         in.ignore();
00162 
00163         in.get(line,1024);
00164         str = stamp(pid());
00165         str += "Testing...";
00166         assert(same(str,line));
00167 
00168         in.ignore();
00169 
00170         in.get(line,1024);
00171         str = stamp(pid());
00172         str += "  1...";
00173         assert(same(str,line));
00174 
00175         in.ignore();
00176 
00177         in.get(line,1024);
00178         str = stamp(pid());
00179         str += "    2...";
00180         assert(same(str,line));
00181 
00182         in.ignore();
00183 
00184         in.get(line,1024);
00185         str = stamp(pid());
00186         str += "      3...";
00187         assert(same(str,line));
00188 
00189         in.ignore();
00190 
00191         in.get(line,1024);
00192         str = stamp(pid());
00193         str += "  Testing...";
00194         assert(same(str,line));
00195 
00196         in.ignore();
00197 
00198         in.get(line,1024);
00199         str = stamp(pid());
00200         str += "  1...";
00201         assert(same(str,line));
00202 
00203         in.ignore();
00204 
00205         in.get(line,1024);
00206         str = stamp(pid());
00207         str += "  2...";
00208         assert(same(str,line));
00209 
00210         in.ignore();
00211 
00212         in.get(line,1024);
00213         str = stamp(pid());
00214         str += "  3...";
00215         assert(same(str,line));
00216 
00217         in.ignore();
00218 
00219         in.get(line,1024);
00220         str = stamp(pid());
00221         str += "PID is ";
00222         str += estring(static_cast<unsigned long>(pid()));
00223         assert(same(str,line));
00224 
00225         in.close();
00226 }
00227 
00228 int main(int argc, char *argv[])
00229 {
00230         cleanup();
00231         setup();
00232         try {
00233                 test();
00234         }
00235         catch(error e) {
00236                 std::cerr << e;
00237                 assert(0);
00238         }
00239         catch(...) {
00240                 std::cerr << err_unknown;
00241                 assert(0);
00242         }
00243         cleanup();
00244         return(0);
00245 }
00246 

Generated on Tue Jul 1 12:09:28 2008 for rvm by  doxygen 1.5.1