Merge pull request #1553 from Human-Connection/helper-for-backend-tests-failed-by-missing-constraints

🍰 [Helper] Message for backend tests failed by missing constraints
This commit is contained in:
Robert Schäfer 2019-09-12 23:51:15 +02:00 committed by GitHub
commit 8fa794f282
No known key found for this signature in database
GPG Key ID: 4AEE18F83AFDEB23

View File

@ -28,7 +28,9 @@ beforeAll(() => {
beforeEach(async () => { beforeEach(async () => {
variables = {} variables = {}
const admin = await factory.create('User', { role: 'admin' }) const admin = await factory.create('User', {
role: 'admin',
})
await factory.create('User', { await factory.create('User', {
email: 'someone@example.org', email: 'someone@example.org',
password: '1234', password: '1234',
@ -66,9 +68,16 @@ describe('slugifyMiddleware', () => {
}) })
it('generates a slug based on title', async () => { it('generates a slug based on title', async () => {
await expect(mutate({ mutation: createPostMutation, variables })).resolves.toMatchObject({ await expect(
mutate({
mutation: createPostMutation,
variables,
}),
).resolves.toMatchObject({
data: { data: {
CreatePost: { slug: 'i-am-a-brand-new-post' }, CreatePost: {
slug: 'i-am-a-brand-new-post',
},
}, },
}) })
}) })
@ -90,13 +99,22 @@ describe('slugifyMiddleware', () => {
content: 'Some content', content: 'Some content',
categoryIds, categoryIds,
} }
await expect(mutate({ mutation: createPostMutation, variables })).resolves.toMatchObject({ await expect(
data: { CreatePost: { slug: 'pre-existing-post-1' } }, mutate({
mutation: createPostMutation,
variables,
}),
).resolves.toMatchObject({
data: {
CreatePost: {
slug: 'pre-existing-post-1',
},
},
}) })
}) })
describe('but if the client specifies a slug', () => { describe('but if the client specifies a slug', () => {
it('rejects CreatePost', async () => { it('rejects CreatePost', async done => {
variables = { variables = {
...variables, ...variables,
title: 'Pre-existing post', title: 'Pre-existing post',
@ -104,9 +122,33 @@ describe('slugifyMiddleware', () => {
slug: 'pre-existing-post', slug: 'pre-existing-post',
categoryIds, categoryIds,
} }
await expect(mutate({ mutation: createPostMutation, variables })).resolves.toMatchObject({ try {
errors: [{ message: 'Post with this slug already exists!' }], await expect(
mutate({ mutation: createPostMutation, variables }),
).resolves.toMatchObject({
errors: [
{
message: 'Post with this slug already exists!',
},
],
}) })
done()
} catch (error) {
throw new Error(`
${error}
Probably your database has no unique constraints!
To see all constraints go to http://localhost:7474/browser/ and
paste the following:
\`\`\`
CALL db.constraints();
\`\`\`
Learn how to setup the database here:
https://docs.human-connection.org/human-connection/neo4j
`)
}
}) })
}) })
}) })
@ -156,31 +198,58 @@ describe('slugifyMiddleware', () => {
}) })
it('generates a slug based on name', async () => { it('generates a slug based on name', async () => {
await expect(mutate({ mutation, variables })).resolves.toMatchObject({ await expect(
data: { SignupVerification: { slug: 'i-am-a-user' } }, mutate({
mutation,
variables,
}),
).resolves.toMatchObject({
data: {
SignupVerification: {
slug: 'i-am-a-user',
},
},
}) })
}) })
describe('if slug exists', () => { describe('if slug exists', () => {
beforeEach(async () => { beforeEach(async () => {
await factory.create('User', { name: 'I am a user', slug: 'i-am-a-user' }) await factory.create('User', {
name: 'I am a user',
slug: 'i-am-a-user',
})
}) })
it('chooses another slug', async () => { it('chooses another slug', async () => {
await expect(mutate({ mutation, variables })).resolves.toMatchObject({ await expect(
mutate({
mutation,
variables,
}),
).resolves.toMatchObject({
data: { data: {
SignupVerification: { slug: 'i-am-a-user-1' }, SignupVerification: {
slug: 'i-am-a-user-1',
},
}, },
}) })
}) })
describe('but if the client specifies a slug', () => { describe('but if the client specifies a slug', () => {
beforeEach(() => { beforeEach(() => {
variables = { ...variables, slug: 'i-am-a-user' } variables = {
...variables,
slug: 'i-am-a-user',
}
}) })
it('rejects SignupVerification', async () => { it('rejects SignupVerification (on FAIL Neo4j constraints may not defined in database)', async () => {
await expect(mutate({ mutation, variables })).resolves.toMatchObject({ await expect(
mutate({
mutation,
variables,
}),
).resolves.toMatchObject({
errors: [ errors: [
{ {
message: 'User with this slug already exists!', message: 'User with this slug already exists!',