242 lines
7.6 KiB
C++
242 lines
7.6 KiB
C++
/*
|
|
|
|
A series of stress tests to more quickly verify that 4coder isn't totally
|
|
broken before I release in the future... "unit tests" perhaps, although
|
|
I guess I don't know what the "units" are... probably just "tests".
|
|
|
|
Allen Webster
|
|
18.07.2016
|
|
|
|
*/
|
|
|
|
// TOP
|
|
|
|
#define LOTS_OF_FILES "w:/4ed/data/lots_of_files"
|
|
#define TEST_FILES "w:/4ed/data/test"
|
|
|
|
#include "4coder_default_include.cpp"
|
|
|
|
#include <assert.h>
|
|
#include <stdio.h>
|
|
|
|
#include <intrin.h>
|
|
#pragma intrinsic(__rdtsc)
|
|
|
|
typedef uint64_t DWORD64;
|
|
|
|
#define TEST_TIME_B(m) DWORD64 time_start = __rdtsc(), time_max = m; (void)(time_start), (void)(time_max)
|
|
#define TEST_TIME_E() DWORD64 time_total = __rdtsc() - time_start; if (time_total > time_max) {assert(!"failed timing");}
|
|
#define TEST_TIME_M(m) m = (float)(__rdtsc() - time_start) / time_max
|
|
|
|
// NOTE(allen): This testing system only verifies that everything works
|
|
// without crashing and without blowing through a fair time budget.
|
|
// These tests do not verify the correctness of the output.
|
|
|
|
CUSTOM_COMMAND_SIG(load_lots_of_files){
|
|
// NOTE(allen): This timing restriction is based on 4GHz and 60fps
|
|
// 4G / 60 ~= 70M Reserving most of that time for rendering and hopefully idling
|
|
// I set the goal of 10M for all tests.
|
|
TEST_TIME_B(10000000);
|
|
|
|
File_List list = get_file_list(app, literal(LOTS_OF_FILES));
|
|
File_Info *info = list.infos;
|
|
|
|
char space[1024];
|
|
String str = make_fixed_width_string(space);
|
|
append_ss(&str, make_lit_string(LOTS_OF_FILES));
|
|
append_s_char(&str, '/');
|
|
int32_t size = str.size;
|
|
|
|
for (uint32_t i = 0; i < list.count; ++i, ++info){
|
|
if (!info->folder){
|
|
append_ss(&str, make_string(info->filename, info->filename_len));
|
|
Buffer_Summary buffer = create_buffer(app, str.str, str.size,
|
|
BufferCreate_Background);
|
|
assert(buffer.size != 0);
|
|
str.size = size;
|
|
}
|
|
}
|
|
|
|
free_file_list(app, list);
|
|
|
|
// TODO(allen): Pass this time test!
|
|
//TEST_TIME_E();
|
|
}
|
|
|
|
CUSTOM_COMMAND_SIG(reopen_test){
|
|
// NOTE(allen): This is set to roughly one percent of the frame budget
|
|
// based on 4GHz and 60fps
|
|
TEST_TIME_B(700000);
|
|
|
|
Buffer_Summary buffer = create_buffer(app, literal(TEST_FILES "/basic.cpp"), 0);
|
|
View_Summary view = get_active_view(app, AccessAll);
|
|
view_set_buffer(app, &view, buffer.buffer_id, 0);
|
|
|
|
exec_command(app, cmdid_reopen);
|
|
|
|
// TODO(allen): Pass this time test!
|
|
//TEST_TIME_E();
|
|
}
|
|
|
|
CUSTOM_COMMAND_SIG(generate_stop_spots_test_data){
|
|
Buffer_Summary buffer = create_buffer(app, literal(LOTS_OF_FILES "/4ed.cpp"), 0);
|
|
View_Summary view = get_active_view(app, AccessAll);
|
|
view_set_buffer(app, &view, buffer.buffer_id, 0);
|
|
|
|
FILE *file = fopen(TEST_FILES "/stop_spots_data", "wb");
|
|
|
|
if (file){
|
|
Partial_Cursor curs;
|
|
int32_t pos;
|
|
|
|
buffer_compute_cursor(app, &buffer, seek_line_char(316, 29), &curs);
|
|
fwrite(&curs.pos, 4, 1, file);
|
|
|
|
for (int32_t i = 0; i < 10; ++i){
|
|
Query_Bar bar = {0};
|
|
bar.prompt = make_lit_string("Do something to continue the test");
|
|
if (start_query_bar(app, &bar, 0)){
|
|
get_user_input(app, EventAll, EventAll);
|
|
}
|
|
refresh_buffer(app, &buffer);
|
|
if (buffer.tokens_are_ready){
|
|
break;
|
|
}
|
|
}
|
|
|
|
static Seek_Boundary_Flag flag_set[] = {
|
|
BoundaryWhitespace,
|
|
BoundaryToken,
|
|
BoundaryAlphanumeric,
|
|
BoundaryCamelCase,
|
|
BoundaryWhitespace | BoundaryToken,
|
|
BoundaryWhitespace | BoundaryAlphanumeric,
|
|
BoundaryToken | BoundaryCamelCase,
|
|
};
|
|
|
|
for (int32_t flag_i = 0; flag_i < ArrayCount(flag_set); ++flag_i){
|
|
for (int32_t seek_forward = 0; seek_forward <= 1; ++seek_forward){
|
|
pos = curs.pos;
|
|
for (int32_t i = 0; i < 100; ++i){
|
|
pos = buffer_boundary_seek(app, &buffer, pos, seek_forward, flag_set[flag_i]);
|
|
fwrite(&pos, 4, 1, file);
|
|
}
|
|
}
|
|
}
|
|
|
|
fclose(file);
|
|
}
|
|
}
|
|
|
|
static void
|
|
fcheck(int32_t x, FILE *file){
|
|
int32_t x0 = 0;
|
|
fread(&x0, 4, 1, file);
|
|
Assert(x == x0);
|
|
}
|
|
|
|
CUSTOM_COMMAND_SIG(stop_spots_test){
|
|
Buffer_Summary buffer = create_buffer(app, literal(LOTS_OF_FILES "/4ed.cpp"), 0);
|
|
View_Summary view = get_active_view(app, AccessAll);
|
|
view_set_buffer(app, &view, buffer.buffer_id, 0);
|
|
|
|
FILE *file = fopen(TEST_FILES "/stop_spots_data", "rb");
|
|
|
|
if (file){
|
|
Partial_Cursor curs;
|
|
int32_t pos;
|
|
|
|
buffer_compute_cursor(app, &buffer, seek_line_char(316, 29), &curs);
|
|
fcheck(curs.pos, file);
|
|
|
|
for (int32_t i = 0; i < 10; ++i){
|
|
Query_Bar bar = {0};
|
|
bar.prompt = make_lit_string("Do something to continue the test");
|
|
if (start_query_bar(app, &bar, 0)){
|
|
get_user_input(app, EventAll, EventAll);
|
|
}
|
|
refresh_buffer(app, &buffer);
|
|
if (buffer.tokens_are_ready){
|
|
break;
|
|
}
|
|
}
|
|
|
|
static Seek_Boundary_Flag flag_set[] = {
|
|
BoundaryWhitespace,
|
|
BoundaryToken,
|
|
BoundaryAlphanumeric,
|
|
BoundaryCamelCase,
|
|
BoundaryWhitespace | BoundaryToken,
|
|
BoundaryWhitespace | BoundaryAlphanumeric,
|
|
BoundaryToken | BoundaryCamelCase,
|
|
};
|
|
|
|
for (int32_t flag_i = 0; flag_i < ArrayCount(flag_set); ++flag_i){
|
|
for (int32_t seek_forward = 0; seek_forward <= 1; ++seek_forward){
|
|
pos = curs.pos;
|
|
for (int32_t i = 0; i < 100; ++i){
|
|
pos = buffer_boundary_seek(app, &buffer, pos, seek_forward, flag_set[flag_i]);
|
|
fcheck(pos, file);
|
|
}
|
|
}
|
|
}
|
|
|
|
fclose(file);
|
|
}
|
|
}
|
|
|
|
CUSTOM_COMMAND_SIG(load_unicode_file){
|
|
Buffer_Summary buffer = create_buffer(app, literal(TEST_FILES "/mod_markov.c"), 0);
|
|
View_Summary view = get_active_view(app, AccessAll);
|
|
view_set_buffer(app, &view, buffer.buffer_id, 0);
|
|
|
|
view_set_cursor(app, &view, seek_line_char(230, 25), 1);
|
|
}
|
|
|
|
CUSTOM_COMMAND_SIG(edit_giant_file){
|
|
Buffer_Summary buffer = create_buffer(app, literal(TEST_FILES "/test_large.cpp"), 0);
|
|
View_Summary view = get_active_view(app, AccessAll);
|
|
view_set_buffer(app, &view, buffer.buffer_id, 0);
|
|
view_set_cursor(app, &view, seek_line_char(230, 25), 1);
|
|
|
|
for (int32_t i = 0; i < 600; ++i){
|
|
Query_Bar bar = {0};
|
|
bar.prompt = make_lit_string("Do something to continue the test");
|
|
if (start_query_bar(app, &bar, 0)){
|
|
get_user_input(app, EventAll, EventAll);
|
|
}
|
|
end_query_bar(app, &bar, 0);
|
|
refresh_buffer(app, &buffer);
|
|
if (buffer.tokens_are_ready){
|
|
break;
|
|
}
|
|
}
|
|
|
|
buffer_replace_range(app, &buffer, 2000, 2000,
|
|
literal("{\n//Not important at all\n}\n"));
|
|
buffer_auto_indent(app, &buffer, 2000, 2100, 4, 0);
|
|
}
|
|
|
|
CUSTOM_COMMAND_SIG(run_all_tests){
|
|
exec_command(app, load_lots_of_files);
|
|
exec_command(app, reopen_test);
|
|
exec_command(app, stop_spots_test);
|
|
exec_command(app, load_unicode_file);
|
|
exec_command(app, edit_giant_file);
|
|
}
|
|
|
|
static void
|
|
test_get_bindings(Bind_Helper *context){
|
|
begin_map(context, mapid_global);
|
|
bind(context, key_f3, MDFR_NONE, run_all_tests);
|
|
end_map(context);
|
|
}
|
|
|
|
#define BIND_4CODER_TESTS(context) test_get_bindings(context)
|
|
|
|
#include "power/4coder_experiments.cpp"
|
|
|
|
|
|
// BOTTOM
|
|
|