2017-12-04 05:46:34 +00:00
|
|
|
/*
|
|
|
|
Examplar - An automation and testing framework.
|
|
|
|
|
|
|
|
© SURRO INDUSTRIES and Chris Punches, 2017.
|
|
|
|
|
|
|
|
This program is free software: you can redistribute it and/or modify
|
|
|
|
it under the terms of the GNU Affero 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 Affero General Public License for more details.
|
|
|
|
|
|
|
|
You should have received a copy of the GNU Affero General Public License
|
|
|
|
along with this program. If not, see <https://www.gnu.org/licenses/>.
|
|
|
|
|
|
|
|
*/
|
2017-12-05 04:25:48 +00:00
|
|
|
|
2017-04-18 23:04:21 +00:00
|
|
|
#include <iostream>
|
|
|
|
#include "src/json/json.h"
|
2017-04-22 12:07:11 +00:00
|
|
|
#include "src/loaders/loaders.h"
|
2017-12-06 00:25:51 +00:00
|
|
|
#include <unistd.h>
|
2017-12-06 04:09:33 +00:00
|
|
|
#include <getopt.h>
|
2017-12-06 00:25:51 +00:00
|
|
|
#include <syslog.h>
|
2017-12-08 03:37:42 +00:00
|
|
|
#include "src/loaders/helpers.h"
|
2017-04-18 23:04:21 +00:00
|
|
|
|
2017-12-05 07:28:52 +00:00
|
|
|
/*
|
|
|
|
* TODO Commandline switches
|
|
|
|
*/
|
|
|
|
|
2017-12-06 00:25:51 +00:00
|
|
|
void print_usage()
|
|
|
|
{
|
2017-12-08 03:37:42 +00:00
|
|
|
printf("examplar [ -h | --help ] [ -v | --verbose ] [ -e | --execution-context EXECUTION_CONTEXT ][ -c | --config CONFIG_PATH ]\n\n");
|
2017-12-06 00:25:51 +00:00
|
|
|
}
|
2017-12-05 07:28:52 +00:00
|
|
|
|
2017-12-08 03:37:42 +00:00
|
|
|
|
|
|
|
|
|
|
|
|
2017-12-06 00:25:51 +00:00
|
|
|
int main( int argc, char * argv[] )
|
2017-04-18 23:04:21 +00:00
|
|
|
{
|
2017-12-06 00:25:51 +00:00
|
|
|
int flags, opt;
|
|
|
|
bool verbose = false;
|
|
|
|
bool show_help = false;
|
2017-12-08 03:37:42 +00:00
|
|
|
|
|
|
|
// indicator of whether examplar should use a commandline argument for overriding the context
|
|
|
|
// instead of what's supplied in the conf file
|
|
|
|
bool cli_context_supplied = false;
|
|
|
|
|
2017-12-06 00:25:51 +00:00
|
|
|
std::string config_path = "/etc/Examplar/config.json";
|
2017-12-08 03:37:42 +00:00
|
|
|
std::string execution_context;
|
2017-12-06 00:25:51 +00:00
|
|
|
|
|
|
|
// commandline switches:
|
|
|
|
// -h help
|
|
|
|
// -v verbose
|
|
|
|
// -c CONFIG_FILE_PATH -- defaults to '/etc/Examplar/config.json'
|
2017-12-08 03:37:42 +00:00
|
|
|
// -e EXECUTION_CONTEXT -- current working directory when executing unit targets
|
2017-12-06 00:25:51 +00:00
|
|
|
|
2017-12-06 04:09:33 +00:00
|
|
|
while (1)
|
2017-12-06 00:25:51 +00:00
|
|
|
{
|
2017-12-06 04:09:33 +00:00
|
|
|
static struct option long_options[] =
|
2017-12-06 00:25:51 +00:00
|
|
|
{
|
2017-12-08 03:37:42 +00:00
|
|
|
{"verbose", no_argument, 0, 'v'},
|
|
|
|
{"help", no_argument, 0, 'h'},
|
|
|
|
{"config", required_argument, 0, 'c'},
|
|
|
|
{"execution-context", required_argument, 0, 'e'},
|
2017-12-06 04:09:33 +00:00
|
|
|
{0, 0}
|
|
|
|
};
|
2017-12-08 03:37:42 +00:00
|
|
|
|
2017-12-06 04:09:33 +00:00
|
|
|
int option_index = 0;
|
|
|
|
|
2017-12-08 03:37:42 +00:00
|
|
|
opt = getopt_long (argc, argv, "vhec:", long_options, &option_index);
|
2017-12-06 04:09:33 +00:00
|
|
|
|
|
|
|
if (opt == -1)
|
|
|
|
break;
|
|
|
|
|
|
|
|
switch (opt)
|
|
|
|
{
|
|
|
|
case 0:
|
|
|
|
if (long_options[option_index].flag !=0)
|
|
|
|
break;
|
2017-12-06 00:25:51 +00:00
|
|
|
case 'h':
|
|
|
|
show_help = true;
|
|
|
|
case 'v':
|
|
|
|
verbose = true;
|
|
|
|
break;
|
|
|
|
case 'c':
|
|
|
|
config_path = std::string(optarg);
|
|
|
|
break;
|
2017-12-06 04:40:57 +00:00
|
|
|
case '?':
|
|
|
|
print_usage();
|
|
|
|
exit(1);
|
2017-12-08 03:37:42 +00:00
|
|
|
case 'e':
|
|
|
|
cli_context_supplied = true;
|
|
|
|
execution_context = std::string(optarg);
|
|
|
|
break;
|
2017-12-06 00:25:51 +00:00
|
|
|
default:
|
|
|
|
break;
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
if ( show_help == true )
|
|
|
|
{
|
|
|
|
print_usage();
|
2017-12-06 04:40:57 +00:00
|
|
|
exit(0);
|
2017-12-06 00:25:51 +00:00
|
|
|
}
|
|
|
|
|
|
|
|
setlogmask( LOG_UPTO( LOG_INFO ) );
|
|
|
|
|
|
|
|
openlog( "Examplar", LOG_CONS | LOG_PID | LOG_NDELAY, LOG_PERROR | LOG_LOCAL1 );
|
|
|
|
|
2017-04-29 21:35:03 +00:00
|
|
|
// A Plan is made up of Tasks, and a Suite is made up of Units.
|
|
|
|
// A Plan declares what units are executed and a Suite declares the definitions of those units.
|
2017-12-06 00:25:51 +00:00
|
|
|
Conf configuration = Conf(config_path, verbose );
|
2017-04-19 05:50:34 +00:00
|
|
|
|
2017-12-08 03:37:42 +00:00
|
|
|
// if the user set this option as a commandline argument
|
|
|
|
if ( cli_context_supplied == true )
|
|
|
|
{
|
|
|
|
// override the conf file's specified execution context
|
|
|
|
configuration.set_execution_context( execution_context );
|
|
|
|
}
|
|
|
|
|
|
|
|
// check if context override
|
|
|
|
if ( configuration.has_context_override() )
|
|
|
|
{
|
|
|
|
// if so, set the CWD.
|
|
|
|
chdir( configuration.get_execution_context().c_str() );
|
|
|
|
std::ostringstream infostring;
|
|
|
|
infostring << "Execution context: " << get_working_path() << std::endl;
|
|
|
|
syslog(LOG_INFO, infostring.str().c_str() );
|
|
|
|
std::cout << infostring.str();
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
// load the filepaths to definitions of a plan and definitions of units.
|
2017-04-29 21:35:03 +00:00
|
|
|
std::string definitions_file = configuration.get_units_path();
|
|
|
|
std::string plan_file = configuration.get_plan_path();
|
2017-04-19 06:27:54 +00:00
|
|
|
|
2017-06-18 14:39:46 +00:00
|
|
|
Suite available_definitions;
|
2017-06-23 19:24:11 +00:00
|
|
|
available_definitions.load_units_file( definitions_file, verbose );
|
2017-06-11 19:14:45 +00:00
|
|
|
|
2017-12-08 03:37:42 +00:00
|
|
|
Plan plan( &configuration );
|
2017-06-25 06:28:22 +00:00
|
|
|
plan.load_plan_file( plan_file, verbose );
|
2017-06-11 19:14:45 +00:00
|
|
|
|
2017-06-25 22:50:14 +00:00
|
|
|
plan.load_definitions( available_definitions, verbose );
|
2017-04-19 05:50:34 +00:00
|
|
|
|
2017-06-27 02:27:24 +00:00
|
|
|
std::cout << "Ready to execute all tasks in Plan." << std::endl;
|
|
|
|
|
2017-12-05 06:13:23 +00:00
|
|
|
try
|
|
|
|
{
|
2017-12-04 02:15:41 +00:00
|
|
|
plan.execute( verbose );
|
|
|
|
}
|
2017-12-05 06:13:23 +00:00
|
|
|
|
|
|
|
catch ( std::exception& e)
|
|
|
|
{
|
2017-12-04 02:15:41 +00:00
|
|
|
std::cerr << e.what() << std::endl;
|
2017-12-06 00:25:51 +00:00
|
|
|
syslog( LOG_ERR, e.what() );
|
|
|
|
closelog();
|
2017-12-05 06:13:23 +00:00
|
|
|
return 1;
|
2017-12-04 02:15:41 +00:00
|
|
|
}
|
2017-06-27 02:27:24 +00:00
|
|
|
|
2017-12-06 00:25:51 +00:00
|
|
|
closelog();
|
2017-04-18 23:04:21 +00:00
|
|
|
return 0;
|
2017-12-06 04:09:33 +00:00
|
|
|
}
|