#include "test_utils.h"
UnittestTestResult_t* test_2d_array_outer_length(void) {
UNITTEST_BEGIN_TEST("TestMultidimArrays", "test_2d_array_outer_length");
RAVA_TEST_RUN(_unittest_result,
"public class Test {\n"
" public static int main() {\n"
" int[][] a = new int[4][5];\n"
" return a.length;\n"
" }\n"
"}\n",
"Test", "main", 4, "2d array outer length should return 4");
UNITTEST_END_TEST();
}
UnittestTestResult_t* test_2d_array_inner_length(void) {
UNITTEST_BEGIN_TEST("TestMultidimArrays", "test_2d_array_inner_length");
RAVA_TEST_RUN(_unittest_result,
"public class Test {\n"
" public static int main() {\n"
" int[][] a = new int[4][5];\n"
" return a[0].length;\n"
" }\n"
"}\n",
"Test", "main", 5, "2d array inner length should return 5");
UNITTEST_END_TEST();
}
UnittestTestResult_t* test_2d_array_basic_store_load(void) {
UNITTEST_BEGIN_TEST("TestMultidimArrays", "test_2d_array_basic_store_load");
RAVA_TEST_RUN(_unittest_result,
"public class Test {\n"
" public static int main() {\n"
" int[][] a = new int[2][3];\n"
" a[0][1] = 15;\n"
" return a[0][1];\n"
" }\n"
"}\n",
"Test", "main", 15, "2d array basic store and load should return 15");
UNITTEST_END_TEST();
}
UnittestTestResult_t* test_2d_array_multiple_cells(void) {
UNITTEST_BEGIN_TEST("TestMultidimArrays", "test_2d_array_multiple_cells");
RAVA_TEST_RUN(_unittest_result,
"public class Test {\n"
" public static int main() {\n"
" int[][] a = new int[2][3];\n"
" a[0][0] = 1;\n"
" a[0][1] = 2;\n"
" a[1][0] = 3;\n"
" a[1][1] = 4;\n"
" return a[0][0] + a[0][1] + a[1][0] + a[1][1];\n"
" }\n"
"}\n",
"Test", "main", 10, "2d array multiple cells sum should return 10");
UNITTEST_END_TEST();
}
UnittestTestResult_t* test_2d_array_row_iteration(void) {
UNITTEST_BEGIN_TEST("TestMultidimArrays", "test_2d_array_row_iteration");
RAVA_TEST_RUN(_unittest_result,
"public class Test {\n"
" public static int main() {\n"
" int[][] a = new int[3][2];\n"
" a[0][0] = 1; a[0][1] = 2;\n"
" a[1][0] = 3; a[1][1] = 4;\n"
" a[2][0] = 5; a[2][1] = 6;\n"
" int sum = 0;\n"
" for (int i = 0; i < a.length; i++) {\n"
" sum = sum + a[i][0] + a[i][1];\n"
" }\n"
" return sum;\n"
" }\n"
"}\n",
"Test", "main", 21, "2d array row iteration sum should return 21");
UNITTEST_END_TEST();
}
UnittestTestResult_t* test_2d_array_nested_loop(void) {
UNITTEST_BEGIN_TEST("TestMultidimArrays", "test_2d_array_nested_loop");
RAVA_TEST_RUN(_unittest_result,
"public class Test {\n"
" public static int main() {\n"
" int[][] a = new int[2][3];\n"
" int v = 1;\n"
" for (int i = 0; i < 2; i++) {\n"
" for (int j = 0; j < 3; j++) {\n"
" a[i][j] = v;\n"
" v = v + 1;\n"
" }\n"
" }\n"
" return a[0][0] + a[0][2] + a[1][1];\n"
" }\n"
"}\n",
"Test", "main", 9, "2d array nested loop sum should return 9");
UNITTEST_END_TEST();
}
UnittestTestResult_t* test_2d_array_different_inner_lengths(void) {
UNITTEST_BEGIN_TEST("TestMultidimArrays", "test_2d_array_different_inner_lengths");
RAVA_TEST_RUN(_unittest_result,
"public class Test {\n"
" public static int main() {\n"
" int[][] a = new int[3][4];\n"
" int[][] b = new int[2][6];\n"
" return a[0].length + b[0].length;\n"
" }\n"
"}\n",
"Test", "main", 10, "2d array different inner lengths sum should return 10");
UNITTEST_END_TEST();
}
int main(int argc, char **argv) {
UnittestConfig_t *config = unittest_config_create();
config->verbosity = 2;
if (argc > 1 && strcmp(argv[1], "--json") == 0) {
config->output_format = UNITTEST_FORMAT_JSON;
config->use_colors = false;
}
UnittestTestSuite_t *suite = unittest_test_suite_create("Multi-dimensional Array Tests");
UnittestTestCase_t *tc = unittest_test_case_create("TestMultidimArrays");
unittest_test_case_add_result(tc, test_2d_array_outer_length());
unittest_test_case_add_result(tc, test_2d_array_inner_length());
unittest_test_case_add_result(tc, test_2d_array_basic_store_load());
unittest_test_case_add_result(tc, test_2d_array_multiple_cells());
unittest_test_case_add_result(tc, test_2d_array_row_iteration());
unittest_test_case_add_result(tc, test_2d_array_nested_loop());
unittest_test_case_add_result(tc, test_2d_array_different_inner_lengths());
unittest_test_suite_add_test_case(suite, tc);
unittest_generate_report(suite, config);
int failures = suite->total_failed + suite->total_errors;
unittest_test_suite_destroy(suite);
unittest_config_destroy(config);
return failures > 0 ? 1 : 0;
}