You cannot select more than 25 topics
Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.
94 lines
3.4 KiB
JavaScript
94 lines
3.4 KiB
JavaScript
4 years ago
|
var assert = require('assert');
|
||
|
const low = require('lowdb')
|
||
|
var winston = require('winston');
|
||
|
|
||
|
process.chdir('./backend')
|
||
|
|
||
|
const FileSync = require('lowdb/adapters/FileSync');
|
||
|
|
||
|
const adapter = new FileSync('./appdata/db.json');
|
||
|
const db = low(adapter)
|
||
|
|
||
|
const users_adapter = new FileSync('./appdata/users.json');
|
||
|
const users_db = low(users_adapter);
|
||
|
|
||
|
const defaultFormat = winston.format.printf(({ level, message, label, timestamp }) => {
|
||
|
return `${timestamp} ${level.toUpperCase()}: ${message}`;
|
||
|
});
|
||
|
|
||
|
let debugMode = process.env.YTDL_MODE === 'debug';
|
||
|
|
||
|
const logger = winston.createLogger({
|
||
|
level: 'info',
|
||
|
format: winston.format.combine(winston.format.timestamp(), defaultFormat),
|
||
|
defaultMeta: {},
|
||
|
transports: [
|
||
|
//
|
||
|
// - Write to all logs with level `info` and below to `combined.log`
|
||
|
// - Write all logs error (and below) to `error.log`.
|
||
|
//
|
||
|
new winston.transports.File({ filename: 'appdata/logs/error.log', level: 'error' }),
|
||
|
new winston.transports.File({ filename: 'appdata/logs/combined.log' }),
|
||
|
new winston.transports.Console({level: !debugMode ? 'info' : 'debug', name: 'console'})
|
||
|
]
|
||
|
});
|
||
|
|
||
|
var auth_api = require('../authentication/auth');
|
||
|
var db_api = require('../db');
|
||
|
|
||
|
db_api.initialize(db, users_db, logger);
|
||
|
auth_api.initialize(db, users_db, logger);
|
||
|
|
||
|
describe('Multi User', async function() {
|
||
|
let user = null;
|
||
|
const user_to_test = 'admin';
|
||
|
before(async function() {
|
||
|
user = await auth_api.login('admin', 'pass');
|
||
|
console.log('hi')
|
||
|
});
|
||
|
describe('Authentication', function() {
|
||
|
it('login', async function() {
|
||
|
assert(user);
|
||
|
});
|
||
|
});
|
||
|
describe('Video player - normal', function() {
|
||
|
const video_to_test = 'ebbcfffb-d6f1-4510-ad25-d1ec82e0477e';
|
||
|
it('Get video', async function() {
|
||
|
const video_obj = db_api.getVideo(video_to_test, 'admin');
|
||
|
assert(video_obj);
|
||
|
});
|
||
|
|
||
|
it('Video access - disallowed', async function() {
|
||
|
await db_api.setVideoProperty(video_to_test, {sharingEnabled: false}, user_to_test);
|
||
|
const video_obj = auth_api.getUserVideo('admin', video_to_test, true);
|
||
|
assert(!video_obj);
|
||
|
});
|
||
|
|
||
|
it('Video access - allowed', async function() {
|
||
|
await db_api.setVideoProperty(video_to_test, {sharingEnabled: true}, user_to_test);
|
||
|
const video_obj = auth_api.getUserVideo('admin', video_to_test, true);
|
||
|
assert(video_obj);
|
||
|
});
|
||
|
});
|
||
|
// describe('Video player - subscription', function() {
|
||
|
// const sub_to_test = '';
|
||
|
// const video_to_test = 'ebbcfffb-d6f1-4510-ad25-d1ec82e0477e';
|
||
|
// it('Get video', async function() {
|
||
|
// const video_obj = db_api.getVideo(video_to_test, 'admin', );
|
||
|
// assert(video_obj);
|
||
|
// });
|
||
|
|
||
|
// it('Video access - disallowed', async function() {
|
||
|
// await db_api.setVideoProperty(video_to_test, {sharingEnabled: false}, user_to_test, sub_to_test);
|
||
|
// const video_obj = auth_api.getUserVideo('admin', video_to_test, true);
|
||
|
// assert(!video_obj);
|
||
|
// });
|
||
|
|
||
|
// it('Video access - allowed', async function() {
|
||
|
// await db_api.setVideoProperty(video_to_test, {sharingEnabled: true}, user_to_test, sub_to_test);
|
||
|
// const video_obj = auth_api.getUserVideo('admin', video_to_test, true);
|
||
|
// assert(video_obj);
|
||
|
// });
|
||
|
// });
|
||
|
|
||
|
});
|