mirror of
https://github.com/Ocelot-Social-Community/Ocelot-Social.git
synced 2025-12-13 07:46:06 +00:00
backend tests for viewed teaser count
This commit is contained in:
parent
6af9c0152f
commit
a5740ebd0a
@ -336,6 +336,7 @@ export default {
|
|||||||
})
|
})
|
||||||
try {
|
try {
|
||||||
const [post] = await writeTxResultPromise
|
const [post] = await writeTxResultPromise
|
||||||
|
post.viewedTeaserCount = post.viewedTeaserCount.low
|
||||||
return post
|
return post
|
||||||
} finally {
|
} finally {
|
||||||
session.close()
|
session.close()
|
||||||
|
|||||||
83
backend/src/schema/resolvers/viewedTeaserCount.spec.js
Normal file
83
backend/src/schema/resolvers/viewedTeaserCount.spec.js
Normal file
@ -0,0 +1,83 @@
|
|||||||
|
import { createTestClient } from 'apollo-server-testing'
|
||||||
|
import Factory, { cleanDatabase } from '../../db/factories'
|
||||||
|
import { gql } from '../../helpers/jest'
|
||||||
|
import { getNeode, getDriver } from '../../db/neo4j'
|
||||||
|
import createServer from '../../server'
|
||||||
|
|
||||||
|
const driver = getDriver()
|
||||||
|
const neode = getNeode()
|
||||||
|
|
||||||
|
let mutate
|
||||||
|
let authenticatedUser
|
||||||
|
let variables
|
||||||
|
|
||||||
|
beforeAll(async () => {
|
||||||
|
await cleanDatabase()
|
||||||
|
const { server } = createServer({
|
||||||
|
context: () => {
|
||||||
|
return {
|
||||||
|
driver,
|
||||||
|
neode,
|
||||||
|
user: authenticatedUser,
|
||||||
|
}
|
||||||
|
},
|
||||||
|
})
|
||||||
|
mutate = createTestClient(server).mutate
|
||||||
|
})
|
||||||
|
|
||||||
|
afterAll(async () => {
|
||||||
|
await cleanDatabase()
|
||||||
|
})
|
||||||
|
|
||||||
|
describe('count post teaser views', () => {
|
||||||
|
let aUser, bUser
|
||||||
|
const markTeaserAsViewed = gql`
|
||||||
|
mutation($id: ID!) {
|
||||||
|
markTeaserAsViewed(id: $id) {
|
||||||
|
id
|
||||||
|
viewedTeaserCount
|
||||||
|
}
|
||||||
|
}
|
||||||
|
`
|
||||||
|
|
||||||
|
beforeAll(async () => {
|
||||||
|
Factory.build('post', { id: 'post-to-be-viewed' })
|
||||||
|
aUser = await Factory.build('user', { id: 'a-user' })
|
||||||
|
bUser = await Factory.build('user', { id: 'b-user' })
|
||||||
|
variables = {
|
||||||
|
id: 'post-to-be-viewed',
|
||||||
|
}
|
||||||
|
authenticatedUser = await aUser.toJson()
|
||||||
|
})
|
||||||
|
|
||||||
|
it('marks the post as viewed and increases the viewedTeaserCount', async () => {
|
||||||
|
await expect(mutate({ mutation: markTeaserAsViewed, variables })).resolves.toMatchObject({
|
||||||
|
data: {
|
||||||
|
markTeaserAsViewed: expect.objectContaining({
|
||||||
|
viewedTeaserCount: 1,
|
||||||
|
}),
|
||||||
|
},
|
||||||
|
})
|
||||||
|
})
|
||||||
|
|
||||||
|
it('does not increase the viewedTeaserCount when accidently called again', async () => {
|
||||||
|
await expect(mutate({ mutation: markTeaserAsViewed, variables })).resolves.toMatchObject({
|
||||||
|
data: {
|
||||||
|
markTeaserAsViewed: expect.objectContaining({
|
||||||
|
viewedTeaserCount: 1,
|
||||||
|
}),
|
||||||
|
},
|
||||||
|
})
|
||||||
|
})
|
||||||
|
|
||||||
|
it('increases the viewedTeaserCount when viewed by another user', async () => {
|
||||||
|
authenticatedUser = await bUser.toJson()
|
||||||
|
await expect(mutate({ mutation: markTeaserAsViewed, variables })).resolves.toMatchObject({
|
||||||
|
data: {
|
||||||
|
markTeaserAsViewed: expect.objectContaining({
|
||||||
|
viewedTeaserCount: 2,
|
||||||
|
}),
|
||||||
|
},
|
||||||
|
})
|
||||||
|
})
|
||||||
|
})
|
||||||
Loading…
x
Reference in New Issue
Block a user