mirror of
https://github.com/NodeBB/NodeBB.git
synced 2025-11-01 19:46:01 +01:00
unread tests
This commit is contained in:
@@ -55,66 +55,66 @@ unreadController.get = function (req, res, next) {
|
|||||||
cutoff: cutoff,
|
cutoff: cutoff,
|
||||||
}, next);
|
}, next);
|
||||||
},
|
},
|
||||||
], function (err, data) {
|
function (data) {
|
||||||
if (err) {
|
data.pageCount = Math.max(1, Math.ceil(data.topicCount / settings.topicsPerPage));
|
||||||
return next(err);
|
data.pagination = pagination.create(page, data.pageCount, req.query);
|
||||||
}
|
|
||||||
|
|
||||||
data.pageCount = Math.max(1, Math.ceil(data.topicCount / settings.topicsPerPage));
|
if (settings.usePagination && (page < 1 || page > data.pageCount)) {
|
||||||
data.pagination = pagination.create(page, data.pageCount, req.query);
|
req.query.page = Math.max(1, Math.min(data.pageCount, page));
|
||||||
|
return helpers.redirect(res, '/unread?' + querystring.stringify(req.query));
|
||||||
|
}
|
||||||
|
|
||||||
if (settings.usePagination && (page < 1 || page > data.pageCount)) {
|
data.categories = results.watchedCategories.categories;
|
||||||
req.query.page = Math.max(1, Math.min(data.pageCount, page));
|
data.selectedCategory = results.watchedCategories.selectedCategory;
|
||||||
return helpers.redirect(res, '/unread?' + querystring.stringify(req.query));
|
|
||||||
}
|
|
||||||
|
|
||||||
data.categories = results.watchedCategories.categories;
|
if (req.path.startsWith('/api/unread') || req.path.startsWith('/unread')) {
|
||||||
data.selectedCategory = results.watchedCategories.selectedCategory;
|
data.breadcrumbs = helpers.buildBreadcrumbs([{ text: '[[unread:title]]' }]);
|
||||||
|
}
|
||||||
|
|
||||||
if (req.path.startsWith('/api/unread') || req.path.startsWith('/unread')) {
|
data.title = '[[pages:unread]]';
|
||||||
data.breadcrumbs = helpers.buildBreadcrumbs([{ text: '[[unread:title]]' }]);
|
data.filters = [{
|
||||||
}
|
name: '[[unread:all-topics]]',
|
||||||
|
url: 'unread',
|
||||||
|
selected: filter === '',
|
||||||
|
filter: '',
|
||||||
|
}, {
|
||||||
|
name: '[[unread:new-topics]]',
|
||||||
|
url: 'unread/new',
|
||||||
|
selected: filter === 'new',
|
||||||
|
filter: 'new',
|
||||||
|
}, {
|
||||||
|
name: '[[unread:watched-topics]]',
|
||||||
|
url: 'unread/watched',
|
||||||
|
selected: filter === 'watched',
|
||||||
|
filter: 'watched',
|
||||||
|
}];
|
||||||
|
|
||||||
data.title = '[[pages:unread]]';
|
data.selectedFilter = data.filters.find(function (filter) {
|
||||||
data.filters = [{
|
return filter && filter.selected;
|
||||||
name: '[[unread:all-topics]]',
|
});
|
||||||
url: 'unread',
|
|
||||||
selected: filter === '',
|
|
||||||
filter: '',
|
|
||||||
}, {
|
|
||||||
name: '[[unread:new-topics]]',
|
|
||||||
url: 'unread/new',
|
|
||||||
selected: filter === 'new',
|
|
||||||
filter: 'new',
|
|
||||||
}, {
|
|
||||||
name: '[[unread:watched-topics]]',
|
|
||||||
url: 'unread/watched',
|
|
||||||
selected: filter === 'watched',
|
|
||||||
filter: 'watched',
|
|
||||||
}];
|
|
||||||
|
|
||||||
data.selectedFilter = data.filters.find(function (filter) {
|
data.querystring = cid ? ('?cid=' + validator.escape(String(cid))) : '';
|
||||||
return filter && filter.selected;
|
|
||||||
});
|
|
||||||
|
|
||||||
data.querystring = cid ? ('?cid=' + validator.escape(String(cid))) : '';
|
res.render('unread', data);
|
||||||
|
},
|
||||||
res.render('unread', data);
|
], next);
|
||||||
});
|
|
||||||
};
|
};
|
||||||
|
|
||||||
unreadController.unreadTotal = function (req, res, next) {
|
unreadController.unreadTotal = function (req, res, next) {
|
||||||
var filter = req.params.filter || '';
|
var filter = req.params.filter || '';
|
||||||
|
|
||||||
if (!validFilter[filter]) {
|
async.waterfall([
|
||||||
return next();
|
function (next) {
|
||||||
}
|
plugins.fireHook('filter:unread.getValidFilters', { filters: validFilter }, next);
|
||||||
|
},
|
||||||
topics.getTotalUnread(req.uid, filter, function (err, data) {
|
function (data, _next) {
|
||||||
if (err) {
|
if (!validFilter[filter]) {
|
||||||
return next(err);
|
return next();
|
||||||
}
|
}
|
||||||
|
topics.getTotalUnread(req.uid, filter, _next);
|
||||||
res.json(data);
|
},
|
||||||
});
|
function (data) {
|
||||||
|
res.json(data);
|
||||||
|
},
|
||||||
|
], next);
|
||||||
};
|
};
|
||||||
|
|||||||
@@ -1564,6 +1564,51 @@ describe('Controllers', function () {
|
|||||||
});
|
});
|
||||||
});
|
});
|
||||||
|
|
||||||
|
describe('unread', function () {
|
||||||
|
var jar;
|
||||||
|
before(function (done) {
|
||||||
|
helpers.loginUser('foo', 'barbar', function (err, _jar) {
|
||||||
|
assert.ifError(err);
|
||||||
|
jar = _jar;
|
||||||
|
done();
|
||||||
|
});
|
||||||
|
});
|
||||||
|
|
||||||
|
it('should 404 if filter is invalid', function (done) {
|
||||||
|
request(nconf.get('url') + '/api/unread/doesnotexist', { jar: jar }, function (err, res) {
|
||||||
|
assert.ifError(err);
|
||||||
|
assert.equal(res.statusCode, 404);
|
||||||
|
done();
|
||||||
|
});
|
||||||
|
});
|
||||||
|
|
||||||
|
it('should 404 if filter is invalid', function (done) {
|
||||||
|
request(nconf.get('url') + '/api/unread/doesnotexist/total', { jar: jar }, function (err, res) {
|
||||||
|
assert.ifError(err);
|
||||||
|
assert.equal(res.statusCode, 404);
|
||||||
|
done();
|
||||||
|
});
|
||||||
|
});
|
||||||
|
|
||||||
|
it('should return total unread count', function (done) {
|
||||||
|
request(nconf.get('url') + '/api/unread/new/total', { jar: jar }, function (err, res, body) {
|
||||||
|
assert.ifError(err);
|
||||||
|
assert.equal(res.statusCode, 200);
|
||||||
|
assert.equal(body, 0);
|
||||||
|
done();
|
||||||
|
});
|
||||||
|
});
|
||||||
|
|
||||||
|
it('should redirect if page is out of bounds', function (done) {
|
||||||
|
request(nconf.get('url') + '/api/unread?page=-1', { jar: jar }, function (err, res, body) {
|
||||||
|
assert.ifError(err);
|
||||||
|
assert.equal(res.statusCode, 308);
|
||||||
|
assert.equal(body, '"/unread?page=1"');
|
||||||
|
done();
|
||||||
|
});
|
||||||
|
});
|
||||||
|
});
|
||||||
|
|
||||||
after(function (done) {
|
after(function (done) {
|
||||||
var analytics = require('../src/analytics');
|
var analytics = require('../src/analytics');
|
||||||
analytics.writeData(function (err) {
|
analytics.writeData(function (err) {
|
||||||
|
|||||||
Reference in New Issue
Block a user