mirror of
https://github.com/IT4Change/Ocelot-Social.git
synced 2026-04-06 01:25:31 +00:00
refactor(backend): test roles (#9157)
This commit is contained in:
parent
753a300c3f
commit
9350ab0378
7
backend/src/graphql/queries/availableRoles.ts
Normal file
7
backend/src/graphql/queries/availableRoles.ts
Normal file
@ -0,0 +1,7 @@
|
|||||||
|
import gql from 'graphql-tag'
|
||||||
|
|
||||||
|
export const availableRoles = gql`
|
||||||
|
query {
|
||||||
|
availableRoles
|
||||||
|
}
|
||||||
|
`
|
||||||
103
backend/src/graphql/resolvers/roles.spec.ts
Normal file
103
backend/src/graphql/resolvers/roles.spec.ts
Normal file
@ -0,0 +1,103 @@
|
|||||||
|
/* eslint-disable @typescript-eslint/no-unsafe-call */
|
||||||
|
/* eslint-disable @typescript-eslint/no-unsafe-member-access */
|
||||||
|
/* eslint-disable @typescript-eslint/no-unsafe-assignment */
|
||||||
|
import { ApolloServerTestClient, createTestClient } from 'apollo-server-testing'
|
||||||
|
|
||||||
|
import Factory, { cleanDatabase } from '@db/factories'
|
||||||
|
import { getDriver, getNeode } from '@db/neo4j'
|
||||||
|
import { availableRoles } from '@graphql/queries/availableRoles'
|
||||||
|
import createServer from '@src/server'
|
||||||
|
|
||||||
|
const instance = getNeode()
|
||||||
|
const driver = getDriver()
|
||||||
|
|
||||||
|
describe('availableRoles', () => {
|
||||||
|
let authenticatedUser
|
||||||
|
let query: ApolloServerTestClient['query']
|
||||||
|
|
||||||
|
beforeAll(async () => {
|
||||||
|
await cleanDatabase()
|
||||||
|
|
||||||
|
const { server } = createServer({
|
||||||
|
context: () => {
|
||||||
|
return {
|
||||||
|
driver,
|
||||||
|
neode: instance,
|
||||||
|
user: authenticatedUser,
|
||||||
|
}
|
||||||
|
},
|
||||||
|
})
|
||||||
|
query = createTestClient(server).query
|
||||||
|
})
|
||||||
|
|
||||||
|
afterAll(async () => {
|
||||||
|
await cleanDatabase()
|
||||||
|
await driver.close()
|
||||||
|
})
|
||||||
|
|
||||||
|
afterEach(async () => {
|
||||||
|
await cleanDatabase()
|
||||||
|
})
|
||||||
|
|
||||||
|
describe('unauthenticated', () => {
|
||||||
|
it('throws authorization error', async () => {
|
||||||
|
authenticatedUser = null
|
||||||
|
const { data, errors } = await query({ query: availableRoles })
|
||||||
|
expect(data).toEqual(null)
|
||||||
|
expect(errors).toEqual([expect.objectContaining({ message: 'Not Authorized!' })])
|
||||||
|
})
|
||||||
|
})
|
||||||
|
|
||||||
|
describe('authenticated', () => {
|
||||||
|
describe('as user', () => {
|
||||||
|
beforeEach(async () => {
|
||||||
|
const user = await Factory.build(
|
||||||
|
'user',
|
||||||
|
{ id: 'user-id', role: 'user' },
|
||||||
|
{ email: 'user@example.org', password: '1234' },
|
||||||
|
)
|
||||||
|
authenticatedUser = await user.toJson()
|
||||||
|
})
|
||||||
|
|
||||||
|
it('throws authorization error', async () => {
|
||||||
|
const { data, errors } = await query({ query: availableRoles })
|
||||||
|
expect(data).toEqual(null)
|
||||||
|
expect(errors).toEqual([expect.objectContaining({ message: 'Not Authorized!' })])
|
||||||
|
})
|
||||||
|
})
|
||||||
|
|
||||||
|
describe('as moderator', () => {
|
||||||
|
beforeEach(async () => {
|
||||||
|
const moderator = await Factory.build(
|
||||||
|
'user',
|
||||||
|
{ id: 'moderator-id', role: 'moderator' },
|
||||||
|
{ email: 'moderator@example.org', password: '1234' },
|
||||||
|
)
|
||||||
|
authenticatedUser = await moderator.toJson()
|
||||||
|
})
|
||||||
|
|
||||||
|
it('throws authorization error', async () => {
|
||||||
|
const { data, errors } = await query({ query: availableRoles })
|
||||||
|
expect(data).toEqual(null)
|
||||||
|
expect(errors).toEqual([expect.objectContaining({ message: 'Not Authorized!' })])
|
||||||
|
})
|
||||||
|
})
|
||||||
|
|
||||||
|
describe('as admin', () => {
|
||||||
|
beforeEach(async () => {
|
||||||
|
const admin = await Factory.build(
|
||||||
|
'user',
|
||||||
|
{ id: 'admin-id', role: 'admin' },
|
||||||
|
{ email: 'admin@example.org', password: '1234' },
|
||||||
|
)
|
||||||
|
authenticatedUser = await admin.toJson()
|
||||||
|
})
|
||||||
|
|
||||||
|
it('returns available roles', async () => {
|
||||||
|
const { data, errors } = await query({ query: availableRoles })
|
||||||
|
expect(errors).toBeUndefined()
|
||||||
|
expect(data?.availableRoles).toEqual(['admin', 'moderator', 'user'])
|
||||||
|
})
|
||||||
|
})
|
||||||
|
})
|
||||||
|
})
|
||||||
Loading…
x
Reference in New Issue
Block a user