2020-07-23 19:21:10 +03:00
|
|
|
const should = require('should');
|
|
|
|
const BaseModel = require('../../../core/server/models/base');
|
|
|
|
const {Label} = require('../../../core/server/models/label');
|
|
|
|
const {Member} = require('../../../core/server/models/member');
|
|
|
|
const {MemberStripeCustomer} = require('../../../core/server/models/member-stripe-customer');
|
|
|
|
const {StripeCustomerSubscription} = require('../../../core/server/models/stripe-customer-subscription');
|
|
|
|
|
|
|
|
const testUtils = require('../../utils');
|
|
|
|
|
|
|
|
describe('Member Model', function run() {
|
|
|
|
before(testUtils.teardownDb);
|
|
|
|
beforeEach(testUtils.setup('roles'));
|
|
|
|
afterEach(testUtils.teardownDb);
|
|
|
|
|
2020-08-12 16:17:44 +03:00
|
|
|
describe('stripeSubscriptions', function () {
|
|
|
|
it('It is correctly mapped to all a members subscriptions, regardless of customer', async function () {
|
|
|
|
const context = testUtils.context.admin;
|
|
|
|
await Member.add({
|
|
|
|
email: 'test@test.member',
|
|
|
|
labels: []
|
|
|
|
}, context);
|
|
|
|
const member = await Member.findOne({
|
|
|
|
email: 'test@test.member'
|
|
|
|
}, context);
|
|
|
|
|
|
|
|
should.exist(member, 'Member should have been created');
|
|
|
|
|
|
|
|
await MemberStripeCustomer.add({
|
|
|
|
member_id: member.get('id'),
|
|
|
|
customer_id: 'fake_customer_id1'
|
|
|
|
}, context);
|
|
|
|
|
|
|
|
await MemberStripeCustomer.add({
|
|
|
|
member_id: member.get('id'),
|
|
|
|
customer_id: 'fake_customer_id2'
|
|
|
|
}, context);
|
|
|
|
|
|
|
|
await StripeCustomerSubscription.add({
|
|
|
|
customer_id: 'fake_customer_id1',
|
|
|
|
subscription_id: 'fake_subscription_id1',
|
|
|
|
plan_id: 'fake_plan_id',
|
|
|
|
plan_amount: 1337,
|
|
|
|
plan_nickname: 'e-LEET',
|
|
|
|
plan_interval: 'year',
|
|
|
|
plan_currency: 'btc',
|
|
|
|
status: 'active',
|
|
|
|
start_date: new Date(),
|
|
|
|
current_period_end: new Date(),
|
|
|
|
cancel_at_period_end: false
|
|
|
|
}, context);
|
|
|
|
|
|
|
|
await StripeCustomerSubscription.add({
|
|
|
|
customer_id: 'fake_customer_id2',
|
|
|
|
subscription_id: 'fake_subscription_id2',
|
|
|
|
plan_id: 'fake_plan_id',
|
|
|
|
plan_amount: 1337,
|
|
|
|
plan_nickname: 'e-LEET',
|
|
|
|
plan_interval: 'year',
|
|
|
|
plan_currency: 'btc',
|
|
|
|
status: 'active',
|
|
|
|
start_date: new Date(),
|
|
|
|
current_period_end: new Date(),
|
|
|
|
cancel_at_period_end: false
|
|
|
|
}, context);
|
|
|
|
|
|
|
|
const memberWithRelations = await Member.findOne({
|
|
|
|
email: 'test@test.member'
|
|
|
|
}, Object.assign({
|
|
|
|
withRelated: [
|
|
|
|
'stripeSubscriptions',
|
|
|
|
'stripeSubscriptions.customer'
|
|
|
|
]
|
|
|
|
}, context));
|
|
|
|
|
|
|
|
const subscriptions = memberWithRelations.related('stripeSubscriptions').toJSON();
|
|
|
|
|
|
|
|
const subscription1 = subscriptions.find(({id}) => id === 'fake_subscription_id1');
|
|
|
|
const subscription2 = subscriptions.find(({id}) => id === 'fake_subscription_id2');
|
|
|
|
|
|
|
|
should.exist(subscription1);
|
|
|
|
should.exist(subscription2);
|
|
|
|
});
|
|
|
|
});
|
|
|
|
|
2020-07-23 19:21:10 +03:00
|
|
|
describe('stripeCustomers', function () {
|
|
|
|
it('Is correctly mapped to the stripe customers', async function () {
|
|
|
|
const context = testUtils.context.admin;
|
|
|
|
await Member.add({
|
|
|
|
email: 'test@test.member',
|
|
|
|
stripeCustomers: [{
|
|
|
|
customer_id: 'fake_customer_id1'
|
|
|
|
}]
|
|
|
|
}, context);
|
|
|
|
|
|
|
|
const customer1 = await MemberStripeCustomer.findOne({
|
|
|
|
customer_id: 'fake_customer_id1'
|
|
|
|
}, context);
|
|
|
|
|
|
|
|
should.exist(customer1, 'MemberStripeCustomer should have been created');
|
|
|
|
|
|
|
|
await MemberStripeCustomer.add({
|
|
|
|
member_id: customer1.get('member_id'),
|
|
|
|
customer_id: 'fake_customer_id2'
|
|
|
|
}, context);
|
|
|
|
|
|
|
|
const member = await Member.findOne({
|
|
|
|
email: 'test@test.member'
|
|
|
|
}, Object.assign({}, context, {
|
|
|
|
withRelated: ['stripeCustomers']
|
|
|
|
}));
|
|
|
|
|
|
|
|
should.exist(member.related('stripeCustomers'), 'Member should have been fetched with stripeCustomers');
|
|
|
|
|
|
|
|
const stripeCustomers = member.related('stripeCustomers');
|
|
|
|
|
|
|
|
should.equal(stripeCustomers.length, 2, 'Should be two stripeCustomers');
|
|
|
|
|
|
|
|
should.equal(stripeCustomers.models[0].get('customer_id'), 'fake_customer_id1');
|
|
|
|
should.equal(stripeCustomers.models[1].get('customer_id'), 'fake_customer_id2');
|
|
|
|
});
|
|
|
|
});
|
|
|
|
|
|
|
|
describe('destroy', function () {
|
|
|
|
it('Cascades to members_labels, members_stripe_customers & members_stripe_customers_subscriptions', async function () {
|
|
|
|
const context = testUtils.context.admin;
|
|
|
|
await Member.add({
|
|
|
|
email: 'test@test.member',
|
|
|
|
labels: [{
|
|
|
|
name: 'A label',
|
|
|
|
slug: 'a-unique-slug-for-testing-members-model'
|
|
|
|
}]
|
|
|
|
}, context);
|
|
|
|
const member = await Member.findOne({
|
|
|
|
email: 'test@test.member'
|
|
|
|
}, context);
|
|
|
|
|
|
|
|
should.exist(member, 'Member should have been created');
|
|
|
|
|
|
|
|
const label = await Label.findOne({
|
|
|
|
slug: 'a-unique-slug-for-testing-members-model'
|
|
|
|
}, context);
|
|
|
|
|
|
|
|
should.exist(label, 'Label should have been created');
|
|
|
|
|
|
|
|
const memberLabel = await BaseModel.knex('members_labels').where({
|
|
|
|
label_id: label.get('id'),
|
|
|
|
member_id: member.get('id')
|
|
|
|
}).select().first();
|
|
|
|
|
|
|
|
should.exist(memberLabel, 'Label should have been attached to member');
|
|
|
|
|
|
|
|
await MemberStripeCustomer.add({
|
|
|
|
member_id: member.get('id'),
|
|
|
|
customer_id: 'fake_customer_id'
|
|
|
|
}, context);
|
|
|
|
|
|
|
|
const customer = await MemberStripeCustomer.findOne({
|
|
|
|
member_id: member.get('id')
|
|
|
|
}, context);
|
|
|
|
|
|
|
|
should.exist(customer, 'Customer should have been created');
|
|
|
|
|
|
|
|
await StripeCustomerSubscription.add({
|
|
|
|
customer_id: 'fake_customer_id',
|
|
|
|
subscription_id: 'fake_subscription_id',
|
|
|
|
plan_id: 'fake_plan_id',
|
|
|
|
plan_amount: 1337,
|
|
|
|
plan_nickname: 'e-LEET',
|
|
|
|
plan_interval: 'year',
|
|
|
|
plan_currency: 'btc',
|
|
|
|
status: 'active',
|
|
|
|
start_date: new Date(),
|
|
|
|
current_period_end: new Date(),
|
|
|
|
cancel_at_period_end: false
|
|
|
|
}, context);
|
|
|
|
|
|
|
|
const subscription = await StripeCustomerSubscription.findOne({
|
|
|
|
customer_id: customer.get('customer_id')
|
|
|
|
}, context);
|
|
|
|
|
|
|
|
should.exist(subscription, 'Subscription should have been created');
|
|
|
|
|
|
|
|
await Member.destroy(Object.assign({
|
|
|
|
id: member.get('id')
|
|
|
|
}, context));
|
|
|
|
|
|
|
|
const memberAfterDestroy = await Member.findOne({
|
|
|
|
email: 'test@test.member'
|
|
|
|
});
|
|
|
|
should.not.exist(memberAfterDestroy, 'Member should have been destroyed');
|
|
|
|
|
|
|
|
const memberLabelAfterDestroy = await BaseModel.knex('members_labels').where({
|
|
|
|
label_id: label.get('id'),
|
|
|
|
member_id: member.get('id')
|
|
|
|
}).select().first();
|
|
|
|
should.not.exist(memberLabelAfterDestroy, 'Label should have been removed from member');
|
|
|
|
|
|
|
|
const customerAfterDestroy = await MemberStripeCustomer.findOne({
|
|
|
|
member_id: member.get('id')
|
|
|
|
});
|
|
|
|
should.not.exist(customerAfterDestroy, 'MemberStripeCustomer should have been destroyed');
|
|
|
|
|
|
|
|
const subscriptionAfterDestroy = await StripeCustomerSubscription.findOne({
|
|
|
|
customer_id: customer.get('customer_id')
|
|
|
|
});
|
|
|
|
should.not.exist(subscriptionAfterDestroy, 'StripeCustomerSubscription should have been destroyed');
|
|
|
|
});
|
|
|
|
});
|
2020-08-27 02:41:22 +03:00
|
|
|
|
|
|
|
describe('findAll', function () {
|
|
|
|
beforeEach(testUtils.setup('members'));
|
|
|
|
|
|
|
|
it('can use custom query', function (done) {
|
|
|
|
Member.findAll().then(function (allResult) {
|
|
|
|
allResult.length.should.equal(3);
|
|
|
|
|
|
|
|
return Member.findAll({paid: true});
|
|
|
|
}).then(function (queryResult) {
|
|
|
|
queryResult.length.should.equal(1);
|
|
|
|
queryResult.models[0].get('email').should.equal('paid@test.com');
|
|
|
|
|
|
|
|
done();
|
|
|
|
}).catch(done);
|
|
|
|
});
|
|
|
|
|
|
|
|
it('can use search query', function (done) {
|
|
|
|
Member.findAll({search: 'egg'}).then(function (queryResult) {
|
|
|
|
queryResult.length.should.equal(1);
|
|
|
|
queryResult.models[0].get('name').should.equal('Mr Egg');
|
|
|
|
done();
|
|
|
|
}).catch(done);
|
|
|
|
});
|
|
|
|
});
|
2020-07-23 19:21:10 +03:00
|
|
|
});
|
|
|
|
|