test: Implement UsageData model tests
This commit is contained in:
52
packages/backend/src/models/usage-data.ee.test.js
Normal file
52
packages/backend/src/models/usage-data.ee.test.js
Normal file
@@ -0,0 +1,52 @@
|
||||
import { describe, it, expect } from 'vitest';
|
||||
import UsageData from './usage-data.ee';
|
||||
import User from './user';
|
||||
import Subscription from './subscription.ee';
|
||||
import Base from './base';
|
||||
import { createUsageData } from '../../test/factories/usage-data';
|
||||
|
||||
describe('UsageData model', () => {
|
||||
it('tableName should return correct name', () => {
|
||||
expect(UsageData.tableName).toBe('usage_data');
|
||||
});
|
||||
|
||||
it('jsonSchema should have correct validations', () => {
|
||||
expect(UsageData.jsonSchema).toMatchSnapshot();
|
||||
});
|
||||
|
||||
it('relationMappings should return correct associations', () => {
|
||||
const relationMappings = UsageData.relationMappings();
|
||||
|
||||
const expectedRelations = {
|
||||
user: {
|
||||
relation: Base.BelongsToOneRelation,
|
||||
modelClass: User,
|
||||
join: {
|
||||
from: 'usage_data.user_id',
|
||||
to: 'users.id',
|
||||
},
|
||||
},
|
||||
subscription: {
|
||||
relation: Base.BelongsToOneRelation,
|
||||
modelClass: Subscription,
|
||||
join: {
|
||||
from: 'usage_data.subscription_id',
|
||||
to: 'subscriptions.id',
|
||||
},
|
||||
},
|
||||
};
|
||||
|
||||
expect(relationMappings).toStrictEqual(expectedRelations);
|
||||
});
|
||||
|
||||
it('increaseConsumedTaskCountByOne should increase consumed task count by one', async () => {
|
||||
const usageData = await createUsageData({
|
||||
consumedTaskCount: 1234,
|
||||
});
|
||||
|
||||
await usageData.increaseConsumedTaskCountByOne();
|
||||
const refetchedUsageData = await usageData.$query();
|
||||
|
||||
expect(refetchedUsageData.consumedTaskCount).toStrictEqual(1235);
|
||||
});
|
||||
});
|
||||
Reference in New Issue
Block a user