Merge branch 'bc/csprng-mktemps'
Pick a better random number generator and use it when we prepare temporary filenames. * bc/csprng-mktemps: wrapper: use a CSPRNG to generate random file names wrapper: add a helper to generate numbers from a CSPRNG
This commit is contained in:
29
t/helper/test-csprng.c
Normal file
29
t/helper/test-csprng.c
Normal file
@ -0,0 +1,29 @@
|
||||
#include "test-tool.h"
|
||||
#include "git-compat-util.h"
|
||||
|
||||
|
||||
int cmd__csprng(int argc, const char **argv)
|
||||
{
|
||||
unsigned long count;
|
||||
unsigned char buf[1024];
|
||||
|
||||
if (argc > 2) {
|
||||
fprintf(stderr, "usage: %s [<size>]\n", argv[0]);
|
||||
return 2;
|
||||
}
|
||||
|
||||
count = (argc == 2) ? strtoul(argv[1], NULL, 0) : -1L;
|
||||
|
||||
while (count) {
|
||||
unsigned long chunk = count < sizeof(buf) ? count : sizeof(buf);
|
||||
if (csprng_bytes(buf, chunk) < 0) {
|
||||
perror("failed to read");
|
||||
return 5;
|
||||
}
|
||||
if (fwrite(buf, chunk, 1, stdout) != chunk)
|
||||
return 1;
|
||||
count -= chunk;
|
||||
}
|
||||
|
||||
return 0;
|
||||
}
|
@ -20,6 +20,7 @@ static struct test_cmd cmds[] = {
|
||||
{ "chmtime", cmd__chmtime },
|
||||
{ "config", cmd__config },
|
||||
{ "crontab", cmd__crontab },
|
||||
{ "csprng", cmd__csprng },
|
||||
{ "ctype", cmd__ctype },
|
||||
{ "date", cmd__date },
|
||||
{ "delta", cmd__delta },
|
||||
|
@ -10,6 +10,7 @@ int cmd__bloom(int argc, const char **argv);
|
||||
int cmd__chmtime(int argc, const char **argv);
|
||||
int cmd__config(int argc, const char **argv);
|
||||
int cmd__crontab(int argc, const char **argv);
|
||||
int cmd__csprng(int argc, const char **argv);
|
||||
int cmd__ctype(int argc, const char **argv);
|
||||
int cmd__date(int argc, const char **argv);
|
||||
int cmd__delta(int argc, const char **argv);
|
||||
|
Reference in New Issue
Block a user