mirror of
https://github.com/RIOT-OS/RIOT.git
synced 2025-01-18 12:52:44 +01:00
tests: Add benchmark for sys/base64
This commit is contained in:
parent
3c7fd0cdc9
commit
e3ea4943af
7
tests/bench_sys_base64/Makefile
Normal file
7
tests/bench_sys_base64/Makefile
Normal file
@ -0,0 +1,7 @@
|
||||
include ../Makefile.tests_common
|
||||
|
||||
USEMODULE += base64
|
||||
USEMODULE += fmt
|
||||
USEMODULE += xtimer
|
||||
|
||||
include $(RIOTBASE)/Makefile.include
|
99
tests/bench_sys_base64/main.c
Normal file
99
tests/bench_sys_base64/main.c
Normal file
@ -0,0 +1,99 @@
|
||||
/*
|
||||
* Copyright (C) 2020 Otto-von-Guericke-Universität Magdeburg
|
||||
*
|
||||
* This file is subject to the terms and conditions of the GNU Lesser
|
||||
* General Public License v2.1. See the file LICENSE in the top level
|
||||
* directory for more details.
|
||||
*/
|
||||
|
||||
/**
|
||||
* @ingroup tests
|
||||
* @{
|
||||
*
|
||||
* @file
|
||||
* @brief Benchmark for the base64 lib
|
||||
*
|
||||
* @author Marian Buschsieweke <marian.buschsieweke@ovgu.de>
|
||||
*
|
||||
* @}
|
||||
*/
|
||||
|
||||
#include <stdint.h>
|
||||
#include <string.h>
|
||||
|
||||
#include "base64.h"
|
||||
#include "fmt.h"
|
||||
#include "xtimer.h"
|
||||
|
||||
#define MIN(a, b) (a < b) ? a : b
|
||||
|
||||
static char buf[128];
|
||||
|
||||
static const char input[96] = "This is an extremely, enormously, greatly, "
|
||||
"immensely, tremendously, remarkably lengthy "
|
||||
"sentence!";
|
||||
static const char base64[128] =
|
||||
"VGhpcyBpcyBhbiBleHRyZW1lbHksIGVub3Jtb3VzbHksIGdyZWF0bHksIGltbWVuc2VseSwgdHJl"
|
||||
"bWVuZG91c2x5LCByZW1hcmthYmx5IGxlbmd0aHkgc2VudGVuY2Uh";
|
||||
|
||||
int main(void) {
|
||||
uint32_t start, stop;
|
||||
size_t size;
|
||||
|
||||
/* We don't want check return value in the benchmark loop, so we just do
|
||||
* a simple self test now. */
|
||||
print_str("Verifying that base64 encoding works for benchmark input: ");
|
||||
size = sizeof(buf);
|
||||
if ((BASE64_SUCCESS != base64_encode(input, sizeof(input), buf, &size)) ||
|
||||
(size != sizeof(buf)) ||
|
||||
(0 != memcmp(base64, buf, sizeof(base64))))
|
||||
{
|
||||
print_str("FAIL\nGot: \"");
|
||||
print(buf, MIN(size, sizeof(base64)));
|
||||
print_str("\"\nExpected: \"");
|
||||
print(base64, sizeof(base64));
|
||||
print_str("\"\n");
|
||||
}
|
||||
else {
|
||||
print_str("OK\n");
|
||||
}
|
||||
|
||||
print_str("Verifying that base64 decoding works for benchmark input: ");
|
||||
size = sizeof(buf);
|
||||
if ((BASE64_SUCCESS != base64_decode(base64, sizeof(base64), buf, &size)) ||
|
||||
(size != sizeof(input)) ||
|
||||
(0 != memcmp(input, buf, sizeof(input))))
|
||||
{
|
||||
print_str("FAIL\nGot: \"");
|
||||
print(buf, MIN(size, sizeof(input)));
|
||||
print_str("\"\nExpected: \"");
|
||||
print(input, sizeof(input));
|
||||
print_str("\"\n");
|
||||
}
|
||||
else {
|
||||
print_str("OK\n");
|
||||
}
|
||||
|
||||
start = xtimer_now_usec();
|
||||
for (unsigned i = 0; i < 10000; i++) {
|
||||
size = sizeof(buf);
|
||||
base64_encode(input, sizeof(input), buf, &size);
|
||||
}
|
||||
stop = xtimer_now_usec();
|
||||
|
||||
print_str("Encoding 10.000 x 96 bytes (128 bytes in base64): ");
|
||||
print_u32_dec(stop - start);
|
||||
print_str(" µs\n");
|
||||
|
||||
start = xtimer_now_usec();
|
||||
for (unsigned i = 0; i < 10000; i++) {
|
||||
size = sizeof(buf);
|
||||
base64_decode(base64, sizeof(base64), buf, &size);
|
||||
}
|
||||
stop = xtimer_now_usec();
|
||||
|
||||
print_str("Decoding 10.000 x 96 bytes (128 bytes in base64): ");
|
||||
print_u32_dec(stop - start);
|
||||
print_str(" µs\n");
|
||||
return 0;
|
||||
}
|
21
tests/bench_sys_base64/tests/01-run.py
Executable file
21
tests/bench_sys_base64/tests/01-run.py
Executable file
@ -0,0 +1,21 @@
|
||||
#!/usr/bin/env python3
|
||||
|
||||
# Copyright (C) 2020 Otto-von-Guericke-Universität Magdeburg
|
||||
#
|
||||
# This file is subject to the terms and conditions of the GNU Lesser
|
||||
# General Public License v2.1. See the file LICENSE in the top level
|
||||
# directory for more details.
|
||||
|
||||
import sys
|
||||
from testrunner import run
|
||||
|
||||
|
||||
def testfunc(child):
|
||||
child.expect_exact("Verifying that base64 encoding works for benchmark input: OK\r\n")
|
||||
child.expect_exact("Verifying that base64 decoding works for benchmark input: OK\r\n")
|
||||
child.expect(r"Encoding 10\.000 x 96 bytes \(128 bytes in base64\): [0-9]+ µs\r\n")
|
||||
child.expect(r"Decoding 10\.000 x 96 bytes \(128 bytes in base64\): [0-9]+ µs\r\n")
|
||||
|
||||
|
||||
if __name__ == "__main__":
|
||||
sys.exit(run(testfunc))
|
Loading…
Reference in New Issue
Block a user