v3: several fixes to class system, move /logout outside of api

This commit is contained in:
Matteo Pagliazzi
2016-04-14 20:05:30 +02:00
parent 7562a589c5
commit 11b5c1b405
9 changed files with 109 additions and 55 deletions

View File

@@ -12,9 +12,36 @@ describe('shared.ops.changeClass', () => {
beforeEach(() => {
user = generateUser();
user.stats.lvl = 11;
user.stats.flagSelected = false;
});
it('user is not level 10', (done) => {
user.stats.lvl = 9;
try {
changeClass(user, {query: {class: 'rogue'}});
} catch (err) {
expect(err).to.be.an.instanceof(NotAuthorized);
expect(err.message).to.equal(i18n.t('lvl10ChangeClass'));
done();
}
});
context('req.query.class is a valid class', () => {
it('errors if user.stats.flagSelected is true and user.balance < 0.75', (done) => {
user.flags.classSelected = true;
user.preferences.disableClasses = false;
user.balance = 0;
try {
changeClass(user, {query: {class: 'rogue'}});
} catch (err) {
expect(err).to.be.an.instanceof(NotAuthorized);
expect(err.message).to.equal(i18n.t('notEnoughGems'));
done();
}
});
it('changes class', () => {
user.stats.class = 'healer';
user.items.gear.owned.armor_rogue_1 = true; // eslint-disable-line camelcase
@@ -41,13 +68,12 @@ describe('shared.ops.changeClass', () => {
});
});
context('req.query.class is missing', () => {
context('req.query.class is missing or user.stats.flagSelected is true', () => {
it('has user.preferences.disableClasses === true', () => {
user.balance = 1;
user.preferences.disableClasses = true;
user.preferences.autoAllocate = true;
user.stats.points = 45;
user.stats.lvl = 3;
user.stats.str = 1;
user.stats.con = 2;
user.stats.per = 3;
@@ -71,7 +97,7 @@ describe('shared.ops.changeClass', () => {
expect(user.stats.con).to.equal(0);
expect(user.stats.per).to.equal(0);
expect(user.stats.int).to.equal(0);
expect(user.stats.points).to.equal(3);
expect(user.stats.points).to.equal(11);
expect(user.flags.classSelected).to.equal(false);
});
@@ -90,7 +116,6 @@ describe('shared.ops.changeClass', () => {
it('and at least 3 gems', () => {
user.balance = 1;
user.stats.points = 45;
user.stats.lvl = 3;
user.stats.str = 1;
user.stats.con = 2;
user.stats.per = 3;
@@ -112,7 +137,7 @@ describe('shared.ops.changeClass', () => {
expect(user.stats.con).to.equal(0);
expect(user.stats.per).to.equal(0);
expect(user.stats.int).to.equal(0);
expect(user.stats.points).to.equal(3);
expect(user.stats.points).to.equal(11);
expect(user.flags.classSelected).to.equal(false);
});
});