Browse Source

init_field any x y --> WAY

main^2
Joe Lukas Kalb 11 months ago
committed by Peter Wiebe
parent
commit
a9872e34a1
  1. 4
      src/main/c/labyrinth.c
  2. 32
      src/test/c/test_labyrinth.c

4
src/main/c/labyrinth.c

@ -49,7 +49,9 @@ void set_wall(Field_State** field, unsigned short x, unsigned short y) {
void init_field(Field_State** field, unsigned short len_x, unsigned short len_y){ void init_field(Field_State** field, unsigned short len_x, unsigned short len_y){
for (int x = 0; x < len_x; x++){ for (int x = 0; x < len_x; x++){
field[x][0] = WAY;
for (int y = 0; y < len_y; y++){
field[x][y] = WAY;
}
} }
} }

32
src/test/c/test_labyrinth.c

@ -323,3 +323,35 @@ void test_init_field_at_2_0_expected_WAY(void)
} }
free(field); free(field);
} }
void test_init_field_at_2_3_expected_WAY(void)
{
/* arrange */
unsigned short x = 2;
unsigned short y = 3;
unsigned short len_x = 5, len_y = 5;
Field_State **field;
field = malloc(len_x * sizeof *field);
for (int c_index = 0; c_index < len_x; c_index++){
field[c_index] = malloc(len_y * sizeof field[c_index]);
}
field[x][y] = WALL;
Field_State expected = WAY;
/* act */
init_field(field, len_x, len_y);
/* assert */
TEST_ASSERT_TRUE(field[x][y] == expected);
for (int c_index = 0; c_index < len_x; c_index++)
{
free(field[c_index]);
}
free(field);
}
Loading…
Cancel
Save