2017-05-19 22:22:40 +02:00
|
|
|
/*****************************************************************************
|
|
|
|
*
|
|
|
|
* This program is free software: you can redistribute it and/or modify
|
|
|
|
* it under the terms of the GNU General Public License as published by
|
|
|
|
* the Free Software Foundation, either version 3 of the License, or
|
|
|
|
* (at your option) any later version.
|
|
|
|
*
|
|
|
|
* This program is distributed in the hope that it will be useful,
|
|
|
|
* but WITHOUT ANY WARRANTY; without even the implied warranty of
|
|
|
|
* MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
|
|
|
|
* GNU General Public License for more details.
|
|
|
|
*
|
|
|
|
* You should have received a copy of the GNU General Public License
|
|
|
|
* along with this program. If not, see <http://www.gnu.org/licenses/>.
|
|
|
|
*
|
|
|
|
*
|
|
|
|
*****************************************************************************/
|
|
|
|
|
|
|
|
#define NSCORE 1
|
|
|
|
#include "config.h"
|
|
|
|
#include "nagios.h"
|
|
|
|
#include "objects.h"
|
|
|
|
#include "tap.h"
|
2017-05-19 23:37:19 +02:00
|
|
|
#include "stub_broker.c"
|
|
|
|
#include "stub_xodtemplate.c"
|
2017-05-19 22:22:40 +02:00
|
|
|
|
|
|
|
#define TEST_LOGGING 1
|
|
|
|
|
2019-04-18 17:09:18 +02:00
|
|
|
int date_format = 0;
|
|
|
|
char *log_file = NULL;
|
|
|
|
int verify_config = FALSE;
|
|
|
|
int test_scheduling = FALSE;
|
|
|
|
int debug_level = DEFAULT_DEBUG_LEVEL;
|
|
|
|
char *debug_file = NULL;
|
|
|
|
int debug_verbosity = DEFAULT_DEBUG_VERBOSITY;
|
2017-05-19 23:37:19 +02:00
|
|
|
unsigned long max_debug_file_size = DEFAULT_MAX_DEBUG_FILE_SIZE;
|
2019-04-18 17:09:18 +02:00
|
|
|
int use_syslog = DEFAULT_USE_SYSLOG;
|
|
|
|
unsigned long syslog_options = 0;
|
|
|
|
unsigned long logging_options = 0;
|
|
|
|
int log_initial_states = DEFAULT_LOG_INITIAL_STATES;
|
|
|
|
char *log_archive_path = "var";
|
|
|
|
int log_current_states = DEFAULT_LOG_CURRENT_STATES;
|
|
|
|
int log_service_retries = DEFAULT_LOG_SERVICE_RETRIES;
|
|
|
|
int use_large_installation_tweaks = DEFAULT_USE_LARGE_INSTALLATION_TWEAKS;
|
|
|
|
|
2017-05-19 22:22:40 +02:00
|
|
|
|
|
|
|
char *saved_source;
|
|
|
|
char *saved_dest;
|
2019-04-18 17:09:18 +02:00
|
|
|
int my_rename(char *source, char *dest)
|
|
|
|
{
|
|
|
|
char *temp = "renamefailure";
|
|
|
|
saved_source = strdup(source);
|
|
|
|
saved_dest = strdup(dest);
|
|
|
|
|
|
|
|
if(strcmp(source, "renamefailure") == 0) {
|
|
|
|
return ERROR;
|
|
|
|
}
|
|
|
|
|
|
|
|
return rename(source, dest);
|
|
|
|
}
|
|
|
|
|
|
|
|
void free_my_saved_chars()
|
|
|
|
{
|
|
|
|
my_free(saved_source);
|
|
|
|
my_free(saved_dest);
|
|
|
|
}
|
|
|
|
|
|
|
|
void update_program_status()
|
|
|
|
{ }
|
|
|
|
|
|
|
|
int main(int argc, char **argv)
|
|
|
|
{
|
|
|
|
time_t rotation_time;
|
|
|
|
struct stat stat_info, stat_new;
|
|
|
|
char *log_filename_localtime = NULL;
|
|
|
|
char *temp_command = NULL;
|
|
|
|
struct tm *t;
|
|
|
|
|
|
|
|
plan_tests(14);
|
|
|
|
|
|
|
|
rotation_time = (time_t)1242949698;
|
|
|
|
t = localtime(&rotation_time);
|
|
|
|
|
|
|
|
asprintf(&log_filename_localtime, "var/nagios-%02d-%02d-%d-%02d.log", t->tm_mon + 1, t->tm_mday, t->tm_year + 1900, t->tm_hour);
|
|
|
|
|
|
|
|
log_rotation_method = 5;
|
|
|
|
ok(rotate_log_file(rotation_time) == ERROR, "Got error for a bad log_rotation_method");
|
|
|
|
free_my_saved_chars();
|
|
|
|
|
|
|
|
log_file = "renamefailure";
|
|
|
|
log_rotation_method = LOG_ROTATION_HOURLY;
|
|
|
|
ok(rotate_log_file(rotation_time) == ERROR, "Got an error with rename");
|
|
|
|
ok(strcmp(saved_dest, log_filename_localtime) == 0, "Got an hourly rotation");
|
|
|
|
unlink(log_file);
|
|
|
|
free_my_saved_chars();
|
|
|
|
|
|
|
|
log_file = "var/nagios.log";
|
|
|
|
log_rotation_method = LOG_ROTATION_HOURLY;
|
|
|
|
ok(system("cp var/nagios.log.dummy var/nagios.log") == 0, "Copied in dummy nagios.log for archiving");
|
|
|
|
ok(rotate_log_file(rotation_time) == OK, "Log rotation should work happily");
|
|
|
|
free_my_saved_chars();
|
|
|
|
|
|
|
|
system("diff var/nagios.log var/nagios.log.expected > var/nagios.log.diff");
|
|
|
|
ok(system("diff var/nagios.log.diff var/nagios.log.diff.expected > /dev/null") == 0, "Got correct contents of nagios.log");
|
|
|
|
unlink("var/nagios.log.diff");
|
|
|
|
|
|
|
|
asprintf(&temp_command, "diff var/nagios.log.dummy %s", log_filename_localtime);
|
|
|
|
ok(system(temp_command) == 0, "nagios log archived correctly");
|
|
|
|
my_free(temp_command);
|
|
|
|
|
|
|
|
unlink(log_filename_localtime);
|
|
|
|
ok(system("chmod 777 var/nagios.log") == 0, "Changed mode of nagios.log");
|
|
|
|
ok(stat("var/nagios.log", &stat_info) == 0, "Got stat info for log file");
|
|
|
|
ok(rotate_log_file(rotation_time) == OK, "Log rotate to check if mode is retained");
|
|
|
|
free_my_saved_chars();
|
|
|
|
ok(stat(log_filename_localtime, &stat_new) == 0, "Got new stat info for archived log file");
|
|
|
|
ok(stat_info.st_mode == stat_new.st_mode, "Mode for archived file same as original log file");
|
|
|
|
|
|
|
|
ok(stat("var/nagios.log", &stat_new) == 0, "Got new stat info for new log file");
|
|
|
|
ok(stat_info.st_mode == stat_new.st_mode, "Mode for new log file kept same as original log file");
|
|
|
|
unlink(log_filename_localtime);
|
|
|
|
|
|
|
|
my_free(log_filename_localtime);
|
|
|
|
close_log_file();
|
|
|
|
|
|
|
|
return exit_status();
|
|
|
|
}
|