Froze rails gems
[depot.git] / vendor / rails / activerecord / test / models / project.rb
1 class Project < ActiveRecord::Base
2 has_and_belongs_to_many :developers, :uniq => true, :order => 'developers.name desc, developers.id desc'
3 has_and_belongs_to_many :readonly_developers, :class_name => "Developer", :readonly => true
4 has_and_belongs_to_many :selected_developers, :class_name => "Developer", :select => "developers.*", :uniq => true
5 has_and_belongs_to_many :non_unique_developers, :order => 'developers.name desc, developers.id desc', :class_name => 'Developer'
6 has_and_belongs_to_many :limited_developers, :class_name => "Developer", :limit => 1
7 has_and_belongs_to_many :developers_named_david, :class_name => "Developer", :conditions => "name = 'David'", :uniq => true
8 has_and_belongs_to_many :developers_named_david_with_hash_conditions, :class_name => "Developer", :conditions => { :name => 'David' }, :uniq => true
9 has_and_belongs_to_many :salaried_developers, :class_name => "Developer", :conditions => "salary > 0"
10 has_and_belongs_to_many :developers_with_finder_sql, :class_name => "Developer", :finder_sql => 'SELECT t.*, j.* FROM developers_projects j, developers t WHERE t.id = j.developer_id AND j.project_id = #{id} ORDER BY t.id'
11 has_and_belongs_to_many :developers_by_sql, :class_name => "Developer", :delete_sql => "DELETE FROM developers_projects WHERE project_id = \#{id} AND developer_id = \#{record.id}"
12 has_and_belongs_to_many :developers_with_callbacks, :class_name => "Developer", :before_add => Proc.new {|o, r| o.developers_log << "before_adding#{r.id || '<new>'}"},
13 :after_add => Proc.new {|o, r| o.developers_log << "after_adding#{r.id || '<new>'}"},
14 :before_remove => Proc.new {|o, r| o.developers_log << "before_removing#{r.id}"},
15 :after_remove => Proc.new {|o, r| o.developers_log << "after_removing#{r.id}"}
16
17 attr_accessor :developers_log
18
19 def after_initialize
20 @developers_log = []
21 end
22
23 end
24
25 class SpecialProject < Project
26 def hello_world
27 "hello there!"
28 end
29 end