147 lines
4.7 KiB
JavaScript
147 lines
4.7 KiB
JavaScript
const chai = require( 'chai' )
|
|
const chaiHttp = require( 'chai-http' )
|
|
const assert = require( 'assert' )
|
|
|
|
const root = require( 'app-root-path' )
|
|
const { init } = require( `${root}/app` )
|
|
const knex = require( `${root}/db/knex` )
|
|
|
|
const expect = chai.expect
|
|
chai.use( chaiHttp )
|
|
|
|
|
|
const { createUser, createToken, revokeToken, revokeTokenById, validateToken, getUserTokens } = require( '../services/users' )
|
|
const { createStream, getStream, updateStream, deleteStream, getUserStreams, getStreamUsers, grantPermissionsStream, revokePermissionsStream } = require( '../services/streams' )
|
|
|
|
describe( 'Streams', ( ) => {
|
|
|
|
let userOne = {
|
|
username: 'dim',
|
|
name: 'Dimitrie Stefanescu',
|
|
email: 'didimitrie@gmail.com',
|
|
password: 'sn3aky-1337-b1m'
|
|
}
|
|
|
|
before( async ( ) => {
|
|
await knex.migrate.rollback( )
|
|
await knex.migrate.latest( )
|
|
|
|
userOne.id = await createUser( userOne )
|
|
} )
|
|
|
|
after( async ( ) => {
|
|
await knex.migrate.rollback( )
|
|
} )
|
|
|
|
let testStream = {
|
|
name: 'Test Stream 01',
|
|
description: 'wonderful test stream'
|
|
}
|
|
|
|
let secondTestStream = { name: 'Test Stream 02' }
|
|
|
|
|
|
describe( 'Base CRUD', ( ) => {
|
|
it( 'Should create a stream', async ( ) => {
|
|
testStream.id = await createStream( testStream, userOne.id )
|
|
expect( testStream ).to.have.property( 'id' )
|
|
expect( testStream.id ).to.not.be.null
|
|
|
|
secondTestStream.id = await createStream( secondTestStream, userOne.id )
|
|
expect( secondTestStream.id ).to.not.be.null
|
|
} )
|
|
|
|
it( 'Should get a stream', async ( ) => {
|
|
let stream = await getStream( testStream.id )
|
|
expect( stream ).to.not.be.null
|
|
} )
|
|
|
|
it( 'Should update a stream', async ( ) => {
|
|
let sid = await updateStream( { id: testStream.id, name: "Modified Name", description: 'Wooot' } )
|
|
let stream = await getStream( testStream.id )
|
|
expect( stream.name ).to.equal( 'Modified Name' )
|
|
expect( stream.description ).to.equal( 'Wooot' )
|
|
} )
|
|
|
|
it( 'Should get all streams for a user', async ( ) => {
|
|
let all = await getUserStreams( userOne.id )
|
|
expect( all ).to.have.lengthOf( 2 )
|
|
} )
|
|
|
|
it( 'Should delete a stream', async ( ) => {
|
|
const id = await createStream( { name: 'to delete' }, userOne.id )
|
|
let all = await getUserStreams( userOne.id )
|
|
expect( all ).to.have.lengthOf( 3 )
|
|
|
|
await deleteStream( id )
|
|
|
|
all = await getUserStreams( userOne.id )
|
|
expect( all ).to.have.lengthOf( 2 )
|
|
} )
|
|
} )
|
|
|
|
describe( 'Sharing', ( ) => {
|
|
let userTwo = {
|
|
username: 'dimsecond',
|
|
name: 'Dimitrie Stefanescu 2',
|
|
email: 'didimitrie2@gmail.com',
|
|
password: 'sn3aky-1337-b1m'
|
|
}
|
|
|
|
before( async ( ) => {
|
|
userTwo.id = await createUser( userTwo )
|
|
} )
|
|
|
|
it( 'Should share a stream with a user', async ( ) => {
|
|
await grantPermissionsStream( testStream.id, userTwo.id, 'stream:reviewer' )
|
|
await grantPermissionsStream( testStream.id, userTwo.id, 'stream:contributor' ) // change perms
|
|
} )
|
|
|
|
it( 'Stream should show up in the other users` list', async ( ) => {
|
|
let userTwoStreams = await getUserStreams( userTwo.id )
|
|
expect( userTwoStreams ).to.have.lengthOf( 1 )
|
|
expect( userTwoStreams[ 0 ] ).to.have.property( 'role' )
|
|
expect( userTwoStreams[ 0 ].role ).to.equal( 'stream:contributor' )
|
|
} )
|
|
|
|
it( 'Should get the users with access to a stream', async ( ) => {
|
|
let users = await getStreamUsers( testStream.id )
|
|
expect( users ).to.have.lengthOf( 2 )
|
|
expect( users[ 0 ] ).to.not.have.property( 'email' )
|
|
expect( users[ 0 ] ).to.have.property( 'id' )
|
|
} )
|
|
|
|
it( 'Should revoke permissions on stream', async ( ) => {
|
|
await revokePermissionsStream( testStream.id, userTwo.id )
|
|
let userTwoStreams = await getUserStreams( userTwo.id )
|
|
expect( userTwoStreams ).to.have.lengthOf( 0 )
|
|
} )
|
|
|
|
it( 'Should not revoke owner permissions', async ( ) => {
|
|
try {
|
|
await revokePermissionsStream( testStream.id, userOne.id )
|
|
assert.fail( )
|
|
} catch {
|
|
// pass
|
|
}
|
|
} )
|
|
|
|
// it( '🤔 DUBIOUS DESIGN DECISION: A stream should not have more than one owner', async ( ) => {
|
|
// let newStream = { name: 'XXX' }
|
|
// newStream.id = await createStream( newStream, userOne.id )
|
|
// await grantPermissionsStream( newStream.id, userTwo.id, 'owner' )
|
|
|
|
// let usrStreams1 = await getUserStreams( userOne.id )
|
|
// let s1 = usrStreams1.find( s => s.name === 'XXX' )
|
|
// let usrStreams2 = await getUserStreams( userTwo.id )
|
|
// let s2 = usrStreams2.find( s => s.name === 'XXX' )
|
|
|
|
// expect( s1.role ).to.not.equal( 'owner' )
|
|
// expect( s1.role ).to.not.equal( s2.role )
|
|
// } )
|
|
|
|
} )
|
|
|
|
|
|
|
|
} ) |