X-Git-Url: https://git.immae.eu/?a=blobdiff_plain;f=server%2Ftests%2Fapi%2Fserver%2Fcontact-form.ts;h=3eb6c85485f888819232d51f038f69a7f865b27b;hb=e0faa8ad6e18ce6248ef1ec93a59dab5b05be468;hp=93221d0a3c6d17e677f43d6dbe69bc11a4ddf3bc;hpb=26a008fe8d71b1bba818dd5f4fae760e0f7fc47c;p=github%2FChocobozzz%2FPeerTube.git diff --git a/server/tests/api/server/contact-form.ts b/server/tests/api/server/contact-form.ts index 93221d0a3..3eb6c8548 100644 --- a/server/tests/api/server/contact-form.ts +++ b/server/tests/api/server/contact-form.ts @@ -1,41 +1,49 @@ -/* tslint:disable:no-unused-expression */ +/* eslint-disable @typescript-eslint/no-unused-expressions,@typescript-eslint/require-await */ import * as chai from 'chai' -import 'mocha' -import { flushTests, killallServers, runServer, ServerInfo, setAccessTokensToServers, wait } from '../../../../shared/utils' -import { MockSmtpServer } from '../../../../shared/utils/miscs/email' -import { waitJobs } from '../../../../shared/utils/server/jobs' -import { sendContactForm } from '../../../../shared/utils/server/contact-form' +import { MockSmtpServer } from '@server/tests/shared' +import { wait } from '@shared/core-utils' +import { HttpStatusCode } from '@shared/models' +import { + cleanupTests, + ContactFormCommand, + createSingleServer, + PeerTubeServer, + setAccessTokensToServers, + waitJobs +} from '@shared/server-commands' const expect = chai.expect describe('Test contact form', function () { - let server: ServerInfo + let server: PeerTubeServer const emails: object[] = [] + let command: ContactFormCommand before(async function () { this.timeout(30000) - await MockSmtpServer.Instance.collectEmails(emails) - - await flushTests() + const port = await MockSmtpServer.Instance.collectEmails(emails) const overrideConfig = { smtp: { - hostname: 'localhost' + hostname: 'localhost', + port } } - server = await runServer(1, overrideConfig) + server = await createSingleServer(1, overrideConfig) await setAccessTokensToServers([ server ]) + + command = server.contactForm }) it('Should send a contact form', async function () { this.timeout(10000) - await sendContactForm({ - url: server.url, + await command.send({ fromEmail: 'toto@example.com', body: 'my super message', + subject: 'my subject', fromName: 'Super toto' }) @@ -45,42 +53,60 @@ describe('Test contact form', function () { const email = emails[0] - expect(email['from'][0]['address']).equal('toto@example.com') - expect(email['to'][0]['address']).equal('admin1@example.com') - expect(email['subject']).contains('Contact form') + expect(email['from'][0]['address']).equal('test-admin@localhost') + expect(email['replyTo'][0]['address']).equal('toto@example.com') + expect(email['to'][0]['address']).equal('admin' + server.internalServerNumber + '@example.com') + expect(email['subject']).contains('my subject') expect(email['text']).contains('my super message') }) + it('Should not have duplicated email address in text message', async function () { + const text = emails[0]['text'] as string + + const matches = text.match(/toto@example.com/g) + expect(matches).to.have.lengthOf(1) + }) + it('Should not be able to send another contact form because of the anti spam checker', async function () { - await sendContactForm({ - url: server.url, + this.timeout(10000) + + await wait(1000) + + await command.send({ fromEmail: 'toto@example.com', body: 'my super message', + subject: 'my subject', fromName: 'Super toto' }) - await sendContactForm({ - url: server.url, + await command.send({ fromEmail: 'toto@example.com', body: 'my super message', fromName: 'Super toto', - expectedStatus: 403 + subject: 'my subject', + expectedStatus: HttpStatusCode.FORBIDDEN_403 }) }) it('Should be able to send another contact form after a while', async function () { await wait(1000) - await sendContactForm({ - url: server.url, + await command.send({ fromEmail: 'toto@example.com', - body: 'my super message', - fromName: 'Super toto' + fromName: 'Super toto', + subject: 'my subject', + body: 'my super message' }) }) + it('Should not have the manage preferences link in the email', async function () { + const email = emails[0] + expect(email['text']).to.not.contain('Manage your notification preferences') + }) + after(async function () { MockSmtpServer.Instance.kill() - killallServers([ server ]) + + await cleanupTests([ server ]) }) })