test: feedback updated on test script

This commit is contained in:
Mir Arif Hasan
2023-01-23 21:32:00 +06:00
parent bfac3f8ad0
commit 3cd9639f34
4 changed files with 21 additions and 28 deletions

View File

@@ -165,7 +165,7 @@ export const TEAM_ENVIRONMENT_NOT_TEAM_MEMBER =
* User setting not found for a user * User setting not found for a user
* (UserSettingsService) * (UserSettingsService)
*/ */
export const USER_SETTINGS_DATA_NOT_FOUND = 'user_settings/data_not_found' as const; export const USER_SETTINGS_NOT_FOUND = 'user_settings/not_found' as const;
/** /**
* User setting not found for a user * User setting not found for a user

View File

@@ -7,8 +7,6 @@ export type TopicDef = {
[ [
topic: `user_environment/${string}/${'created' | 'updated' | 'deleted'}` topic: `user_environment/${string}/${'created' | 'updated' | 'deleted'}`
]: UserEnvironment; ]: UserEnvironment;
[ [topic: `user_settings/${string}/${'created' | 'updated'}`]: UserSettings;
topic: `user_settings/${string}/${'created' | 'updated' | 'deleted'}`
]: UserSettings;
[topic: `user_environment/${string}/deleted_many`]: number; [topic: `user_environment/${string}/deleted_many`]: number;
}; };

View File

@@ -2,12 +2,7 @@ import { mockDeep, mockReset } from 'jest-mock-extended';
import { PrismaService } from 'src/prisma/prisma.service'; import { PrismaService } from 'src/prisma/prisma.service';
import { PubSubService } from 'src/pubsub/pubsub.service'; import { PubSubService } from 'src/pubsub/pubsub.service';
import { UserSettingsService } from './user-settings.service'; import { UserSettingsService } from './user-settings.service';
import { import { JSON_INVALID, USER_SETTINGS_NULL_SETTINGS } from 'src/errors';
JSON_INVALID,
USER_NOT_FOUND,
USER_SETTINGS_NULL_SETTINGS,
USER_SETTINGS_DATA_NOT_FOUND,
} from 'src/errors';
import { UserSettings } from './user-settings.model'; import { UserSettings } from './user-settings.model';
import { User } from 'src/user/user.model'; import { User } from 'src/user/user.model';
@@ -30,7 +25,7 @@ const user: User = {
const settings: UserSettings = { const settings: UserSettings = {
id: '1', id: '1',
userUid: user.uid, userUid: user.uid,
userSettings: JSON.stringify({ key: 'k', value: 'v' }), properties: JSON.stringify({ key: 'k', value: 'v' }),
updatedOn: new Date('2022-12-19T12:43:18.635Z'), updatedOn: new Date('2022-12-19T12:43:18.635Z'),
}; };
@@ -41,20 +36,20 @@ beforeEach(() => {
describe('UserSettingsService', () => { describe('UserSettingsService', () => {
describe('createUserSettings', () => { describe('createUserSettings', () => {
test('should create a user setting with valid user and properties', async () => { test('Should resolve right and create an user setting with valid user and properties', async () => {
mockPrisma.userSettings.create.mockResolvedValue({ mockPrisma.userSettings.create.mockResolvedValue({
...settings, ...settings,
settings: JSON.parse(settings.userSettings), properties: JSON.parse(settings.properties),
}); });
const result = await userSettingsService.createUserSettings( const result = await userSettingsService.createUserSettings(
user, user,
settings.userSettings, settings.properties,
); );
expect(result).toEqualRight(settings); expect(result).toEqualRight(settings);
}); });
test('should reject for invalid properties', async () => { test('Should reject user settings creation for invalid properties', async () => {
const result = await userSettingsService.createUserSettings( const result = await userSettingsService.createUserSettings(
user, user,
'invalid-settings', 'invalid-settings',
@@ -62,7 +57,7 @@ describe('UserSettingsService', () => {
expect(result).toEqualLeft(JSON_INVALID); expect(result).toEqualLeft(JSON_INVALID);
}); });
test('should reject for null settings', async () => { test('Should reject user settings creation for null properties', async () => {
const result = await userSettingsService.createUserSettings( const result = await userSettingsService.createUserSettings(
user, user,
null as any, null as any,
@@ -72,20 +67,20 @@ describe('UserSettingsService', () => {
}); });
}); });
describe('updateUserSettings', () => { describe('updateUserSettings', () => {
test('should update a user setting for valid user and settings', async () => { test('Should update a user setting for valid user and settings', async () => {
mockPrisma.userSettings.update.mockResolvedValue({ mockPrisma.userSettings.update.mockResolvedValue({
...settings, ...settings,
settings: JSON.parse(settings.userSettings), properties: JSON.parse(settings.properties),
}); });
const result = await userSettingsService.updateUserSettings( const result = await userSettingsService.updateUserSettings(
user, user,
settings.userSettings, settings.properties,
); );
expect(result).toEqualRight(settings); expect(result).toEqualRight(settings);
}); });
test('should reject for invalid stringified JSON settings', async () => { test('Should reject user settings updation for invalid stringified JSON settings', async () => {
const result = await userSettingsService.updateUserSettings( const result = await userSettingsService.updateUserSettings(
user, user,
'invalid-settings', 'invalid-settings',
@@ -93,7 +88,7 @@ describe('UserSettingsService', () => {
expect(result).toEqualLeft(JSON_INVALID); expect(result).toEqualLeft(JSON_INVALID);
}); });
test('should reject for null settings', async () => { test('Should reject user settings updation for null properties', async () => {
const result = await userSettingsService.updateUserSettings( const result = await userSettingsService.updateUserSettings(
user, user,
null as any, null as any,
@@ -103,10 +98,10 @@ describe('UserSettingsService', () => {
test('should publish message over pubsub on successful update', async () => { test('should publish message over pubsub on successful update', async () => {
mockPrisma.userSettings.update.mockResolvedValue({ mockPrisma.userSettings.update.mockResolvedValue({
...settings, ...settings,
settings: JSON.parse(settings.userSettings), properties: JSON.parse(settings.properties),
}); });
await userSettingsService.updateUserSettings(user, settings.userSettings); await userSettingsService.updateUserSettings(user, settings.properties);
expect(mockPubSub.publish).toBeCalledWith( expect(mockPubSub.publish).toBeCalledWith(
`user_settings/${user.uid}/updated`, `user_settings/${user.uid}/updated`,

View File

@@ -8,7 +8,7 @@ import { UserSettings } from './user-settings.model';
import { import {
USER_SETTINGS_ALREADY_EXISTS, USER_SETTINGS_ALREADY_EXISTS,
USER_SETTINGS_NULL_SETTINGS, USER_SETTINGS_NULL_SETTINGS,
USER_SETTINGS_DATA_NOT_FOUND, USER_SETTINGS_NOT_FOUND,
} from 'src/errors'; } from 'src/errors';
@Injectable() @Injectable()
@@ -36,7 +36,7 @@ export class UserSettingsService {
return E.right(settings); return E.right(settings);
} catch (e) { } catch (e) {
return E.left(USER_SETTINGS_DATA_NOT_FOUND); return E.left(USER_SETTINGS_NOT_FOUND);
} }
} }
@@ -65,7 +65,7 @@ export class UserSettingsService {
properties: JSON.stringify(userSettings.properties), properties: JSON.stringify(userSettings.properties),
}; };
// Publish subscription for environment creation // Publish subscription for user settings creation
await this.pubsub.publish(`user_settings/${user.uid}/created`, settings); await this.pubsub.publish(`user_settings/${user.uid}/created`, settings);
return E.right(settings); return E.right(settings);
@@ -99,12 +99,12 @@ export class UserSettingsService {
properties: JSON.stringify(updatedUserSettings.properties), properties: JSON.stringify(updatedUserSettings.properties),
}; };
// Publish subscription for environment creation // Publish subscription for user settings update
await this.pubsub.publish(`user_settings/${user.uid}/updated`, settings); await this.pubsub.publish(`user_settings/${user.uid}/updated`, settings);
return E.right(settings); return E.right(settings);
} catch (e) { } catch (e) {
return E.left(USER_SETTINGS_DATA_NOT_FOUND); return E.left(USER_SETTINGS_NOT_FOUND);
} }
} }
} }