|
|
|
'use strict';
|
|
|
|
|
|
|
|
var async = require('async');
|
|
|
|
var assert = require('assert');
|
|
|
|
var nconf = require('nconf');
|
|
|
|
var path = require('path');
|
|
|
|
|
|
|
|
var db = require('./mocks/databasemock');
|
|
|
|
var categories = require('../src/categories');
|
|
|
|
var topics = require('../src/topics');
|
|
|
|
var user = require('../src/user');
|
|
|
|
var groups = require('../src/groups');
|
|
|
|
var privileges = require('../src/privileges');
|
|
|
|
var meta = require('../src/meta');
|
|
|
|
var helpers = require('./helpers');
|
|
|
|
|
|
|
|
|
|
|
|
describe('Upload Controllers', function () {
|
|
|
|
|
|
|
|
var tid;
|
|
|
|
var cid;
|
|
|
|
var pid;
|
|
|
|
var adminUid;
|
|
|
|
var regularUid;
|
|
|
|
|
|
|
|
before(function (done) {
|
|
|
|
async.series({
|
|
|
|
category: function (next) {
|
|
|
|
categories.create({
|
|
|
|
name: 'Test Category',
|
|
|
|
description: 'Test category created by testing script'
|
|
|
|
}, next);
|
|
|
|
},
|
|
|
|
adminUid: function (next) {
|
|
|
|
user.create({username: 'admin', password: 'barbar'}, next);
|
|
|
|
},
|
|
|
|
regularUid: function (next) {
|
|
|
|
user.create({username: 'regular', password: 'zugzug'}, next);
|
|
|
|
}
|
|
|
|
}, function (err, results) {
|
|
|
|
if (err) {
|
|
|
|
return done(err);
|
|
|
|
}
|
|
|
|
adminUid = results.adminUid;
|
|
|
|
regularUid = results.regularUid;
|
|
|
|
cid = results.category.cid;
|
|
|
|
|
|
|
|
topics.post({uid: adminUid, title: 'test topic title', content: 'test topic content', cid: results.category.cid}, function (err, result) {
|
|
|
|
tid = result.topicData.tid;
|
|
|
|
pid = result.postData.pid;
|
|
|
|
done(err);
|
|
|
|
});
|
|
|
|
});
|
|
|
|
});
|
|
|
|
|
|
|
|
describe('regular user uploads', function () {
|
|
|
|
var jar;
|
|
|
|
var csrf_token;
|
|
|
|
|
|
|
|
before(function (done) {
|
|
|
|
helpers.loginUser('regular', 'zugzug', function (err, _jar, io, _csrf_token) {
|
|
|
|
assert.ifError(err);
|
|
|
|
jar = _jar;
|
|
|
|
csrf_token = _csrf_token;
|
|
|
|
privileges.categories.give(['upload:post:file'], cid, 'registered-users', done);
|
|
|
|
});
|
|
|
|
});
|
|
|
|
|
|
|
|
it('should upload a profile picture', function (done) {
|
|
|
|
helpers.uploadFile(nconf.get('url') + '/api/user/regular/uploadpicture', path.join(__dirname, '../public/logo.png'), {}, jar, csrf_token, function (err, res, body) {
|
|
|
|
assert.ifError(err);
|
|
|
|
assert.equal(res.statusCode, 200);
|
|
|
|
assert(Array.isArray(body));
|
|
|
|
assert.equal(body.length, 1);
|
|
|
|
assert.equal(body[0].url, '/uploads/profile/' + regularUid + '-profileimg.png');
|
|
|
|
done();
|
|
|
|
});
|
|
|
|
});
|
|
|
|
|
|
|
|
it('should upload an image to a post', function (done) {
|
|
|
|
helpers.uploadFile(nconf.get('url') + '/api/post/upload', path.join(__dirname, '../public/logo.png'), {cid: cid}, jar, csrf_token, function (err, res, body) {
|
|
|
|
assert.ifError(err);
|
|
|
|
assert.equal(res.statusCode, 200);
|
|
|
|
assert(Array.isArray(body));
|
|
|
|
assert(body[0].path);
|
|
|
|
assert(body[0].url);
|
|
|
|
done();
|
|
|
|
});
|
|
|
|
});
|
|
|
|
|
|
|
|
|
|
|
|
it('should upload a file to a post', function (done) {
|
|
|
|
meta.config.allowFileUploads = 1;
|
|
|
|
helpers.uploadFile(nconf.get('url') + '/api/post/upload', path.join(__dirname, '../public/503.html'), {cid: cid}, jar, csrf_token, function (err, res, body) {
|
|
|
|
assert.ifError(err);
|
|
|
|
assert.equal(res.statusCode, 200);
|
|
|
|
assert(Array.isArray(body));
|
|
|
|
assert(body[0].path);
|
|
|
|
assert(body[0].url);
|
|
|
|
done();
|
|
|
|
});
|
|
|
|
});
|
|
|
|
|
|
|
|
});
|
|
|
|
|
|
|
|
|
|
|
|
describe('admin uploads', function () {
|
|
|
|
var jar;
|
|
|
|
var csrf_token;
|
|
|
|
|
|
|
|
before(function (done) {
|
|
|
|
helpers.loginUser('admin', 'barbar', function (err, _jar, io, _csrf_token) {
|
|
|
|
assert.ifError(err);
|
|
|
|
jar = _jar;
|
|
|
|
csrf_token = _csrf_token;
|
|
|
|
groups.join('administrators', adminUid, done);
|
|
|
|
});
|
|
|
|
});
|
|
|
|
|
|
|
|
it('should upload site logo', function (done) {
|
|
|
|
helpers.uploadFile(nconf.get('url') + '/api/admin/uploadlogo', path.join(__dirname, '../public/logo.png'), {}, jar, csrf_token, function (err, res, body) {
|
|
|
|
assert.ifError(err);
|
|
|
|
assert.equal(res.statusCode, 200);
|
|
|
|
assert(Array.isArray(body));
|
|
|
|
assert.equal(body[0].url, '/uploads/system/site-logo.png');
|
|
|
|
done();
|
|
|
|
});
|
|
|
|
});
|
|
|
|
|
|
|
|
it('should upload category image', function (done) {
|
|
|
|
helpers.uploadFile(nconf.get('url') + '/api/admin/category/uploadpicture', path.join(__dirname, '../public/logo.png'), {params: JSON.stringify({cid: cid})}, jar, csrf_token, function (err, res, body) {
|
|
|
|
assert.ifError(err);
|
|
|
|
assert.equal(res.statusCode, 200);
|
|
|
|
assert(Array.isArray(body));
|
|
|
|
assert.equal(body[0].url, '/uploads/category/category-1.png');
|
|
|
|
done();
|
|
|
|
});
|
|
|
|
});
|
|
|
|
|
|
|
|
it('should upload favicon', function (done) {
|
|
|
|
helpers.uploadFile(nconf.get('url') + '/api/admin/uploadfavicon', path.join(__dirname, '../public/favicon.ico'), {}, jar, csrf_token, function (err, res, body) {
|
|
|
|
assert.ifError(err);
|
|
|
|
assert.equal(res.statusCode, 200);
|
|
|
|
assert(Array.isArray(body));
|
|
|
|
assert.equal(body[0].url, '/uploads/system/favicon.ico');
|
|
|
|
done();
|
|
|
|
});
|
|
|
|
});
|
|
|
|
|
|
|
|
it('should upload touch icon', function (done) {
|
|
|
|
helpers.uploadFile(nconf.get('url') + '/api/admin/uploadTouchIcon', path.join(__dirname, '../public/logo.png'), {}, jar, csrf_token, function (err, res, body) {
|
|
|
|
assert.ifError(err);
|
|
|
|
assert.equal(res.statusCode, 200);
|
|
|
|
assert(Array.isArray(body));
|
|
|
|
assert.equal(body[0].url, '/uploads/system/touchicon-orig.png');
|
|
|
|
done();
|
|
|
|
});
|
|
|
|
});
|
|
|
|
});
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
after(function (done) {
|
|
|
|
db.emptydb(done);
|
|
|
|
});
|
|
|
|
});
|