2012-06-16 11:02:48 +02:00
|
|
|
/* file minunit_example.c */
|
|
|
|
#include <stdio.h>
|
|
|
|
#include <stdlib.h>
|
|
|
|
#include <time.h>
|
|
|
|
#include <limits.h>
|
2012-11-18 22:16:49 +01:00
|
|
|
#include <signal.h>
|
2017-03-19 13:43:55 -04:00
|
|
|
#include <stdbool.h>
|
2014-06-23 10:24:03 +02:00
|
|
|
#include <sys/utsname.h>
|
2012-08-23 22:32:49 +02:00
|
|
|
#include "global.h"
|
2012-06-16 11:02:48 +02:00
|
|
|
#include "mbpfan.h"
|
2012-08-22 15:05:52 +02:00
|
|
|
#include "settings.h"
|
2018-08-15 13:14:35 -07:00
|
|
|
#include "main.h"
|
2012-06-16 11:02:48 +02:00
|
|
|
#include "minunit.h"
|
|
|
|
|
|
|
|
int tests_run = 0;
|
|
|
|
|
2019-10-30 16:04:51 -07:00
|
|
|
static void free_fans(t_fans* fans)
|
|
|
|
{
|
|
|
|
while (fans != NULL) {
|
|
|
|
t_fans* tmp = fans->next;
|
|
|
|
free(fans->fan_manual_path);
|
|
|
|
free(fans->fan_output_path);
|
|
|
|
free(fans->label);
|
|
|
|
free(fans);
|
|
|
|
fans = tmp;
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
static void free_sensors(t_sensors* sensors)
|
|
|
|
{
|
|
|
|
while (sensors != NULL) {
|
|
|
|
t_sensors* tmp = sensors->next;
|
|
|
|
free(sensors->path);
|
|
|
|
free(sensors);
|
|
|
|
sensors = tmp;
|
|
|
|
}
|
|
|
|
}
|
2012-06-16 11:02:48 +02:00
|
|
|
|
2012-08-23 22:32:49 +02:00
|
|
|
static const char *test_sensor_paths()
|
2012-06-16 11:02:48 +02:00
|
|
|
{
|
2012-08-22 15:05:52 +02:00
|
|
|
t_sensors* sensors = retrieve_sensors();
|
|
|
|
mu_assert("No sensors found", sensors != NULL);
|
|
|
|
t_sensors* tmp = sensors;
|
2012-08-23 22:32:49 +02:00
|
|
|
|
2012-08-22 15:05:52 +02:00
|
|
|
while(tmp != NULL) {
|
|
|
|
mu_assert("Sensor does not have a valid path", tmp->path != NULL);
|
2012-08-23 22:32:49 +02:00
|
|
|
|
|
|
|
if(tmp->path != NULL) {
|
2012-08-22 15:05:52 +02:00
|
|
|
mu_assert("Sensor does not have valid temperature", tmp->temperature > 0);
|
2012-08-23 22:32:49 +02:00
|
|
|
}
|
|
|
|
|
2012-08-22 15:05:52 +02:00
|
|
|
tmp = tmp->next;
|
2012-06-16 11:02:48 +02:00
|
|
|
}
|
2012-08-23 22:32:49 +02:00
|
|
|
|
2019-10-30 16:04:51 -07:00
|
|
|
free_sensors(sensors);
|
2012-08-22 15:05:52 +02:00
|
|
|
return 0;
|
2012-06-16 11:02:48 +02:00
|
|
|
}
|
|
|
|
|
|
|
|
|
2012-08-23 22:32:49 +02:00
|
|
|
static const char *test_fan_paths()
|
2012-06-16 11:02:48 +02:00
|
|
|
{
|
2012-10-24 11:13:25 +02:00
|
|
|
t_fans* fans = retrieve_fans();
|
|
|
|
mu_assert("No fans found", fans != NULL);
|
|
|
|
t_fans* tmp = fans;
|
2012-08-22 15:05:52 +02:00
|
|
|
int found_fan_path = 0;
|
2012-08-23 22:32:49 +02:00
|
|
|
|
2012-08-22 15:05:52 +02:00
|
|
|
while(tmp != NULL) {
|
2012-08-23 22:32:49 +02:00
|
|
|
if(tmp->fan_output_path != NULL) {
|
2012-08-22 15:05:52 +02:00
|
|
|
found_fan_path++;
|
2012-08-23 22:32:49 +02:00
|
|
|
}
|
|
|
|
|
2012-08-22 15:05:52 +02:00
|
|
|
tmp = tmp->next;
|
2012-06-16 11:02:48 +02:00
|
|
|
}
|
2012-08-23 22:32:49 +02:00
|
|
|
|
2012-08-22 15:05:52 +02:00
|
|
|
mu_assert("No fans found", found_fan_path != 0);
|
2019-10-30 16:04:51 -07:00
|
|
|
free_fans(fans);
|
2012-08-22 15:05:52 +02:00
|
|
|
return 0;
|
2012-06-16 11:02:48 +02:00
|
|
|
}
|
|
|
|
|
|
|
|
unsigned time_seed()
|
|
|
|
{
|
2012-08-22 15:05:52 +02:00
|
|
|
time_t now = time ( 0 );
|
|
|
|
unsigned char *p = (unsigned char *)&now;
|
|
|
|
unsigned seed = 0;
|
|
|
|
size_t i;
|
2012-08-23 22:32:49 +02:00
|
|
|
|
|
|
|
for ( i = 0; i < sizeof now; i++ ) {
|
2012-08-22 15:05:52 +02:00
|
|
|
seed = seed * ( UCHAR_MAX + 2U ) + p[i];
|
2012-08-23 22:32:49 +02:00
|
|
|
}
|
|
|
|
|
2012-08-22 15:05:52 +02:00
|
|
|
return seed;
|
2012-06-16 11:02:48 +02:00
|
|
|
}
|
|
|
|
|
|
|
|
// nothing better than a horrible piece of code to
|
|
|
|
// stress a little bit the CPU
|
|
|
|
int stress(int n)
|
|
|
|
{
|
2012-08-22 15:05:52 +02:00
|
|
|
int f = n;
|
2012-08-23 22:32:49 +02:00
|
|
|
|
2012-08-22 15:05:52 +02:00
|
|
|
while (f > 0) {
|
|
|
|
while(n > 0) {
|
|
|
|
srand ( time_seed() );
|
|
|
|
n--;
|
2012-06-16 11:02:48 +02:00
|
|
|
}
|
2012-08-23 22:32:49 +02:00
|
|
|
|
2012-08-22 15:05:52 +02:00
|
|
|
f--;
|
|
|
|
n = f;
|
2012-06-16 11:02:48 +02:00
|
|
|
}
|
2016-11-18 14:16:59 -05:00
|
|
|
return 0;
|
2012-06-16 11:02:48 +02:00
|
|
|
}
|
|
|
|
|
2012-08-23 22:32:49 +02:00
|
|
|
static const char *test_get_temp()
|
2012-06-16 11:02:48 +02:00
|
|
|
{
|
2012-08-22 15:05:52 +02:00
|
|
|
t_sensors* sensors = retrieve_sensors();
|
|
|
|
mu_assert("No sensors found", sensors != NULL);
|
|
|
|
unsigned short temp_1 = get_temp(sensors);
|
|
|
|
mu_assert("Invalid Global Temperature Found", temp_1 > 1 && temp_1 < 150);
|
|
|
|
stress(2000);
|
|
|
|
unsigned short temp_2 = get_temp(sensors);
|
|
|
|
mu_assert("Invalid Higher temp test (if fan was already spinning high, this is not worrying)", temp_1 < temp_2);
|
2019-10-30 16:04:51 -07:00
|
|
|
free_sensors(sensors);
|
2012-08-22 15:05:52 +02:00
|
|
|
return 0;
|
|
|
|
}
|
|
|
|
|
2012-08-23 22:32:49 +02:00
|
|
|
static const char *test_config_file()
|
2012-08-22 15:05:52 +02:00
|
|
|
{
|
|
|
|
FILE *f = NULL;
|
|
|
|
Settings *settings = NULL;
|
|
|
|
f = fopen("/etc/mbpfan.conf", "r");
|
|
|
|
mu_assert("No config file found", f != NULL);
|
|
|
|
|
2012-08-23 22:32:49 +02:00
|
|
|
if (f == NULL) {
|
2012-08-22 15:05:52 +02:00
|
|
|
return 0;
|
2012-08-23 22:32:49 +02:00
|
|
|
}
|
2012-08-22 15:05:52 +02:00
|
|
|
|
|
|
|
settings = settings_open(f);
|
|
|
|
fclose(f);
|
|
|
|
mu_assert("Could not read settings from config file", settings != NULL);
|
2012-08-23 22:32:49 +02:00
|
|
|
|
|
|
|
if (settings == NULL) {
|
2012-08-22 15:05:52 +02:00
|
|
|
return 0;
|
2012-08-23 22:32:49 +02:00
|
|
|
}
|
2012-08-22 15:05:52 +02:00
|
|
|
|
|
|
|
mu_assert("Could not read low_temp from config file",settings_get_int(settings, "general", "low_temp") != 0);
|
|
|
|
mu_assert("Could not read high_temp from config file",settings_get_int(settings, "general", "high_temp") != 0);
|
|
|
|
mu_assert("Could not read max_temp from config file",settings_get_int(settings, "general", "max_temp") != 0);
|
|
|
|
mu_assert("Could not read polling_interval from config file",settings_get_int(settings, "general", "polling_interval") != 0);
|
|
|
|
/* Destroy the settings object */
|
|
|
|
settings_delete(settings);
|
|
|
|
|
|
|
|
return 0;
|
2012-06-16 11:02:48 +02:00
|
|
|
}
|
|
|
|
|
2012-11-18 22:16:49 +01:00
|
|
|
static const char *test_settings()
|
|
|
|
{
|
2019-01-18 20:26:11 +01:00
|
|
|
t_fans* fan = (t_fans *) malloc( sizeof( t_fans ) );
|
|
|
|
fan->fan_id = 1;
|
|
|
|
fan->fan_max_speed = -1;
|
|
|
|
fan->next = NULL;
|
|
|
|
|
|
|
|
retrieve_settings("./mbpfan.conf.test1", fan);
|
|
|
|
mu_assert("max_fan_speed value is not 6200", fan->fan_max_speed == 6200);
|
2019-01-18 11:32:16 -08:00
|
|
|
mu_assert("polling_interval is not 2", polling_interval == 2);
|
2019-01-18 20:26:11 +01:00
|
|
|
|
|
|
|
fan->fan_min_speed = -1;
|
|
|
|
retrieve_settings("./mbpfan.conf.test0", fan);
|
|
|
|
mu_assert("min_fan_speed value is not 2000", fan->fan_min_speed == 2000);
|
2012-11-18 22:16:49 +01:00
|
|
|
mu_assert("polling_interval is not 7", polling_interval == 7);
|
2019-01-18 20:26:11 +01:00
|
|
|
|
|
|
|
t_fans* fan2 = (t_fans *)malloc(sizeof(t_fans));
|
|
|
|
fan2->fan_id = 2;
|
|
|
|
fan2->fan_max_speed = -1;
|
2019-10-30 16:04:33 -07:00
|
|
|
fan2->next = NULL;
|
2019-01-18 20:26:11 +01:00
|
|
|
fan->next = fan2;
|
|
|
|
|
|
|
|
retrieve_settings("./mbpfan.conf.test2", fan);
|
|
|
|
mu_assert("min_fan1_speed value is not 2000", fan->fan_min_speed == 2000);
|
|
|
|
mu_assert("min_fan2_speed value is not 2000", fan->next->fan_min_speed == 2000);
|
|
|
|
|
|
|
|
free(fan2);
|
|
|
|
fan->next = NULL;
|
|
|
|
free(fan);
|
|
|
|
|
2012-11-18 22:16:49 +01:00
|
|
|
return 0;
|
|
|
|
|
2019-01-18 20:26:11 +01:00
|
|
|
}
|
2012-11-18 22:16:49 +01:00
|
|
|
int received = 0;
|
|
|
|
|
|
|
|
static void handler(int signal)
|
|
|
|
{
|
2019-01-18 20:26:11 +01:00
|
|
|
t_fans* fan = (t_fans *) malloc( sizeof( t_fans ) );
|
|
|
|
fan->fan_id = 1;
|
|
|
|
fan->next = NULL;
|
|
|
|
|
2012-11-18 22:16:49 +01:00
|
|
|
|
|
|
|
switch(signal) {
|
|
|
|
case SIGHUP:
|
|
|
|
received = 1;
|
2019-01-18 20:26:11 +01:00
|
|
|
retrieve_settings("./mbpfan.conf.test1", fan);
|
|
|
|
free(fan);
|
2012-11-18 22:16:49 +01:00
|
|
|
break;
|
2014-06-22 16:48:44 +02:00
|
|
|
|
2012-11-18 22:16:49 +01:00
|
|
|
default:
|
|
|
|
received = 0;
|
2019-01-18 20:26:11 +01:00
|
|
|
free(fan);
|
2012-11-18 22:16:49 +01:00
|
|
|
break;
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
static const char *test_sighup_receive()
|
|
|
|
{
|
|
|
|
signal(SIGHUP, handler);
|
|
|
|
raise(SIGHUP);
|
|
|
|
mu_assert("did not receive SIGHUP signal", received == 1);
|
|
|
|
return 0;
|
|
|
|
}
|
|
|
|
|
|
|
|
static const char *test_settings_reload()
|
|
|
|
{
|
2019-01-18 20:26:11 +01:00
|
|
|
t_fans* fan = (t_fans *) malloc( sizeof( t_fans ) );
|
|
|
|
fan->fan_id = 1;
|
2019-10-30 16:04:33 -07:00
|
|
|
fan->fan_min_speed = -1;
|
2019-10-30 16:04:51 -07:00
|
|
|
fan->fan_manual_path = NULL;
|
|
|
|
fan->fan_output_path = NULL;
|
|
|
|
fan->label = NULL;
|
2019-01-18 20:26:11 +01:00
|
|
|
fan->next = NULL;
|
|
|
|
|
2012-11-18 22:16:49 +01:00
|
|
|
signal(SIGHUP, handler);
|
2019-01-18 20:26:11 +01:00
|
|
|
retrieve_settings("./mbpfan.conf", fan);
|
2016-08-29 10:00:27 +02:00
|
|
|
printf("Testing the _supplied_ mbpfan.conf (not the one you are using)..\n");
|
2018-09-13 10:29:48 -07:00
|
|
|
// cannot tests min_fan_speed since it is not set and thus auto-detected
|
2019-01-18 11:32:16 -08:00
|
|
|
mu_assert("polling_interval is not 1 before SIGHUP", polling_interval == 1);
|
2012-11-18 22:16:49 +01:00
|
|
|
raise(SIGHUP);
|
2019-01-18 20:26:11 +01:00
|
|
|
mu_assert("min_fan_speed value is not 6200 after SIGHUP", fan->fan_min_speed == 6200);
|
2019-01-18 11:32:16 -08:00
|
|
|
mu_assert("polling_interval is not 2 after SIGHUP", polling_interval == 2);
|
2019-01-18 20:26:11 +01:00
|
|
|
retrieve_settings("./mbpfan.conf", fan);
|
2019-10-30 16:04:51 -07:00
|
|
|
free_fans(fan);
|
2012-11-18 22:16:49 +01:00
|
|
|
return 0;
|
|
|
|
}
|
|
|
|
|
2012-06-16 11:02:48 +02:00
|
|
|
|
2012-08-23 22:32:49 +02:00
|
|
|
static const char *all_tests()
|
2012-06-16 11:02:48 +02:00
|
|
|
{
|
2012-08-22 15:05:52 +02:00
|
|
|
mu_run_test(test_sensor_paths);
|
|
|
|
mu_run_test(test_fan_paths);
|
|
|
|
mu_run_test(test_get_temp);
|
|
|
|
mu_run_test(test_config_file);
|
2012-11-18 22:16:49 +01:00
|
|
|
mu_run_test(test_settings);
|
|
|
|
mu_run_test(test_sighup_receive);
|
|
|
|
mu_run_test(test_settings_reload);
|
2012-08-22 15:05:52 +02:00
|
|
|
return 0;
|
2012-06-16 11:02:48 +02:00
|
|
|
}
|
|
|
|
|
|
|
|
int tests()
|
|
|
|
{
|
2018-08-15 13:14:35 -07:00
|
|
|
check_requirements();
|
|
|
|
|
2012-08-22 15:05:52 +02:00
|
|
|
printf("Starting the tests..\n");
|
|
|
|
printf("It is normal for them to take a bit to finish.\n");
|
2015-05-05 16:54:41 +02:00
|
|
|
|
2012-08-23 22:32:49 +02:00
|
|
|
const char *result = all_tests();
|
|
|
|
|
2012-08-22 15:05:52 +02:00
|
|
|
if (result != 0) {
|
2018-09-13 10:06:52 -07:00
|
|
|
printf("Error: %s \n", result);
|
2012-08-23 22:32:49 +02:00
|
|
|
|
2012-08-22 15:05:52 +02:00
|
|
|
} else {
|
|
|
|
printf("ALL TESTS PASSED\n");
|
2012-06-16 11:02:48 +02:00
|
|
|
}
|
2012-08-23 22:32:49 +02:00
|
|
|
|
2012-08-22 15:05:52 +02:00
|
|
|
printf("Tests run: %d\n", tests_run);
|
2012-06-16 11:02:48 +02:00
|
|
|
|
2012-08-22 15:05:52 +02:00
|
|
|
return result != 0;
|
2015-05-05 16:54:41 +02:00
|
|
|
}
|