|
4 | 4 | require 'annotate/active_record_patch' |
5 | 5 |
|
6 | 6 | describe AnnotateModels do |
7 | | - def mock_class(table_name, primary_key, columns) |
| 7 | + def mock_foreign_key(name, from_column, to_table, to_column = 'id') |
| 8 | + double("ForeignKeyDefinition", |
| 9 | + :name => name, |
| 10 | + :column => from_column, |
| 11 | + :to_table => to_table, |
| 12 | + :primary_key => to_column, |
| 13 | + ) |
| 14 | + end |
| 15 | + |
| 16 | + def mock_connection(indexes = [], foreign_keys = []) |
| 17 | + double("Conn", |
| 18 | + :indexes => indexes, |
| 19 | + :foreign_keys => foreign_keys, |
| 20 | + ) |
| 21 | + end |
| 22 | + |
| 23 | + def mock_class(table_name, primary_key, columns, foreign_keys = []) |
8 | 24 | options = { |
9 | | - :connection => double("Conn", :indexes => []), |
10 | | - :table_name => table_name, |
11 | | - :primary_key => primary_key, |
12 | | - :column_names => columns.map { |col| col.name.to_s }, |
13 | | - :columns => columns, |
14 | | - :column_defaults => Hash[columns.map { |col| |
15 | | - [col.name, col.default] |
| 25 | + :connection => mock_connection([], foreign_keys), |
| 26 | + :table_exists? => true, |
| 27 | + :table_name => table_name, |
| 28 | + :primary_key => primary_key, |
| 29 | + :column_names => columns.map { |col| col.name.to_s }, |
| 30 | + :columns => columns, |
| 31 | + :column_defaults => Hash[columns.map { |col| |
| 32 | + [col.name, col.default] |
16 | 33 | }] |
17 | 34 | } |
18 | 35 |
|
@@ -127,6 +144,33 @@ def mock_column(name, type, options={}) |
127 | 144 | EOS |
128 | 145 | end |
129 | 146 |
|
| 147 | + it "should get foreign key info" do |
| 148 | + klass = mock_class(:users, :id, [ |
| 149 | + mock_column(:id, :integer), |
| 150 | + mock_column(:foreign_thing_id, :integer), |
| 151 | + ], |
| 152 | + [ |
| 153 | + mock_foreign_key( |
| 154 | + 'fk_rails_02e851e3b7', |
| 155 | + 'foreign_thing_id', |
| 156 | + 'foreign_things' |
| 157 | + ) |
| 158 | + ]) |
| 159 | + expect(AnnotateModels.get_schema_info(klass, "Schema Info", :show_foreign_keys => true)).to eql(<<-EOS) |
| 160 | +# Schema Info |
| 161 | +# |
| 162 | +# Table name: users |
| 163 | +# |
| 164 | +# id :integer not null, primary key |
| 165 | +# foreign_thing_id :integer not null |
| 166 | +# |
| 167 | +# Foreign Keys |
| 168 | +# |
| 169 | +# fk_rails_02e851e3b7 (foreign_thing_id => foreign_things.id) |
| 170 | +# |
| 171 | +EOS |
| 172 | + end |
| 173 | + |
130 | 174 | it "should get schema info as RDoc" do |
131 | 175 | klass = mock_class(:users, :id, [ |
132 | 176 | mock_column(:id, :integer), |
|
0 commit comments