mirror of
https://github.com/HabitRPG/habitica.git
synced 2025-10-26 18:52:37 +01:00
* content: add gems blocks * gemsBlocks: include ios and android identifiers * wip: promo code * split common constants into multiple files * add second promo part * geCurrentEvent, refactor promo * fix lint * fix exports, use world state api * start adding world state tests * remove console.log * use gems block for purchases * remove comments * fix most unit tests * restore comment * fix lint * prevent apple/google gift tests from breaking other tests when stub is not reset * fix unit tests, clarify tests names * iap: use gift object when gifting gems * allow gift object with less data * fix iap tests, remove findById stubs * iap: require less data from the mobile apps * apply discounts * add missing worldState file * fix lint * add test event * start removing 20 gems option for web * start adding support for all gems packages on web * fix unit tests for apple, stripe and google * amazon: support all gems blocks * paypal: support all gems blocks * fix payments unit tests, add tests for getGemsBlock * web: add gems plans with discounts, update stripe * fix amazon and paypal clients, payments success modals * amazon pay: disabled state * update icons, start abstracting payments buttons * begin redesign * redesign gems modal * fix buttons * fix hover color for gems modal close icon * add key to world state current event * extend test event length * implement gems modals designs * early test fall2020 * fix header banner position * add missing files * use iso 8601 for dates, minor ui fixes * fix time zones * events: fix ISO8601 format * fix css indentation * start abstracting banners * refactor payments buttons * test spooky, fix group plans box * implement gems promo banners, refactor banners, fixes * fix lint * fix dates * remove unused i18n strings * fix stripe integration test * fix world state integration tests * the current active event * add missing unit tests * add storybook story for payments buttons component * fix typo * fix(stripe): correct label when gifting subscriptions
127 lines
4.4 KiB
JavaScript
127 lines
4.4 KiB
JavaScript
/* eslint-disable camelcase */
|
|
import paypalPayments from '../../../../../../website/server/libs/payments/paypal';
|
|
import payments from '../../../../../../website/server/libs/payments/payments';
|
|
import {
|
|
generateGroup,
|
|
} from '../../../../../helpers/api-unit.helper';
|
|
import { model as User } from '../../../../../../website/server/models/user';
|
|
import common from '../../../../../../website/common';
|
|
import { createNonLeaderGroupMember } from '../paymentHelpers';
|
|
|
|
const { i18n } = common;
|
|
|
|
describe('paypal - subscribeCancel', () => {
|
|
const subKey = 'basic_3mo';
|
|
let user; let group; let groupId; let customerId; let groupCustomerId; let
|
|
nextBillingDate;
|
|
let paymentCancelSubscriptionSpy; let paypalBillingAgreementCancelStub; let
|
|
paypalBillingAgreementGetStub;
|
|
|
|
beforeEach(async () => {
|
|
customerId = 'customer-id';
|
|
groupCustomerId = 'groupCustomerId-test';
|
|
|
|
user = new User();
|
|
user.profile.name = 'sender';
|
|
user.purchased.plan.customerId = customerId;
|
|
user.purchased.plan.planId = subKey;
|
|
user.purchased.plan.lastBillingDate = new Date();
|
|
|
|
group = generateGroup({
|
|
name: 'test group',
|
|
type: 'guild',
|
|
privacy: 'public',
|
|
leader: user._id,
|
|
});
|
|
group.purchased.plan.customerId = groupCustomerId;
|
|
group.purchased.plan.planId = subKey;
|
|
group.purchased.plan.lastBillingDate = new Date();
|
|
await group.save();
|
|
|
|
nextBillingDate = new Date();
|
|
|
|
paypalBillingAgreementCancelStub = sinon.stub(paypalPayments, 'paypalBillingAgreementCancel').resolves({});
|
|
paypalBillingAgreementGetStub = sinon.stub(paypalPayments, 'paypalBillingAgreementGet')
|
|
.resolves({
|
|
agreement_details: {
|
|
next_billing_date: nextBillingDate,
|
|
cycles_completed: 1,
|
|
},
|
|
});
|
|
paymentCancelSubscriptionSpy = sinon.stub(payments, 'cancelSubscription').resolves({});
|
|
});
|
|
|
|
afterEach(() => {
|
|
paypalPayments.paypalBillingAgreementGet.restore();
|
|
paypalPayments.paypalBillingAgreementCancel.restore();
|
|
payments.cancelSubscription.restore();
|
|
});
|
|
|
|
it('should throw an error if we are missing a subscription', async () => {
|
|
user.purchased.plan.customerId = undefined;
|
|
|
|
await expect(paypalPayments.subscribeCancel({ user }))
|
|
.to.eventually.be.rejected.and.to.eql({
|
|
httpCode: 401,
|
|
name: 'NotAuthorized',
|
|
message: i18n.t('missingSubscription'),
|
|
});
|
|
});
|
|
|
|
it('should throw an error if group is not found', async () => {
|
|
await expect(paypalPayments.subscribeCancel({ user, groupId: 'fake-id' }))
|
|
.to.eventually.be.rejected.and.to.eql({
|
|
httpCode: 404,
|
|
name: 'NotFound',
|
|
message: i18n.t('groupNotFound'),
|
|
});
|
|
});
|
|
|
|
it('should throw an error if user is not group leader', async () => {
|
|
const nonLeader = await createNonLeaderGroupMember(group);
|
|
|
|
await expect(paypalPayments.subscribeCancel({ user: nonLeader, groupId: group._id }))
|
|
.to.eventually.be.rejected.and.to.eql({
|
|
httpCode: 401,
|
|
name: 'NotAuthorized',
|
|
message: i18n.t('onlyGroupLeaderCanManageSubscription'),
|
|
});
|
|
});
|
|
|
|
it('should cancel a user subscription', async () => {
|
|
await paypalPayments.subscribeCancel({ user });
|
|
|
|
expect(paypalBillingAgreementGetStub).to.be.calledOnce;
|
|
expect(paypalBillingAgreementGetStub).to.be.calledWith(customerId);
|
|
expect(paypalBillingAgreementCancelStub).to.be.calledOnce;
|
|
expect(paypalBillingAgreementCancelStub).to.be.calledWith(customerId, { note: i18n.t('cancelingSubscription') });
|
|
|
|
expect(paymentCancelSubscriptionSpy).to.be.calledOnce;
|
|
expect(paymentCancelSubscriptionSpy).to.be.calledWith({
|
|
user,
|
|
groupId,
|
|
paymentMethod: 'Paypal',
|
|
nextBill: nextBillingDate,
|
|
cancellationReason: undefined,
|
|
});
|
|
});
|
|
|
|
it('should cancel a group subscription', async () => {
|
|
await paypalPayments.subscribeCancel({ user, groupId: group._id });
|
|
|
|
expect(paypalBillingAgreementGetStub).to.be.calledOnce;
|
|
expect(paypalBillingAgreementGetStub).to.be.calledWith(groupCustomerId);
|
|
expect(paypalBillingAgreementCancelStub).to.be.calledOnce;
|
|
expect(paypalBillingAgreementCancelStub).to.be.calledWith(groupCustomerId, { note: i18n.t('cancelingSubscription') });
|
|
|
|
expect(paymentCancelSubscriptionSpy).to.be.calledOnce;
|
|
expect(paymentCancelSubscriptionSpy).to.be.calledWith({
|
|
user,
|
|
groupId: group._id,
|
|
paymentMethod: 'Paypal',
|
|
nextBill: nextBillingDate,
|
|
cancellationReason: undefined,
|
|
});
|
|
});
|
|
});
|