2
0
mirror of https://github.com/sudo-project/sudo.git synced 2025-08-22 09:57:41 +00:00
sudo/plugins/sudoers/regress/parser/check_hexchar.c

82 lines
2.5 KiB
C
Raw Normal View History

2014-09-03 10:31:47 -06:00
/*
2019-04-29 07:21:51 -06:00
* SPDX-License-Identifier: ISC
*
2017-12-03 17:53:40 -07:00
* Copyright (c) 2014-2015 Todd C. Miller <Todd.Miller@sudo.ws>
2014-09-03 10:31:47 -06:00
*
* Permission to use, copy, modify, and distribute this software for any
* purpose with or without fee is hereby granted, provided that the above
* copyright notice and this permission notice appear in all copies.
*
* THE SOFTWARE IS PROVIDED "AS IS" AND THE AUTHOR DISCLAIMS ALL WARRANTIES
* WITH REGARD TO THIS SOFTWARE INCLUDING ALL IMPLIED WARRANTIES OF
* MERCHANTABILITY AND FITNESS. IN NO EVENT SHALL THE AUTHOR BE LIABLE FOR
* ANY SPECIAL, DIRECT, INDIRECT, OR CONSEQUENTIAL DAMAGES OR ANY DAMAGES
* WHATSOEVER RESULTING FROM LOSS OF USE, DATA OR PROFITS, WHETHER IN AN
* ACTION OF CONTRACT, NEGLIGENCE OR OTHER TORTIOUS ACTION, ARISING OUT OF
* OR IN CONNECTION WITH THE USE OR PERFORMANCE OF THIS SOFTWARE.
*/
#include <config.h>
#include <stdio.h>
#include <stdlib.h>
#include <string.h>
2014-09-03 10:31:47 -06:00
#define SUDO_ERROR_WRAP 0
#include "sudo_compat.h"
2017-11-28 09:06:44 -07:00
#include "sudo_util.h"
2014-09-03 10:31:47 -06:00
int hexchar(const char *s);
sudo_dso_public int main(int argc, char *argv[]);
2014-09-03 10:31:47 -06:00
struct hexchar_test {
char hex[3];
int value;
};
int
main(int argc, char *argv[])
{
struct hexchar_test *test_data;
int i, ntests, result, errors = 0;
static const char xdigs_lower[] = "0123456789abcdef";
static const char xdigs_upper[] = "0123456789ABCDEF";
2014-09-03 10:31:47 -06:00
2017-11-28 09:06:44 -07:00
initprogname(argc > 0 ? argv[0] : "check_hexchar");
2014-09-03 10:31:47 -06:00
/* Build up test data. */
ntests = 256 + 256 + 3;
test_data = calloc(sizeof(*test_data), ntests);
for (i = 0; i < 256; i++) {
/* lower case */
test_data[i].value = i;
test_data[i].hex[1] = xdigs_lower[ (i & 0x0f)];
test_data[i].hex[0] = xdigs_lower[((i & 0xf0) >> 4)];
2014-09-03 10:31:47 -06:00
/* upper case */
test_data[i + 256].value = i;
test_data[i + 256].hex[1] = xdigs_upper[ (i & 0x0f)];
test_data[i + 256].hex[0] = xdigs_upper[((i & 0xf0) >> 4)];
2014-09-03 10:31:47 -06:00
}
/* Also test invalid data */
test_data[ntests - 3].hex[0] = '\0';
test_data[ntests - 3].value = -1;
strlcpy(test_data[ntests - 2].hex, "AG", sizeof(test_data[ntests - 2].hex));
test_data[ntests - 2].value = -1;
strlcpy(test_data[ntests - 1].hex, "-1", sizeof(test_data[ntests - 1].hex));
test_data[ntests - 1].value = -1;
for (i = 0; i < ntests; i++) {
result = hexchar(test_data[i].hex);
if (result != test_data[i].value) {
fprintf(stderr, "check_hexchar: expected %d, got %d\n",
2014-09-03 10:31:47 -06:00
test_data[i].value, result);
errors++;
}
}
printf("check_hexchar: %d tests run, %d errors, %d%% success rate\n",
ntests, errors, (ntests - errors) * 100 / ntests);
exit(errors);
}