Disable tests, remove brazilian-rails git repository

master
Alinson S. Xavier 10 years ago
parent cdafe05e86
commit 3705590e4e

@ -0,0 +1 @@
wikiufc-1.2

@ -0,0 +1 @@
1.8.7

@ -23,9 +23,9 @@ gem 'jquery-rails'
gem 'shoulda', "~>2.11" gem 'shoulda', "~>2.11"
gem 'will_paginate', "~>3.0" gem 'will_paginate', "~>3.0"
group :development, :production do #group :development, :production do
gem 'brazilian-rails', '3.3.0', :path => './vendor/gems/brazilian-rails/brI18n/' # gem 'brazilian-rails', '3.3.0', :path => './vendor/gems/brazilian-rails/brI18n/'
end #end
group :development do group :development do
gem 'mongrel' gem 'mongrel'

@ -10,11 +10,6 @@ PATH
specs: specs:
bluecloth (1.0.0) bluecloth (1.0.0)
PATH
remote: ./vendor/gems/brazilian-rails/brI18n/
specs:
brazilian-rails (3.3.0)
GEM GEM
remote: https://rubygems.org/ remote: https://rubygems.org/
specs: specs:
@ -146,7 +141,6 @@ DEPENDENCIES
acts_as_paranoid (~> 0.4) acts_as_paranoid (~> 0.4)
acts_as_versioned! acts_as_versioned!
bluecloth (= 1.0.0)! bluecloth (= 1.0.0)!
brazilian-rails (= 3.3.0)!
calendar_helper (~> 0.2) calendar_helper (~> 0.2)
coffee-rails (~> 3.2.1) coffee-rails (~> 3.2.1)
dynamic_form dynamic_form

@ -4,3 +4,4 @@
//= require lib/dragdrop //= require lib/dragdrop
//= require lib/event-selectors //= require lib/event-selectors
//= require application //= require application
//= require latex

@ -0,0 +1,10 @@
MathJax.Hub.Config({
tex2jax: {
inlineMath: [['{$','$}']],
displayMath: [['{$$','$$}']]
},
TeX: {
equationNumbers: { autoNumber: "AMS" },
extensions: ["AMSmath.js", "AMSsymbols.js", "color.js"]
}
});

@ -19,10 +19,8 @@
%script{:type => 'text/javascript'} %script{:type => 'text/javascript'}
== BASE_PATH = "#{App.base_path}"; == BASE_PATH = "#{App.base_path}";
= javascript_include_tag :base
= javascript_include_tag 'http://cdn.mathjax.org/mathjax/latest/MathJax.js?config=TeX-AMS_HTML' = javascript_include_tag 'http://cdn.mathjax.org/mathjax/latest/MathJax.js?config=TeX-AMS_HTML'
%script{:type => 'text/x-mathjax-config'} = javascript_include_tag :base
== MathJax.Hub.Config({tex2jax: {inlineMath: [['{$','$}']], displayMath: [['{$$','$$}']]}});
%body{'onload' => 'javascript: startup()'} %body{'onload' => 'javascript: startup()'}
#wrapper #wrapper

@ -1,4 +1,4 @@
require 'brI18n' #require 'brI18n'
WikiUFC::Application.configure do WikiUFC::Application.configure do
# Settings specified here will take precedence over those in config/application.rb # Settings specified here will take precedence over those in config/application.rb

@ -1,4 +1,4 @@
require 'brI18n' #require 'brI18n'
WikiUFC::Application.configure do WikiUFC::Application.configure do
# Settings specified here will take precedence over those in config/application.rb # Settings specified here will take precedence over those in config/application.rb

@ -14,145 +14,146 @@
# You should have received a copy of the GNU Affero General Public License # You should have received a copy of the GNU Affero General Public License
# along with this program. If not, see <http://www.gnu.org/licenses/>. # along with this program. If not, see <http://www.gnu.org/licenses/>.
require File.dirname(__FILE__) + '/../test_helper' #require File.dirname(__FILE__) + '/../test_helper'
require 'attachments_controller' #require 'attachments_controller'
#
# Re-raise errors caught by the controller. ## Re-raise errors caught by the controller.
class AttachmentsController; def rescue_action(e) raise e end; end #class AttachmentsController; def rescue_action(e) raise e end; end
#
class AttachmentsControllerTest < ActionController::TestCase #class AttachmentsControllerTest < ActionController::TestCase
fixtures :attachments # fixtures :attachments
#
def setup # def setup
@course = Course.find(:first) # @course = Course.find(:first)
@data = fixture_file_upload('/files/attachment.txt', 'text/plain') # @data = fixture_file_upload('/files/attachment.txt', 'text/plain')
@att = @course.attachments.create(:file => @data, :file_name => 'attachment.txt', # @att = @course.attachments.create(:file => @data, :file_name => 'attachment.txt',
:description => 'hello world', :path => "", :front_page => true) # :description => 'hello world', :path => "", :front_page => true)
@att.save! # @att.save!
end # end
#
def teardown # def teardown
@data.close! # @data.close!
end # end
#
context "An anonymous user" do # context "An anonymous user" do
#
should_request_login_on_post_to(:new, {:course_id => 1}) # should_request_login_on_post_to(:new, {:course_id => 1})
should_request_login_on_post_to(:create, {:course_id => 1}) # should_request_login_on_post_to(:create, {:course_id => 1})
should_request_login_on_post_to(:edit, {:course_id => 1, :id => 1}) # should_request_login_on_post_to(:edit, {:course_id => 1, :id => 1})
should_request_login_on_post_to(:update, {:course_id => 1, :id => 1}) # should_request_login_on_post_to(:update, {:course_id => 1, :id => 1})
should_request_login_on_post_to(:destroy, {:course_id => 1, :id => 1}) # should_request_login_on_post_to(:destroy, {:course_id => 1, :id => 1})
#
context "on get to :show" do # context "on get to :show" do
setup { get :show, :course_id => @course.id, :id => @att.id } # setup { get :show, :course_id => @course.id, :id => @att.id }
#
should respond_with :success # should respond_with :success
#
should "link to the attachment" do # should "link to the attachment" do
assert_select 'a[href=?]', download_course_attachment_url(@course, @att) # assert_select 'a[href=?]', download_course_attachment_url(@course, @att)
end # end
end # end
end # end
#
context "An authenticated user" do # context "An authenticated user" do
setup { login_as :bob } # setup { login_as :bob }
#
context "on get to :new" do # context "on get to :new" do
setup { get :new, :course_id => @course.id } # setup { get :new, :course_id => @course.id }
#should render_a_form # #should render_a_form
should respond_with :success # should respond_with :success
end # end
#
context "on post to :create" do # context "on post to :create" do
setup do # setup do
assert_nil @course.attachments.find_by_description('test') # assert_nil @course.attachments.find_by_description('test')
post :create, :course_id => @course.id, :attachment => { :description => 'test', :file => @data, :path => "", :front_page => 't' } # post :create, :course_id => @course.id, :attachment => { :description => 'test', :file => @data, :path => "", :front_page => 't' }
@att = @course.attachments.find_by_description('test') # @att = @course.attachments.find_by_description('test')
end # end
#
should "create a new attachment" do # should "create a new attachment" do
assert @att # assert @att
end # end
#
should set_the_flash.to(/created/i) # should set_the_flash.to(/created/i)
should redirect_to('the attachment') { course_attachment_url(@course, @att) } # should redirect_to('the attachment') { course_attachment_url(@course, @att) }
should_create_log_entry {[ AttachmentCreateLogEntry, @att.id, users(:bob).id ]} # should_create_log_entry {[ AttachmentCreateLogEntry, @att.id, users(:bob).id ]}
end # end
#
context "on get to :edit" do # context "on get to :edit" do
setup { get :edit, :course_id => @course.id, :id => @att.id } # setup { get :edit, :course_id => @course.id, :id => @att.id }
#should render_a_form # #should render_a_form
should render_template 'edit' # should render_template 'edit'
end # end
#
context "on post to :update" do # context "on post to :update" do
context "with unmodified data" do # context "with unmodified data" do
setup do # setup do
post :update, :course_id => @course.id, :id => @att.id, :attachment => { :description => @att.description, :path => "", :front_page => 't' } # post :update, :course_id => @course.id, :id => @att.id, :attachment => { :description => @att.description, :path => "", :front_page => 't' }
end # end
#
should_not set_the_flash # should_not set_the_flash
should redirect_to('the attachment') { course_attachment_url(@course, @att) } # should redirect_to('the attachment') { course_attachment_url(@course, @att) }
#
should "not create a new log entry" do # should "not create a new log entry" do
assert_nil AttachmentEditLogEntry.find(:first, :conditions => { :target_id => @att.id }) # assert_nil AttachmentEditLogEntry.find(:first, :conditions => { :target_id => @att.id })
end # end
end # end
#
context "with new description only" do # context "with new description only" do
setup do # setup do
post :update, :course_id => @course.id, :id => @att.id, :attachment => { :description => 'new description', :front_page => 't' } # post :update, :course_id => @course.id, :id => @att.id, :attachment => { :description => 'new description', :front_page => 't' }
end # end
should set_the_flash.to(/updated/i) # should set_the_flash.to(/updated/i)
should redirect_to('the attachment') { course_attachment_url(@course, @att) } # should redirect_to('the attachment') { course_attachment_url(@course, @att) }
should_create_log_entry {[ AttachmentEditLogEntry, @att.id, users(:bob).id ]} # should_create_log_entry {[ AttachmentEditLogEntry, @att.id, users(:bob).id ]}
end # end
#
context "with new file" do # context "with new file" do
setup do # setup do
@new_data = fixture_file_upload('/files/another_attachment.txt', 'plain/text') # @new_data = fixture_file_upload('/files/another_attachment.txt', 'plain/text')
post :update, :course_id => @course.id, :id => @att.id, :attachment => { :data => @new_data, :front_page => 't' } # post :update, :course_id => @course.id, :id => @att.id, :attachment => { :data => @new_data, :front_page => 't' }
end # end
teardown do # teardown do
@new_data.close! # @new_data.close!
end # end
should set_the_flash.to(/updated/i) # should set_the_flash.to(/updated/i)
should redirect_to('the attachment') { course_attachment_url(@course, @att) } # should redirect_to('the attachment') { course_attachment_url(@course, @att) }
should_create_log_entry {[ AttachmentEditLogEntry, @att.id, users(:bob).id ]} # should_create_log_entry {[ AttachmentEditLogEntry, @att.id, users(:bob).id ]}
end # end
end # end
#
context "on post to :destroy" do # context "on post to :destroy" do
setup { post :destroy, :course_id => @course.id, :id => @att.id } # setup { post :destroy, :course_id => @course.id, :id => @att.id }
#
should set_the_flash.to(/removed/i) # should set_the_flash.to(/removed/i)
should redirect_to('the course page'){ course_url(@course) } # should redirect_to('the course page'){ course_url(@course) }
should_create_log_entry {[ AttachmentDeleteLogEntry, @att.id, users(:bob).id ]} # should_create_log_entry {[ AttachmentDeleteLogEntry, @att.id, users(:bob).id ]}
#
should "destroy the attachment" do # should "destroy the attachment" do
@att = Attachment.find_with_deleted(@att.id) # @att = Attachment.find_with_deleted(@att.id)
assert @att.deleted? # assert @att.deleted?
end # end
end # end
#
#context "on post to :undelete" do # #context "on post to :undelete" do
# setup do # # setup do
# @att.destroy # # @att.destroy
# post :undelete, :course_id => @course.id, :id => @att.id # # post :undelete, :course_id => @course.id, :id => @att.id
# end # # end
#
# should set_the_flash.to(/restored/i) # # should set_the_flash.to(/restored/i)
# should redirect_to('the attachment'){ course_attachment_url(@course, @att) } # # should redirect_to('the attachment'){ course_attachment_url(@course, @att) }
# should_create_log_entry {[ AttachmentRestoreLogEntry, @att.id, users(:bob).id ]} # # should_create_log_entry {[ AttachmentRestoreLogEntry, @att.id, users(:bob).id ]}
#
# should "restore the attachment" do # # should "restore the attachment" do
# assert Attachment.find(@att.id) # # assert Attachment.find(@att.id)
# end # # end
#end # #end
#
context "on get to :download" do # context "on get to :download" do
setup { get :download, :course_id => @course.id, :id => @att.id } # setup { get :download, :course_id => @course.id, :id => @att.id }
should respond_with :success # should respond_with :success
end # end
end # end
end #end
#

@ -14,87 +14,87 @@
# You should have received a copy of the GNU Affero General Public License # You should have received a copy of the GNU Affero General Public License
# along with this program. If not, see <http://www.gnu.org/licenses/>. # along with this program. If not, see <http://www.gnu.org/licenses/>.
require File.dirname(__FILE__) + '/../test_helper.rb' #require File.dirname(__FILE__) + '/../test_helper.rb'
require 'courses_controller' #require 'courses_controller'
#
# Re-raise errors caught by the controller. ## Re-raise errors caught by the controller.
#class CoursesController; def rescue_action(e) raise e end; end ##class CoursesController; def rescue_action(e) raise e end; end
#
class CoursesControllerTest < ActionController::TestCase #class CoursesControllerTest < ActionController::TestCase
#
def setup # def setup
@course = courses(:course_1) # @course = courses(:course_1)
@old_course = courses(:old_course) # @old_course = courses(:old_course)
LogEntry.delete_all # LogEntry.delete_all
end # end
#
context "An anonymous user" do # context "An anonymous user" do
#
should_request_login_on_post_to(:new, {}) # should_request_login_on_post_to(:new, {})
should_request_login_on_post_to(:create, {}) # should_request_login_on_post_to(:create, {})
should_request_login_on_post_to(:edit, {:id => 1}) # should_request_login_on_post_to(:edit, {:id => 1})
should_request_login_on_post_to(:update, {:id => 1}) # should_request_login_on_post_to(:update, {:id => 1})
should_request_login_on_post_to(:destroy, {:id => 1}) # should_request_login_on_post_to(:destroy, {:id => 1})
should_request_login_on_post_to(:enroll, {:id => 1}) # should_request_login_on_post_to(:enroll, {:id => 1})
should_request_login_on_post_to(:unenroll, {:id => 1}) # should_request_login_on_post_to(:unenroll, {:id => 1})
#
context "on get to :index" do # context "on get to :index" do
setup { get :index } # setup { get :index }
#
should respond_with :success # should respond_with :success
should render_template 'index' # should render_template 'index'
#
should "display the course list" do # should "display the course list" do
assert_select 'h1', "Disciplinas #{App.current_period}" # assert_select 'h1', "Disciplinas #{App.current_period}"
assert_select 'a[href=?]', course_url(@course) # assert_select 'a[href=?]', course_url(@course)
end # end
#
should "choose display the selected period" do # should "choose display the selected period" do
get :index, :period => "1970.1" # get :index, :period => "1970.1"
assert_select 'h1', "Disciplinas 1970.1" # assert_select 'h1', "Disciplinas 1970.1"
end # end
end # end
#
context "on get to :show" do # context "on get to :show" do
setup { get :show, :id => @course.id } # setup { get :show, :id => @course.id }
#
should respond_with :success # should respond_with :success
should render_template 'show' # should render_template 'show'
#
should "display the course" do # should "display the course" do
assert_select 'a[href=?]', course_log_url(@course) # assert_select 'a[href=?]', course_log_url(@course)
assert_select 'a[href=?]', course_news_url(@course) # assert_select 'a[href=?]', course_news_url(@course)
assert_select 'a[href=?]', course_events_url(@course) # assert_select 'a[href=?]', course_events_url(@course)
assert_select 'a[href=?]', new_course_event_url(@course) # assert_select 'a[href=?]', new_course_event_url(@course)
assert_select 'a[href=?]', new_course_attachment_url(@course) # assert_select 'a[href=?]', new_course_attachment_url(@course)
assert_select 'a[href=?]', new_course_wiki_instance_url(@course) # assert_select 'a[href=?]', new_course_wiki_instance_url(@course)
end # end
end # end
end # end
#
context "An authenticated user" do # context "An authenticated user" do
setup { login_as :bob } # setup { login_as :bob }
end # end
#
# REST - usuários autenticados # # REST - usuários autenticados
#context "A user" do # #context "A user" do
# #setup { login_as :bob } # # #setup { login_as :bob }
# should_be_restful do |resource| # # should_be_restful do |resource|
# resource.create.params = { :short_name => 'test', :full_name => 'test', :description => 'test' } # # resource.create.params = { :short_name => 'test', :full_name => 'test', :description => 'test' }
# resource.update.params = { :short_name => 'test', :full_name => 'test', :description => 'test' } # # resource.update.params = { :short_name => 'test', :full_name => 'test', :description => 'test' }
# end # # end
#end # #end
#
## REST - usuários quaisquer # ## REST - usuários quaisquer
#context "A stranger" do # #context "A stranger" do
# setup { logout } # # setup { logout }
# should_be_restful do |resource| # # should_be_restful do |resource|
# resource.create.params = { :short_name => 'test', :full_name => 'test', :description => 'test' } # # resource.create.params = { :short_name => 'test', :full_name => 'test', :description => 'test' }
# resource.update.params = { :short_name => 'test', :full_name => 'test', :description => 'test' } # # resource.update.params = { :short_name => 'test', :full_name => 'test', :description => 'test' }
# resource.denied.actions = [ :new, :edit, :create, :update, :destroy ] # # resource.denied.actions = [ :new, :edit, :create, :update, :destroy ]
# resource.denied.redirect = "'/login'" # # resource.denied.redirect = "'/login'"
# resource.denied.flash = /must be logged in/i # # resource.denied.flash = /must be logged in/i
# end # # end
#end # #end
#
end #end

@ -14,48 +14,49 @@
# You should have received a copy of the GNU Affero General Public License # You should have received a copy of the GNU Affero General Public License
# along with this program. If not, see <http://www.gnu.org/licenses/>. # along with this program. If not, see <http://www.gnu.org/licenses/>.
require File.dirname(__FILE__) + '/../test_helper' #require File.dirname(__FILE__) + '/../test_helper'
require 'events_controller' #require 'events_controller'
#
# Re-raise errors caught by the controller. ## Re-raise errors caught by the controller.
class EventsController; def rescue_action(e) raise e end; end #class EventsController; def rescue_action(e) raise e end; end
#
class EventsControllerTest < ActionController::TestCase #class EventsControllerTest < ActionController::TestCase
#
def setup # def setup
@controller = EventsController.new # @controller = EventsController.new
@request = ActionController::TestRequest.new # @request = ActionController::TestRequest.new
@response = ActionController::TestResponse.new # @response = ActionController::TestResponse.new
@course = Course.find(:first) # @course = Course.find(:first)
@event = @course.events.find(:first) # @event = @course.events.find(:first)
end # end
#
# REST - usuários autenticados # # REST - usuários autenticados
#context "A user" do # #context "A user" do
# setup { login_as :bob } # # setup { login_as :bob }
# should_be_restful do |resource| # # should_be_restful do |resource|
# resource.parent = [ :course ] # # resource.parent = [ :course ]
# resource.create.params = { :title => 'test', :time => Time.now, :description => 'test', :created_by => 1 } # # resource.create.params = { :title => 'test', :time => Time.now, :description => 'test', :created_by => 1 }
# resource.update.params = { :title => 'test', :time => Time.now, :description => 'test', :created_by => 1 } # # resource.update.params = { :title => 'test', :time => Time.now, :description => 'test', :created_by => 1 }
#
# end # # end
#end # #end
#
## REST - usuários quaisquer # ## REST - usuários quaisquer
#context "A stranger" do # #context "A stranger" do
# setup { logout } # # setup { logout }
# should_be_restful do |resource| # # should_be_restful do |resource|
# resource.parent = [ :course ] # # resource.parent = [ :course ]
# resource.create.params = { :title => 'test', :time => Time.now, :description => 'test', :created_by => 1 } # # resource.create.params = { :title => 'test', :time => Time.now, :description => 'test', :created_by => 1 }
# resource.update.params = { :title => 'test', :time => Time.now, :description => 'test', :created_by => 1 } # # resource.update.params = { :title => 'test', :time => Time.now, :description => 'test', :created_by => 1 }
# resource.denied.actions = [ :new, :edit, :create, :update, :destroy ] # # resource.denied.actions = [ :new, :edit, :create, :update, :destroy ]
# resource.denied.redirect = "'/login'" # # resource.denied.redirect = "'/login'"
# resource.denied.flash = /must be logged in/i # # resource.denied.flash = /must be logged in/i
# end # # end
#end # #end
#
def test_should_accept_icalendar_on_index # def test_should_accept_icalendar_on_index
get :index, :format => 'ics', :course_id => 1 # get :index, :format => 'ics', :course_id => 1
assert_formatted_response :ics # assert_formatted_response :ics
end # end
end #end
#

@ -14,11 +14,12 @@
# You should have received a copy of the GNU Affero General Public License # You should have received a copy of the GNU Affero General Public License
# along with this program. If not, see <http://www.gnu.org/licenses/>. # along with this program. If not, see <http://www.gnu.org/licenses/>.
require File.dirname(__FILE__) + '/../test_helper' #require File.dirname(__FILE__) + '/../test_helper'
#
class LogControllerTest < ActionController::TestCase #class LogControllerTest < ActionController::TestCase
# Replace this with your real tests. # # Replace this with your real tests.
def test_truth # def test_truth
assert true # assert true
end # end
end #end
#

@ -14,52 +14,53 @@
# You should have received a copy of the GNU Affero General Public License # You should have received a copy of the GNU Affero General Public License
# along with this program. If not, see <http://www.gnu.org/licenses/>. # along with this program. If not, see <http://www.gnu.org/licenses/>.
require File.dirname(__FILE__) + '/../test_helper' #require File.dirname(__FILE__) + '/../test_helper'
require 'news_controller' #require 'news_controller'
#
# Re-raise errors caught by the controller. ## Re-raise errors caught by the controller.
class NewsController; def rescue_action(e) raise e end; end #class NewsController; def rescue_action(e) raise e end; end
#
class NewsControllerTest < ActionController::TestCase #class NewsControllerTest < ActionController::TestCase
def setup # def setup
@controller = NewsController.new # @controller = NewsController.new
@request = ActionController::TestRequest.new # @request = ActionController::TestRequest.new
@response = ActionController::TestResponse.new # @response = ActionController::TestResponse.new
#
@course = Course.find(:first) # @course = Course.find(:first)
@news = @course.news.find(:first) # @news = @course.news.find(:first)
end # end
#
# REST - usuários autenticados # # REST - usuários autenticados
#context "A user" do # #context "A user" do
# setup { login_as :bob } # # setup { login_as :bob }
# should_be_restful do |resource| # # should_be_restful do |resource|
# resource.klass = News # # resource.klass = News
# resource.object = 'news' # # resource.object = 'news'
# resource.parent = [ :course ] # # resource.parent = [ :course ]
# resource.create.params = { :title => 'test', :body => 'test', :receiver_id => 1 } # # resource.create.params = { :title => 'test', :body => 'test', :receiver_id => 1 }
# resource.update.params = { :title => 'test', :body => 'test', :receiver_id => 1 } # # resource.update.params = { :title => 'test', :body => 'test', :receiver_id => 1 }
# resource.destroy.redirect = "course_news_url(@course)" # # resource.destroy.redirect = "course_news_url(@course)"
# end # # end
#end # #end
#
## REST - usuários quaisquer # ## REST - usuários quaisquer
#context "A stranger" do # #context "A stranger" do
# setup { logout } # # setup { logout }
# should_be_restful do |resource| # # should_be_restful do |resource|
# resource.klass = News # # resource.klass = News
# resource.object = 'news' # # resource.object = 'news'
# resource.parent = [ :course ] # # resource.parent = [ :course ]
# resource.create.params = { :title => 'test', :body => 'test', :receiver_id => 1 } # # resource.create.params = { :title => 'test', :body => 'test', :receiver_id => 1 }
# resource.update.params = { :title => 'test', :body => 'test', :receiver_id => 1 } # # resource.update.params = { :title => 'test', :body => 'test', :receiver_id => 1 }
# resource.denied.actions = [ :new, :edit, :create, :update, :destroy ] # # resource.denied.actions = [ :new, :edit, :create, :update, :destroy ]
# resource.denied.redirect = "'/login'" # # resource.denied.redirect = "'/login'"
# resource.denied.flash = /must be logged in/i # # resource.denied.flash = /must be logged in/i
# end # # end
#end # #end
#
#def test_should_accept_rss_on_index # #def test_should_accept_rss_on_index
# get :index, :format => 'rss', :course_id => 1 # # get :index, :format => 'rss', :course_id => 1
# assert_formatted_response :rss # # assert_formatted_response :rss
#end # #end
end #end
#

@ -14,23 +14,24 @@
# You should have received a copy of the GNU Affero General Public License # You should have received a copy of the GNU Affero General Public License
# along with this program. If not, see <http://www.gnu.org/licenses/>. # along with this program. If not, see <http://www.gnu.org/licenses/>.
require File.dirname(__FILE__) + '/../test_helper' #require File.dirname(__FILE__) + '/../test_helper'
require 'stylesheets_controller' #require 'stylesheets_controller'
#
# Re-raise errors caught by the controller. ## Re-raise errors caught by the controller.
class StylesheetsController; def rescue_action(e) raise e end; end #class StylesheetsController; def rescue_action(e) raise e end; end
#
class StylesheetsControllerTest < ActionController::TestCase #class StylesheetsControllerTest < ActionController::TestCase
#
def setup # def setup
@controller = StylesheetsController.new # @controller = StylesheetsController.new
@request = ActionController::TestRequest.new # @request = ActionController::TestRequest.new
@response = ActionController::TestResponse.new # @response = ActionController::TestResponse.new
end # end
#
# Replace this with your real tests. # # Replace this with your real tests.
def test_truth # def test_truth
assert true # assert true
end # end
#
end #end
#

@ -14,35 +14,36 @@
# You should have received a copy of the GNU Affero General Public License # You should have received a copy of the GNU Affero General Public License
# along with this program. If not, see <http://www.gnu.org/licenses/>. # along with this program. If not, see <http://www.gnu.org/licenses/>.
require File.dirname(__FILE__) + '/../test_helper' #require File.dirname(__FILE__) + '/../test_helper'
require 'users_controller' #require 'users_controller'
#
# Re-raise errors caught by the controller. ## Re-raise errors caught by the controller.
class UsersController; def rescue_action(e) raise e end; end #class UsersController; def rescue_action(e) raise e end; end
#
class UsersControllerTest < ActionController::TestCase #class UsersControllerTest < ActionController::TestCase
#
context "An authenticated user" do # context "An authenticated user" do
setup { login_as :bob } # setup { login_as :bob }
#
context "on get to :dashboard" do # context "on get to :dashboard" do
setup { get :dashboard } # setup { get :dashboard }
#
should respond_with :success # should respond_with :success
should render_template "dashboard" # should render_template "dashboard"
end # end
#
context "on post to :logout" do # context "on post to :logout" do
setup { get :logout } # setup { get :logout }
#
should respond_with :redirect # should respond_with :redirect
should redirect_to('the main page') { index_url } # should redirect_to('the main page') { index_url }
#
should "log out" do # should "log out" do
assert_nil session[:user_id] # assert_nil session[:user_id]
assert_nil cookies[:login_token] # assert_nil cookies[:login_token]
end # end
end # end
#
end # end
end #end
#

@ -14,250 +14,251 @@
# You should have received a copy of the GNU Affero General Public License # You should have received a copy of the GNU Affero General Public License
# along with this program. If not, see <http://www.gnu.org/licenses/>. # along with this program. If not, see <http://www.gnu.org/licenses/>.
require File.dirname(__FILE__) + '/../test_helper' #require File.dirname(__FILE__) + '/../test_helper'
require 'wiki_controller' #require 'wiki_controller'
#
# Re-raise errors caught by the controller. ## Re-raise errors caught by the controller.
class WikiController; def rescue_action(e) raise e end; end #class WikiController; def rescue_action(e) raise e end; end
#
class WikiControllerTest < ActionController::TestCase #class WikiControllerTest < ActionController::TestCase
def setup # def setup
@course = Course.find(:first) # @course = Course.find(:first)
#
@wiki_page = @course.wiki_pages.create(:title => 'test1', :content => 'content1', # @wiki_page = @course.wiki_pages.create(:title => 'test1', :content => 'content1',
:user_id => users(:bob).id, :description => 'test', :version => 1) # :user_id => users(:bob).id, :description => 'test', :version => 1)
@wiki_page.save! # @wiki_page.save!
@wiki_page.title = 'new title' # @wiki_page.title = 'new title'
@wiki_page.save! # @wiki_page.save!
#
@another_wiki_page = @course.wiki_pages.create(:title => 'another', :content => 'another', # @another_wiki_page = @course.wiki_pages.create(:title => 'another', :content => 'another',
:description => 'test', :user_id => users(:bob).id, :version => 1) # :description => 'test', :user_id => users(:bob).id, :version => 1)
@another_wiki_page.move_to_bottom # @another_wiki_page.move_to_bottom
@another_wiki_page.save! # @another_wiki_page.save!
@wiki_page.reload # @wiki_page.reload
#
LogEntry.delete_all # LogEntry.delete_all
end # end
#
context "An anonymous user" do # context "An anonymous user" do
#
should_request_login_on_post_to(:new, {:course_id => 1}) # should_request_login_on_post_to(:new, {:course_id => 1})
should_request_login_on_post_to(:create, {:course_id => 1}) # should_request_login_on_post_to(:create, {:course_id => 1})
should_request_login_on_post_to(:edit, {:course_id => 1, :id => 1}) # should_request_login_on_post_to(:edit, {:course_id => 1, :id => 1})
should_request_login_on_post_to(:update, {:course_id => 1, :id => 1}) # should_request_login_on_post_to(:update, {:course_id => 1, :id => 1})
should_request_login_on_post_to(:destroy, {:course_id => 1, :id => 1}) # should_request_login_on_post_to(:destroy, {:course_id => 1, :id => 1})
should_request_login_on_post_to(:move_up, {:course_id => 1, :id => 1}) # should_request_login_on_post_to(:move_up, {:course_id => 1, :id => 1})
should_request_login_on_post_to(:move_down, {:course_id => 1, :id => 1}) # should_request_login_on_post_to(:move_down, {:course_id => 1, :id => 1})
#
#context "on get to :index" do # #context "on get to :index" do
# setup { get :index, :course_id => @course.id } # # setup { get :index, :course_id => @course.id }
# should redirect_to('the course page') { course_url(@course) } # # should redirect_to('the course page') { course_url(@course) }
#end # #end
#
context "on get to :show" do # context "on get to :show" do
setup { get :show, :course_id => @course.id, :id => @wiki_page.id } # setup { get :show, :course_id => @course.id, :id => @wiki_page.id }
#
should respond_with :success # should respond_with :success
should render_template 'show' # should render_template 'show'
#
should "show the wiki page" do # should "show the wiki page" do
assert_select 'h1.title', @wiki_page.title # assert_select 'h1.title', @wiki_page.title
end # end
#
should "show the selected version" do # should "show the selected version" do
@wiki_page.revert_to(1) # @wiki_page.revert_to(1)
get :show, :course_id => @course.id, :id => @wiki_page.id, :version => 1 # get :show, :course_id => @course.id, :id => @wiki_page.id, :version => 1
assert_select 'h1.title', @wiki_page.title # assert_select 'h1.title', @wiki_page.title
end # end
end # end
#
context "on get to :versions" do # context "on get to :versions" do
setup { get :versions, :course_id => @course.id, :id => @wiki_page.id } # setup { get :versions, :course_id => @course.id, :id => @wiki_page.id }
#
should respond_with :success # should respond_with :success
should render_template 'versions' # should render_template 'versions'
#
should "show the wiki page versions" do # should "show the wiki page versions" do
@wiki_page.versions.each do |v| # @wiki_page.versions.each do |v|
assert_select 'a[href=?]', course_wiki_instance_url(@course, @wiki_page, :version => v.version) # assert_select 'a[href=?]', course_wiki_instance_url(@course, @wiki_page, :version => v.version)
end # end
end # end
end # end
#
context "on get to :preview" do # context "on get to :preview" do
context "with valid markup" do # context "with valid markup" do
setup { get :preview, :text => "hello {$x$} <script>foo();</script> <i onclick='foo()'>x</i>" } # setup { get :preview, :text => "hello {$x$} <script>foo();</script> <i onclick='foo()'>x</i>" }
#
should respond_with :success # should respond_with :success
#
should "display latex formulas" do # should "display latex formulas" do
assert_select 'img[class=tex_inline]' # assert_select 'img[class=tex_inline]'
end # end
#
should "strip harmful tags" do # should "strip harmful tags" do
assert_select 'script', false # assert_select 'script', false
assert_select '*[onclick]', false # assert_select '*[onclick]', false
end # end
end # end
#
context "with invalid markup" do # context "with invalid markup" do
setup { get :preview, :text => "<a" } # setup { get :preview, :text => "<a" }
should respond_with :bad_request # should respond_with :bad_request
end # end
end # end
#
context "on get to :diff" do # context "on get to :diff" do
setup { get :diff, :course_id => @course.id, :id => @wiki_page.id, :from => 1, :to => 2 } # setup { get :diff, :course_id => @course.id, :id => @wiki_page.id, :from => 1, :to => 2 }
should respond_with :success # should respond_with :success
should assign_to :diff # should assign_to :diff
end # end
#
end # end
#
context "An authenticated user" do # context "An authenticated user" do
setup { login_as :bob } # setup { login_as :bob }
#
context "on get to :new" do # context "on get to :new" do
setup { get :new, :course_id => @course.id } # setup { get :new, :course_id => @course.id }
#should render_a_form # #should render_a_form
should respond_with :success # should respond_with :success
end # end
#
context "on post to :create" do # context "on post to :create" do
setup do # setup do
assert_nil @course.wiki_pages.find_by_title('test2') # assert_nil @course.wiki_pages.find_by_title('test2')
post :create, :course_id => @course.id, :wiki_page => { :title => 'test2', :content => 'test2' } # post :create, :course_id => @course.id, :wiki_page => { :title => 'test2', :content => 'test2' }
@wiki_page = @course.wiki_pages.find_by_title('test2') # @wiki_page = @course.wiki_pages.find_by_title('test2')
end # end
#
should set_the_flash.to(/created/i) # should set_the_flash.to(/created/i)
should redirect_to('the wiki page') { course_wiki_instance_url(@course, @wiki_page) } # should redirect_to('the wiki page') { course_wiki_instance_url(@course, @wiki_page) }
should_create_log_entry {[ WikiCreateLogEntry, @wiki_page.id, users(:bob).id ]} # should_create_log_entry {[ WikiCreateLogEntry, @wiki_page.id, users(:bob).id ]}
#
should "create a new wiki page" do # should "create a new wiki page" do
assert @wiki_page # assert @wiki_page
assert_equal @wiki_page.version, 1 # assert_equal @wiki_page.version, 1
assert_equal users(:bob).id, @wiki_page.user_id # assert_equal users(:bob).id, @wiki_page.user_id
end # end
end # end
#
context "on get to :edit" do # context "on get to :edit" do
setup { get :edit, :course_id => @course.id, :id => @wiki_page.id } # setup { get :edit, :course_id => @course.id, :id => @wiki_page.id }
#
#should render_a_form # #should render_a_form
should render_template 'edit' # should render_template 'edit'
#
should "render a form with the correct fields" do # should "render a form with the correct fields" do
assert_select "input[name='wiki_page[title]'][value=?]", @wiki_page.title # assert_select "input[name='wiki_page[title]'][value=?]", @wiki_page.title
assert_select "input[name='wiki_page[description]'][value=?]", "" # assert_select "input[name='wiki_page[description]'][value=?]", ""
assert_select 'textarea', @wiki_page.content # assert_select 'textarea', @wiki_page.content
end # end
#
should "edit the selected version" do # should "edit the selected version" do
@wiki_page.revert_to(1) # @wiki_page.revert_to(1)
get :edit, :course_id => @course.id, :id => @wiki_page.id, :version => 1 # get :edit, :course_id => @course.id, :id => @wiki_page.id, :version => 1
assert_select "input[name='wiki_page[title]'][value=?]", @wiki_page.title # assert_select "input[name='wiki_page[title]'][value=?]", @wiki_page.title
assert_select 'textarea', @wiki_page.content # assert_select 'textarea', @wiki_page.content
end # end
end # end
#
context "on post to :update" do # context "on post to :update" do
context "with unmodified data" do # context "with unmodified data" do
setup do # setup do
post :update, :course_id => @course.id, :id => @wiki_page.id, :wiki_page => { # post :update, :course_id => @course.id, :id => @wiki_page.id, :wiki_page => {
:title => @wiki_page.title, :content => @wiki_page.content} # :title => @wiki_page.title, :content => @wiki_page.content}
end # end
#
should_not set_the_flash # should_not set_the_flash
should redirect_to('the wiki page') { course_wiki_instance_url(@course, @wiki_page) } # should redirect_to('the wiki page') { course_wiki_instance_url(@course, @wiki_page) }
#
should "not create a new log entry" do # should "not create a new log entry" do
assert_nil WikiEditLogEntry.find(:first, :conditions => { :target_id => @wiki_page.id }) # assert_nil WikiEditLogEntry.find(:first, :conditions => { :target_id => @wiki_page.id })
end # end
end # end
#
context "with new data" do # context "with new data" do
setup do # setup do
post :update, :course_id => @course.id, :id => @wiki_page.id, :wiki_page => { # post :update, :course_id => @course.id, :id => @wiki_page.id, :wiki_page => {
:user_id => 999, :course_id => 999, # not user definable # :user_id => 999, :course_id => 999, # not user definable
:title => 'brand new title', :content => 'brand new content'} # :title => 'brand new title', :content => 'brand new content'}
@wiki_page.reload # @wiki_page.reload
end # end
#
should set_the_flash.to(/updated/i) # should set_the_flash.to(/updated/i)
should redirect_to('the wiki page') { course_wiki_instance_url(@course, @wiki_page) } # should redirect_to('the wiki page') { course_wiki_instance_url(@course, @wiki_page) }
should_create_log_entry {[ WikiEditLogEntry, @wiki_page.id, users(:bob).id ]} # should_create_log_entry {[ WikiEditLogEntry, @wiki_page.id, users(:bob).id ]}
#
should "update the wiki page" do # should "update the wiki page" do
assert_equal "brand new title", @wiki_page.title # assert_equal "brand new title", @wiki_page.title
assert_equal "brand new content", @wiki_page.content # assert_equal "brand new content", @wiki_page.content
assert_equal users(:bob).id, @wiki_page.user_id # assert_equal users(:bob).id, @wiki_page.user_id
assert_equal @course.id, @wiki_page.course_id # assert_equal @course.id, @wiki_page.course_id
end # end
end # end
end # end
#
context "on post to :destroy" do # context "on post to :destroy" do
setup { post :destroy, :course_id => @course.id, :id => @wiki_page.id } # setup { post :destroy, :course_id => @course.id, :id => @wiki_page.id }
#
should set_the_flash.to(/removed/i) # should set_the_flash.to(/removed/i)
should redirect_to('the course page') { course_url(@course) } # should redirect_to('the course page') { course_url(@course) }
should_create_log_entry {[ WikiDeleteLogEntry, @wiki_page.id, users(:bob).id ]} # should_create_log_entry {[ WikiDeleteLogEntry, @wiki_page.id, users(:bob).id ]}
#
should "delete the wiki page" do # should "delete the wiki page" do
@wiki_page = WikiPage.find_with_deleted(@wiki_page.id) # @wiki_page = WikiPage.find_with_deleted(@wiki_page.id)
assert @wiki_page.deleted? # assert @wiki_page.deleted?
end # end
end # end
#
context "on get to :move_up" do # context "on get to :move_up" do
setup do # setup do
assert_equal 1, @wiki_page.position # assert_equal 1, @wiki_page.position
assert_equal 2, @another_wiki_page.position # assert_equal 2, @another_wiki_page.position
get :move_up, :course_id => @course.id, :id => @another_wiki_page.id # get :move_up, :course_id => @course.id, :id => @another_wiki_page.id
end # end
#
should redirect_to('the course page') { course_url(@course) } # should redirect_to('the course page') { course_url(@course) }
#
should "move the page up" do # should "move the page up" do
@wiki_page.reload # @wiki_page.reload
@another_wiki_page.reload # @another_wiki_page.reload
assert_equal 2, @wiki_page.position # assert_equal 2, @wiki_page.position
assert_equal 1, @another_wiki_page.position # assert_equal 1, @another_wiki_page.position
end # end
end # end
#
context "on get to :move_down" do # context "on get to :move_down" do
setup do # setup do
assert_equal 1, @wiki_page.position # assert_equal 1, @wiki_page.position
assert_equal 2, @another_wiki_page.position # assert_equal 2, @another_wiki_page.position
get :move_down, :course_id => @course.id, :id => @wiki_page.id # get :move_down, :course_id => @course.id, :id => @wiki_page.id
end # end
#
should redirect_to('the course page') { course_url(@course) } # should redirect_to('the course page') { course_url(@course) }
#
should "move the page up" do # should "move the page up" do
@wiki_page.reload # @wiki_page.reload
@another_wiki_page.reload # @another_wiki_page.reload
assert_equal 2, @wiki_page.position # assert_equal 2, @wiki_page.position
assert_equal 1, @another_wiki_page.position # assert_equal 1, @another_wiki_page.position
end # end
end # end
#
end # end
#
#def test_should accept_text_on_show # #def test_should accept_text_on_show
# get :show, :format => 'txt', :course_id => 1, :id => @wiki_page.id # # get :show, :format => 'txt', :course_id => 1, :id => @wiki_page.id
# assert_formatted_response :text # # assert_formatted_response :text
#end # #end
#
#def test_should accept_html_on_versions # #def test_should accept_html_on_versions
# get :versions, :course_id => 1, :id => @wiki_page.id # # get :versions, :course_id => 1, :id => @wiki_page.id
# assert_response :success # # assert_response :success
#end # #end
#
#def test_should accept_xml_on_versions # #def test_should accept_xml_on_versions
# get :versions, :format => 'xml', :course_id => 1, :id => @wiki_page.id # # get :versions, :format => 'xml', :course_id => 1, :id => @wiki_page.id
# assert_formatted_response :xml, :versions # # assert_formatted_response :xml, :versions
#end # #end
end #end
#

@ -14,41 +14,42 @@
# You should have received a copy of the GNU Affero General Public License # You should have received a copy of the GNU Affero General Public License
# along with this program. If not, see <http://www.gnu.org/licenses/>. # along with this program. If not, see <http://www.gnu.org/licenses/>.
require File.dirname(__FILE__) + '/../test_helper' #require File.dirname(__FILE__) + '/../test_helper'
#
class AttachmentTest < ActiveSupport::TestCase #class AttachmentTest < ActiveSupport::TestCase
fixtures :attachments # fixtures :attachments
#
def setup # def setup
# Cria um pseudo-arquivo, com conteudo qualquer # # Cria um pseudo-arquivo, com conteudo qualquer
@test_file = StringIO.new # @test_file = StringIO.new
@test_file.puts("temp" * 10) # @test_file.puts("temp" * 10)
@test_file.rewind # @test_file.rewind
end # end
#
def test_create_and_destroy_attachment # def test_create_and_destroy_attachment
# Cria o anexo # # Cria o anexo
att = Attachment.new(:file_name => 'test_file', :content_type => 'text/plain', # att = Attachment.new(:file_name => 'test_file', :content_type => 'text/plain',
:description => 'A test file', :course_id => 1) # :description => 'A test file', :course_id => 1)
att.file = @test_file # att.file = @test_file
#
# Verifica gravacao no bando de dados # # Verifica gravacao no bando de dados
assert att.save # assert att.save
#
# Verifica se o arquivo foi criado no sistema de arquivos # # Verifica se o arquivo foi criado no sistema de arquivos
file_path = "#{RAILS_ROOT}/public/upload/1/#{att.id}" # file_path = "#{RAILS_ROOT}/public/upload/1/#{att.id}"
assert_equal @test_file.size, att.size # assert_equal @test_file.size, att.size
assert File.exists?(file_path) # assert File.exists?(file_path)
#
# Verifica se o conteudo do arquivo gerado eh igual ao conteudo do # # Verifica se o conteudo do arquivo gerado eh igual ao conteudo do
# arquivo original # # arquivo original
@test_file.rewind # @test_file.rewind
assert_equal @test_file.read, File.open(file_path, "r").read # assert_equal @test_file.read, File.open(file_path, "r").read
#
# Deleta o anexo # # Deleta o anexo
#att.destroy # #att.destroy
#
# Verifica se o arquivo foi excluido # # Verifica se o arquivo foi excluido
#assert !File.exists?(file_path) # #assert !File.exists?(file_path)
end # end
end #end
#

@ -14,14 +14,15 @@
# You should have received a copy of the GNU Affero General Public License # You should have received a copy of the GNU Affero General Public License
# along with this program. If not, see <http://www.gnu.org/licenses/>. # along with this program. If not, see <http://www.gnu.org/licenses/>.
require File.dirname(__FILE__) + '/../test_helper' #require File.dirname(__FILE__) + '/../test_helper'
#
class CourseTest < ActiveSupport::TestCase #class CourseTest < ActiveSupport::TestCase
#
fixtures :courses # fixtures :courses
#
def test_truth # def test_truth
assert true # assert true
end # end
#
end #end
#

@ -14,13 +14,14 @@
# You should have received a copy of the GNU Affero General Public License # You should have received a copy of the GNU Affero General Public License
# along with this program. If not, see <http://www.gnu.org/licenses/>. # along with this program. If not, see <http://www.gnu.org/licenses/>.
require File.dirname(__FILE__) + '/../test_helper' #require File.dirname(__FILE__) + '/../test_helper'
#
class EventTest < ActiveSupport::TestCase #class EventTest < ActiveSupport::TestCase
fixtures :events # fixtures :events
#
# Replace this with your real tests. # # Replace this with your real tests.
def test_truth # def test_truth
assert true # assert true
end # end
end #end
#

@ -14,11 +14,12 @@
# You should have received a copy of the GNU Affero General Public License # You should have received a copy of the GNU Affero General Public License
# along with this program. If not, see <http://www.gnu.org/licenses/>. # along with this program. If not, see <http://www.gnu.org/licenses/>.
require File.dirname(__FILE__) + '/../test_helper' #require File.dirname(__FILE__) + '/../test_helper'
#
class LogEntryTest < ActiveSupport::TestCase #class LogEntryTest < ActiveSupport::TestCase
# Replace this with your real tests. # # Replace this with your real tests.
def test_truth # def test_truth
assert true # assert true
end # end
end #end
#

@ -14,23 +14,24 @@
# You should have received a copy of the GNU Affero General Public License # You should have received a copy of the GNU Affero General Public License
# along with this program. If not, see <http://www.gnu.org/licenses/>. # along with this program. If not, see <http://www.gnu.org/licenses/>.
require File.dirname(__FILE__) + '/../test_helper' #require File.dirname(__FILE__) + '/../test_helper'
#
class MessageTest < ActiveSupport::TestCase #class MessageTest < ActiveSupport::TestCase
fixtures :messages # fixtures :messages
#
def test_should_create_new_version # def test_should_create_new_version
news = News.find(1) # news = News.find(1)
news.title = "another title" # news.title = "another title"
assert news.save_version? # assert news.save_version?
end # end
#
def test_should_not_create_new_version # def test_should_not_create_new_version
news = News.find(1) # news = News.find(1)
news.destroy # news.destroy
#
news = News.find_with_deleted(1) # news = News.find_with_deleted(1)
news.recover! # news.recover!
assert !news.save_version? # assert !news.save_version?
end # end
end #end
#

@ -14,38 +14,39 @@
# You should have received a copy of the GNU Affero General Public License # You should have received a copy of the GNU Affero General Public License
# along with this program. If not, see <http://www.gnu.org/licenses/>. # along with this program. If not, see <http://www.gnu.org/licenses/>.
require File.dirname(__FILE__) + '/../test_helper' #require File.dirname(__FILE__) + '/../test_helper'
#
class NotificationsTest < ActiveSupport::TestCase #class NotificationsTest < ActiveSupport::TestCase
FIXTURES_PATH = File.dirname(__FILE__) + '/../fixtures' # FIXTURES_PATH = File.dirname(__FILE__) + '/../fixtures'
CHARSET = "utf-8" # CHARSET = "utf-8"
#
include ActionMailer::Quoting # #include ActionMailer::Quoting
#
def setup # def setup
ActionMailer::Base.delivery_method = :test # ActionMailer::Base.delivery_method = :test
ActionMailer::Base.perform_deliveries = true # ActionMailer::Base.perform_deliveries = true
ActionMailer::Base.deliveries = [] # ActionMailer::Base.deliveries = []
#
@expected = TMail::Mail.new # @expected = TMail::Mail.new
@expected.set_content_type "text", "plain", { "charset" => CHARSET } # @expected.set_content_type "text", "plain", { "charset" => CHARSET }
@expected.mime_version = '1.0' # @expected.mime_version = '1.0'
end # end
#
def test_forgot_password # def test_forgot_password
@expected.subject = 'Notifications#forgot_password' # @expected.subject = 'Notifications#forgot_password'
@expected.body = read_fixture('forgot_password') # @expected.body = read_fixture('forgot_password')
@expected.date = Time.now # @expected.date = Time.now
#
#assert_equal @expected.encoded, Notifications.create_forgot_password(@expected.date).encoded # #assert_equal @expected.encoded, Notifications.create_forgot_password(@expected.date).encoded
end # end
#
private # private
def read_fixture(action) # def read_fixture(action)
IO.readlines("#{FIXTURES_PATH}/notifications/#{action}") # IO.readlines("#{FIXTURES_PATH}/notifications/#{action}")
end # end
#
def encode(subject) # def encode(subject)
quoted_printable(subject, CHARSET) # quoted_printable(subject, CHARSET)
end # end
end #end
#

@ -14,234 +14,235 @@
# You should have received a copy of the GNU Affero General Public License # You should have received a copy of the GNU Affero General Public License
# along with this program. If not, see <http://www.gnu.org/licenses/>. # along with this program. If not, see <http://www.gnu.org/licenses/>.
require File.dirname(__FILE__) + '/../test_helper' #require File.dirname(__FILE__) + '/../test_helper'
class UserTest < ActiveSupport::TestCase
fixtures :users
def test_login
assert_equal users(:bob), User.find_by_login_and_pass("bob", "test")
assert_nil User.find_by_login_and_pass("wrong_bob", "test")
assert_nil User.find_by_login_and_pass("bob", "wrongpass")
assert_nil User.find_by_login_and_pass("wrong_bob", "wrongpass")
end
def test_change_password
user = users(:longbob)
# Check success
assert_equal user, User.find_by_login_and_pass("longbob", "longtest")
# Change password
user.password = user.password_confirmation = "nonbobpasswd"
assert user.save, user.errors.full_messages
# New password works
assert_equal user, User.find_by_login_and_pass("longbob", "nonbobpasswd")
# Old pasword doesn't work anymore
assert_nil User.find_by_login_and_pass("longbob", "longtest")
# Change back again
user.password = user.password_confirmation = "longtest"
assert user.save
assert_equal user, User.find_by_login_and_pass("longbob", "longtest")
assert_nil User.find_by_login_and_pass("longbob", "nonbobpasswd")
end
def test_keep_old_password
# Dont change the password
user = users(:longbob)
user.name = "brand new bob"
assert user.save
assert_equal user, User.find_by_login_and_pass("longbob", "longtest")
assert_nil User.find_by_login_and_pass("longbob", "")
# Set a blank password
user.password = user.password_confirmation = ""
assert user.save
assert_equal user, User.find_by_login_and_pass("longbob", "longtest")
assert_nil User.find_by_login_and_pass("longbob", "")
end
def test_validate_password_confirmation
u = users(:longbob)
# No confirmation
u.password = "hello"
assert !u.valid?
assert u.errors.invalid?('password_confirmation')
# Wrong confirmation
u.password_confirmation = "wrong hello"
assert !u.valid?
assert u.errors.invalid?('password_confirmation')
# Valid confirmation
u.password = u.password_confirmation = "hello world"
assert u.valid?
end
def test_validate_password
u = users(:bob)
u.login = "anotherbob"
u.email = "anotherbob@bob.com"
# Too short
u.password = u.password_confirmation = "tiny"
assert !u.valid?
assert u.errors.invalid?('password')
# Too long
u.password = u.password_confirmation = "huge" * 50
assert !u.valid?
assert u.errors.invalid?('password')
# Empty
newbob = User.new(:login => 'newbob', :email => 'bob@bob.com', :name => 'bob')
newbob.password = newbob.password_confirmation = ""
assert !newbob.valid?
assert newbob.errors.invalid?('password')
# OK
u.password = u.password_confirmation = "bobs_secure_password"
assert u.save, u.errors.full_messages
assert u.errors.empty?
end
def test_validate_login
u = users(:bob)
u.password = u.password_confirmation = "bobs_secure_password"
u.email = "okbob@mcbob.com"
# Too short
u.login = "x"
assert !u.valid?
assert u.errors.invalid?('login')
assert_equal 1, u.errors.count, u.errors.full_messages
# Too long
u.login = "hugebob" * 50
assert !u.valid?
assert u.errors.invalid?('login')
assert_equal 1, u.errors.count, u.errors.full_messages
# Empty
u.login = ""
assert !u.valid?
assert u.errors.invalid?('login')
assert_equal 3, u.errors.count, u.errors.full_messages
# OK
u.login = "okbob"
assert u.valid?
assert u.errors.empty?
end
def test_validate_email
u = users(:longbob)
# No email
u.email = nil
assert !u.valid?
assert u.errors.invalid?('email')
assert_equal 2, u.errors.count, u.errors.full_messages
# Invalid email
u.email='notavalidemail'
assert !u.valid?
assert u.errors.invalid?('email')
assert_equal 1, u.errors.count, u.errors.full_messages
# OK
u.email="validbob@mcbob.com"
assert u.valid?
assert u.errors.empty?
end
def test_signup
u = User.new
u.last_seen = Time.now
u.login = "new bob"
u.display_name = "new bob"
u.name = u.email = "new@email.com"
u.password = u.password_confirmation = "new password"
assert u.save, u.errors.full_messages
assert_equal u, User.find_by_login_and_pass(u.login, u.password)
assert_not_nil u.salt
assert_equal 10, u.salt.length
end
# def test_send_new_password
# #check user find_by_login_and_passs
# assert_equal @bob, User.find_by_login_and_pass("bob", "test")
# #
# #send new password #class UserTest < ActiveSupport::TestCase
# sent = @bob.send_new_password
# assert_not_nil sent
# #
# #old password no longer workd # fixtures :users
# assert_nil User.find_by_login_and_pass("bob", "test")
# #
# #email sent... # def test_login
# assert_equal "Your password is ...", sent.subject # assert_equal users(:bob), User.find_by_login_and_pass("bob", "test")
# assert_nil User.find_by_login_and_pass("wrong_bob", "test")
# assert_nil User.find_by_login_and_pass("bob", "wrongpass")
# assert_nil User.find_by_login_and_pass("wrong_bob", "wrongpass")
# end
# #
# #... to bob
# assert_equal @bob.email, sent.to[0]
# #assert_match Regexp.new("Your username is bob."), sent.body
# #
# #can find_by_login_and_pass with the new password # def test_change_password
# #new_pass = $1 if Regexp.new("Your new password is (\\w+).") =~ sent.body # user = users(:longbob)
# #assert_not_nil new_pass #
# #assert_equal @bob, User.find_by_login_and_pass("bob", new_pass) # # Check success
# assert_equal user, User.find_by_login_and_pass("longbob", "longtest")
#
# # Change password
# user.password = user.password_confirmation = "nonbobpasswd"
# assert user.save, user.errors.full_messages
#
# # New password works
# assert_equal user, User.find_by_login_and_pass("longbob", "nonbobpasswd")
#
# # Old pasword doesn't work anymore
# assert_nil User.find_by_login_and_pass("longbob", "longtest")
#
# # Change back again
# user.password = user.password_confirmation = "longtest"
#
# assert user.save
# assert_equal user, User.find_by_login_and_pass("longbob", "longtest")
# assert_nil User.find_by_login_and_pass("longbob", "nonbobpasswd")
# end # end
#
def test_generate_random_pass #
new_pass = User.random_string(10) # def test_keep_old_password
assert_not_nil new_pass # # Dont change the password
assert_equal 10, new_pass.length # user = users(:longbob)
end # user.name = "brand new bob"
#
# assert user.save
def test_sha1 # assert_equal user, User.find_by_login_and_pass("longbob", "longtest")
u = users(:bob) # assert_nil User.find_by_login_and_pass("longbob", "")
u.password = u.password_confirmation = "bobs_secure_password" #
# # Set a blank password
assert u.save # user.password = user.password_confirmation = ""
assert_equal 'b1d27036d59f9499d403f90e0bcf43281adaa844', u.hashed_password #
assert_equal 'b1d27036d59f9499d403f90e0bcf43281adaa844', User.encrypt("bobs_secure_password", u.salt) # assert user.save
end # assert_equal user, User.find_by_login_and_pass("longbob", "longtest")
# assert_nil User.find_by_login_and_pass("longbob", "")
# end
def test_protected_attributes #
u = users(:bob) #
u.update_attributes(:id => 999999, :salt => "I-want-to-set-my-salt", :login => "verybadbob") # def test_validate_password_confirmation
# u = users(:longbob)
assert u.save #
assert_not_equal 999999, u.id # # No confirmation
assert_not_equal "I-want-to-set-my-salt", u.salt # u.password = "hello"
assert_equal "verybadbob", u.login # assert !u.valid?
end # assert u.errors.invalid?('password_confirmation')
#
def test_paranoid # # Wrong confirmation
assert User.paranoid? # u.password_confirmation = "wrong hello"
# assert !u.valid?
u = users(:bob) # assert u.errors.invalid?('password_confirmation')
u.destroy #
# # Valid confirmation
assert_raises(ActiveRecord::RecordNotFound) { User.find(u.id) } # u.password = u.password_confirmation = "hello world"
assert_nothing_raised { User.find_with_deleted(u.id) } # assert u.valid?
end # end
end #
#
# def test_validate_password
# u = users(:bob)
# u.login = "anotherbob"
# u.email = "anotherbob@bob.com"
#
# # Too short
# u.password = u.password_confirmation = "tiny"
# assert !u.valid?
# assert u.errors.invalid?('password')
#
# # Too long
# u.password = u.password_confirmation = "huge" * 50
# assert !u.valid?
# assert u.errors.invalid?('password')
#
# # Empty
# newbob = User.new(:login => 'newbob', :email => 'bob@bob.com', :name => 'bob')
# newbob.password = newbob.password_confirmation = ""
# assert !newbob.valid?
# assert newbob.errors.invalid?('password')
#
# # OK
# u.password = u.password_confirmation = "bobs_secure_password"
# assert u.save, u.errors.full_messages
# assert u.errors.empty?
# end
#
#
# def test_validate_login
# u = users(:bob)
# u.password = u.password_confirmation = "bobs_secure_password"
# u.email = "okbob@mcbob.com"
#
# # Too short
# u.login = "x"
# assert !u.valid?
# assert u.errors.invalid?('login')
# assert_equal 1, u.errors.count, u.errors.full_messages
#
# # Too long
# u.login = "hugebob" * 50
# assert !u.valid?
# assert u.errors.invalid?('login')
# assert_equal 1, u.errors.count, u.errors.full_messages
#
# # Empty
# u.login = ""
# assert !u.valid?
# assert u.errors.invalid?('login')
# assert_equal 3, u.errors.count, u.errors.full_messages
#
# # OK
# u.login = "okbob"
# assert u.valid?
# assert u.errors.empty?
# end
#
#
# def test_validate_email
# u = users(:longbob)
#
# # No email
# u.email = nil
# assert !u.valid?
# assert u.errors.invalid?('email')
# assert_equal 2, u.errors.count, u.errors.full_messages
#
# # Invalid email
# u.email='notavalidemail'
# assert !u.valid?
# assert u.errors.invalid?('email')
# assert_equal 1, u.errors.count, u.errors.full_messages
#
# # OK
# u.email="validbob@mcbob.com"
# assert u.valid?
# assert u.errors.empty?
# end
#
# def test_signup
# u = User.new
# u.last_seen = Time.now
# u.login = "new bob"
# u.display_name = "new bob"
# u.name = u.email = "new@email.com"
# u.password = u.password_confirmation = "new password"
#
# assert u.save, u.errors.full_messages
# assert_equal u, User.find_by_login_and_pass(u.login, u.password)
#
# assert_not_nil u.salt
# assert_equal 10, u.salt.length
# end
#
## def test_send_new_password
## #check user find_by_login_and_passs
## assert_equal @bob, User.find_by_login_and_pass("bob", "test")
##
## #send new password
## sent = @bob.send_new_password
## assert_not_nil sent
##
## #old password no longer workd
## assert_nil User.find_by_login_and_pass("bob", "test")
##
## #email sent...
## assert_equal "Your password is ...", sent.subject
##
## #... to bob
## assert_equal @bob.email, sent.to[0]
## #assert_match Regexp.new("Your username is bob."), sent.body
##
## #can find_by_login_and_pass with the new password
## #new_pass = $1 if Regexp.new("Your new password is (\\w+).") =~ sent.body
## #assert_not_nil new_pass
## #assert_equal @bob, User.find_by_login_and_pass("bob", new_pass)
## end
#
# def test_generate_random_pass
# new_pass = User.random_string(10)
# assert_not_nil new_pass
# assert_equal 10, new_pass.length
# end
#
#
# def test_sha1
# u = users(:bob)
# u.password = u.password_confirmation = "bobs_secure_password"
#
# assert u.save
# assert_equal 'b1d27036d59f9499d403f90e0bcf43281adaa844', u.hashed_password
# assert_equal 'b1d27036d59f9499d403f90e0bcf43281adaa844', User.encrypt("bobs_secure_password", u.salt)
# end
#
#
# def test_protected_attributes
# u = users(:bob)
# u.update_attributes(:id => 999999, :salt => "I-want-to-set-my-salt", :login => "verybadbob")
#
# assert u.save
# assert_not_equal 999999, u.id
# assert_not_equal "I-want-to-set-my-salt", u.salt
# assert_equal "verybadbob", u.login
# end
#
# def test_paranoid
# assert User.paranoid?
#
# u = users(:bob)
# u.destroy
#
# assert_raises(ActiveRecord::RecordNotFound) { User.find(u.id) }
# assert_nothing_raised { User.find_with_deleted(u.id) }
# end
#end
#

@ -14,33 +14,34 @@
# You should have received a copy of the GNU Affero General Public License # You should have received a copy of the GNU Affero General Public License
# along with this program. If not, see <http://www.gnu.org/licenses/>. # along with this program. If not, see <http://www.gnu.org/licenses/>.
require File.dirname(__FILE__) + '/../test_helper' #require File.dirname(__FILE__) + '/../test_helper'
#
class WikiPageTest < ActiveSupport::TestCase #class WikiPageTest < ActiveSupport::TestCase
#
should "not delete versions on destroy" do # should "not delete versions on destroy" do
wp = WikiPage.new(:course_id => 1, :user_id => 1, :title => "t", :content => "c", :description => "d", :version => 1) # wp = WikiPage.new(:course_id => 1, :user_id => 1, :title => "t", :content => "c", :description => "d", :version => 1)
wp.save! # wp.save!
wp.destroy # wp.destroy
#
wp = WikiPage.find_with_deleted(wp.id) # wp = WikiPage.find_with_deleted(wp.id)
wp.recover! # wp.recover!
assert !wp.versions.empty? # assert !wp.versions.empty?
end # end
#
def test_should_create_new_version_when_editing # def test_should_create_new_version_when_editing
wp = WikiPage.new # wp = WikiPage.new
assert !wp.save_version? # assert !wp.save_version?
#
wp.content = 'new content' # wp.content = 'new content'
assert wp.save_version? # assert wp.save_version?
end # end
#
def test_should_not_create_new_version_when_reordering # def test_should_not_create_new_version_when_reordering
wp = WikiPage.new # wp = WikiPage.new
assert !wp.save_version? # assert !wp.save_version?
#
wp.move_higher # wp.move_higher
assert !wp.save_version? # assert !wp.save_version?
end # end
end #end
#

@ -1,10 +0,0 @@
**/doc
**/pkg
*swo
*swp
*~
.bundle
.DS_Store
.rvmrc
doc
pkg