aboutsummaryrefslogtreecommitdiffstats
path: root/activerecord
Commit message (Collapse)AuthorAgeFilesLines
* Add find(ids) to relationsPratik Naik2009-12-273-2/+91
|
* Make Model.all return an array rather than a relation for consistency. Use ↵Pratik Naik2009-12-272-3/+9
| | | | Model.scoped to get a relation
* Fix dynamic finder docsPratik Naik2009-12-271-3/+2
|
* Make Model.find_or_create_by_* and find_or_initialize_by_* use relations and ↵Pratik Naik2009-12-273-64/+5
| | | | remove method caching
* Add find_or_create_by_* and find_or_initialize_by_* to relationsPratik Naik2009-12-272-0/+44
|
* Make Model.find_by_* and Model.find_all_by_* use relations and remove ↵Pratik Naik2009-12-274-124/+38
| | | | dynamic method caching
* Add find_by_* and find_all_by_* finders to ActiveRecord::RelationPratik Naik2009-12-272-1/+47
|
* Replace Model.first(options) with new finder methods inside testsPratik Naik2009-12-272-3/+3
|
* Add new finder methods to association collection.Pratik Naik2009-12-277-13/+38
|
* Ensure Model.scoped adds type conditions for STI modelsPratik Naik2009-12-273-12/+16
|
* Ensure all the finder methods respect scopingPratik Naik2009-12-262-2/+7
|
* Add relation.reload to force reloading the recordsPratik Naik2009-12-263-0/+29
|
* Cache the loaded relationsPratik Naik2009-12-262-33/+75
|
* Ensure preload and eager_load finder methods accept multiple argumentsPratik Naik2009-12-262-6/+12
|
* Make sure the relations are always immutablePratik Naik2009-12-261-8/+5
|
* Add support for multiple arguments to .where finderPratik Naik2009-12-262-2/+8
|
* Add missing changelog entriesPratik Naik2009-12-261-0/+25
|
* Add Relation#all as an alias for to_aPratik Naik2009-12-262-0/+8
|
* Stop supporting blank arguments to AR#relation query methodsPratik Naik2009-12-261-27/+19
|
* Rename Model.conditions and relation.conditions to .wherePratik Naik2009-12-267-20/+20
|
* No parentheses for assert_equalPratik Naik2009-12-261-6/+6
|
* Add Model.select/group/order/limit/joins/conditions/preload/eager_load class ↵Pratik Naik2009-12-264-59/+88
| | | | | | | | | methods returning a lazy relation. Examples : posts = Post.select('id).order('name') # Returns a lazy relation posts.each {|p| puts p.id } # Fires "select id from posts order by name"
* Model.scoped now returns a relation if invoked without any argumentsPratik Naik2009-12-262-11/+25
| | | | | | | | Example : posts = Post.scoped posts.size # Fires "select count(*) from posts" and returns the count posts.each {|p| puts p.name } # Fires "select * from posts" and loads post objects
* Finish moving config.frameworks-dependent code to the framework pluginCarlhuda2009-12-232-5/+8
|
* Moving out some framework specific initializers into the framework libraries.Carlhuda2009-12-231-0/+51
|
* Flip deferrable autoload conventionJoshua Peek2009-12-221-52/+64
|
* Missed changelog entry for :inverse_ofJeremy Kemper2009-12-211-0/+7
|
* Fully expand relative rails framework paths and make sure we aren'tJoshua Peek2009-12-162-11/+10
| | | | adding any to the load path more than once.
* When passing force_reload = true to an association, don't use the query ↵Will2009-12-162-2/+12
| | | | | | cache [#1827 state:resolved] Signed-off-by: Joshua Peek <josh@joshpeek.com>
* Added #to_i to DateTime in ActiveSupport so #to_yaml works correctly on ↵Serguei Filimonov2009-12-151-0/+11
| | | | ActiveRecord models with DateTime attributes.
* Forgot to revert tests from that last commitJoshua Peek2009-12-121-8/+0
|
* Revert "Fix instance_eval calls to association proxies"Joshua Peek2009-12-122-3/+6
| | | | | | | | | | I think it may of broke the build. Lets see. This reverts commit 49e943c4f0ac3459bd53023167aaa08fc8e46733. Conflicts: activerecord/test/cases/associations/has_many_associations_test.rb
* Fix postgresql AR test failureJohn Pignata2009-12-111-2/+2
| | | | | | | | Due to the ordering of the returning result set, the test fails under the postgresql adapter. Order results by id prior to checking the first item [#3542 state:committed] Signed-off-by: Jeremy Kemper <jeremy@bitsweat.net>
* Replace reset_counter_cache with reset_counters that has API inline with ↵Gabe da Silveira2009-12-033-11/+16
| | | | | | | | existing update_counters method [#1211 state:committed] Signed-off-by: Jeremy Kemper <jeremy@bitsweat.net>
* Add support for Mysql column positioning via #add_column and #change_columnBen Marini2009-12-033-0/+64
| | | | | | | | | | | | | | add_column and change_column in the Mysql adapter now accept some additional options: :first => true # Put the column in front of all the columns :after => column_name # Put the colmn after 'column_name' add_column :new_col, :string, :first => true add_column :another_col, :integer, :default => 0, :after => :new_col [#3286 state:committed] Signed-off-by: Jeremy Kemper <jeremy@bitsweat.net>
* Reorganize autoloads:Carlhuda2009-12-021-47/+53
| | | | | | | | | | | | | | | | | | | | | * A new module (ActiveSupport::Autoload) is provide that extends autoloading with new behavior. * All autoloads in modules that have extended ActiveSupport::Autoload will be eagerly required in threadsafe environments * Autoloads can optionally leave off the path if the path is the same as full_constant_name.underscore * It is possible to specify that a group of autoloads live under an additional path. For instance, all of ActionDispatch's middlewares are ActionDispatch::MiddlewareName, but they live under "action_dispatch/middlewares/middleware_name" * It is possible to specify that a group of autoloads are all found at the same path. For instance, a number of exceptions might all be declared there. * One consequence of this is that testing-related constants are not autoloaded. To get the testing helpers for a given component, require "component_name/test_case". For instance, "action_controller/test_case". * test_help.rb, which is automatically required by a Rails application's test helper, requires the test_case.rb for all active components, so this change will not be disruptive in existing or new applications.
* Fix instance_eval calls to association proxiesMat Brown2009-12-022-6/+10
| | | | | | | | In the current stable, ActiveRecord::Associations::AssociationProxy#method_missing calls yield() if a block is given, causing the block to always be evaluated in its calling context. However, in the case of instance_eval, correct behavior requires that the block be passed directly to the @target, rather than being evaluated inside a different block. Incidentally, this also simplifies the code slightly. [#3412 state:committed] Signed-off-by: Jeremy Kemper <jeremy@bitsweat.net>
* Implement ActiveRecord#reset_counter_cacheMike Breen2009-12-023-0/+30
| | | | | | [#1211 state:committed] Signed-off-by: Jeremy Kemper <jeremy@bitsweat.net>
* Revert "Revert "Assert primary key does not exist in habtm when the ↵Jeremy Kemper2009-11-235-31/+14
| | | | | | | | | | | | | association is defined, instead of doing that everytime a record is inserted."" This reverts commit 2b82708b0efb3a3458e8177beab58f0c585788ae. [#3128 state:resolved] Conflicts: activerecord/lib/active_record/associations.rb activerecord/lib/active_record/associations/has_and_belongs_to_many_association.rb
* Insert generated association members in the same order they are specified ↵Gabe da Silveira2009-11-172-2/+25
| | | | | | | | when assigning to a has_many :through using the generated *_ids method [#3491 state:committed] Signed-off-by: Jeremy Kemper <jeremy@bitsweat.net>
* Revert "Ensure Model#destroy respects optimistic locking"Jeremy Kemper2009-11-172-52/+0
| | | | | | | | | | [#1966 state:open] This reverts commit 0d922885fb54c19f04680482f024452859218910. Conflicts: activerecord/lib/active_record/locking/optimistic.rb
* Ruby 1.9: skip pg locking test for 1.9.1 alsoJeremy Kemper2009-11-151-1/+1
|
* No need to check for generated method, just redispatchJeremy Kemper2009-11-141-4/+3
|
* Ruby 1.9.2: use recursive flattenJeremy Kemper2009-11-141-7/+1
|
* Skip pg locking test due to connection checkout deadlock detectionJeremy Kemper2009-11-141-5/+8
|
* Ruby 1.9.2: fix flatten_deeper to preserve nilsJeremy Kemper2009-11-141-1/+1
|
* Revert "Split arel_table into method to get a relation and another to ↵Jeremy Kemper2009-11-135-13/+13
| | | | | | memoize the default relation." This reverts commit bd51790895fc75a3b4e19e8dd7aa6dc389d77068.
* Split arel_table into method to get a relation and another to memoize the ↵Jeremy Kemper2009-11-135-13/+13
| | | | default relation.
* Missing customers fixtureJeremy Kemper2009-11-131-2/+2
|
* Ruby 1.9.2: avoid #flattenJeremy Kemper2009-11-133-18/+38
|