aboutsummaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
-rw-r--r--activerecord/lib/active_record/associations/has_and_belongs_to_many_association.rb6
-rwxr-xr-xactiverecord/test/associations_test.rb20
-rw-r--r--activerecord/test/fixtures/db_definitions/db2.sql3
-rwxr-xr-xactiverecord/test/fixtures/db_definitions/mysql.sql3
-rw-r--r--activerecord/test/fixtures/db_definitions/oci.sql3
-rw-r--r--activerecord/test/fixtures/db_definitions/postgresql.sql3
-rw-r--r--activerecord/test/fixtures/db_definitions/sqlite.sql3
-rw-r--r--activerecord/test/fixtures/db_definitions/sqlserver.sql3
8 files changed, 36 insertions, 8 deletions
diff --git a/activerecord/lib/active_record/associations/has_and_belongs_to_many_association.rb b/activerecord/lib/active_record/associations/has_and_belongs_to_many_association.rb
index 9183445d74..107f3ef12c 100644
--- a/activerecord/lib/active_record/associations/has_and_belongs_to_many_association.rb
+++ b/activerecord/lib/active_record/associations/has_and_belongs_to_many_association.rb
@@ -122,8 +122,10 @@ module ActiveRecord
when @association_foreign_key
attributes[column.name] = record.quoted_id
else
- value = @owner.send(:quote, record[column.name], column)
- attributes[column.name] = value unless value.nil?
+ if record.attributes.has_key?(column.name)
+ value = @owner.send(:quote, record[column.name], column)
+ attributes[column.name] = value unless value.nil?
+ end
end
attributes
end
diff --git a/activerecord/test/associations_test.rb b/activerecord/test/associations_test.rb
index 25b5457051..f922359d0a 100755
--- a/activerecord/test/associations_test.rb
+++ b/activerecord/test/associations_test.rb
@@ -883,6 +883,26 @@ class HasAndBelongsToManyAssociationsTest < Test::Unit::TestCase
assert_equal 2, aredridel.projects(true).size
end
+ def test_adding_uses_default_values_on_join_table
+ ac = projects(:action_controller)
+ assert !developers(:jamis).projects.include?(ac)
+ developers(:jamis).projects << ac
+
+ assert developers(:jamis, :reload).projects.include?(ac)
+ project = developers(:jamis).projects.detect { |p| p == ac }
+ assert_equal 1, project.access_level.to_i
+ end
+
+ def test_adding_uses_explicit_values_on_join_table
+ ac = projects(:action_controller)
+ assert !developers(:jamis).projects.include?(ac)
+ developers(:jamis).projects.push_with_attributes(ac, :access_level => 3)
+
+ assert developers(:jamis, :reload).projects.include?(ac)
+ project = developers(:jamis).projects.detect { |p| p == ac }
+ assert_equal 3, project.access_level.to_i
+ end
+
def test_habtm_adding_before_save
no_of_devels = Developer.count
no_of_projects = Project.count
diff --git a/activerecord/test/fixtures/db_definitions/db2.sql b/activerecord/test/fixtures/db_definitions/db2.sql
index 90f57a0c08..5977dc4bb2 100644
--- a/activerecord/test/fixtures/db_definitions/db2.sql
+++ b/activerecord/test/fixtures/db_definitions/db2.sql
@@ -51,7 +51,8 @@ CREATE TABLE projects (
CREATE TABLE developers_projects (
developer_id int NOT NULL,
project_id int NOT NULL,
- joined_on date default NULL
+ joined_on date default NULL,
+ access_level smallint default 1
);
CREATE TABLE customers (
diff --git a/activerecord/test/fixtures/db_definitions/mysql.sql b/activerecord/test/fixtures/db_definitions/mysql.sql
index d1d65194cb..1400f1608b 100755
--- a/activerecord/test/fixtures/db_definitions/mysql.sql
+++ b/activerecord/test/fixtures/db_definitions/mysql.sql
@@ -52,7 +52,8 @@ CREATE TABLE `projects` (
CREATE TABLE `developers_projects` (
`developer_id` int(11) NOT NULL,
`project_id` int(11) NOT NULL,
- `joined_on` date default NULL
+ `joined_on` date default NULL,
+ `access_level` smallint default 1
) TYPE=InnoDB;
CREATE TABLE `customers` (
diff --git a/activerecord/test/fixtures/db_definitions/oci.sql b/activerecord/test/fixtures/db_definitions/oci.sql
index 43a54df604..0923651dfc 100644
--- a/activerecord/test/fixtures/db_definitions/oci.sql
+++ b/activerecord/test/fixtures/db_definitions/oci.sql
@@ -70,7 +70,8 @@ create table projects (
create table developers_projects (
developer_id integer not null references developers initially deferred disable,
project_id integer not null references projects initially deferred disable,
- joined_on timestamp default null
+ joined_on timestamp default null,
+ access_level integer default 1
);
-- Try again for 8i
create table developers_projects (
diff --git a/activerecord/test/fixtures/db_definitions/postgresql.sql b/activerecord/test/fixtures/db_definitions/postgresql.sql
index 37f3ae5f29..9d2e50132a 100644
--- a/activerecord/test/fixtures/db_definitions/postgresql.sql
+++ b/activerecord/test/fixtures/db_definitions/postgresql.sql
@@ -21,7 +21,8 @@ SELECT setval('companies_id_seq', 100);
CREATE TABLE developers_projects (
developer_id integer NOT NULL,
project_id integer NOT NULL,
- joined_on date
+ joined_on date,
+ access_level integer default 1
);
CREATE TABLE developers (
diff --git a/activerecord/test/fixtures/db_definitions/sqlite.sql b/activerecord/test/fixtures/db_definitions/sqlite.sql
index ab06d4a4d7..2ffe91324c 100644
--- a/activerecord/test/fixtures/db_definitions/sqlite.sql
+++ b/activerecord/test/fixtures/db_definitions/sqlite.sql
@@ -47,7 +47,8 @@ CREATE TABLE 'projects' (
CREATE TABLE 'developers_projects' (
'developer_id' INTEGER NOT NULL,
'project_id' INTEGER NOT NULL,
- 'joined_on' DATE DEFAULT NULL
+ 'joined_on' DATE DEFAULT NULL,
+ 'access_level' INTEGER DEFAULT 1
);
CREATE TABLE 'customers' (
diff --git a/activerecord/test/fixtures/db_definitions/sqlserver.sql b/activerecord/test/fixtures/db_definitions/sqlserver.sql
index 6a15c0cbfd..e5123ccef0 100644
--- a/activerecord/test/fixtures/db_definitions/sqlserver.sql
+++ b/activerecord/test/fixtures/db_definitions/sqlserver.sql
@@ -46,7 +46,8 @@ CREATE TABLE projects (
CREATE TABLE developers_projects (
developer_id int NOT NULL,
project_id int NOT NULL,
- joined_on datetime default NULL
+ joined_on datetime default NULL,
+ access_level int default 1
);
CREATE TABLE customers (