FIX: editing a post wasn't showing error messages from the server

This commit is contained in:
Régis Hanol 2015-03-19 12:22:56 +01:00
parent b071bd3c7c
commit df3b1f6968
21 changed files with 113 additions and 117 deletions

View File

@ -211,13 +211,13 @@ export default DiscourseController.extend({
} }
} }
var staged = false, var staged = false;
disableJumpReply = Discourse.User.currentProp('disable_jump_reply'); const disableJumpReply = Discourse.User.currentProp('disable_jump_reply');
var promise = composer.save({
const promise = composer.save({
imageSizes: this.get('view').imageSizes(), imageSizes: this.get('view').imageSizes(),
editReason: this.get("editReason") editReason: this.get("editReason")
}).then(function(opts) { }).then(function(opts) {
// If we replied as a new topic successfully, remove the draft. // If we replied as a new topic successfully, remove the draft.
if (self.get('replyAsNewTopicDraft')) { if (self.get('replyAsNewTopicDraft')) {
self.destroyDraft(); self.destroyDraft();
@ -240,21 +240,21 @@ export default DiscourseController.extend({
Discourse.URL.routeTo(opts.post.get('url')); Discourse.URL.routeTo(opts.post.get('url'));
} }
} }
}, function(error) { }).catch(function(error) {
composer.set('disableDrafts', false); composer.set('disableDrafts', false);
bootbox.alert(error); bootbox.alert(error);
}); });
if ( this.get('controllers.application.currentRouteName').split('.')[0] === 'topic' && if (this.get('controllers.application.currentRouteName').split('.')[0] === 'topic' &&
composer.get('topic.id') === this.get('controllers.topic.model.id') ) { composer.get('topic.id') === this.get('controllers.topic.model.id')) {
staged = composer.get('stagedPost'); staged = composer.get('stagedPost');
} }
Em.run.schedule('afterRender', function() { Em.run.schedule('afterRender', function() {
if (staged && !disableJumpReply) { if (staged && !disableJumpReply) {
var postNumber = staged.get('post_number'); const postNumber = staged.get('post_number');
Discourse.URL.jumpToPost(postNumber, {skipIfOnScreen: true}); Discourse.URL.jumpToPost(postNumber, { skipIfOnScreen: true });
self.appEvents.trigger('post:highlight', postNumber); self.appEvents.trigger('post:highlight', postNumber);
} }
}); });

View File

@ -123,7 +123,6 @@ Discourse.Post = Discourse.Model.extend({
save: function(complete, error) { save: function(complete, error) {
var self = this; var self = this;
if (!this.get('newPost')) { if (!this.get('newPost')) {
// We're updating a post // We're updating a post
return Discourse.ajax("/posts/" + (this.get('id')), { return Discourse.ajax("/posts/" + (this.get('id')), {
type: 'PUT', type: 'PUT',
@ -137,13 +136,12 @@ Discourse.Post = Discourse.Model.extend({
self.set('version', result.post.version); self.set('version', result.post.version);
if (result.category) Discourse.Site.current().updateCategory(result.category); if (result.category) Discourse.Site.current().updateCategory(result.category);
if (complete) complete(Discourse.Post.create(result.post)); if (complete) complete(Discourse.Post.create(result.post));
}, function(result) { }).catch(function(result) {
// Post failed to update // Post failed to update
if (error) error(result); if (error) error(result);
}); });
} else { } else {
// We're saving a post // We're saving a post
var data = this.getProperties(Discourse.Composer.serializedFieldsForCreate()); var data = this.getProperties(Discourse.Composer.serializedFieldsForCreate());
data.reply_to_post_number = this.get('reply_to_post_number'); data.reply_to_post_number = this.get('reply_to_post_number');
@ -162,7 +160,7 @@ Discourse.Post = Discourse.Model.extend({
}).then(function(result) { }).then(function(result) {
// Post created // Post created
if (complete) complete(Discourse.Post.create(result)); if (complete) complete(Discourse.Post.create(result));
}, function(result) { }).catch(function(result) {
// Failed to create a post // Failed to create a post
if (error) error(result); if (error) error(result);
}); });

View File

@ -385,7 +385,7 @@ const Composer = Discourse.Model.extend({
}, },
save(opts) { save(opts) {
if( !this.get('cantSubmitPost') ) { if (!this.get('cantSubmitPost')) {
return this.get('editingPost') ? this.editPost(opts) : this.createPost(opts); return this.get('editingPost') ? this.editPost(opts) : this.createPost(opts);
} }
}, },
@ -409,8 +409,9 @@ const Composer = Discourse.Model.extend({
// When you edit a post // When you edit a post
editPost(opts) { editPost(opts) {
const post = this.get('post'), const post = this.get('post'),
oldCooked = post.get('cooked'), oldCooked = post.get('cooked'),
self = this; self = this;
let promise; let promise;
// Update the title if we've changed it, otherwise consider it a // Update the title if we've changed it, otherwise consider it a
@ -418,7 +419,6 @@ const Composer = Discourse.Model.extend({
if (this.get('title') && if (this.get('title') &&
post.get('post_number') === 1 && post.get('post_number') === 1 &&
this.get('topic.details.can_edit')) { this.get('topic.details.can_edit')) {
const topicProps = this.getProperties(Object.keys(_edit_topic_serializer)); const topicProps = this.getProperties(Object.keys(_edit_topic_serializer));
promise = Discourse.Topic.update(this.get('topic'), topicProps); promise = Discourse.Topic.update(this.get('topic'), topicProps);
} else { } else {
@ -431,33 +431,26 @@ const Composer = Discourse.Model.extend({
imageSizes: opts.imageSizes, imageSizes: opts.imageSizes,
cooked: this.getCookedHtml() cooked: this.getCookedHtml()
}); });
this.set('composeState', CLOSED); this.set('composeState', CLOSED);
return promise.then(function() { return promise.then(function() {
return post.save(function(result) { return post.save(function(result) {
post.updateFromPost(result); post.updateFromPost(result);
self.clearState(); self.clearState();
}).catch(function(error) { }, function (error) {
const response = $.parseJSON(error.responseText);
if (response && response.errors) {
return(response.errors[0]);
} else {
return(I18n.t('generic_error'));
}
post.set('cooked', oldCooked); post.set('cooked', oldCooked);
self.set('composeState', OPEN); self.set('composeState', OPEN);
const response = $.parseJSON(error.responseText);
throw response && response.errors ? response.errors[0] : I18n.t('generic_error');
}); });
}); });
}, },
serialize(serializer, dest) { serialize(serializer, dest) {
if (!dest) { dest = dest || {};
dest = {}; Object.keys(serializer).forEach(f => {
} const val = this.get(serializer[f]);
const self = this;
Object.keys(serializer).forEach(function(f) {
const val = self.get(serializer[f]);
if (typeof val !== 'undefined') { if (typeof val !== 'undefined') {
Ember.set(dest, f, val); Ember.set(dest, f, val);
} }
@ -468,9 +461,10 @@ const Composer = Discourse.Model.extend({
// Create a new Post // Create a new Post
createPost(opts) { createPost(opts) {
const post = this.get('post'), const post = this.get('post'),
topic = this.get('topic'), topic = this.get('topic'),
currentUser = Discourse.User.current(), currentUser = Discourse.User.current(),
postStream = this.get('topic.postStream'); postStream = this.get('topic.postStream');
let addedToStream = false; let addedToStream = false;
// Build the post object // Build the post object
@ -530,10 +524,10 @@ const Composer = Discourse.Model.extend({
} }
} }
const composer = this; const composer = this,
const promise = new Ember.RSVP.Promise(function(resolve, reject) { promise = new Ember.RSVP.Promise(function(resolve, reject) {
composer.set('composeState', SAVING); composer.set('composeState', SAVING);
createdPost.save(function(result) { createdPost.save(function(result) {
let saving = true; let saving = true;

View File

@ -316,9 +316,7 @@ class ApplicationController < ActionController::Base
# type - a machine-readable description of the error # type - a machine-readable description of the error
# status - HTTP status code to return # status - HTTP status code to return
def render_json_error(obj, opts={}) def render_json_error(obj, opts={})
if opts.is_a? Fixnum opts = { status: opts } if opts.is_a?(Fixnum)
opts = {status: opts}
end
render json: MultiJson.dump(create_errors_json(obj, opts[:type])), status: opts[:status] || 422 render json: MultiJson.dump(create_errors_json(obj, opts[:type])), status: opts[:status] || 422
end end

View File

@ -9,18 +9,17 @@ module JsonError
private private
def create_errors_array(obj) def create_errors_array(obj)
# If we're passed a string, assume that is the error message # If we're passed a string, assume that is the error message
return {errors: [obj]} if obj.is_a?(String) return { errors: [obj] } if obj.is_a?(String)
# If it's an AR exception target the record # If it's an AR exception target the record
obj = obj.record if obj.is_a?(ActiveRecord::RecordInvalid) obj = obj.record if obj.is_a?(ActiveRecord::RecordInvalid)
# If it looks like an activerecord object, extract its messages # If it looks like an activerecord object, extract its messages
return {errors: obj.errors.full_messages } if obj.respond_to?(:errors) && obj.errors.present? return { errors: obj.errors.full_messages } if obj.respond_to?(:errors) && obj.errors.present?
# If we're passed an array, it's an array of error messages # If we're passed an array, it's an array of error messages
return {errors: obj.map {|e| e.to_s}} if obj.is_a?(Array) && obj.present? return { errors: obj.map(&:to_s) } if obj.is_a?(Array) && obj.present?
# Log a warning (unless obj is nil) # Log a warning (unless obj is nil)
Rails.logger.warn("create_errors_json called with unrecognized type: #{obj.inspect}") if obj Rails.logger.warn("create_errors_json called with unrecognized type: #{obj.inspect}") if obj
@ -30,7 +29,7 @@ module JsonError
end end
def self.generic_error def self.generic_error
{errors: [I18n.t('js.generic_error')]} { errors: [I18n.t('js.generic_error')] }
end end
end end

View File

@ -1,8 +1,8 @@
integration("About"); integration("About");
test("viewing", function() { test("viewing", () => {
visit("/about"); visit("/about");
andThen(function() { andThen(() => {
ok(exists('.about.admins .user-small'), 'has admins'); ok(exists('.about.admins .user-small'), 'has admins');
ok(exists('.about.moderators .user-small'), 'has moderators'); ok(exists('.about.moderators .user-small'), 'has moderators');
ok(exists('.about.stats tr td'), 'has stats'); ok(exists('.about.stats tr td'), 'has stats');

View File

@ -1,13 +1,13 @@
integration("Badges"); integration("Badges");
test("Visit Badge Pages", function() { test("Visit Badge Pages", () => {
visit("/badges"); visit("/badges");
andThen(function() { andThen(() => {
ok(exists('.badges-listing tr'), "has a list of badges"); ok(exists('.badges-listing tr'), "has a list of badges");
}); });
visit("/badges/9/autobiographer"); visit("/badges/9/autobiographer");
andThen(function() { andThen(() => {
ok(exists('.badges-listing tr'), "has the badge in the listing"); ok(exists('.badges-listing tr'), "has the badge in the listing");
ok(exists('.badge-user'), "has the list of users with that badge"); ok(exists('.badge-user'), "has the list of users with that badge");
}); });

View File

@ -8,11 +8,11 @@ integration("Create Account - User Fields", {
} }
}); });
test("create account with user fields", function() { test("create account with user fields", () => {
visit("/"); visit("/");
click("header .sign-up-button"); click("header .sign-up-button");
andThen(function() { andThen(() => {
ok(exists('.create-account'), "it shows the create account modal"); ok(exists('.create-account'), "it shows the create account modal");
ok(exists('.user-field'), "it has at least one user field"); ok(exists('.user-field'), "it has at least one user field");
ok(exists('.modal-footer .btn-primary:disabled'), 'create account is disabled at first'); ok(exists('.modal-footer .btn-primary:disabled'), 'create account is disabled at first');
@ -23,24 +23,24 @@ test("create account with user fields", function() {
fillIn('#new-account-email', 'good.tuna@test.com'); fillIn('#new-account-email', 'good.tuna@test.com');
fillIn('#new-account-username', 'goodtuna'); fillIn('#new-account-username', 'goodtuna');
andThen(function() { andThen(() => {
ok(exists('#username-validation.good'), 'the username validation is good'); ok(exists('#username-validation.good'), 'the username validation is good');
ok(exists('.modal-footer .btn-primary:disabled'), 'create account is still disabled due to lack of user fields'); ok(exists('.modal-footer .btn-primary:disabled'), 'create account is still disabled due to lack of user fields');
}); });
fillIn(".user-field input[type=text]:first", "Barky"); fillIn(".user-field input[type=text]:first", "Barky");
andThen(function() { andThen(() => {
ok(exists('.modal-footer .btn-primary:disabled'), 'create account is disabled because field is not checked'); ok(exists('.modal-footer .btn-primary:disabled'), 'create account is disabled because field is not checked');
}); });
click(".user-field input[type=checkbox]"); click(".user-field input[type=checkbox]");
andThen(function() { andThen(() => {
not(exists('.modal-footer .btn-primary:disabled'), 'create account is enabled because field is not checked'); not(exists('.modal-footer .btn-primary:disabled'), 'create account is enabled because field is not checked');
}); });
click(".user-field input[type=checkbox]"); click(".user-field input[type=checkbox]");
andThen(function() { andThen(() => {
ok(exists('.modal-footer .btn-primary:disabled'), 'unclicking the checkbox disables the submit'); ok(exists('.modal-footer .btn-primary:disabled'), 'unclicking the checkbox disables the submit');
}); });

View File

@ -1,8 +1,8 @@
integration("User Directory"); integration("User Directory");
test("Visit Page", function() { test("Visit Page", () => {
visit("/directory/all"); visit("/directory/all");
andThen(function() { andThen(() => {
ok(exists('.directory table tr'), "has a list of users"); ok(exists('.directory table tr'), "has a list of users");
}); });
}); });

View File

@ -1,12 +1,13 @@
integration("Groups"); integration("Groups");
test("Browsing Groups", function() { test("Browsing Groups", () => {
visit("/groups/discourse"); visit("/groups/discourse");
andThen(function() { andThen(() => {
ok(count('.user-stream .item') > 0, "it has stream items"); ok(count('.user-stream .item') > 0, "it has stream items");
}); });
visit("/groups/discourse/members"); visit("/groups/discourse/members");
andThen(function() { andThen(() => {
ok(count('.group-members tr') > 0, "it lists group members"); ok(count('.group-members tr') > 0, "it lists group members");
}); });
}); });

View File

@ -1,8 +1,8 @@
integration("Header (Anonymous)"); integration("Header (Anonymous)");
test("header", function() { test("header", () => {
visit("/"); visit("/");
andThen(function() { andThen(() => {
ok(exists("header"), "is rendered"); ok(exists("header"), "is rendered");
ok(exists(".logo-big"), "it renders the large logo by default"); ok(exists(".logo-big"), "it renders the large logo by default");
not(exists("#notifications-dropdown li"), "no notifications at first"); not(exists("#notifications-dropdown li"), "no notifications at first");
@ -12,17 +12,17 @@ test("header", function() {
}); });
// Logo changing // Logo changing
andThen(function() { andThen(() => {
controllerFor('header').set("showExtraInfo", true); controllerFor('header').set("showExtraInfo", true);
}); });
andThen(function() { andThen(() => {
ok(exists(".logo-small"), "it shows the small logo when `showExtraInfo` is enabled"); ok(exists(".logo-small"), "it shows the small logo when `showExtraInfo` is enabled");
}); });
// Site Map // Site Map
click("#site-map"); click("#site-map");
andThen(function() { andThen(() => {
ok(exists('#site-map-dropdown'), "is rendered after user opens it"); ok(exists('#site-map-dropdown'), "is rendered after user opens it");
ok(exists("#site-map-dropdown .faq-link"), "it shows the faq link"); ok(exists("#site-map-dropdown .faq-link"), "it shows the faq link");
ok(exists("#site-map-dropdown .category-links"), "has categories correctly bound"); ok(exists("#site-map-dropdown .category-links"), "has categories correctly bound");
@ -30,14 +30,14 @@ test("header", function() {
// Search // Search
click("#search-button"); click("#search-button");
andThen(function() { andThen(() => {
ok(exists("#search-dropdown:visible"), "after clicking a button search box opens"); ok(exists("#search-dropdown:visible"), "after clicking a button search box opens");
not(exists("#search-dropdown .heading"), "initially, immediately after opening, search box is empty"); not(exists("#search-dropdown .heading"), "initially, immediately after opening, search box is empty");
}); });
// Perform Search // Perform Search
fillIn("#search-term", "hello"); fillIn("#search-term", "hello");
andThen(function() { andThen(() => {
ok(exists("#search-dropdown .heading"), "when user completes a search, search box shows search results"); ok(exists("#search-dropdown .heading"), "when user completes a search, search box shows search results");
equal(find("#search-dropdown .results a:first").attr("href"), "/t/hello-bar-integration-issues/17638", "there is a search result"); equal(find("#search-dropdown .results a:first").attr("href"), "/t/hello-bar-integration-issues/17638", "there is a search result");
}); });

View File

@ -4,12 +4,12 @@ integration("Header (Staff)", {
site_flagged_posts_count: 1 } site_flagged_posts_count: 1 }
}); });
test("header", function() { test("header", () => {
visit("/"); visit("/");
// Notifications // Notifications
click("#user-notifications"); click("#user-notifications");
andThen(function() { andThen(() => {
var $items = $("#notifications-dropdown li"); var $items = $("#notifications-dropdown li");
ok(exists($items), "is lazily populated after user opens it"); ok(exists($items), "is lazily populated after user opens it");
ok($items.first().hasClass("read"), "correctly binds items' 'read' class"); ok($items.first().hasClass("read"), "correctly binds items' 'read' class");
@ -17,14 +17,14 @@ test("header", function() {
// Site Map // Site Map
click("#site-map"); click("#site-map");
andThen(function() { andThen(() => {
ok(exists("#site-map-dropdown .admin-link"), "it has the admin link"); ok(exists("#site-map-dropdown .admin-link"), "it has the admin link");
ok(exists("#site-map-dropdown .flagged-posts.badge-notification"), "it displays flag notifications"); ok(exists("#site-map-dropdown .flagged-posts.badge-notification"), "it displays flag notifications");
}); });
// User dropdown // User dropdown
click("#current-user"); click("#current-user");
andThen(function() { andThen(() => {
ok(exists("#user-dropdown:visible"), "is lazily rendered after user opens it"); ok(exists("#user-dropdown:visible"), "is lazily rendered after user opens it");
ok(exists("#user-dropdown .user-dropdown-links"), "has showing / hiding user-dropdown links correctly bound"); ok(exists("#user-dropdown .user-dropdown-links"), "has showing / hiding user-dropdown links correctly bound");
}); });

View File

@ -4,39 +4,39 @@ integration("Login Required", {
} }
}); });
test("redirect", function() { test("redirect", () => {
visit('/latest'); visit('/latest');
andThen(function() { andThen(() => {
equal(currentPath(), "login", "it redirects them to login"); equal(currentPath(), "login", "it redirects them to login");
}); });
click('#site-logo'); click('#site-logo');
andThen(function() { andThen(() => {
equal(currentPath(), "login", "clicking the logo keeps them on login"); equal(currentPath(), "login", "clicking the logo keeps them on login");
}); });
click('header .login-button'); click('header .login-button');
andThen(function() { andThen(() => {
ok(exists('.login-modal'), "they can still access the login modal"); ok(exists('.login-modal'), "they can still access the login modal");
}); });
click('.modal-header .close'); click('.modal-header .close');
andThen(function() { andThen(() => {
ok(!exists('.login-modal'), "it closes the login modal"); ok(!exists('.login-modal'), "it closes the login modal");
}); });
click('#search-button'); click('#search-button');
andThen(function() { andThen(() => {
ok(exists('.login-modal'), "clicking search opens the login modal"); ok(exists('.login-modal'), "clicking search opens the login modal");
}); });
click('.modal-header .close'); click('.modal-header .close');
andThen(function() { andThen(() => {
ok(!exists('.login-modal'), "it closes the login modal"); ok(!exists('.login-modal'), "it closes the login modal");
}); });
click('#site-map'); click('#site-map');
andThen(function() { andThen(() => {
ok(exists('.login-modal'), "site map opens the login modal"); ok(exists('.login-modal'), "site map opens the login modal");
}); });
}); });

View File

@ -1,29 +1,29 @@
integration("Modal"); integration("Modal");
test("modal", function() { test("modal", () => {
visit('/'); visit('/');
andThen(function() { andThen(() => {
ok(find('#discourse-modal:visible').length === 0, 'there is no modal at first'); ok(find('#discourse-modal:visible').length === 0, 'there is no modal at first');
}); });
click('.login-button'); click('.login-button');
andThen(function() { andThen(() => {
ok(find('#discourse-modal:visible').length === 1, 'modal should appear'); ok(find('#discourse-modal:visible').length === 1, 'modal should appear');
}); });
click('.modal-outer-container'); click('.modal-outer-container');
andThen(function() { andThen(() => {
ok(find('#discourse-modal:visible').length === 0, 'modal should disappear when you click outside'); ok(find('#discourse-modal:visible').length === 0, 'modal should disappear when you click outside');
}); });
click('.login-button'); click('.login-button');
andThen(function() { andThen(() => {
ok(find('#discourse-modal:visible').length === 1, 'modal should reappear'); ok(find('#discourse-modal:visible').length === 1, 'modal should reappear');
}); });
keyEvent('#main-outlet', 'keyup', 27); keyEvent('#main-outlet', 'keyup', 27);
andThen(function() { andThen(() => {
ok(find('#discourse-modal:visible').length === 0, 'ESC should close the modal'); ok(find('#discourse-modal:visible').length === 0, 'ESC should close the modal');
}); });
}); });

View File

@ -1,9 +1,9 @@
integration("Signing In"); integration("Signing In");
test("sign in", function() { test("sign in", () => {
visit("/"); visit("/");
click("header .login-button"); click("header .login-button");
andThen(function() { andThen(() => {
ok(exists('.login-modal'), "it shows the login modal"); ok(exists('.login-modal'), "it shows the login modal");
}); });
@ -11,7 +11,7 @@ test("sign in", function() {
fillIn('#login-account-name', 'eviltrout'); fillIn('#login-account-name', 'eviltrout');
fillIn('#login-account-password', 'incorrect'); fillIn('#login-account-password', 'incorrect');
click('.modal-footer .btn-primary'); click('.modal-footer .btn-primary');
andThen(function() { andThen(() => {
ok(exists('#modal-alert:visible', 'it displays the login error')); ok(exists('#modal-alert:visible', 'it displays the login error'));
not(exists('.modal-footer .btn-primary:disabled'), "enables the login button"); not(exists('.modal-footer .btn-primary:disabled'), "enables the login button");
}); });
@ -19,16 +19,16 @@ test("sign in", function() {
// Use the correct password // Use the correct password
fillIn('#login-account-password', 'correct'); fillIn('#login-account-password', 'correct');
click('.modal-footer .btn-primary'); click('.modal-footer .btn-primary');
andThen(function() { andThen(() => {
ok(exists('.modal-footer .btn-primary:disabled'), "disables the login button"); ok(exists('.modal-footer .btn-primary:disabled'), "disables the login button");
}); });
}); });
test("create account", function() { test("create account", () => {
visit("/"); visit("/");
click("header .sign-up-button"); click("header .sign-up-button");
andThen(function() { andThen(() => {
ok(exists('.create-account'), "it shows the create account modal"); ok(exists('.create-account'), "it shows the create account modal");
ok(exists('.modal-footer .btn-primary:disabled'), 'create account is disabled at first'); ok(exists('.modal-footer .btn-primary:disabled'), 'create account is disabled at first');
}); });
@ -39,19 +39,19 @@ test("create account", function() {
// Check username // Check username
fillIn('#new-account-email', 'good.tuna@test.com'); fillIn('#new-account-email', 'good.tuna@test.com');
fillIn('#new-account-username', 'taken'); fillIn('#new-account-username', 'taken');
andThen(function() { andThen(() => {
ok(exists('#username-validation.bad'), 'the username validation is bad'); ok(exists('#username-validation.bad'), 'the username validation is bad');
ok(exists('.modal-footer .btn-primary:disabled'), 'create account is still disabled'); ok(exists('.modal-footer .btn-primary:disabled'), 'create account is still disabled');
}); });
fillIn('#new-account-username', 'goodtuna'); fillIn('#new-account-username', 'goodtuna');
andThen(function() { andThen(() => {
ok(exists('#username-validation.good'), 'the username validation is good'); ok(exists('#username-validation.good'), 'the username validation is good');
not(exists('.modal-footer .btn-primary:disabled'), 'create account is enabled'); not(exists('.modal-footer .btn-primary:disabled'), 'create account is enabled');
}); });
click('.modal-footer .btn-primary'); click('.modal-footer .btn-primary');
andThen(function() { andThen(() => {
ok(exists('.modal-footer .btn-primary:disabled'), "create account is disabled"); ok(exists('.modal-footer .btn-primary:disabled'), "create account is disabled");
}); });

View File

@ -1,28 +1,28 @@
integration("Static"); integration("Static");
test("Static Pages", function() { test("Static Pages", () => {
visit("/faq"); visit("/faq");
andThen(function() { andThen(() => {
ok(exists(".body-page"), "The content is present"); ok(exists(".body-page"), "The content is present");
}); });
visit("/guidelines"); visit("/guidelines");
andThen(function() { andThen(() => {
ok(exists(".body-page"), "The content is present"); ok(exists(".body-page"), "The content is present");
}); });
visit("/tos"); visit("/tos");
andThen(function() { andThen(() => {
ok(exists(".body-page"), "The content is present"); ok(exists(".body-page"), "The content is present");
}); });
visit("/privacy"); visit("/privacy");
andThen(function() { andThen(() => {
ok(exists(".body-page"), "The content is present"); ok(exists(".body-page"), "The content is present");
}); });
visit("/login"); visit("/login");
andThen(function() { andThen(() => {
equal(currentPath(), "discovery.latest", "it redirects them to latest unless `login_required`"); equal(currentPath(), "discovery.latest", "it redirects them to latest unless `login_required`");
}); });
}); });

View File

@ -1,21 +1,21 @@
integration("Topic Discovery"); integration("Topic Discovery");
test("Visit Discovery Pages", function() { test("Visit Discovery Pages", () => {
visit("/"); visit("/");
andThen(function() { andThen(() => {
ok(exists(".topic-list"), "The list of topics was rendered"); ok(exists(".topic-list"), "The list of topics was rendered");
ok(exists('.topic-list .topic-list-item'), "has topics"); ok(exists('.topic-list .topic-list-item'), "has topics");
}); });
visit("/c/bug"); visit("/c/bug");
andThen(function() { andThen(() => {
ok(exists(".topic-list"), "The list of topics was rendered"); ok(exists(".topic-list"), "The list of topics was rendered");
ok(exists('.topic-list .topic-list-item'), "has topics"); ok(exists('.topic-list .topic-list-item'), "has topics");
ok($('body.category-bug').length, "has a custom css class for the category id on the body"); ok($('body.category-bug').length, "has a custom css class for the category id on the body");
}); });
visit("/categories"); visit("/categories");
andThen(function() { andThen(() => {
ok($('body.category-bug').length === 0, "removes the custom category class"); ok($('body.category-bug').length === 0, "removes the custom category class");
ok(exists('.category'), "has a list of categories"); ok(exists('.category'), "has a list of categories");
@ -23,7 +23,7 @@ test("Visit Discovery Pages", function() {
}); });
visit("/top"); visit("/top");
andThen(function() { andThen(() => {
ok($('body.categories-list').length === 0, "removes the `categories-list` class"); ok($('body.categories-list').length === 0, "removes the `categories-list` class");
ok(exists('.topic-list .topic-list-item'), "has topics"); ok(exists('.topic-list .topic-list-item'), "has topics");
}); });

View File

@ -1,16 +1,16 @@
integration("View Topic"); integration("View Topic");
test("Enter a Topic", function() { test("Enter a Topic", () => {
visit("/t/internationalization-localization/280"); visit("/t/internationalization-localization/280");
andThen(function() { andThen(() => {
ok(exists("#topic"), "The topic was rendered"); ok(exists("#topic"), "The topic was rendered");
ok(exists("#topic .post-cloak"), "The topic has cloaked posts"); ok(exists("#topic .post-cloak"), "The topic has cloaked posts");
}); });
}); });
test("Enter without an id", function() { test("Enter without an id", () => {
visit("/t/internationalization-localization"); visit("/t/internationalization-localization");
andThen(function() { andThen(() => {
ok(exists("#topic"), "The topic was rendered"); ok(exists("#topic"), "The topic was rendered");
}); });
}); });

View File

@ -1,9 +1,9 @@
integration("Unknown"); integration("Unknown");
test("Unknown URL", function() { test("Unknown URL", () => {
expect(1); expect(1);
visit("/url-that-doesn't-exist"); visit("/url-that-doesn't-exist");
andThen(function() { andThen(() => {
ok(exists(".page-not-found"), "The not found content is present"); ok(exists(".page-not-found"), "The not found content is present");
}); });
}); });

View File

@ -1,12 +1,12 @@
integration("User Card"); integration("User Card");
test("card", function() { test("card", () => {
visit('/'); visit('/');
ok(invisible('#user-card'), 'user card is invisible by default'); ok(invisible('#user-card'), 'user card is invisible by default');
click('a[data-user-card=eviltrout]:first'); click('a[data-user-card=eviltrout]:first');
andThen(function() { andThen(() => {
ok(visible('#user-card'), 'card should appear'); ok(visible('#user-card'), 'card should appear');
}); });

View File

@ -1,34 +1,40 @@
integration("User"); integration("User");
function hasStream() { function hasStream() {
andThen(function() { andThen(() => {
ok(exists('.user-main .about'), 'it has the about section'); ok(exists('.user-main .about'), 'it has the about section');
ok(count('.user-stream .item') > 0, 'it has stream items'); ok(count('.user-stream .item') > 0, 'it has stream items');
}); });
} }
function hasTopicList() { function hasTopicList() {
andThen(function() { andThen(() => {
equal(count('.user-stream .item'), 0, "has no stream displayed"); equal(count('.user-stream .item'), 0, "has no stream displayed");
ok(count('.topic-list tr') > 0, 'it has a topic list'); ok(count('.topic-list tr') > 0, 'it has a topic list');
}); });
} }
test("Filters", function() { test("Filters", () => {
expect(14); expect(14);
visit("/users/eviltrout"); visit("/users/eviltrout");
hasStream(); hasStream();
visit("/users/eviltrout/activity/topics"); visit("/users/eviltrout/activity/topics");
hasTopicList(); hasTopicList();
visit("/users/eviltrout/activity/posts"); visit("/users/eviltrout/activity/posts");
hasStream(); hasStream();
visit("/users/eviltrout/activity/replies"); visit("/users/eviltrout/activity/replies");
hasStream(); hasStream();
visit("/users/eviltrout/activity/likes-given"); visit("/users/eviltrout/activity/likes-given");
hasStream(); hasStream();
visit("/users/eviltrout/activity/likes-received"); visit("/users/eviltrout/activity/likes-received");
hasStream(); hasStream();
visit("/users/eviltrout/activity/edits"); visit("/users/eviltrout/activity/edits");
hasStream(); hasStream();
}); });