mirror of
https://git.tartarus.org/simon/putty.git
synced 2025-01-10 01:48:00 +00:00
test_conf: directly check consistency of conf_key_info.
This is why I wrote conf.h in the form of macros that expanded to named structure field assignments, instead of just filling it with named structure field assignments directly. This way, I can #include the same file again with different macro definitions, and build up a list of what fields were set in what config options. This new code checks that if a config option has a default, then the type of the default matches the declared type of the option value itself. That's what caught the two goofs in the previous commit. This is also the part of test_conf that I _won't_ want to delete once I've finished with the refactoring: it can stay there forever, doing type checking at test time that the compiler isn't doing for me at build time.
This commit is contained in:
parent
30d3b609d3
commit
92594f3e41
@ -766,8 +766,53 @@ void test_simple(void)
|
||||
AUTO, 0, FORCE_OFF, 1, FORCE_ON, 2, -1);
|
||||
}
|
||||
|
||||
void test_conf_key_info(void)
|
||||
{
|
||||
struct test_data {
|
||||
const char *name;
|
||||
bool got_value_type : 1;
|
||||
bool got_subkey_type : 1;
|
||||
bool got_default_int : 1;
|
||||
bool got_default_str : 1;
|
||||
bool got_default_bool : 1;
|
||||
bool got_save_keyword : 1;
|
||||
bool got_storage_enum : 1;
|
||||
};
|
||||
|
||||
#define CONF_OPTION(id, ...) { .name = "CONF_" #id, __VA_ARGS__ },
|
||||
#define VALUE_TYPE(x) .got_value_type = true
|
||||
#define SUBKEY_TYPE(x) .got_subkey_type = true
|
||||
#define DEFAULT_INT(x) .got_default_int = true
|
||||
#define DEFAULT_STR(x) .got_default_str = true
|
||||
#define DEFAULT_BOOL(x) .got_default_bool = true
|
||||
#define SAVE_KEYWORD(x) .got_save_keyword = true
|
||||
#define STORAGE_ENUM(x) .got_storage_enum = true
|
||||
|
||||
static const struct test_data conf_key_test_data[] = {
|
||||
#include "conf.h"
|
||||
};
|
||||
|
||||
for (size_t key = 0; key < N_CONFIG_OPTIONS; key++) {
|
||||
const ConfKeyInfo *info = &conf_key_info[key];
|
||||
const struct test_data *td = &conf_key_test_data[key];
|
||||
|
||||
if (!td->got_value_type) {
|
||||
fprintf(stderr, "%s: no value type\n", td->name);
|
||||
nfails++;
|
||||
}
|
||||
|
||||
if ((td->got_default_int && info->value_type != CONF_TYPE_INT) ||
|
||||
(td->got_default_str && info->value_type != CONF_TYPE_STR) ||
|
||||
(td->got_default_bool && info->value_type != CONF_TYPE_BOOL)) {
|
||||
fprintf(stderr, "%s: default doesn't match type\n", td->name);
|
||||
nfails++;
|
||||
}
|
||||
}
|
||||
}
|
||||
|
||||
int main(void)
|
||||
{
|
||||
test_simple();
|
||||
test_conf_key_info();
|
||||
return nfails != 0;
|
||||
}
|
||||
|
Loading…
Reference in New Issue
Block a user