forked from CleverRaven/Cataclysm-DDA
-
Notifications
You must be signed in to change notification settings - Fork 0
/
active_item_cache_test.cpp
47 lines (44 loc) · 1.77 KB
/
active_item_cache_test.cpp
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
#include <set>
#include "calendar.h"
#include "cata_catch.h"
#include "game_constants.h"
#include "item.h"
#include "map.h"
#include "map_helpers.h"
#include "point.h"
TEST_CASE( "place_active_item_at_various_coordinates", "[item]" )
{
clear_map();
map &here = get_map();
for( int z = -OVERMAP_DEPTH; z < OVERMAP_HEIGHT; ++z ) {
for( int x = 0; x < MAPSIZE_X; ++x ) {
for( int y = 0; y < MAPSIZE_Y; ++y ) {
here.i_clear( { x, y, z } );
}
}
}
REQUIRE( here.get_submaps_with_active_items().empty() );
// An arbitrary active item.
item active( "firecracker_act", calendar::turn_zero, item::default_charges_tag() );
active.activate();
// For each space in a wide area place the item and check if the cache has been updated.
int z = 0;
for( int x = 0; x < MAPSIZE_X; ++x ) {
for( int y = 0; y < MAPSIZE_Y; ++y ) {
REQUIRE( here.i_at( tripoint{ x, y, z } ).empty() );
CAPTURE( x, y, z );
tripoint_abs_sm abs_loc = here.get_abs_sub() + tripoint( x / SEEX, y / SEEY, z );
CAPTURE( abs_loc );
REQUIRE( here.get_submaps_with_active_items().empty() );
REQUIRE( here.get_submaps_with_active_items().find( abs_loc ) ==
here.get_submaps_with_active_items().end() );
item &item_ref = here.add_item( { x, y, z }, active );
REQUIRE( item_ref.active );
REQUIRE_FALSE( here.get_submaps_with_active_items().empty() );
REQUIRE( here.get_submaps_with_active_items().find( abs_loc ) !=
here.get_submaps_with_active_items().end() );
REQUIRE_FALSE( here.i_at( tripoint{ x, y, z } ).empty() );
here.i_clear( { x, y, z } );
}
}
}