Commit Graph

48542 Commits

Author SHA1 Message Date
Daniel Fox
2859341c38 Fixing numeric attrs when set to same negative value
This bug occurs when an attribute of an ActiveRecord model is an
ActiveRecord::Type::Integer type or a ActiveRecord::Type::Decimal type (or any
other type that includes the ActiveRecord::Type::Numeric module. When the value
of the attribute is negative and is set to the same negative value, it is marked
as changed.

Take the following example of a Person model with the integer attribute age:

    class Person < ActiveRecord::Base
      # age          :integer(4)
    end

The following will produce the error:

    person = Person.new(age: -1)
    person.age = -1
    person.changes
    => { "age" => [-1, -1] }
    person.age_changed?
    => true

The problematic line is here:

    module ActiveRecord
      module Type
        module Numeric
          ...

          def non_numeric_string?(value)
            # 'wibble'.to_i will give zero, we want to make sure
            # that we aren't marking int zero to string zero as
            # changed.
            value.to_s !~ /\A\d+\.?\d*\z/
          end
        end
      end
    end

The regex match doesn't accept numbers with a leading '-'.
2014-12-23 00:19:14 -06:00
Sean Griffin
38e9f5b1d8 Merge pull request #18158 from YayConnolly/master
Describe gotcha for 'status' option [ci skip]
2014-12-22 21:30:09 -07:00
J Connolly
2ad466b867 Describe gotcha for 'status' option [ci skip] 2014-12-22 19:04:57 -08:00
Sean Griffin
d9d865aa40 Merge pull request #18156 from claudiob/better-record-identifier-tests
Better tests for AV::RecordIdentifier
2014-12-22 18:06:16 -07:00
claudiob
b26338e83b Better tests for AV::RecordIdentifier
This commit intends to clarify the scope of ActionView::RecordIdentifier
methods `dom_id` and `dom_class`.

Most of the current documentation comes from da257eb8 (7 years ago) when
the decoupling of ActionView, ActiveRecord and ActiveModel was not a concern.

Since then, steps have been taken to reach such decoupling.
Therefore I think it's important to show that ActionView::RecordIdentifier
**does not strictly depend on the ActiveRecord API**:
any class `Post` implementing `post.to_key` and `post.model_name.param_key`
will work.

This commit adds a test to prove that ActionView::RecordIdentifier methods
can also be used on objects that do not subclass ActiveRecord::Base.
2014-12-23 01:59:25 +01:00
Sean Griffin
8259d79560 Merge pull request #18147 from andreynering/guides-line-breaks-fix
Do not use line breaks on notes [ci skip]
2014-12-22 17:04:26 -07:00
Sean Griffin
be2b98b4ae Improve the performance of reading belongs_to associations
`ActiveRecord::Base#[]` has overhead that was introduced in 4.2. The
`foo["id"]` working with PKs other than ID isn't really a case that we
want to support publicly, but deprecating was painful enough that we
avoid it. `_read_attribute` was introduced as the faster alternative for
use internally. By using that, we can save a lot of overhead. We also
save some overhead by reading the attribute one fewer times in
`stale_state`.

Fixes #18151
2014-12-22 16:38:38 -07:00
Sean Griffin
fb160f6e7d Don't perform statement caching for find when called from a scope
If there is a method defined such as `find_and_do_stuff(id)`, which then
gets called on an association, we will perform statement caching and the
parent ID will not change on subsequent calls.

Fixes #18117
2014-12-22 15:38:58 -07:00
Sean Griffin
18ae0656f5 Don't calculate all in-place changes to determine if attribute_changed?
Calling `changed_attributes` will ultimately check if every mutable
attribute has changed in place. Since this gets called whenever an
attribute is assigned, it's extremely slow. Instead, we can avoid this
calculation until we actually need it.

Fixes #18029
2014-12-22 14:55:58 -07:00
Sean Griffin
849274316d Don't wrap create_table in a transaction for tests which run on MySQL
PG will warn without it, but mysql2 errors out.
2014-12-22 14:15:56 -07:00
Sean Griffin
b7d7e0b15e Add test missed by a03ea684efc3505647cf0327a501aa2dbb591ad2 2014-12-22 14:05:35 -07:00
Sean Griffin
a03ea684ef Use the new foreign_key option on references in generators
Changes `rails g model Post user:references` from

    def change
      create_table :posts do |t|
        t.references :user, index: true
      end

      add_foreign_key :posts, :users
    end

to

    def change
      create_table :posts do |t|
        t.references :user, index: true, foreign_key: true
      end
    end

Changes `rails g migration add_user_to_posts user:references` from

    def change
      add_reference :posts, :users, index: true
      add_foreign_key :posts, :users
    end

to

    def change
      add_reference :posts, :users, index: true, foreign_key: true
    end
2014-12-22 13:47:11 -07:00
Sean Griffin
82afeaf23b Add foreign_key as an option to references for change_table
This has the same comments as 9af90ffa00ba35bdee888e3e1ab775ba0bdbe72c,
however it affects the `add_reference` method, and `t.references` in the
context of a `change_table` block.

There is a lot of duplication of code between creating and updating
tables. We should re-evaluate the structure of this code from a high
level so changes like this don't need to be made in two places. (Note to
self)
2014-12-22 13:47:11 -07:00
Sean Griffin
68a6c8ecc4 Convert add_references to use kwargs
While we still aren't accepting PRs that only make changes like this,
it's fine when we're actively working on a method if it makes our lives
easier.
2014-12-22 13:47:11 -07:00
Sean Griffin
99a6f9e60e Add a foreign_key option to references while creating the table
Rather than having to do:

    create_table :posts do |t|
      t.references :user
    end

    add_foreign_key :posts, :users

You can instead do:

    create_table :posts do |t|
      t.references :user, foreign_key: true
    end

Similar to the `index` option, you can also pass a hash. This will be
passed as the options to `add_foreign_key`. e.g.:

    create_table :posts do |t|
      t.references :user, foreign_key: { primary_key: :other_id }
    end

is equivalent to

    create_table :posts do |t|
      t.references :user
    end

    add_foreign_key :posts, :users, primary_key: :other_id
2014-12-22 13:47:10 -07:00
Sean Griffin
a9c0c46263 Convert references to kwargs
While we aren't taking PRs with these kinds of changes just yet, they
are fine if we're actively working on the method and it makes things
easier.
2014-12-22 13:47:10 -07:00
Sean Griffin
9fff631a06 Skip byebug on all non-MRI rubies, fix tests
The changes in #18149 added tests for the app generator, but only fixed
it for the plugin generator (I should have let CI finish though I think
it would have failed as an allowed failure).
2014-12-22 13:43:58 -07:00
Sean Griffin
569c674773 Merge pull request #18149 from arthurnn/byebug_on_mri
Only add debugger/byebug if on MRI
2014-12-22 13:31:30 -07:00
Arthur Neves
0bb73f03e4
Only add debugger/byebug if on MRI 2014-12-22 15:27:56 -05:00
Sean Griffin
32f30d22d5 Add force: true to table created in tests
If the test is interrupted in a way that the teardown block fails to
run, the tests will fail to run until the table is removed manually
without this option.
2014-12-22 12:49:34 -07:00
Andrey Nering
024edd365b Do not use line breaks on notes [ci skip]
References #18138
2014-12-22 15:25:32 -02:00
Sean Griffin
b0f2b94dd3 Correctly handle limit on int4 and int8 types in PG
PG doesn't register it's types using the `int(4)` format that others do.
As such, if we alias `int8` to the other integer types, the range
information is lost. This is fixed by simply registering it separately.

The other option (which I specifically chose to avoid) is to pass the
information of the original type that was being aliased as an argument.
I'd rather avoid that, since an alias should truly be treated the same.
If we need different behavior for a different type, we should explicitly
register it with that, and not have a conditional based on aliasing.

Fixes #18144

[Sean Griffin & ysbaddaden]
2014-12-22 09:55:41 -07:00
Zachary Scott
0369808917 Merge branch 'master' of github.com:rails/rails 2014-12-22 11:11:32 -05:00
Zachary Scott
3cc9359c2d Remove this section, it adds no real value [ci skip] 2014-12-22 11:11:12 -05:00
Arthur Neves
58b7567bda
Use serve_static_files in guides, take 2 [skip ci] 2014-12-22 10:27:44 -05:00
Arthur Neves
85f7924af1
Use serve_static_files in guides [skip ci] 2014-12-22 10:22:14 -05:00
Zachary Scott
cd01f9f9c5 Add subheadings for these sections [ci skip] 2014-12-22 10:12:06 -05:00
Zachary Scott
eb93e70263 I'm sorry but I would rather not link to a 7 year old blog post [ci skip] 2014-12-22 10:07:15 -05:00
Zachary Scott
2526b95f20 Remove this line since we are using Rake to run our tests [ci skip] 2014-12-22 10:03:03 -05:00
Zachary Scott
a6d9049dc0 s/are edited and rerun/required modifications [ci skip] 2014-12-22 09:50:20 -05:00
Yves Senn
3b34cf3042 document the return of db:test:prepare. Closes #18136. [ci skip]
This is a doc follow-up to #17739.

/cc @zzak
2014-12-22 15:37:59 +01:00
Sean Griffin
41f1323e74 Correctly handle Float -> BigDecimal with unspecified precision
Fixes #18122
2014-12-22 07:08:31 -07:00
Zachary Scott
d610cd0ff8 Merge pull request #18099 from robsonmarques/fix_active_model_errors_add_docs
Fix inaccurate docs in active_model errors [ci skip]
2014-12-22 06:53:12 -05:00
Zachary Scott
84af1e6d07 s/a unobtrusive/an unobtrusive [ci skip] 2014-12-22 06:51:21 -05:00
Zachary Scott
bac74d66ec Merge pull request #18105 from andreynering/guides-csrf
Add note about Ajax and CSRF-Token [ci skip]
2014-12-22 06:50:10 -05:00
Zachary Scott
a1ec6a5d1a Merge pull request #18125 from codeodor/master
Clarify ActiveRecord testing guidelines [ci skip]
2014-12-22 06:45:33 -05:00
Zachary Scott
e77f24b937 Merge pull request #18131 from y-yagi/fix_command_in_plugins_guide
`bin/rake` does not exist in plugin directory [ci skip]
2014-12-22 06:41:24 -05:00
Zachary Scott
334f620858 Better explain number of assertions per test [ci skip] 2014-12-22 03:29:34 -08:00
Zachary Scott
0cf3f9adf5 Remove duplicate description of the previous line [ci skip] 2014-12-22 03:29:16 -08:00
Zachary Scott
f2852298a1 Fix NOTE for method naming in Ruby and add intro sentence to next section.
[ci skip]
2014-12-22 03:25:40 -08:00
Zachary Scott
e36d79fbde Removed run-on sentence and replace with sectional comments [ci skip] 2014-12-22 03:25:18 -08:00
Zachary Scott
0145cc6e50 Better explain how test() methods get defined and kill this run-on sentence.
[ci skip]
2014-12-22 03:24:22 -08:00
Zachary Scott
2d224a6b67 We may only look at some of the methods available from TestCase [ci skip] 2014-12-22 03:23:23 -08:00
Zachary Scott
d6fc5af1df Better explain what test_helper.rb is designed for [ci skip] 2014-12-22 03:17:13 -08:00
Robson Marques
ebaf4e40cd Fix inaccurate docs in active_model errors [ci skip]
The default value for the argument `message` in
`ActiveModel::Errors#add` has a new behavior
since ca99ab2481d44d67bc392d0ec1125ff1439e9f94.

Before
  person.errors.add(:name, nil)
  # => ["is invalid"]

After
  person.errors.add(:name, nil)
  # => [nil]
2014-12-22 09:06:30 -02:00
Yves Senn
a407bb245b Merge pull request #18132 from rochefort/fix-typo-nodoc
Fix typo in nodoc [ci skip]
2014-12-22 09:23:35 +01:00
rochefort
2114e6bf29 Fix typo in nodoc 2014-12-22 17:14:58 +09:00
yuuji.yaginuma
1581348f28 bin/rake does not exist in plugin directory [ci skip] 2014-12-22 13:45:03 +09:00
Guillermo Iguaran
d402b15d39 Merge pull request #18129 from claudiob/remove-unused-sheep-fixture-from-action-view
Remove unused Sheep fixture from AV
2014-12-21 22:36:31 -05:00
claudiob
7375c17114 Remove unused Sheep fixture from AV
The `Sheep` fixture was added in eb23754e when moving template tests
from actionpack to actionview, but it's not actually used in ActionView tests.

The `Sheep` fixture is only used to test `uncountable` in ActiveModel tests,
and is already defined in activemodel/test/models/sheep.rb
2014-12-22 04:02:35 +01:00