2014-08-18 17:43:06 +01:00
|
|
|
// # Post Settings Menu Tests
|
|
|
|
// Test the post settings menu on the editor screen works as expected
|
|
|
|
|
2014-09-03 17:42:55 +02:00
|
|
|
/*globals CasperTest, casper, __utils__ */
|
2014-08-18 17:43:06 +01:00
|
|
|
|
2014-09-23 08:47:35 +00:00
|
|
|
CasperTest.begin('Post settings menu', 10, function suite(test) {
|
2014-08-18 17:43:06 +01:00
|
|
|
casper.thenOpenAndWaitForPageLoad('editor', function testTitleAndUrl() {
|
2014-11-25 12:56:08 -08:00
|
|
|
test.assertTitle('Editor - Test Blog', 'Ghost admin has incorrect title');
|
2014-08-18 17:43:06 +01:00
|
|
|
test.assertUrlMatch(/ghost\/editor\/$/, 'Landed on the correct URL');
|
|
|
|
});
|
|
|
|
|
|
|
|
casper.then(function () {
|
|
|
|
test.assertExists('.post-settings', 'icon toggle should exist');
|
2014-10-13 16:23:06 +01:00
|
|
|
test.assertExists('.settings-menu', 'popup menu should be rendered at startup');
|
|
|
|
test.assertExists('.settings-menu #url', 'url field exists');
|
|
|
|
test.assertExists('.settings-menu .post-setting-date', 'publication date field exists');
|
|
|
|
test.assertExists('.settings-menu .post-setting-static-page', 'static page checkbox field exists');
|
2014-08-18 17:43:06 +01:00
|
|
|
});
|
|
|
|
|
|
|
|
// Enter a title and save draft so converting to/from static post
|
|
|
|
// will result in notifications and 'Delete This Post' button appears
|
2014-09-03 17:42:55 +02:00
|
|
|
casper.then(function () {
|
2014-08-18 17:43:06 +01:00
|
|
|
casper.sendKeys('#entry-title', 'aTitle');
|
|
|
|
casper.thenClick('.js-publish-button');
|
|
|
|
});
|
|
|
|
|
|
|
|
casper.waitForSelector('.notification-success', function waitForSuccess() {
|
|
|
|
test.assert(true, 'got success notification');
|
2015-06-03 15:50:52 +01:00
|
|
|
test.assertSelectorHasText('.notification-success', 'Saved.', '.notification-success has correct text');
|
2015-05-22 09:38:46 +01:00
|
|
|
casper.click('.gh-notification-close');
|
2014-08-18 17:43:06 +01:00
|
|
|
}, function onTimeout() {
|
|
|
|
test.assert(false, 'No success notification');
|
|
|
|
});
|
|
|
|
|
|
|
|
casper.waitWhileSelector('.notification-success');
|
|
|
|
|
|
|
|
casper.thenClick('.post-settings');
|
|
|
|
|
2014-10-13 16:23:06 +01:00
|
|
|
casper.waitForOpaque('.settings-menu', function onSuccess() {
|
2014-08-18 17:43:06 +01:00
|
|
|
test.assert(true, 'post settings menu should be visible after clicking post-settings icon');
|
|
|
|
});
|
|
|
|
});
|
|
|
|
|
|
|
|
CasperTest.begin('Post url can be changed', 4, function suite(test) {
|
|
|
|
// Create a sample post
|
|
|
|
CasperTest.Routines.createTestPost.run(false);
|
|
|
|
|
|
|
|
// Begin test
|
|
|
|
casper.thenOpenAndWaitForPageLoad('content', function testTitleAndUrl() {
|
2014-11-25 12:56:08 -08:00
|
|
|
test.assertTitle('Content - Test Blog', 'Title is "Content - Test Blog"');
|
2014-08-18 17:43:06 +01:00
|
|
|
test.assertUrlMatch(/ghost\/\d+\/$/, 'Landed on the correct URL');
|
|
|
|
});
|
|
|
|
|
2015-04-30 16:14:19 -05:00
|
|
|
// Transition to the editor
|
2014-08-18 17:43:06 +01:00
|
|
|
casper.thenClick('.post-edit');
|
|
|
|
casper.waitForSelector('#entry-title');
|
|
|
|
|
|
|
|
casper.thenClick('.post-settings');
|
|
|
|
|
|
|
|
// Test change permalink
|
|
|
|
casper.then(function () {
|
2014-10-13 16:23:06 +01:00
|
|
|
this.fillSelectors('.settings-menu form', {
|
2014-08-18 17:43:06 +01:00
|
|
|
'#url': 'new-url'
|
|
|
|
}, false);
|
|
|
|
|
|
|
|
this.click('.post-settings');
|
|
|
|
});
|
|
|
|
|
|
|
|
casper.waitForResource(/\/posts\/\d+\/\?include=tags/, function testGoodResponse(resource) {
|
2015-06-03 15:50:52 +01:00
|
|
|
test.assert(resource.status < 400, 'resource.status < 400');
|
2014-08-18 17:43:06 +01:00
|
|
|
});
|
|
|
|
|
|
|
|
casper.then(function checkValueMatches() {
|
2014-09-10 00:06:24 -04:00
|
|
|
// using assertField(name) checks the htmls initial "value" attribute, so have to hack around it.
|
2014-08-18 17:43:06 +01:00
|
|
|
var slugVal = this.evaluate(function () {
|
|
|
|
return __utils__.getFieldValue('post-setting-slug');
|
|
|
|
});
|
2015-06-03 15:50:52 +01:00
|
|
|
test.assertEquals(slugVal, 'new-url', 'slug has correct value');
|
2014-08-18 17:43:06 +01:00
|
|
|
});
|
|
|
|
});
|
|
|
|
|
|
|
|
CasperTest.begin('Post published date can be changed', 4, function suite(test) {
|
|
|
|
// Create a sample post
|
|
|
|
CasperTest.Routines.createTestPost.run(false);
|
|
|
|
|
|
|
|
// Begin test
|
|
|
|
casper.thenOpenAndWaitForPageLoad('content', function testTitleAndUrl() {
|
2014-11-25 12:56:08 -08:00
|
|
|
test.assertTitle('Content - Test Blog', 'Title is "Content - Test Blog"');
|
2014-08-18 17:43:06 +01:00
|
|
|
test.assertUrlMatch(/ghost\/\d+\/$/, 'Landed on the correct URL');
|
|
|
|
});
|
|
|
|
|
2015-04-30 16:14:19 -05:00
|
|
|
// Transition to the editor
|
2014-08-18 17:43:06 +01:00
|
|
|
casper.thenClick('.post-edit');
|
|
|
|
casper.waitForSelector('#entry-title');
|
|
|
|
|
|
|
|
casper.thenClick('.post-settings');
|
|
|
|
|
|
|
|
// Test change published date
|
|
|
|
casper.then(function () {
|
2014-10-13 16:23:06 +01:00
|
|
|
this.fillSelectors('.settings-menu form', {
|
2014-08-18 17:43:06 +01:00
|
|
|
'.post-setting-date': '22 May 14 @ 23:39'
|
|
|
|
}, false);
|
|
|
|
|
|
|
|
this.click('.post-settings');
|
|
|
|
});
|
|
|
|
|
|
|
|
casper.waitForResource(/\/posts\/\d+\/\?include=tags/, function testGoodResponse(resource) {
|
2015-06-03 15:50:52 +01:00
|
|
|
test.assert(resource.status < 400, 'resource.status < 400');
|
2014-08-18 17:43:06 +01:00
|
|
|
});
|
|
|
|
|
|
|
|
casper.then(function checkValueMatches() {
|
2014-09-10 00:06:24 -04:00
|
|
|
// using assertField(name) checks the htmls initial "value" attribute, so have to hack around it.
|
2014-08-18 17:43:06 +01:00
|
|
|
var dateVal = this.evaluate(function () {
|
|
|
|
return __utils__.getFieldValue('post-setting-date');
|
|
|
|
});
|
2015-06-03 15:50:52 +01:00
|
|
|
test.assertEquals(dateVal, '22 May 14 @ 23:39', 'date is correct');
|
2014-08-18 17:43:06 +01:00
|
|
|
});
|
|
|
|
});
|
|
|
|
|
2014-10-20 22:05:41 +02:00
|
|
|
CasperTest.begin('Post can be changed to static page', 2, function suite(test) {
|
2014-08-18 17:43:06 +01:00
|
|
|
// Create a sample post
|
|
|
|
CasperTest.Routines.createTestPost.run(false);
|
|
|
|
|
|
|
|
// Begin test
|
|
|
|
casper.thenOpenAndWaitForPageLoad('content', function testTitleAndUrl() {
|
2014-11-25 12:56:08 -08:00
|
|
|
test.assertTitle('Content - Test Blog', 'Title is "Content - Test Blog"');
|
2014-08-18 17:43:06 +01:00
|
|
|
test.assertUrlMatch(/ghost\/\d+\/$/, 'Landed on the correct URL');
|
|
|
|
});
|
|
|
|
|
|
|
|
// Transition to the editor
|
|
|
|
casper.thenClick('.post-edit');
|
|
|
|
casper.waitForSelector('#entry-title');
|
|
|
|
|
|
|
|
casper.thenClick('.post-settings');
|
|
|
|
|
|
|
|
casper.thenClick('label[for=static-page]');
|
|
|
|
|
2014-10-20 22:05:41 +02:00
|
|
|
casper.waitForSelector('.post-setting-static-page:checked', function onSuccess() {
|
|
|
|
casper.click('label[for=static-page]');
|
|
|
|
}, function onTimeout() {
|
|
|
|
casper.test.fail('Post was not changed to static page.');
|
|
|
|
}, 2000);
|
2014-08-18 17:43:06 +01:00
|
|
|
|
2014-10-20 22:05:41 +02:00
|
|
|
casper.waitForSelector('.post-setting-static-page:not(checked)', function onSuccess() {
|
|
|
|
return;
|
|
|
|
}, function onTimeout() {
|
|
|
|
casper.test.fail('Static page was not changed to post.');
|
|
|
|
}, 2000);
|
2014-08-12 17:00:09 +00:00
|
|
|
});
|
|
|
|
|
2015-06-03 15:50:52 +01:00
|
|
|
CasperTest.begin('Post url input is reset from all whitespace back to original value', 4, function suite(test) {
|
2014-08-12 17:00:09 +00:00
|
|
|
// Create a sample post
|
|
|
|
CasperTest.Routines.createTestPost.run(false);
|
|
|
|
|
|
|
|
// Begin test
|
|
|
|
casper.thenOpenAndWaitForPageLoad('content', function testTitleAndUrl() {
|
2014-11-25 12:56:08 -08:00
|
|
|
test.assertTitle('Content - Test Blog', 'Title is "Content - Test Blog"');
|
2014-08-12 17:00:09 +00:00
|
|
|
test.assertUrlMatch(/ghost\/\d+\/$/, 'Landed on the correct URL');
|
|
|
|
});
|
|
|
|
|
|
|
|
// Transition to the editor
|
|
|
|
casper.thenClick('.post-edit');
|
|
|
|
casper.waitForSelector('#entry-title');
|
|
|
|
|
|
|
|
casper.thenClick('.post-settings');
|
|
|
|
|
|
|
|
var originalSlug;
|
|
|
|
casper.then(function () {
|
|
|
|
originalSlug = casper.evaluate(function () {
|
|
|
|
return __utils__.getFieldValue('post-setting-slug');
|
|
|
|
});
|
|
|
|
});
|
|
|
|
|
|
|
|
// Test change permalink
|
|
|
|
casper.then(function () {
|
2014-10-13 16:23:06 +01:00
|
|
|
this.fillSelectors('.settings-menu form', {
|
2014-08-12 17:00:09 +00:00
|
|
|
'#url': ' '
|
|
|
|
}, false);
|
|
|
|
});
|
|
|
|
|
2015-06-03 15:50:52 +01:00
|
|
|
// Click in a different field
|
|
|
|
casper.thenClick('#post-setting-date');
|
|
|
|
|
2014-08-12 17:00:09 +00:00
|
|
|
casper.then(function checkValueMatches() {
|
2014-09-10 00:06:24 -04:00
|
|
|
// using assertField(name) checks the htmls initial "value" attribute, so have to hack around it.
|
2014-08-12 17:00:09 +00:00
|
|
|
var slugVal = this.evaluate(function () {
|
|
|
|
return __utils__.getFieldValue('post-setting-slug');
|
|
|
|
});
|
2015-06-03 15:50:52 +01:00
|
|
|
test.assertNotEquals(slugVal, ' ', 'slug is not just spaces');
|
|
|
|
test.assertEquals(slugVal, originalSlug, 'slug gets reset to original value');
|
2014-08-12 17:00:09 +00:00
|
|
|
});
|
2014-09-10 00:06:24 -04:00
|
|
|
});
|
2015-06-04 20:53:08 +01:00
|
|
|
// TODO this test is from editor_test and needs to come back in some form when tags are moved into PSM
|
|
|
|
// CasperTest.begin('Tag editor', 7, function suite(test) {
|
|
|
|
// casper.thenOpenAndWaitForPageLoad('editor', function testTitleAndUrl() {
|
|
|
|
// test.assertTitle('Editor - Test Blog', 'Ghost admin has incorrect title');
|
|
|
|
// test.assertUrlMatch(/ghost\/editor\/$/, 'Landed on the correct URL');
|
|
|
|
// });
|
|
|
|
//
|
|
|
|
// var tagName = 'someTagName',
|
|
|
|
// createdTagSelector = '#entry-tags .tags .tag';
|
|
|
|
//
|
|
|
|
// casper.then(function () {
|
|
|
|
// test.assertExists('#entry-tags', 'should have tag label area');
|
|
|
|
// test.assertExists('#entry-tags .tag-label', 'should have tag label icon');
|
|
|
|
// test.assertExists('#entry-tags input.tag-input', 'should have tag input area');
|
|
|
|
// });
|
|
|
|
//
|
|
|
|
// casper.thenClick('#entry-tags input.tag-input');
|
|
|
|
// casper.then(function () {
|
|
|
|
// casper.sendKeys('#entry-tags input.tag-input', tagName, {keepFocus: true});
|
|
|
|
// });
|
|
|
|
// casper.then(function () {
|
|
|
|
// casper.sendKeys('#entry-tags input.tag-input', casper.page.event.key.Enter);
|
|
|
|
// });
|
|
|
|
//
|
|
|
|
// casper.waitForSelector(createdTagSelector, function onSuccess() {
|
|
|
|
// test.assertSelectorHasText(createdTagSelector, tagName, 'typing enter after tag name should create tag');
|
|
|
|
// });
|
|
|
|
//
|
|
|
|
// casper.thenClick(createdTagSelector);
|
|
|
|
//
|
|
|
|
// casper.waitWhileSelector(createdTagSelector, function onSuccess() {
|
|
|
|
// test.assert(true, 'clicking the tag should delete the tag');
|
|
|
|
// });
|
|
|
|
// });
|