forked from PalisadoesFoundation/talawa-api
-
Notifications
You must be signed in to change notification settings - Fork 0
Commit
This commit does not belong to any branch on this repository, and may belong to a fork outside of the repository.
Test file for updatePluginStatus.ts (PalisadoesFoundation#1682)
* Improved code coverage * Revert "Improved code coverage" This reverts commit 1ac5f89. * Tests for updatePluginStatus.ts file
- Loading branch information
1 parent
325c687
commit ad3e16e
Showing
3 changed files
with
147 additions
and
3 deletions.
There are no files selected for viewing
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,133 @@ | ||
import type mongoose from "mongoose"; | ||
import { Types } from "mongoose"; | ||
import { nanoid } from "nanoid"; | ||
import { | ||
beforeAll, | ||
afterAll, | ||
afterEach, | ||
describe, | ||
it, | ||
expect, | ||
vi, | ||
} from "vitest"; | ||
|
||
import { PLUGIN_NOT_FOUND } from "../../../src/constants"; | ||
import { pubsub } from "../../../src/index"; | ||
import { createTestUserAndOrganization } from "../../helpers/userAndOrg"; | ||
import type { TestOrganizationType } from "../../helpers/userAndOrg"; | ||
import { connect, disconnect } from "../../helpers/db"; | ||
import type { MutationUpdatePluginStatusArgs } from "../../../src/types/generatedGraphQLTypes"; | ||
import { updatePluginStatus } from "../../../src/resolvers/Mutation/updatePluginStatus"; | ||
import { Plugin } from "../../../src/models"; | ||
import type { InterfacePlugin } from "../../../src/models"; | ||
|
||
let MONGOOSE_INSTANCE: typeof mongoose; | ||
let testOrganization: TestOrganizationType; | ||
|
||
beforeAll(async () => { | ||
MONGOOSE_INSTANCE = await connect(); | ||
const temp = await createTestUserAndOrganization(); | ||
testOrganization = temp[1]; | ||
}); | ||
|
||
afterAll(async () => { | ||
await disconnect(MONGOOSE_INSTANCE); | ||
}); | ||
|
||
afterEach(() => { | ||
vi.doUnmock("../../../src/constants"); | ||
vi.resetModules(); | ||
}); | ||
|
||
afterEach(() => { | ||
vi.doUnmock("../../../src/constants"); | ||
vi.resetModules(); | ||
}); | ||
|
||
describe("resolvers -> Mutation -> updatePluginStatus", () => { | ||
it(`throws NotFoundError if no plugin exists with _id === args.id`, async () => { | ||
const { requestContext } = await import("../../../src/libraries"); | ||
|
||
const spy = vi | ||
.spyOn(requestContext, "translate") | ||
.mockImplementation((message) => `Translated ${message}`); | ||
|
||
try { | ||
const args: MutationUpdatePluginStatusArgs = { | ||
id: Types.ObjectId().toString(), | ||
orgId: Types.ObjectId().toString(), | ||
}; | ||
|
||
const context = async () => { | ||
pubsub; | ||
}; | ||
|
||
const { updatePluginStatus: updatePluginStatusResolver } = await import( | ||
"../../../src/resolvers/Mutation/updatePluginStatus" | ||
); | ||
|
||
await updatePluginStatusResolver?.({}, args, context); | ||
} catch (error: any) { | ||
expect(spy).toHaveBeenCalledWith(PLUGIN_NOT_FOUND.MESSAGE); | ||
expect(error.message).toEqual(`Translated ${PLUGIN_NOT_FOUND.MESSAGE}`); | ||
} | ||
}); | ||
|
||
it(`updates the plugin with _id === args.id and returns the updated plugin when orgId does no exists in uninstalled orgs`, async () => { | ||
const testPlugin: InterfacePlugin = await Plugin.create({ | ||
pluginName: `${nanoid()}`, | ||
pluginCreatedBy: `${nanoid()}`, | ||
pluginDesc: `${nanoid()}`, | ||
uninstalledOrgs: [], | ||
}); | ||
const args: MutationUpdatePluginStatusArgs = { | ||
id: testPlugin._id.toString(), | ||
orgId: testOrganization?._id.toString(), | ||
}; | ||
|
||
const context = { | ||
pubsub, | ||
}; | ||
|
||
const updatePluginStatusPayload = await updatePluginStatus?.( | ||
{}, | ||
args, | ||
context | ||
); | ||
|
||
const testUpdatePluginStatusPayload = await Plugin.findOne({ | ||
_id: testPlugin._id, | ||
}).lean(); | ||
|
||
expect(updatePluginStatusPayload).toEqual(testUpdatePluginStatusPayload); | ||
}); | ||
|
||
it(`updates the plugin with _id === args.id and returns the updated plugin when orgId exists in uninstalled orgs`, async () => { | ||
const testPlugin: InterfacePlugin = await Plugin.create({ | ||
pluginName: `${nanoid()}`, | ||
pluginCreatedBy: `${nanoid()}`, | ||
pluginDesc: `${nanoid()}`, | ||
uninstalledOrgs: [testOrganization?._id], | ||
}); | ||
const args: MutationUpdatePluginStatusArgs = { | ||
id: testPlugin._id.toString(), | ||
orgId: testOrganization?._id.toString(), | ||
}; | ||
|
||
const context = { | ||
pubsub, | ||
}; | ||
|
||
const updatePluginStatusPayload = await updatePluginStatus?.( | ||
{}, | ||
args, | ||
context | ||
); | ||
|
||
const testUpdatePluginStatusPayload = await Plugin.findOne({ | ||
_id: testPlugin._id, | ||
}).lean(); | ||
|
||
expect(updatePluginStatusPayload).toEqual(testUpdatePluginStatusPayload); | ||
}); | ||
}); |