mirror of
https://github.com/HabitRPG/habitica.git
synced 2025-12-18 15:17:25 +01:00
v3: several fixes to class system, move /logout outside of api
This commit is contained in:
@@ -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);
|
||||
});
|
||||
});
|
||||
|
||||
Reference in New Issue
Block a user