|
@@ -2,7 +2,11 @@ import { mockDeep, mockReset } from 'jest-mock-extended';
|
|
|
import { PrismaService } from 'src/prisma/prisma.service';
|
|
|
import { TeamEnvironment } from './team-environments.model';
|
|
|
import { TeamEnvironmentsService } from './team-environments.service';
|
|
|
-import { TEAM_ENVIRONMENT_NOT_FOUND } from 'src/errors';
|
|
|
+import {
|
|
|
+ JSON_INVALID,
|
|
|
+ TEAM_ENVIRONMENT_NOT_FOUND,
|
|
|
+ TEAM_ENVIRONMENT_SHORT_NAME,
|
|
|
+} from 'src/errors';
|
|
|
|
|
|
const mockPrisma = mockDeep<PrismaService>();
|
|
|
|
|
@@ -31,125 +35,81 @@ beforeEach(() => {
|
|
|
|
|
|
describe('TeamEnvironmentsService', () => {
|
|
|
describe('getTeamEnvironment', () => {
|
|
|
- test('queries the db with the id', async () => {
|
|
|
- mockPrisma.teamEnvironment.findFirst.mockResolvedValue(teamEnvironment);
|
|
|
-
|
|
|
- await teamEnvironmentsService.getTeamEnvironment('123')();
|
|
|
-
|
|
|
- expect(mockPrisma.teamEnvironment.findFirst).toHaveBeenCalledWith(
|
|
|
- expect.objectContaining({
|
|
|
- where: {
|
|
|
- id: '123',
|
|
|
- },
|
|
|
- }),
|
|
|
+ test('should successfully return a TeamEnvironment with valid ID', async () => {
|
|
|
+ mockPrisma.teamEnvironment.findFirstOrThrow.mockResolvedValueOnce(
|
|
|
+ teamEnvironment,
|
|
|
);
|
|
|
- });
|
|
|
-
|
|
|
- test('requests prisma to reject the query promise if not found', async () => {
|
|
|
- mockPrisma.teamEnvironment.findFirst.mockResolvedValue(teamEnvironment);
|
|
|
|
|
|
- await teamEnvironmentsService.getTeamEnvironment('123')();
|
|
|
-
|
|
|
- expect(mockPrisma.teamEnvironment.findFirst).toHaveBeenCalledWith(
|
|
|
- expect.objectContaining({
|
|
|
- rejectOnNotFound: true,
|
|
|
- }),
|
|
|
+ const result = await teamEnvironmentsService.getTeamEnvironment(
|
|
|
+ teamEnvironment.id,
|
|
|
);
|
|
|
+ expect(result).toEqualRight(teamEnvironment);
|
|
|
});
|
|
|
|
|
|
- test('should return a Some of the correct environment if exists', async () => {
|
|
|
- mockPrisma.teamEnvironment.findFirst.mockResolvedValue(teamEnvironment);
|
|
|
-
|
|
|
- const result = await teamEnvironmentsService.getTeamEnvironment('123')();
|
|
|
-
|
|
|
- expect(result).toEqualSome(teamEnvironment);
|
|
|
- });
|
|
|
-
|
|
|
- test('should return a None if the environment does not exist', async () => {
|
|
|
- mockPrisma.teamEnvironment.findFirst.mockRejectedValue('NotFoundError');
|
|
|
-
|
|
|
- const result = await teamEnvironmentsService.getTeamEnvironment('123')();
|
|
|
+ test('should throw TEAM_ENVIRONMENT_NOT_FOUND with invalid ID', async () => {
|
|
|
+ mockPrisma.teamEnvironment.findFirstOrThrow.mockRejectedValueOnce(
|
|
|
+ 'RejectOnNotFound',
|
|
|
+ );
|
|
|
|
|
|
- expect(result).toBeNone();
|
|
|
+ const result = await teamEnvironmentsService.getTeamEnvironment(
|
|
|
+ teamEnvironment.id,
|
|
|
+ );
|
|
|
+ expect(result).toEqualLeft(TEAM_ENVIRONMENT_NOT_FOUND);
|
|
|
});
|
|
|
});
|
|
|
+
|
|
|
describe('createTeamEnvironment', () => {
|
|
|
- test('should create and return a new team environment given a valid name,variable and team ID', async () => {
|
|
|
+ test('should successfully create and return a new team environment given valid inputs', async () => {
|
|
|
mockPrisma.teamEnvironment.create.mockResolvedValue(teamEnvironment);
|
|
|
|
|
|
const result = await teamEnvironmentsService.createTeamEnvironment(
|
|
|
teamEnvironment.name,
|
|
|
teamEnvironment.teamID,
|
|
|
JSON.stringify(teamEnvironment.variables),
|
|
|
- )();
|
|
|
+ );
|
|
|
|
|
|
- expect(result).toEqual(<TeamEnvironment>{
|
|
|
- id: teamEnvironment.id,
|
|
|
- name: teamEnvironment.name,
|
|
|
- teamID: teamEnvironment.teamID,
|
|
|
+ expect(result).toEqualRight({
|
|
|
+ ...teamEnvironment,
|
|
|
variables: JSON.stringify(teamEnvironment.variables),
|
|
|
});
|
|
|
});
|
|
|
|
|
|
- test('should reject if given team ID is invalid', async () => {
|
|
|
- mockPrisma.teamEnvironment.create.mockRejectedValue(null as any);
|
|
|
-
|
|
|
- await expect(
|
|
|
- teamEnvironmentsService.createTeamEnvironment(
|
|
|
- teamEnvironment.name,
|
|
|
- 'invalidteamid',
|
|
|
- JSON.stringify(teamEnvironment.variables),
|
|
|
- ),
|
|
|
- ).rejects.toBeDefined();
|
|
|
- });
|
|
|
-
|
|
|
- test('should reject if provided team environment name is not a string', async () => {
|
|
|
- mockPrisma.teamEnvironment.create.mockRejectedValue(null as any);
|
|
|
-
|
|
|
- await expect(
|
|
|
- teamEnvironmentsService.createTeamEnvironment(
|
|
|
- null as any,
|
|
|
- teamEnvironment.teamID,
|
|
|
- JSON.stringify(teamEnvironment.variables),
|
|
|
- ),
|
|
|
- ).rejects.toBeDefined();
|
|
|
- });
|
|
|
-
|
|
|
- test('should reject if provided variable is not a string', async () => {
|
|
|
- mockPrisma.teamEnvironment.create.mockRejectedValue(null as any);
|
|
|
+ test('should throw TEAM_ENVIRONMENT_SHORT_NAME if input TeamEnvironment name is invalid', async () => {
|
|
|
+ const result = await teamEnvironmentsService.createTeamEnvironment(
|
|
|
+ '12',
|
|
|
+ teamEnvironment.teamID,
|
|
|
+ JSON.stringify(teamEnvironment.variables),
|
|
|
+ );
|
|
|
|
|
|
- await expect(
|
|
|
- teamEnvironmentsService.createTeamEnvironment(
|
|
|
- teamEnvironment.name,
|
|
|
- teamEnvironment.teamID,
|
|
|
- null as any,
|
|
|
- ),
|
|
|
- ).rejects.toBeDefined();
|
|
|
+ expect(result).toEqualLeft(TEAM_ENVIRONMENT_SHORT_NAME);
|
|
|
});
|
|
|
|
|
|
test('should send pubsub message to "team_environment/<teamID>/created" if team environment is created successfully', async () => {
|
|
|
- mockPrisma.teamEnvironment.create.mockResolvedValueOnce(teamEnvironment);
|
|
|
+ mockPrisma.teamEnvironment.create.mockResolvedValue(teamEnvironment);
|
|
|
|
|
|
const result = await teamEnvironmentsService.createTeamEnvironment(
|
|
|
teamEnvironment.name,
|
|
|
teamEnvironment.teamID,
|
|
|
JSON.stringify(teamEnvironment.variables),
|
|
|
- )();
|
|
|
+ );
|
|
|
|
|
|
expect(mockPubSub.publish).toHaveBeenCalledWith(
|
|
|
`team_environment/${teamEnvironment.teamID}/created`,
|
|
|
- result,
|
|
|
+ {
|
|
|
+ ...teamEnvironment,
|
|
|
+ variables: JSON.stringify(teamEnvironment.variables),
|
|
|
+ },
|
|
|
);
|
|
|
});
|
|
|
});
|
|
|
|
|
|
describe('deleteTeamEnvironment', () => {
|
|
|
- test('should resolve to true given a valid team environment ID', async () => {
|
|
|
+ test('should successfully delete a TeamEnvironment with a valid ID', async () => {
|
|
|
mockPrisma.teamEnvironment.delete.mockResolvedValueOnce(teamEnvironment);
|
|
|
|
|
|
const result = await teamEnvironmentsService.deleteTeamEnvironment(
|
|
|
teamEnvironment.id,
|
|
|
- )();
|
|
|
+ );
|
|
|
|
|
|
expect(result).toEqualRight(true);
|
|
|
});
|
|
@@ -159,7 +119,7 @@ describe('TeamEnvironmentsService', () => {
|
|
|
|
|
|
const result = await teamEnvironmentsService.deleteTeamEnvironment(
|
|
|
'invalidid',
|
|
|
- )();
|
|
|
+ );
|
|
|
|
|
|
expect(result).toEqualLeft(TEAM_ENVIRONMENT_NOT_FOUND);
|
|
|
});
|
|
@@ -169,7 +129,7 @@ describe('TeamEnvironmentsService', () => {
|
|
|
|
|
|
const result = await teamEnvironmentsService.deleteTeamEnvironment(
|
|
|
teamEnvironment.id,
|
|
|
- )();
|
|
|
+ );
|
|
|
|
|
|
expect(mockPubSub.publish).toHaveBeenCalledWith(
|
|
|
`team_environment/${teamEnvironment.teamID}/deleted`,
|
|
@@ -182,7 +142,7 @@ describe('TeamEnvironmentsService', () => {
|
|
|
});
|
|
|
|
|
|
describe('updateVariablesInTeamEnvironment', () => {
|
|
|
- test('should add new variable to a team environment', async () => {
|
|
|
+ test('should successfully add new variable to a team environment', async () => {
|
|
|
mockPrisma.teamEnvironment.update.mockResolvedValueOnce({
|
|
|
...teamEnvironment,
|
|
|
variables: [{ key: 'value' }],
|
|
@@ -192,7 +152,7 @@ describe('TeamEnvironmentsService', () => {
|
|
|
teamEnvironment.id,
|
|
|
teamEnvironment.name,
|
|
|
JSON.stringify([{ key: 'value' }]),
|
|
|
- )();
|
|
|
+ );
|
|
|
|
|
|
expect(result).toEqualRight(<TeamEnvironment>{
|
|
|
...teamEnvironment,
|
|
@@ -200,7 +160,7 @@ describe('TeamEnvironmentsService', () => {
|
|
|
});
|
|
|
});
|
|
|
|
|
|
- test('should add new variable to already existing list of variables in a team environment', async () => {
|
|
|
+ test('should successfully add new variable to already existing list of variables in a team environment', async () => {
|
|
|
mockPrisma.teamEnvironment.update.mockResolvedValueOnce({
|
|
|
...teamEnvironment,
|
|
|
variables: [{ key: 'value' }, { key_2: 'value_2' }],
|
|
@@ -210,7 +170,7 @@ describe('TeamEnvironmentsService', () => {
|
|
|
teamEnvironment.id,
|
|
|
teamEnvironment.name,
|
|
|
JSON.stringify([{ key: 'value' }, { key_2: 'value_2' }]),
|
|
|
- )();
|
|
|
+ );
|
|
|
|
|
|
expect(result).toEqualRight(<TeamEnvironment>{
|
|
|
...teamEnvironment,
|
|
@@ -218,7 +178,7 @@ describe('TeamEnvironmentsService', () => {
|
|
|
});
|
|
|
});
|
|
|
|
|
|
- test('should edit existing variables in a team environment', async () => {
|
|
|
+ test('should successfully edit existing variables in a team environment', async () => {
|
|
|
mockPrisma.teamEnvironment.update.mockResolvedValueOnce({
|
|
|
...teamEnvironment,
|
|
|
variables: [{ key: '1234' }],
|
|
@@ -228,7 +188,7 @@ describe('TeamEnvironmentsService', () => {
|
|
|
teamEnvironment.id,
|
|
|
teamEnvironment.name,
|
|
|
JSON.stringify([{ key: '1234' }]),
|
|
|
- )();
|
|
|
+ );
|
|
|
|
|
|
expect(result).toEqualRight(<TeamEnvironment>{
|
|
|
...teamEnvironment,
|
|
@@ -236,22 +196,7 @@ describe('TeamEnvironmentsService', () => {
|
|
|
});
|
|
|
});
|
|
|
|
|
|
- test('should delete existing variable in a team environment', async () => {
|
|
|
- mockPrisma.teamEnvironment.update.mockResolvedValueOnce(teamEnvironment);
|
|
|
-
|
|
|
- const result = await teamEnvironmentsService.updateTeamEnvironment(
|
|
|
- teamEnvironment.id,
|
|
|
- teamEnvironment.name,
|
|
|
- JSON.stringify([{}]),
|
|
|
- )();
|
|
|
-
|
|
|
- expect(result).toEqualRight(<TeamEnvironment>{
|
|
|
- ...teamEnvironment,
|
|
|
- variables: JSON.stringify([{}]),
|
|
|
- });
|
|
|
- });
|
|
|
-
|
|
|
- test('should edit name of an existing team environment', async () => {
|
|
|
+ test('should successfully edit name of an existing team environment', async () => {
|
|
|
mockPrisma.teamEnvironment.update.mockResolvedValueOnce({
|
|
|
...teamEnvironment,
|
|
|
variables: [{ key: '123' }],
|
|
@@ -261,7 +206,7 @@ describe('TeamEnvironmentsService', () => {
|
|
|
teamEnvironment.id,
|
|
|
teamEnvironment.name,
|
|
|
JSON.stringify([{ key: '123' }]),
|
|
|
- )();
|
|
|
+ );
|
|
|
|
|
|
expect(result).toEqualRight(<TeamEnvironment>{
|
|
|
...teamEnvironment,
|
|
@@ -269,14 +214,24 @@ describe('TeamEnvironmentsService', () => {
|
|
|
});
|
|
|
});
|
|
|
|
|
|
- test('should reject to TEAM_ENVIRONMMENT_NOT_FOUND if provided id is invalid', async () => {
|
|
|
+ test('should throw TEAM_ENVIRONMENT_SHORT_NAME if input TeamEnvironment name is invalid', async () => {
|
|
|
+ const result = await teamEnvironmentsService.updateTeamEnvironment(
|
|
|
+ teamEnvironment.id,
|
|
|
+ '12',
|
|
|
+ JSON.stringify([{ key: 'value' }]),
|
|
|
+ );
|
|
|
+
|
|
|
+ expect(result).toEqualLeft(TEAM_ENVIRONMENT_SHORT_NAME);
|
|
|
+ });
|
|
|
+
|
|
|
+ test('should throw TEAM_ENVIRONMMENT_NOT_FOUND if provided id is invalid', async () => {
|
|
|
mockPrisma.teamEnvironment.update.mockRejectedValue('RecordNotFound');
|
|
|
|
|
|
const result = await teamEnvironmentsService.updateTeamEnvironment(
|
|
|
'invalidid',
|
|
|
teamEnvironment.name,
|
|
|
JSON.stringify(teamEnvironment.variables),
|
|
|
- )();
|
|
|
+ );
|
|
|
|
|
|
expect(result).toEqualLeft(TEAM_ENVIRONMENT_NOT_FOUND);
|
|
|
});
|
|
@@ -288,7 +243,7 @@ describe('TeamEnvironmentsService', () => {
|
|
|
teamEnvironment.id,
|
|
|
teamEnvironment.name,
|
|
|
JSON.stringify([{ key: 'value' }]),
|
|
|
- )();
|
|
|
+ );
|
|
|
|
|
|
expect(mockPubSub.publish).toHaveBeenCalledWith(
|
|
|
`team_environment/${teamEnvironment.teamID}/updated`,
|
|
@@ -301,13 +256,13 @@ describe('TeamEnvironmentsService', () => {
|
|
|
});
|
|
|
|
|
|
describe('deleteAllVariablesFromTeamEnvironment', () => {
|
|
|
- test('should delete all variables in a team environment', async () => {
|
|
|
+ test('should successfully delete all variables in a team environment', async () => {
|
|
|
mockPrisma.teamEnvironment.update.mockResolvedValueOnce(teamEnvironment);
|
|
|
|
|
|
const result =
|
|
|
await teamEnvironmentsService.deleteAllVariablesFromTeamEnvironment(
|
|
|
teamEnvironment.id,
|
|
|
- )();
|
|
|
+ );
|
|
|
|
|
|
expect(result).toEqualRight(<TeamEnvironment>{
|
|
|
...teamEnvironment,
|
|
@@ -315,13 +270,13 @@ describe('TeamEnvironmentsService', () => {
|
|
|
});
|
|
|
});
|
|
|
|
|
|
- test('should reject to TEAM_ENVIRONMMENT_NOT_FOUND if provided id is invalid', async () => {
|
|
|
+ test('should throw TEAM_ENVIRONMMENT_NOT_FOUND if provided id is invalid', async () => {
|
|
|
mockPrisma.teamEnvironment.update.mockRejectedValue('RecordNotFound');
|
|
|
|
|
|
const result =
|
|
|
await teamEnvironmentsService.deleteAllVariablesFromTeamEnvironment(
|
|
|
'invalidid',
|
|
|
- )();
|
|
|
+ );
|
|
|
|
|
|
expect(result).toEqualLeft(TEAM_ENVIRONMENT_NOT_FOUND);
|
|
|
});
|
|
@@ -332,7 +287,7 @@ describe('TeamEnvironmentsService', () => {
|
|
|
const result =
|
|
|
await teamEnvironmentsService.deleteAllVariablesFromTeamEnvironment(
|
|
|
teamEnvironment.id,
|
|
|
- )();
|
|
|
+ );
|
|
|
|
|
|
expect(mockPubSub.publish).toHaveBeenCalledWith(
|
|
|
`team_environment/${teamEnvironment.teamID}/updated`,
|
|
@@ -345,7 +300,7 @@ describe('TeamEnvironmentsService', () => {
|
|
|
});
|
|
|
|
|
|
describe('createDuplicateEnvironment', () => {
|
|
|
- test('should duplicate an existing team environment', async () => {
|
|
|
+ test('should successfully duplicate an existing team environment', async () => {
|
|
|
mockPrisma.teamEnvironment.findFirst.mockResolvedValueOnce(
|
|
|
teamEnvironment,
|
|
|
);
|
|
@@ -357,21 +312,21 @@ describe('TeamEnvironmentsService', () => {
|
|
|
|
|
|
const result = await teamEnvironmentsService.createDuplicateEnvironment(
|
|
|
teamEnvironment.id,
|
|
|
- )();
|
|
|
+ );
|
|
|
|
|
|
expect(result).toEqualRight(<TeamEnvironment>{
|
|
|
- ...teamEnvironment,
|
|
|
id: 'newid',
|
|
|
+ ...teamEnvironment,
|
|
|
variables: JSON.stringify(teamEnvironment.variables),
|
|
|
});
|
|
|
});
|
|
|
|
|
|
- test('should reject to TEAM_ENVIRONMMENT_NOT_FOUND if provided id is invalid', async () => {
|
|
|
+ test('should throw TEAM_ENVIRONMMENT_NOT_FOUND if provided id is invalid', async () => {
|
|
|
mockPrisma.teamEnvironment.findFirst.mockRejectedValue('NotFoundError');
|
|
|
|
|
|
const result = await teamEnvironmentsService.createDuplicateEnvironment(
|
|
|
teamEnvironment.id,
|
|
|
- )();
|
|
|
+ );
|
|
|
|
|
|
expect(result).toEqualLeft(TEAM_ENVIRONMENT_NOT_FOUND);
|
|
|
});
|
|
@@ -388,13 +343,13 @@ describe('TeamEnvironmentsService', () => {
|
|
|
|
|
|
const result = await teamEnvironmentsService.createDuplicateEnvironment(
|
|
|
teamEnvironment.id,
|
|
|
- )();
|
|
|
+ );
|
|
|
|
|
|
expect(mockPubSub.publish).toHaveBeenCalledWith(
|
|
|
`team_environment/${teamEnvironment.teamID}/created`,
|
|
|
{
|
|
|
- ...teamEnvironment,
|
|
|
id: 'newid',
|
|
|
+ ...teamEnvironment,
|
|
|
variables: JSON.stringify([{}]),
|
|
|
},
|
|
|
);
|