Test Unshouting of a post

-  Tests passing individually but test suites failing
This commit is contained in:
aonomike 2019-09-25 21:44:47 +03:00
parent 4488008a2c
commit 53aa87ea3c

View File

@ -3,6 +3,7 @@ import Factory from '../../seed/factories'
import { gql } from '../../jest/helpers'
import { neode as getNeode, getDriver } from '../../bootstrap/neo4j'
import createServer from '../../server'
import expectExport from 'expect'
let mutate, query, authenticatedUser, variables
const factory = Factory()
@ -30,6 +31,7 @@ const queryPost = gql`
}
`
describe('shout and unshout posts', () => {
let currentUser, postAuthor
beforeAll(() => {
authenticatedUser = undefined
const { server } = createServer({
@ -53,13 +55,13 @@ describe('shout and unshout posts', () => {
describe('unauthenticated', () => {
it('throws authorization error', async () => {
variables = { id: 'post-to-shout-id' }
authenticatedUser = undefined
await expect(mutate({ mutation: mutationShoutPost, variables })).resolves.toMatchObject({
errors: [{ message: 'Not Authorised!' }],
})
})
})
describe('authenticated', () => {
let currentUser, postAuthor
beforeEach(async () => {
currentUser = await factory.create('User', {
id: 'current-user-id',
@ -77,7 +79,7 @@ describe('shout and unshout posts', () => {
authenticatedUser = await currentUser.toJson()
await factory.create('Post', {
name: 'Other user post',
id: 'other-user-post-id',
id: 'another-user-post-id',
author: postAuthor,
})
await factory.create('Post', {
@ -88,13 +90,13 @@ describe('shout and unshout posts', () => {
variables = {}
})
it('post of another user', async () => {
variables = { id: 'other-user-post-id' }
it("another user's post", async () => {
variables = { id: 'another-user-post-id' }
await expect(mutate({ mutation: mutationShoutPost, variables })).resolves.toMatchObject({
data: { shout: true },
})
await expect(query({ query: queryPost, variables })).resolves.toMatchObject({
data: { Post: [{ id: 'other-user-post-id', shoutedBy: [{ id: 'current-user-id' }] }] },
data: { Post: [{ id: 'another-user-post-id', shoutedBy: [{ id: 'current-user-id' }] }] },
errors: undefined,
})
})
@ -111,118 +113,52 @@ describe('shout and unshout posts', () => {
})
})
})
describe('unshout', () => {
describe('unauthenticated', () => {
it('throws authorization error', async () => {
authenticatedUser = undefined
variables = { id: 'post-to-shout-id' }
await expect(mutate({ mutation: mutationUnshoutPost, variables })).resolves.toMatchObject({
errors: [{ message: 'Not Authorised!' }],
})
})
})
describe('authenticated', () => {
beforeEach(async () => {
currentUser = await factory.create('User', {
id: 'current-user-id',
name: 'Current User',
email: 'current.user@example.org',
password: '1234',
})
postAuthor = await factory.create('User', {
id: 'post-author-id',
name: 'Post Author',
email: 'post.author@example.org',
password: '1234',
})
authenticatedUser = await currentUser.toJson()
await factory.create('Post', {
name: 'Other user post',
id: 'another-user-post-id',
author: postAuthor,
})
variables = {}
await mutate({ mutation: mutationShoutPost, variables: { id: 'another-user-post-id' } })
})
it("another user's post", async () => {
variables = { id: 'another-user-post-id' }
await expect(mutate({ mutation: mutationUnshoutPost, variables })).resolves.toMatchObject({
data: { unshout: true },
})
await expect(query({ query: queryPost, variables })).resolves.toMatchObject({
data: { Post: [{ id: 'another-user-post-id', shoutedBy: [] }] },
errors: undefined,
})
})
})
})
})
// let clientUser1, clientUser2
// let headersUser1, headersUser2
// const factory = Factory()
// const instance = neode()
// const categoryIds = ['cat9']
// const mutationShoutPost = gql`
// mutation($id: ID!) {
// shout(id: $id, type: Post)
// }
// `
// const mutationUnshoutPost = gql`
// mutation($id: ID!) {
// unshout(id: $id, type: Post)
// }
// `
// const createPostMutation = gql`
// mutation($id: ID, $title: String!, $content: String!, $categoryIds: [ID]!) {
// CreatePost(id: $id, title: $title, content: $content, categoryIds: $categoryIds) {
// id
// title
// content
// }
// }
// `
// const createPostVariables = {
// id: 'p1234',
// title: 'Post Title 1234',
// content: 'Some Post Content 1234',
// categoryIds,
// }
// beforeEach(async () => {
// await factory.create('User', {
// id: 'u1',
// email: 'test@example.org',
// password: '1234',
// })
// await factory.create('User', {
// id: 'u2',
// email: 'test2@example.org',
// password: '1234',
// })
// await instance.create('Category', {
// id: 'cat9',
// name: 'Democracy & Politics',
// icon: 'university',
// })
// headersUser1 = await login({ email: 'test@example.org', password: '1234' })
// headersUser2 = await login({ email: 'test2@example.org', password: '1234' })
// clientUser1 = new GraphQLClient(host, { headers: headersUser1 })
// clientUser2 = new GraphQLClient(host, { headers: headersUser2 })
// await clientUser1.request(createPostMutation, createPostVariables)
// await clientUser2.request(createPostMutation, {
// id: 'p12345',
// title: 'Post Title 12345',
// content: 'Some Post Content 12345',
// categoryIds,
// })
// })
// afterEach(async () => {
// await factory.cleanDatabase()
// })
// describe('shout', () => {
// describe('shout foreign post', () => {
// describe('unauthenticated shout', () => {
// it('throws authorization error', async () => {
// const client = new GraphQLClient(host)
// await expect(client.request(mutationShoutPost, { id: 'p1234' })).rejects.toThrow(
// 'Not Authorised',
// )
// })
// })
// describe('unshout foreign post', () => {
// describe('unauthenticated shout', () => {
// it('throws authorization error', async () => {
// // shout
// await clientUser1.request(mutationShoutPost, { id: 'p12345' })
// // unshout
// const client = new GraphQLClient(host)
// await expect(client.request(mutationUnshoutPost, { id: 'p12345' })).rejects.toThrow(
// 'Not Authorised',
// )
// })
// })
// it('I unshout a post of another user', async () => {
// // shout
// await clientUser1.request(mutationShoutPost, { id: 'p12345' })
// const expected = {
// unshout: true,
// }
// // unshout
// const res = await clientUser1.request(mutationUnshoutPost, { id: 'p12345' })
// expect(res).toMatchObject(expected)
// const { Post } = await clientUser1.request(gql`
// query {
// Post(id: "p12345") {
// shoutedByCurrentUser
// }
// }
// `)
// const expected2 = {
// shoutedByCurrentUser: false,
// }
// expect(Post[0]).toMatchObject(expected2)
// })
// })
// })