From 2ef77d69de6bf6535cc4ad42aff9daa021c9e0a5 Mon Sep 17 00:00:00 2001 From: Hannah Wolfe Date: Tue, 9 Dec 2014 17:12:00 +0000 Subject: [PATCH] Sitemaps correctly filter draft posts fixes #4612 - adds missing line of code to remove draft posts - adds tests to check drafts aren't added --- core/server/data/sitemap/manager.js | 4 +++ core/test/integration/sitemap_spec.js | 37 +++++++++++++++++++++++++++ 2 files changed, 41 insertions(+) diff --git a/core/server/data/sitemap/manager.js b/core/server/data/sitemap/manager.js index f6300e8039..93f213ac27 100644 --- a/core/server/data/sitemap/manager.js +++ b/core/server/data/sitemap/manager.js @@ -118,6 +118,10 @@ _.extend(SiteMapManager.prototype, { return; } + if (post.get('status') !== 'published') { + return; + } + this.posts.addUrl(post.toJSON()); }, diff --git a/core/test/integration/sitemap_spec.js b/core/test/integration/sitemap_spec.js index f893b4e962..793bb2a90f 100644 --- a/core/test/integration/sitemap_spec.js +++ b/core/test/integration/sitemap_spec.js @@ -157,6 +157,25 @@ describe('Sitemap', function () { }).catch(done); }); + it('doesn\'t add draft pages', function (done) { + var manager = makeStubManager(), + fake = { + toJSON: sandbox.stub().returns({ + status: 'draft' + }), + get: sandbox.stub().returns('draft'), + updated: sandbox.stub().returns('draft') + }; + + manager.init().then(function () { + manager.pageAdded(fake); + + manager.pages.addUrl.called.should.equal(false); + + done(); + }).catch(done); + }); + it('deletes pages that were unpublished', function (done) { var manager = makeStubManager(), fake = { @@ -225,6 +244,24 @@ describe('Sitemap', function () { }).catch(done); }); + it('doesn\'t add draft posts', function (done) { + var manager = makeStubManager(), + fake = { + toJSON: sandbox.stub().returns({ + status: 'draft' + }), + get: sandbox.stub().returns('draft'), + updated: sandbox.stub().returns('draft') + }; + + manager.init().then(function () { + manager.postAdded(fake); + manager.posts.addUrl.called.should.equal(false); + + done(); + }).catch(done); + }); + it('deletes posts that were unpublished', function (done) { var manager = makeStubManager(), fake = {