123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131 |
- /* tslint:disable:no-unused-expression */
- import * as chai from 'chai'
- import 'mocha'
- import {
- checkBadCountPagination,
- checkBadStartPagination,
- cleanupTests,
- flushAndRunServer,
- makeGetRequest,
- makePostBodyRequest,
- makePutBodyRequest,
- ServerInfo,
- setAccessTokensToServers,
- uploadVideo
- } from '../../../../shared/extra-utils'
- const expect = chai.expect
- describe('Test videos history API validator', function () {
- let watchingPath: string
- let myHistoryPath = '/api/v1/users/me/history/videos'
- let myHistoryRemove = myHistoryPath + '/remove'
- let server: ServerInfo
- // ---------------------------------------------------------------
- before(async function () {
- this.timeout(30000)
- server = await flushAndRunServer(1)
- await setAccessTokensToServers([ server ])
- const res = await uploadVideo(server.url, server.accessToken, {})
- const videoUUID = res.body.video.uuid
- watchingPath = '/api/v1/videos/' + videoUUID + '/watching'
- })
- describe('When notifying a user is watching a video', function () {
- it('Should fail with an unauthenticated user', async function () {
- const fields = { currentTime: 5 }
- await makePutBodyRequest({ url: server.url, path: watchingPath, fields, statusCodeExpected: 401 })
- })
- it('Should fail with an incorrect video id', async function () {
- const fields = { currentTime: 5 }
- const path = '/api/v1/videos/blabla/watching'
- await makePutBodyRequest({ url: server.url, path, fields, token: server.accessToken, statusCodeExpected: 400 })
- })
- it('Should fail with an unknown video', async function () {
- const fields = { currentTime: 5 }
- const path = '/api/v1/videos/d91fff41-c24d-4508-8e13-3bd5902c3b02/watching'
- await makePutBodyRequest({ url: server.url, path, fields, token: server.accessToken, statusCodeExpected: 404 })
- })
- it('Should fail with a bad current time', async function () {
- const fields = { currentTime: 'hello' }
- await makePutBodyRequest({ url: server.url, path: watchingPath, fields, token: server.accessToken, statusCodeExpected: 400 })
- })
- it('Should succeed with the correct parameters', async function () {
- const fields = { currentTime: 5 }
- await makePutBodyRequest({ url: server.url, path: watchingPath, fields, token: server.accessToken, statusCodeExpected: 204 })
- })
- })
- describe('When listing user videos history', function () {
- it('Should fail with a bad start pagination', async function () {
- await checkBadStartPagination(server.url, myHistoryPath, server.accessToken)
- })
- it('Should fail with a bad count pagination', async function () {
- await checkBadCountPagination(server.url, myHistoryPath, server.accessToken)
- })
- it('Should fail with an unauthenticated user', async function () {
- await makeGetRequest({ url: server.url, path: myHistoryPath, statusCodeExpected: 401 })
- })
- it('Should succeed with the correct params', async function () {
- await makeGetRequest({ url: server.url, token: server.accessToken, path: myHistoryPath, statusCodeExpected: 200 })
- })
- })
- describe('When removing user videos history', function () {
- it('Should fail with an unauthenticated user', async function () {
- await makePostBodyRequest({ url: server.url, path: myHistoryPath + '/remove', statusCodeExpected: 401 })
- })
- it('Should fail with a bad beforeDate parameter', async function () {
- const body = { beforeDate: '15' }
- await makePostBodyRequest({
- url: server.url,
- token: server.accessToken,
- path: myHistoryRemove,
- fields: body,
- statusCodeExpected: 400
- })
- })
- it('Should succeed with a valid beforeDate param', async function () {
- const body = { beforeDate: new Date().toISOString() }
- await makePostBodyRequest({
- url: server.url,
- token: server.accessToken,
- path: myHistoryRemove,
- fields: body,
- statusCodeExpected: 204
- })
- })
- it('Should succeed without body', async function () {
- await makePostBodyRequest({
- url: server.url,
- token: server.accessToken,
- path: myHistoryRemove,
- statusCodeExpected: 204
- })
- })
- })
- after(async function () {
- await cleanupTests([ server ])
- })
- })
|