Fixed: no :author method error on projects atom feed (#1623).

git-svn-id: http://redmine.rubyforge.org/svn/trunk@1653 e93f8b46-1217-0410-a6f0-8f06a7374b81
This commit is contained in:
Jean-Philippe Lang 2008-07-12 09:42:18 +00:00
parent 622b6121f4
commit b5444b5fcd
3 changed files with 18 additions and 8 deletions

View File

@ -48,7 +48,8 @@ class Project < ActiveRecord::Base
acts_as_customizable acts_as_customizable
acts_as_searchable :columns => ['name', 'description'], :project_key => 'id', :permission => nil acts_as_searchable :columns => ['name', 'description'], :project_key => 'id', :permission => nil
acts_as_event :title => Proc.new {|o| "#{l(:label_project)}: #{o.name}"}, acts_as_event :title => Proc.new {|o| "#{l(:label_project)}: #{o.name}"},
:url => Proc.new {|o| {:controller => 'projects', :action => 'show', :id => o.id}} :url => Proc.new {|o| {:controller => 'projects', :action => 'show', :id => o.id}},
:author => nil
attr_protected :status, :enabled_module_names attr_protected :status, :enabled_module_names

View File

@ -42,6 +42,14 @@ class ProjectsControllerTest < Test::Unit::TestCase
# Subproject in corresponding value # Subproject in corresponding value
assert assigns(:project_tree)[Project.find(1)].include?(Project.find(3)) assert assigns(:project_tree)[Project.find(1)].include?(Project.find(3))
end end
def test_index_atom
get :index, :format => 'atom'
assert_response :success
assert_template 'common/feed.atom.rxml'
assert_select 'feed>title', :text => 'Redmine: Latest projects'
assert_select 'feed>entry', :count => Project.count(:conditions => Project.visible_by(User.current))
end
def test_show_by_id def test_show_by_id
get :show, :id => 1 get :show, :id => 1

View File

@ -25,14 +25,15 @@ module Redmine
module ClassMethods module ClassMethods
def acts_as_event(options = {}) def acts_as_event(options = {})
return if self.included_modules.include?(Redmine::Acts::Event::InstanceMethods) return if self.included_modules.include?(Redmine::Acts::Event::InstanceMethods)
options[:datetime] ||= :created_on default_options = { :datetime => :created_on,
options[:title] ||= :title :title => :title,
options[:description] ||= :description :description => :description,
options[:author] ||= :author :author => :author,
options[:url] ||= {:controller => 'welcome'} :url => {:controller => 'welcome'},
options[:type] ||= self.name.underscore.dasherize :type => self.name.underscore.dasherize }
cattr_accessor :event_options cattr_accessor :event_options
self.event_options = options self.event_options = default_options.merge(options)
send :include, Redmine::Acts::Event::InstanceMethods send :include, Redmine::Acts::Event::InstanceMethods
end end
end end