summaryrefslogtreecommitdiffstatshomepage
path: root/unix/coverage.c
diff options
context:
space:
mode:
Diffstat (limited to 'unix/coverage.c')
-rw-r--r--unix/coverage.c340
1 files changed, 0 insertions, 340 deletions
diff --git a/unix/coverage.c b/unix/coverage.c
deleted file mode 100644
index 4a9ab194bb..0000000000
--- a/unix/coverage.c
+++ /dev/null
@@ -1,340 +0,0 @@
-#include <stdio.h>
-#include <string.h>
-
-#include "py/obj.h"
-#include "py/objstr.h"
-#include "py/runtime.h"
-#include "py/repl.h"
-#include "py/mpz.h"
-#include "py/builtin.h"
-#include "py/emit.h"
-#include "py/formatfloat.h"
-#include "py/stream.h"
-#include "py/binary.h"
-
-#if defined(MICROPY_UNIX_COVERAGE)
-
-// stream testing object
-typedef struct _mp_obj_streamtest_t {
- mp_obj_base_t base;
- uint8_t *buf;
- size_t len;
- size_t pos;
- int error_code;
-} mp_obj_streamtest_t;
-
-STATIC mp_obj_t stest_set_buf(mp_obj_t o_in, mp_obj_t buf_in) {
- mp_obj_streamtest_t *o = MP_OBJ_TO_PTR(o_in);
- mp_buffer_info_t bufinfo;
- mp_get_buffer_raise(buf_in, &bufinfo, MP_BUFFER_READ);
- o->buf = m_new(uint8_t, bufinfo.len);
- memcpy(o->buf, bufinfo.buf, bufinfo.len);
- o->len = bufinfo.len;
- o->pos = 0;
- return mp_const_none;
-}
-STATIC MP_DEFINE_CONST_FUN_OBJ_2(stest_set_buf_obj, stest_set_buf);
-
-STATIC mp_obj_t stest_set_error(mp_obj_t o_in, mp_obj_t err_in) {
- mp_obj_streamtest_t *o = MP_OBJ_TO_PTR(o_in);
- o->error_code = mp_obj_get_int(err_in);
- return mp_const_none;
-}
-STATIC MP_DEFINE_CONST_FUN_OBJ_2(stest_set_error_obj, stest_set_error);
-
-STATIC mp_uint_t stest_read(mp_obj_t o_in, void *buf, mp_uint_t size, int *errcode) {
- mp_obj_streamtest_t *o = MP_OBJ_TO_PTR(o_in);
- if (o->pos < o->len) {
- if (size > o->len - o->pos) {
- size = o->len - o->pos;
- }
- memcpy(buf, o->buf + o->pos, size);
- o->pos += size;
- return size;
- } else if (o->error_code == 0) {
- return 0;
- } else {
- *errcode = o->error_code;
- return MP_STREAM_ERROR;
- }
-}
-
-STATIC mp_uint_t stest_write(mp_obj_t o_in, const void *buf, mp_uint_t size, int *errcode) {
- mp_obj_streamtest_t *o = MP_OBJ_TO_PTR(o_in);
- (void)buf;
- (void)size;
- *errcode = o->error_code;
- return MP_STREAM_ERROR;
-}
-
-STATIC mp_uint_t stest_ioctl(mp_obj_t o_in, mp_uint_t request, uintptr_t arg, int *errcode) {
- mp_obj_streamtest_t *o = MP_OBJ_TO_PTR(o_in);
- (void)arg;
- (void)request;
- (void)errcode;
- if (o->error_code != 0) {
- *errcode = o->error_code;
- return MP_STREAM_ERROR;
- }
- return 0;
-}
-
-STATIC const mp_rom_map_elem_t rawfile_locals_dict_table[] = {
- { MP_ROM_QSTR(MP_QSTR_set_buf), MP_ROM_PTR(&stest_set_buf_obj) },
- { MP_ROM_QSTR(MP_QSTR_set_error), MP_ROM_PTR(&stest_set_error_obj) },
- { MP_ROM_QSTR(MP_QSTR_read), MP_ROM_PTR(&mp_stream_read_obj) },
- { MP_ROM_QSTR(MP_QSTR_read1), MP_ROM_PTR(&mp_stream_read1_obj) },
- { MP_ROM_QSTR(MP_QSTR_write), MP_ROM_PTR(&mp_stream_write_obj) },
- { MP_ROM_QSTR(MP_QSTR_write1), MP_ROM_PTR(&mp_stream_write1_obj) },
- { MP_ROM_QSTR(MP_QSTR_readinto), MP_ROM_PTR(&mp_stream_readinto_obj) },
- { MP_ROM_QSTR(MP_QSTR_readline), MP_ROM_PTR(&mp_stream_unbuffered_readline_obj) },
- { MP_ROM_QSTR(MP_QSTR_ioctl), MP_ROM_PTR(&mp_stream_ioctl_obj) },
-};
-
-STATIC MP_DEFINE_CONST_DICT(rawfile_locals_dict, rawfile_locals_dict_table);
-
-STATIC const mp_stream_p_t fileio_stream_p = {
- .read = stest_read,
- .write = stest_write,
- .ioctl = stest_ioctl,
-};
-
-STATIC const mp_obj_type_t mp_type_stest_fileio = {
- { &mp_type_type },
- .protocol = &fileio_stream_p,
- .locals_dict = (mp_obj_dict_t*)&rawfile_locals_dict,
-};
-
-// stream read returns non-blocking error
-STATIC mp_uint_t stest_read2(mp_obj_t o_in, void *buf, mp_uint_t size, int *errcode) {
- (void)o_in;
- (void)buf;
- (void)size;
- *errcode = MP_EAGAIN;
- return MP_STREAM_ERROR;
-}
-
-STATIC const mp_rom_map_elem_t rawfile_locals_dict_table2[] = {
- { MP_ROM_QSTR(MP_QSTR_read), MP_ROM_PTR(&mp_stream_read_obj) },
- { MP_ROM_QSTR(MP_QSTR_write), MP_ROM_PTR(&mp_stream_write_obj) },
-};
-
-STATIC MP_DEFINE_CONST_DICT(rawfile_locals_dict2, rawfile_locals_dict_table2);
-
-STATIC const mp_stream_p_t textio_stream_p2 = {
- .read = stest_read2,
- .write = NULL,
- .is_text = true,
-};
-
-STATIC const mp_obj_type_t mp_type_stest_textio2 = {
- { &mp_type_type },
- .protocol = &textio_stream_p2,
- .locals_dict = (mp_obj_dict_t*)&rawfile_locals_dict2,
-};
-
-// str/bytes objects without a valid hash
-STATIC const mp_obj_str_t str_no_hash_obj = {{&mp_type_str}, 0, 10, (const byte*)"0123456789"};
-STATIC const mp_obj_str_t bytes_no_hash_obj = {{&mp_type_bytes}, 0, 10, (const byte*)"0123456789"};
-
-// function to run extra tests for things that can't be checked by scripts
-STATIC mp_obj_t extra_coverage(void) {
- // mp_printf (used by ports that don't have a native printf)
- {
- mp_printf(&mp_plat_print, "# mp_printf\n");
- mp_printf(&mp_plat_print, "%d %+d % d\n", -123, 123, 123); // sign
- mp_printf(&mp_plat_print, "%05d\n", -123); // negative number with zero padding
- mp_printf(&mp_plat_print, "%ld\n", 123); // long
- mp_printf(&mp_plat_print, "%X\n", 0x1abcdef); // capital hex
- mp_printf(&mp_plat_print, "%.2s %.3s\n", "abc", "abc"); // fixed string precision
- mp_printf(&mp_plat_print, "%.*s\n", -1, "abc"); // negative string precision
- mp_printf(&mp_plat_print, "%b %b\n", 0, 1); // bools
- mp_printf(&mp_plat_print, "%s\n", NULL); // null string
- mp_printf(&mp_plat_print, "%d\n", 0x80000000); // should print signed
- mp_printf(&mp_plat_print, "%u\n", 0x80000000); // should print unsigned
- mp_printf(&mp_plat_print, "%x\n", 0x80000000); // should print unsigned
- mp_printf(&mp_plat_print, "%X\n", 0x80000000); // should print unsigned
- mp_printf(&mp_plat_print, "abc\n%"); // string ends in middle of format specifier
- }
-
- // vstr
- {
- mp_printf(&mp_plat_print, "# vstr\n");
- vstr_t *vstr = vstr_new(16);
- vstr_hint_size(vstr, 32);
- vstr_add_str(vstr, "ts");
- vstr_ins_byte(vstr, 1, 'e');
- vstr_ins_char(vstr, 3, 't');
- vstr_ins_char(vstr, 10, 's');
- mp_printf(&mp_plat_print, "%.*s\n", (int)vstr->len, vstr->buf);
-
- vstr_cut_head_bytes(vstr, 2);
- mp_printf(&mp_plat_print, "%.*s\n", (int)vstr->len, vstr->buf);
-
- vstr_cut_tail_bytes(vstr, 10);
- mp_printf(&mp_plat_print, "%.*s\n", (int)vstr->len, vstr->buf);
-
- vstr_printf(vstr, "t%cst", 'e');
- mp_printf(&mp_plat_print, "%.*s\n", (int)vstr->len, vstr->buf);
-
- vstr_cut_out_bytes(vstr, 3, 10);
- mp_printf(&mp_plat_print, "%.*s\n", (int)vstr->len, vstr->buf);
-
- VSTR_FIXED(fix, 4);
- vstr_add_str(&fix, "large");
- mp_printf(&mp_plat_print, "%.*s\n", (int)fix.len, fix.buf);
- }
-
- // repl autocomplete
- {
- mp_printf(&mp_plat_print, "# repl\n");
-
- const char *str;
- size_t len = mp_repl_autocomplete("__n", 3, &mp_plat_print, &str);
- mp_printf(&mp_plat_print, "%.*s\n", (int)len, str);
-
- mp_store_global(MP_QSTR_sys, mp_import_name(MP_QSTR_sys, mp_const_none, MP_OBJ_NEW_SMALL_INT(0)));
- mp_repl_autocomplete("sys.", 4, &mp_plat_print, &str);
- len = mp_repl_autocomplete("sys.impl", 8, &mp_plat_print, &str);
- mp_printf(&mp_plat_print, "%.*s\n", (int)len, str);
- }
-
- // attrtuple
- {
- mp_printf(&mp_plat_print, "# attrtuple\n");
-
- static const qstr fields[] = {MP_QSTR_start, MP_QSTR_stop, MP_QSTR_step};
- static const mp_obj_t items[] = {MP_OBJ_NEW_SMALL_INT(1), MP_OBJ_NEW_SMALL_INT(2), MP_OBJ_NEW_SMALL_INT(3)};
- mp_obj_print_helper(&mp_plat_print, mp_obj_new_attrtuple(fields, 3, items), PRINT_REPR);
- mp_printf(&mp_plat_print, "\n");
- }
-
- // str
- {
- mp_printf(&mp_plat_print, "# str\n");
-
- // intern string
- mp_printf(&mp_plat_print, "%d\n", MP_OBJ_IS_QSTR(mp_obj_str_intern(mp_obj_new_str("intern me", 9, false))));
- }
-
- // mpz
- {
- mp_printf(&mp_plat_print, "# mpz\n");
-
- mp_uint_t value;
- mpz_t mpz;
- mpz_init_zero(&mpz);
-
- // mpz_as_uint_checked, with success
- mpz_set_from_int(&mpz, 12345678);
- mp_printf(&mp_plat_print, "%d\n", mpz_as_uint_checked(&mpz, &value));
- mp_printf(&mp_plat_print, "%d\n", (int)value);
-
- // mpz_as_uint_checked, with negative arg
- mpz_set_from_int(&mpz, -1);
- mp_printf(&mp_plat_print, "%d\n", mpz_as_uint_checked(&mpz, &value));
-
- // mpz_as_uint_checked, with overflowing arg
- mpz_set_from_int(&mpz, 1);
- mpz_shl_inpl(&mpz, &mpz, 70);
- mp_printf(&mp_plat_print, "%d\n", mpz_as_uint_checked(&mpz, &value));
- }
-
- // runtime utils
- {
- mp_printf(&mp_plat_print, "# runtime utils\n");
-
- // call mp_call_function_1_protected
- mp_call_function_1_protected(MP_OBJ_FROM_PTR(&mp_builtin_abs_obj), MP_OBJ_NEW_SMALL_INT(1));
- // call mp_call_function_1_protected with invalid args
- mp_call_function_1_protected(MP_OBJ_FROM_PTR(&mp_builtin_abs_obj), mp_obj_new_str("abc", 3, false));
-
- // call mp_call_function_2_protected
- mp_call_function_2_protected(MP_OBJ_FROM_PTR(&mp_builtin_divmod_obj), MP_OBJ_NEW_SMALL_INT(1), MP_OBJ_NEW_SMALL_INT(1));
- // call mp_call_function_2_protected with invalid args
- mp_call_function_2_protected(MP_OBJ_FROM_PTR(&mp_builtin_divmod_obj), mp_obj_new_str("abc", 3, false), mp_obj_new_str("abc", 3, false));
- }
-
- // warning
- {
- mp_emitter_warning(MP_PASS_CODE_SIZE, "test");
- }
-
- // format float
- {
- mp_printf(&mp_plat_print, "# format float\n");
-
- // format with inadequate buffer size
- char buf[5];
- mp_format_float(1, buf, sizeof(buf), 'g', 0, '+');
- mp_printf(&mp_plat_print, "%s\n", buf);
-
- // format with just enough buffer so that precision must be
- // set from 0 to 1 twice
- char buf2[8];
- mp_format_float(1, buf2, sizeof(buf2), 'g', 0, '+');
- mp_printf(&mp_plat_print, "%s\n", buf2);
-
- // format where precision is trimmed to avoid buffer overflow
- mp_format_float(1, buf2, sizeof(buf2), 'e', 0, '+');
- mp_printf(&mp_plat_print, "%s\n", buf2);
- }
-
- // binary
- {
- mp_printf(&mp_plat_print, "# binary\n");
-
- // call function with float and double typecodes
- float far[1];
- double dar[1];
- mp_binary_set_val_array_from_int('f', far, 0, 123);
- mp_printf(&mp_plat_print, "%.0f\n", (double)far[0]);
- mp_binary_set_val_array_from_int('d', dar, 0, 456);
- mp_printf(&mp_plat_print, "%.0lf\n", dar[0]);
- }
-
- // scheduler
- {
- mp_printf(&mp_plat_print, "# scheduler\n");
-
- // lock scheduler
- mp_sched_lock();
-
- // schedule multiple callbacks; last one should fail
- for (int i = 0; i < 5; ++i) {
- mp_printf(&mp_plat_print, "sched(%d)=%d\n", i, mp_sched_schedule(MP_OBJ_FROM_PTR(&mp_builtin_print_obj), MP_OBJ_NEW_SMALL_INT(i)));
- }
-
- // test nested locking/unlocking
- mp_sched_lock();
- mp_sched_unlock();
-
- // shouldn't do anything while scheduler is locked
- mp_handle_pending();
-
- // unlock scheduler
- mp_sched_unlock();
- mp_printf(&mp_plat_print, "unlocked\n");
-
- // drain pending callbacks
- while (mp_sched_num_pending()) {
- mp_handle_pending();
- }
- }
-
- mp_obj_streamtest_t *s = m_new_obj(mp_obj_streamtest_t);
- s->base.type = &mp_type_stest_fileio;
- s->buf = NULL;
- s->len = 0;
- s->pos = 0;
- s->error_code = 0;
- mp_obj_streamtest_t *s2 = m_new_obj(mp_obj_streamtest_t);
- s2->base.type = &mp_type_stest_textio2;
-
- // return a tuple of data for testing on the Python side
- mp_obj_t items[] = {(mp_obj_t)&str_no_hash_obj, (mp_obj_t)&bytes_no_hash_obj, MP_OBJ_FROM_PTR(s), MP_OBJ_FROM_PTR(s2)};
- return mp_obj_new_tuple(MP_ARRAY_SIZE(items), items);
-}
-MP_DEFINE_CONST_FUN_OBJ_0(extra_coverage_obj, extra_coverage);
-
-#endif