forked from github/server
BUG 2366: add a test to verify that view_reality sets an observer.
This commit is contained in:
parent
0ffb4e3ca9
commit
9d48bfc36c
4 changed files with 65 additions and 21 deletions
|
@ -22,11 +22,10 @@
|
||||||
extern "C" {
|
extern "C" {
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
|
struct castorder;
|
||||||
struct curse_type;
|
struct curse_type;
|
||||||
struct region;
|
struct region;
|
||||||
struct unit;
|
struct unit;
|
||||||
struct faction;
|
|
||||||
struct region;
|
|
||||||
struct message;
|
struct message;
|
||||||
|
|
||||||
extern const struct curse_type ct_magicresistance;
|
extern const struct curse_type ct_magicresistance;
|
||||||
|
@ -34,8 +33,9 @@ extern "C" {
|
||||||
void register_magicresistance(void);
|
void register_magicresistance(void);
|
||||||
void register_spells(void);
|
void register_spells(void);
|
||||||
|
|
||||||
int sp_baddreams(castorder * co);
|
int sp_baddreams(struct castorder * co);
|
||||||
int sp_gooddreams(castorder * co);
|
int sp_gooddreams(struct castorder * co);
|
||||||
|
int sp_viewreality(struct castorder * co);
|
||||||
|
|
||||||
#define ACTION_RESET 0x01 /* reset the one-time-flag FFL_SELECT (on first pass) */
|
#define ACTION_RESET 0x01 /* reset the one-time-flag FFL_SELECT (on first pass) */
|
||||||
#define ACTION_CANSEE 0x02 /* to people who can see the actor */
|
#define ACTION_CANSEE 0x02 /* to people who can see the actor */
|
||||||
|
|
|
@ -1,11 +1,13 @@
|
||||||
#include <platform.h>
|
#include <platform.h>
|
||||||
|
|
||||||
#include "spells.h"
|
#include "spells.h"
|
||||||
|
#include "teleport.h"
|
||||||
|
|
||||||
#include <kernel/config.h>
|
#include <kernel/config.h>
|
||||||
#include <kernel/curse.h>
|
#include <kernel/curse.h>
|
||||||
#include <kernel/faction.h>
|
#include <kernel/faction.h>
|
||||||
#include <kernel/order.h>
|
#include <kernel/order.h>
|
||||||
|
#include <kernel/plane.h>
|
||||||
#include <kernel/race.h>
|
#include <kernel/race.h>
|
||||||
#include <kernel/region.h>
|
#include <kernel/region.h>
|
||||||
#include <kernel/spell.h>
|
#include <kernel/spell.h>
|
||||||
|
@ -113,6 +115,40 @@ static void test_bad_dreams(CuTest *tc) {
|
||||||
test_cleanup();
|
test_cleanup();
|
||||||
}
|
}
|
||||||
|
|
||||||
|
static void test_view_reality(CuTest *tc) {
|
||||||
|
region *r, *ra;
|
||||||
|
faction *f;
|
||||||
|
unit *u;
|
||||||
|
castorder co;
|
||||||
|
|
||||||
|
test_setup();
|
||||||
|
r = test_create_region(0, 0, NULL);
|
||||||
|
ra = test_create_region(real2tp(r->x), real2tp(r->y), NULL);
|
||||||
|
ra->_plane = get_astralplane();
|
||||||
|
f = test_create_faction(0);
|
||||||
|
u = test_create_unit(f, r);
|
||||||
|
|
||||||
|
test_create_castorder(&co, u, 10, 10., 0, NULL);
|
||||||
|
CuAssertIntEquals(tc, -1, get_observer(r, f));
|
||||||
|
CuAssertIntEquals(tc, 0, sp_viewreality(&co));
|
||||||
|
CuAssertPtrNotNull(tc, test_find_messagetype(f->msgs, "spell_astral_only"));
|
||||||
|
free_castorder(&co);
|
||||||
|
|
||||||
|
test_clear_messagelist(&f->msgs);
|
||||||
|
move_unit(u, ra, NULL);
|
||||||
|
|
||||||
|
test_create_castorder(&co, u, 9, 10., 0, NULL);
|
||||||
|
CuAssertIntEquals(tc, -1, get_observer(r, f));
|
||||||
|
CuAssertIntEquals(tc, 9, sp_viewreality(&co));
|
||||||
|
CuAssertPtrEquals(tc, NULL, test_find_messagetype(f->msgs, "spell_astral_only"));
|
||||||
|
CuAssertIntEquals(tc, 4, get_observer(r, f));
|
||||||
|
CuAssertPtrEquals(tc, f, (void *)ra->individual_messages->viewer);
|
||||||
|
CuAssertPtrNotNull(tc, test_find_messagetype(ra->individual_messages->msgs, "viewreality_effect"));
|
||||||
|
free_castorder(&co);
|
||||||
|
|
||||||
|
test_cleanup();
|
||||||
|
}
|
||||||
|
|
||||||
static void test_watch_region(CuTest *tc) {
|
static void test_watch_region(CuTest *tc) {
|
||||||
region *r;
|
region *r;
|
||||||
faction *f;
|
faction *f;
|
||||||
|
@ -133,6 +169,7 @@ CuSuite *get_spells_suite(void)
|
||||||
{
|
{
|
||||||
CuSuite *suite = CuSuiteNew();
|
CuSuite *suite = CuSuiteNew();
|
||||||
SUITE_ADD_TEST(suite, test_watch_region);
|
SUITE_ADD_TEST(suite, test_watch_region);
|
||||||
|
SUITE_ADD_TEST(suite, test_view_reality);
|
||||||
SUITE_ADD_TEST(suite, test_good_dreams);
|
SUITE_ADD_TEST(suite, test_good_dreams);
|
||||||
SUITE_ADD_TEST(suite, test_bad_dreams);
|
SUITE_ADD_TEST(suite, test_bad_dreams);
|
||||||
SUITE_ADD_TEST(suite, test_dreams);
|
SUITE_ADD_TEST(suite, test_dreams);
|
||||||
|
|
|
@ -39,25 +39,24 @@ OR IN CONNECTION WITH THE USE OR PERFORMANCE OF THIS SOFTWARE.
|
||||||
/* libc includes */
|
/* libc includes */
|
||||||
#include <assert.h>
|
#include <assert.h>
|
||||||
|
|
||||||
#define TE_CENTER_X 1000
|
#define TE_CENTER 1000
|
||||||
#define TE_CENTER_Y 1000
|
|
||||||
#define TP_RADIUS 2
|
#define TP_RADIUS 2
|
||||||
#define TP_DISTANCE 4
|
#define TP_DISTANCE 4
|
||||||
|
|
||||||
static int real2tp(int rk)
|
int real2tp(int rk)
|
||||||
{
|
{
|
||||||
/* in C:
|
/* in C:
|
||||||
* -4 / 5 = 0;
|
* -4 / 5 = 0;
|
||||||
* +4 / 5 = 0;
|
* +4 / 5 = 0;
|
||||||
* !!!!!!!!!!;
|
* !!!!!!!!!!;
|
||||||
*/
|
*/
|
||||||
return (rk + (TP_DISTANCE * 5000)) / TP_DISTANCE - 5000;
|
return TE_CENTER + (rk + (TP_DISTANCE * 5000)) / TP_DISTANCE - 5000;
|
||||||
}
|
}
|
||||||
|
|
||||||
static region *tpregion(const region * r)
|
static region *tpregion(const region * r)
|
||||||
{
|
{
|
||||||
region *rt =
|
region *rt =
|
||||||
findregion(TE_CENTER_X + real2tp(r->x), TE_CENTER_Y + real2tp(r->y));
|
findregion(real2tp(r->x), real2tp(r->y));
|
||||||
if (!is_astral(rt))
|
if (!is_astral(rt))
|
||||||
return NULL;
|
return NULL;
|
||||||
return rt;
|
return rt;
|
||||||
|
@ -106,8 +105,8 @@ region *r_astral_to_standard(const region * r)
|
||||||
region *r2;
|
region *r2;
|
||||||
|
|
||||||
assert(is_astral(r));
|
assert(is_astral(r));
|
||||||
x = (r->x - TE_CENTER_X) * TP_DISTANCE;
|
x = (r->x - TE_CENTER) * TP_DISTANCE;
|
||||||
y = (r->y - TE_CENTER_Y) * TP_DISTANCE;
|
y = (r->y - TE_CENTER) * TP_DISTANCE;
|
||||||
pnormalize(&x, &y, NULL);
|
pnormalize(&x, &y, NULL);
|
||||||
r2 = findregion(x, y);
|
r2 = findregion(x, y);
|
||||||
if (r2 == NULL || rplane(r2))
|
if (r2 == NULL || rplane(r2))
|
||||||
|
@ -188,8 +187,8 @@ plane *get_astralplane(void)
|
||||||
astralspace = getplanebyname("Astralraum");
|
astralspace = getplanebyname("Astralraum");
|
||||||
if (!astralspace) {
|
if (!astralspace) {
|
||||||
astralspace = create_new_plane(1, "Astralraum",
|
astralspace = create_new_plane(1, "Astralraum",
|
||||||
TE_CENTER_X - 500, TE_CENTER_X + 500,
|
TE_CENTER - 500, TE_CENTER + 500,
|
||||||
TE_CENTER_Y - 500, TE_CENTER_Y + 500, 0);
|
TE_CENTER - 500, TE_CENTER + 500, 0);
|
||||||
}
|
}
|
||||||
return astralspace;
|
return astralspace;
|
||||||
}
|
}
|
||||||
|
@ -208,8 +207,8 @@ void create_teleport_plane(void)
|
||||||
region *ra = tpregion(r);
|
region *ra = tpregion(r);
|
||||||
|
|
||||||
if (ra == NULL) {
|
if (ra == NULL) {
|
||||||
int x = TE_CENTER_X + real2tp(r->x);
|
int x = real2tp(r->x);
|
||||||
int y = TE_CENTER_Y + real2tp(r->y);
|
int y = real2tp(r->y);
|
||||||
pnormalize(&x, &y, aplane);
|
pnormalize(&x, &y, aplane);
|
||||||
|
|
||||||
ra = new_region(x, y, aplane, 0);
|
ra = new_region(x, y, aplane, 0);
|
||||||
|
|
|
@ -18,24 +18,32 @@ OR IN CONNECTION WITH THE USE OR PERFORMANCE OF THIS SOFTWARE.
|
||||||
|
|
||||||
#ifndef TELEPORT_H
|
#ifndef TELEPORT_H
|
||||||
#define TELEPORT_H
|
#define TELEPORT_H
|
||||||
|
|
||||||
|
#include <stdbool.h>
|
||||||
|
|
||||||
#ifdef __cplusplus
|
#ifdef __cplusplus
|
||||||
extern "C" {
|
extern "C" {
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
|
struct region;
|
||||||
|
struct region_list;
|
||||||
|
struct plane;
|
||||||
|
|
||||||
struct region *r_standard_to_astral(const struct region *r);
|
struct region *r_standard_to_astral(const struct region *r);
|
||||||
struct region *r_astral_to_standard(const struct region *);
|
struct region *r_astral_to_standard(const struct region *);
|
||||||
extern struct region_list *astralregions(const struct region *rastral,
|
struct region_list *astralregions(const struct region *rastral,
|
||||||
bool(*valid) (const struct region *));
|
bool(*valid) (const struct region *));
|
||||||
extern struct region_list *all_in_range(const struct region *r, int n,
|
struct region_list *all_in_range(const struct region *r, int n,
|
||||||
bool(*valid) (const struct region *));
|
bool(*valid) (const struct region *));
|
||||||
extern bool inhabitable(const struct region *r);
|
bool inhabitable(const struct region *r);
|
||||||
extern bool is_astral(const struct region *r);
|
bool is_astral(const struct region *r);
|
||||||
extern struct plane *get_astralplane(void);
|
struct plane *get_astralplane(void);
|
||||||
|
|
||||||
void create_teleport_plane(void);
|
void create_teleport_plane(void);
|
||||||
void set_teleport_plane_regiontypes(void);
|
|
||||||
void spawn_braineaters(float chance);
|
void spawn_braineaters(float chance);
|
||||||
|
|
||||||
|
int real2tp(int rk);
|
||||||
|
|
||||||
#ifdef __cplusplus
|
#ifdef __cplusplus
|
||||||
}
|
}
|
||||||
#endif
|
#endif
|
||||||
|
|
Loading…
Reference in a new issue