Commit a07338d6ec14158b3ce4482c3b64213e600157db
1 parent
26a4d4aa
Exists in
master
and in
29 other branches
ActionItem132: adding HABTM relationship between articles and categories. Declar…
…ed only in articles by now, though. git-svn-id: https://svn.colivre.coop.br/svn/noosfero/trunk@1159 3f533792-8f58-4932-b0fe-aaf55b0a4547
Showing
3 changed files
with
34 additions
and
0 deletions
Show diff stats
app/models/article.rb
@@ -0,0 +1,14 @@ | @@ -0,0 +1,14 @@ | ||
1 | +class AddArticlesCategories < ActiveRecord::Migration | ||
2 | + def self.up | ||
3 | + create_table :articles_categories do |t| | ||
4 | + t.column :article_id, :integer | ||
5 | + t.column :category_id, :integer | ||
6 | + end | ||
7 | + add_index(:articles_categories, :article_id) | ||
8 | + add_index(:articles_categories, :category_id) | ||
9 | + end | ||
10 | + | ||
11 | + def self.down | ||
12 | + drop_table :articles_categories | ||
13 | + end | ||
14 | +end |
test/unit/article_test.rb
@@ -171,4 +171,22 @@ class ArticleTest < Test::Unit::TestCase | @@ -171,4 +171,22 @@ class ArticleTest < Test::Unit::TestCase | ||
171 | assert_equal(profile.url + "/myarticle", article.url) | 171 | assert_equal(profile.url + "/myarticle", article.url) |
172 | end | 172 | end |
173 | 173 | ||
174 | + should 'associate with categories' do | ||
175 | + env = Environment.default | ||
176 | + c1 = env.categories.build(:name => "test category 1"); c1.save! | ||
177 | + c2 = env.categories.build(:name => "test category 2"); c2.save! | ||
178 | + | ||
179 | + article = profile.articles.build(:name => 'withcategories') | ||
180 | + article.save! | ||
181 | + | ||
182 | + assert_raise ActiveRecord::AssociationTypeMismatch do | ||
183 | + article.categories << 1 | ||
184 | + end | ||
185 | + | ||
186 | + assert_nothing_raised do | ||
187 | + article.categories << c1 | ||
188 | + article.categories << c2 | ||
189 | + end | ||
190 | + end | ||
191 | + | ||
174 | end | 192 | end |