ninoxe 1.1.4 → 1.1.5

Sign up to get free protection for your applications and to get access to all the features.
Files changed (74) hide show
  1. checksums.yaml +5 -13
  2. data/app/models/chouette/footnote.rb +7 -0
  3. data/app/models/chouette/line.rb +6 -1
  4. data/app/models/chouette/vehicle_journey.rb +7 -4
  5. data/db/migrate/20150115153453_create_footnotes.rb +11 -0
  6. data/db/migrate/20150119160029_create_vehicle_journey_footnotes.rb +8 -0
  7. data/lib/factories/chouette_footnotes.rb +6 -0
  8. data/lib/ninoxe/version.rb +1 -1
  9. data/spec/dummy/README.rdoc +261 -0
  10. data/spec/dummy/Rakefile +6 -0
  11. data/spec/dummy/app/assets/javascripts/application.js +15 -0
  12. data/spec/dummy/app/assets/stylesheets/application.css +13 -0
  13. data/spec/dummy/app/controllers/application_controller.rb +3 -0
  14. data/spec/dummy/app/helpers/application_helper.rb +2 -0
  15. data/spec/dummy/app/mailers/.gitkeep +0 -0
  16. data/spec/dummy/app/models/.gitkeep +0 -0
  17. data/spec/dummy/app/views/layouts/application.html.erb +14 -0
  18. data/spec/dummy/config/application.rb +56 -0
  19. data/spec/dummy/config/boot.rb +10 -0
  20. data/{config/database.yml.me → spec/dummy/config/database.yml} +2 -2
  21. data/spec/dummy/config/environment.rb +7 -0
  22. data/spec/dummy/config/environments/development.rb +37 -0
  23. data/spec/dummy/config/environments/production.rb +67 -0
  24. data/spec/dummy/config/environments/test.rb +37 -0
  25. data/spec/dummy/config/initializers/active_record.rb +2 -0
  26. data/spec/dummy/config/initializers/backtrace_silencers.rb +7 -0
  27. data/spec/dummy/config/initializers/inflections.rb +15 -0
  28. data/spec/dummy/config/initializers/mime_types.rb +5 -0
  29. data/spec/dummy/config/initializers/secret_token.rb +7 -0
  30. data/spec/dummy/config/initializers/session_store.rb +8 -0
  31. data/spec/dummy/config/initializers/wrap_parameters.rb +14 -0
  32. data/spec/dummy/config/locales/en.yml +5 -0
  33. data/spec/dummy/config/routes.rb +4 -0
  34. data/spec/dummy/config.ru +4 -0
  35. data/spec/dummy/db/schema.rb +485 -0
  36. data/spec/dummy/db/test.sqlite3 +0 -0
  37. data/spec/dummy/lib/assets/.gitkeep +0 -0
  38. data/spec/dummy/log/.gitkeep +0 -0
  39. data/spec/dummy/public/404.html +26 -0
  40. data/spec/dummy/public/422.html +26 -0
  41. data/spec/dummy/public/500.html +25 -0
  42. data/spec/dummy/public/favicon.ico +0 -0
  43. data/spec/dummy/script/rails +6 -0
  44. data/spec/models/chouette/access_link_spec.rb +78 -0
  45. data/spec/models/chouette/access_point_spec.rb +266 -0
  46. data/spec/models/chouette/active_record_spec.rb +121 -0
  47. data/spec/models/chouette/area_type_spec.rb +53 -0
  48. data/spec/models/chouette/company_spec.rb +51 -0
  49. data/spec/models/chouette/connection_link_spec.rb +56 -0
  50. data/spec/models/chouette/direction_spec.rb +60 -0
  51. data/spec/models/chouette/exporter_spec.rb +28 -0
  52. data/spec/models/chouette/file_validator_spec.rb +28 -0
  53. data/spec/models/chouette/footnote_spec.rb +9 -0
  54. data/spec/models/chouette/group_of_line_spec.rb +31 -0
  55. data/spec/models/chouette/journey_pattern_spec.rb +62 -0
  56. data/spec/models/chouette/line_spec.rb +119 -0
  57. data/spec/models/chouette/loader_spec.rb +69 -0
  58. data/spec/models/chouette/network_spec.rb +22 -0
  59. data/spec/models/chouette/object_id_spec.rb +146 -0
  60. data/spec/models/chouette/route_spec.rb +234 -0
  61. data/spec/models/chouette/stop_area_spec.rb +440 -0
  62. data/spec/models/chouette/stop_point_spec.rb +38 -0
  63. data/spec/models/chouette/time_table_period_spec.rb +66 -0
  64. data/spec/models/chouette/time_table_spec.rb +1218 -0
  65. data/spec/models/chouette/transport_mode_spec.rb +64 -0
  66. data/spec/models/chouette/trident_active_record_spec.rb +115 -0
  67. data/spec/models/chouette/vehicle_journey_at_stop_spec.rb +46 -0
  68. data/spec/models/chouette/vehicle_journey_spec.rb +223 -0
  69. data/spec/presenters/chouette/geometry/general_presenter.rb +1 -0
  70. data/spec/presenters/chouette/geometry/line_presenter_spec.rb +13 -0
  71. data/spec/spec_helper.rb +45 -0
  72. metadata +160 -33
  73. data/app/models/chouette/time_table_vehicle_journey.rb +0 -5
  74. data/lib/ninoxe.rb~ +0 -7
@@ -0,0 +1,64 @@
1
+ require 'spec_helper'
2
+
3
+ describe Chouette::TransportMode do
4
+
5
+ def mode(text_code = "test", numerical_code = nil)
6
+ numerical_code ||= 1 if text_code == "test"
7
+ Chouette::TransportMode.new(text_code, numerical_code)
8
+ end
9
+
10
+ describe "#to_i" do
11
+
12
+ it "should return numerical code" do
13
+ mode("test", 1).to_i.should == 1
14
+ end
15
+
16
+ end
17
+
18
+ it "should return true to #test? when text code is 'test'" do
19
+ mode("test").should be_test
20
+ end
21
+
22
+ it "should be equal when text codes are identical" do
23
+ mode("test",1).should == mode("test", 2)
24
+ end
25
+
26
+ describe ".new" do
27
+
28
+ it "should find numerical code from text code" do
29
+ mode("unknown").to_i.should == 0
30
+ end
31
+
32
+ it "should find text code from numerical code" do
33
+ mode(0).should be_unknown
34
+ end
35
+
36
+ it "should accept another mode" do
37
+ Chouette::TransportMode.new(mode("test")).should == mode("test")
38
+ end
39
+
40
+ end
41
+
42
+ describe "#public_transport?" do
43
+
44
+ it "should return false for interchange" do
45
+ mode("interchange").should_not be_public_transport
46
+ end
47
+
48
+ it "should return true for other modes" do
49
+ mode("unknown").should be_public_transport
50
+ end
51
+
52
+ end
53
+
54
+ describe ".all" do
55
+
56
+ Chouette::TransportMode.definitions.each do |text_code, numerical_code|
57
+ it "should include a TransportMode #{text_code}" do
58
+ Chouette::TransportMode.all.should include(Chouette::TransportMode.new(text_code))
59
+ end
60
+ end
61
+
62
+ end
63
+
64
+ end
@@ -0,0 +1,115 @@
1
+ require 'spec_helper'
2
+
3
+ describe Chouette::TridentActiveRecord do
4
+
5
+ it { Chouette::TridentActiveRecord.ancestors.should include(Chouette::ActiveRecord) }
6
+
7
+ subject { Factory(:time_table) }
8
+
9
+ describe "#uniq_objectid" do
10
+
11
+ it "should rebuild objectid" do
12
+ tm = Factory(:time_table)
13
+ tm.objectid = subject.objectid
14
+ tm.uniq_objectid
15
+ tm.objectid.should == subject.objectid+"_1"
16
+ end
17
+
18
+ it "should rebuild objectid" do
19
+ tm = Factory(:time_table)
20
+ tm.objectid = subject.objectid
21
+ tm.uniq_objectid
22
+ tm.save
23
+ tm = Factory(:time_table)
24
+ tm.objectid = subject.objectid
25
+ tm.uniq_objectid
26
+ tm.objectid.should == subject.objectid+"_2"
27
+ end
28
+
29
+ end
30
+
31
+ describe "#prepare_auto_columns" do
32
+
33
+ it "should left objectid" do
34
+ tm = Chouette::TimeTable.new :comment => "merge1" , :objectid => "NINOXE:Timetable:merge1"
35
+ tm.prepare_auto_columns
36
+ tm.objectid.should == "NINOXE:Timetable:merge1"
37
+ end
38
+
39
+ it "should add pending_id to objectid" do
40
+ tm = Chouette::TimeTable.new :comment => "merge1"
41
+ tm.prepare_auto_columns
42
+ tm.objectid.start_with?("NINOXE:Timetable:__pending_id__").should be_true
43
+ end
44
+
45
+ it "should set id to objectid" do
46
+ tm = Chouette::TimeTable.new :comment => "merge1"
47
+ tm.save
48
+ tm.objectid.should == "NINOXE:Timetable:"+tm.id.to_s
49
+ end
50
+
51
+ it "should detect objectid conflicts" do
52
+ tm = Chouette::TimeTable.new :comment => "merge1"
53
+ tm.save
54
+ tm.objectid = "NINOXE:Timetable:"+(tm.id+1).to_s
55
+ tm.save
56
+ tm = Chouette::TimeTable.new :comment => "merge1"
57
+ tm.save
58
+ tm.objectid.should == "NINOXE:Timetable:"+tm.id.to_s+"_1"
59
+ end
60
+
61
+ end
62
+
63
+ describe "objectid" do
64
+
65
+ it "should build automatic objectid when empty" do
66
+ g1 = Chouette::GroupOfLine.new( :name => "g1")
67
+ g1.save
68
+ g1.objectid.should == "NINOXE:GroupOfLine:"+g1.id.to_s
69
+ end
70
+
71
+ it "should build automatic objectid with fixed when only suffix given" do
72
+ g1 = Chouette::GroupOfLine.new( :name => "g1")
73
+ g1.objectid = "toto"
74
+ g1.save
75
+ g1.objectid.should == "NINOXE:GroupOfLine:toto"
76
+ end
77
+
78
+ it "should build automatic objectid with extension when already exists" do
79
+ g1 = Chouette::GroupOfLine.new( :name => "g1")
80
+ g1.save
81
+ cnt = g1.id + 1
82
+ g1.objectid = "NINOXE:GroupOfLine:"+cnt.to_s
83
+ g1.save
84
+ g2 = Chouette::GroupOfLine.new( :name => "g2")
85
+ g2.save
86
+ g2.objectid.should == "NINOXE:GroupOfLine:"+g2.id.to_s+"_1"
87
+ end
88
+
89
+ it "should build automatic objectid with extension when already exists" do
90
+ g1 = Chouette::GroupOfLine.new( :name => "g1")
91
+ g1.save
92
+ cnt = g1.id + 2
93
+ g1.objectid = "NINOXE:GroupOfLine:"+cnt.to_s
94
+ g1.save
95
+ g2 = Chouette::GroupOfLine.new( :name => "g2")
96
+ g2.objectid = "NINOXE:GroupOfLine:"+cnt.to_s+"_1"
97
+ g2.save
98
+ g3 = Chouette::GroupOfLine.new( :name => "g3")
99
+ g3.save
100
+ g3.objectid.should == "NINOXE:GroupOfLine:"+g3.id.to_s+"_2"
101
+ end
102
+
103
+ it "should build automatic objectid when id cleared" do
104
+ g1 = Chouette::GroupOfLine.new( :name => "g1")
105
+ g1.objectid = "NINOXE:GroupOfLine:xxxx"
106
+ g1.save
107
+ g1.objectid = nil
108
+ g1.save
109
+ g1.objectid.should == "NINOXE:GroupOfLine:"+g1.id.to_s
110
+ end
111
+ end
112
+
113
+ end
114
+
115
+
@@ -0,0 +1,46 @@
1
+ require 'spec_helper'
2
+
3
+ describe Chouette::VehicleJourneyAtStop do
4
+ let!(:vehicle_journey){ Factory(:vehicle_journey_odd)}
5
+ subject { vehicle_journey.vehicle_journey_at_stops.first }
6
+
7
+ describe "#exceeds_gap?" do
8
+ it "should return false if gap < 1.hour" do
9
+ t1 = 1.minutes.ago
10
+ t2 = 1.minutes.ago + 3.hour
11
+ subject.exceeds_gap?(t1, t2).should be_true
12
+ end
13
+ it "should return false if gap > 2.hour" do
14
+ t1 = 1.minutes.ago
15
+ t2 = 1.minutes.ago + 3.minutes
16
+ subject.exceeds_gap?(t1, t2).should be_false
17
+ end
18
+ end
19
+
20
+ describe "#increasing_times_validate" do
21
+ let(:vjas1){ vehicle_journey.vehicle_journey_at_stops[0]}
22
+ let(:vjas2){ vehicle_journey.vehicle_journey_at_stops[1]}
23
+ context "when vjas#arrival_time exceeds gap" do
24
+ it "should add errors on arrival_time" do
25
+ vjas1.arrival_time = vjas2.arrival_time - 3.hour
26
+ vjas2.increasing_times_validate(vjas1).should be_false
27
+ vjas2.errors.should_not be_empty
28
+ vjas2.errors[:arrival_time].should_not be_blank
29
+ end
30
+ end
31
+ context "when vjas#departure_time exceeds gap" do
32
+ it "should add errors on departure_time" do
33
+ vjas1.departure_time = vjas2.departure_time - 3.hour
34
+ vjas2.increasing_times_validate(vjas1).should be_false
35
+ vjas2.errors.should_not be_empty
36
+ vjas2.errors[:departure_time].should_not be_blank
37
+ end
38
+ end
39
+ context "when vjas does'nt exceed gap" do
40
+ it "should not add errors" do
41
+ vjas2.increasing_times_validate(vjas1).should be_true
42
+ vjas2.errors.should be_empty
43
+ end
44
+ end
45
+ end
46
+ end
@@ -0,0 +1,223 @@
1
+ require 'spec_helper'
2
+
3
+ describe Chouette::VehicleJourney do
4
+ subject { Factory(:vehicle_journey_odd) }
5
+
6
+ describe "in_relation_to_a_journey_pattern methods" do
7
+ let!(:route) { Factory(:route)}
8
+ let!(:journey_pattern) { Factory(:journey_pattern, :route => route)}
9
+ let!(:journey_pattern_odd) { Factory(:journey_pattern_odd, :route => route)}
10
+ let!(:journey_pattern_even) { Factory(:journey_pattern_even, :route => route)}
11
+
12
+ context "when vehicle_journey is on odd stop whereas selected journey_pattern is on all stops" do
13
+ subject { Factory(:vehicle_journey, :route => route, :journey_pattern => journey_pattern_odd)}
14
+ describe "#extra_stops_in_relation_to_a_journey_pattern" do
15
+ it "should be empty" do
16
+ subject.extra_stops_in_relation_to_a_journey_pattern( journey_pattern).should be_empty
17
+ end
18
+ end
19
+ describe "#extra_vjas_in_relation_to_a_journey_pattern" do
20
+ it "should be empty" do
21
+ subject.extra_vjas_in_relation_to_a_journey_pattern( journey_pattern).should be_empty
22
+ end
23
+ end
24
+ describe "#missing_stops_in_relation_to_a_journey_pattern" do
25
+ it "should return even stops" do
26
+ result = subject.missing_stops_in_relation_to_a_journey_pattern( journey_pattern)
27
+ result.should == journey_pattern_even.stop_points
28
+ end
29
+ end
30
+ describe "#update_journey_pattern" do
31
+ it "should new_record for added vjas" do
32
+ subject.update_journey_pattern( journey_pattern)
33
+ subject.vehicle_journey_at_stops.select{ |vjas| vjas.new_record? }.each do |vjas|
34
+ journey_pattern_even.stop_points.should include( vjas.stop_point)
35
+ end
36
+ end
37
+ it "should add vjas on each even stops" do
38
+ subject.update_journey_pattern( journey_pattern)
39
+ vehicle_stops = subject.vehicle_journey_at_stops.map(&:stop_point)
40
+ journey_pattern_even.stop_points.each do |sp|
41
+ vehicle_stops.should include(sp)
42
+ end
43
+ end
44
+ it "should not mark any vjas as _destroy" do
45
+ subject.update_journey_pattern( journey_pattern)
46
+ subject.vehicle_journey_at_stops.any?{ |vjas| vjas._destroy }.should be_false
47
+ end
48
+ end
49
+ end
50
+ context "when vehicle_journey is on all stops whereas selected journey_pattern is on odd stops" do
51
+ subject { Factory(:vehicle_journey, :route => route, :journey_pattern => journey_pattern)}
52
+ describe "#missing_stops_in_relation_to_a_journey_pattern" do
53
+ it "should be empty" do
54
+ subject.missing_stops_in_relation_to_a_journey_pattern( journey_pattern_odd).should be_empty
55
+ end
56
+ end
57
+ describe "#extra_stops_in_relation_to_a_journey_pattern" do
58
+ it "should return even stops" do
59
+ result = subject.extra_stops_in_relation_to_a_journey_pattern( journey_pattern_odd)
60
+ result.should == journey_pattern_even.stop_points
61
+ end
62
+ end
63
+ describe "#extra_vjas_in_relation_to_a_journey_pattern" do
64
+ it "should return vjas on even stops" do
65
+ result = subject.extra_vjas_in_relation_to_a_journey_pattern( journey_pattern_odd)
66
+ result.map(&:stop_point).should == journey_pattern_even.stop_points
67
+ end
68
+ end
69
+ describe "#update_journey_pattern" do
70
+ it "should add no new vjas" do
71
+ subject.update_journey_pattern( journey_pattern_odd)
72
+ subject.vehicle_journey_at_stops.any?{ |vjas| vjas.new_record? }.should be_false
73
+ end
74
+ it "should mark vehicle_journey_at_stops as _destroy on even stops" do
75
+ subject.update_journey_pattern( journey_pattern_odd)
76
+ subject.vehicle_journey_at_stops.each { |vjas|
77
+ vjas._destroy.should == journey_pattern_even.stop_points.include?(vjas.stop_point)
78
+ }
79
+ end
80
+ end
81
+ end
82
+
83
+ end
84
+ context "when following departure times exceeds gap" do
85
+ describe "#increasing_times" do
86
+ before(:each) do
87
+ subject.vehicle_journey_at_stops[0].departure_time = subject.vehicle_journey_at_stops[1].departure_time - 2.hour
88
+ subject.vehicle_journey_at_stops[0].arrival_time = subject.vehicle_journey_at_stops[0].departure_time
89
+ subject.vehicle_journey_at_stops[1].arrival_time = subject.vehicle_journey_at_stops[1].departure_time
90
+ end
91
+ it "should make instance invalid" do
92
+ subject.increasing_times
93
+ subject.vehicle_journey_at_stops[1].errors[:departure_time].should_not be_blank
94
+ subject.should_not be_valid
95
+ end
96
+ end
97
+ describe "#update_attributes" do
98
+ let!(:params){ {"vehicle_journey_at_stops_attributes" => {
99
+ "0"=>{"id" => subject.vehicle_journey_at_stops[0].id ,"arrival_time" => 1.minutes.ago,"departure_time" => 1.minutes.ago},
100
+ "1"=>{"id" => subject.vehicle_journey_at_stops[1].id, "arrival_time" => (1.minutes.ago + 2.hour),"departure_time" => (1.minutes.ago + 2.hour)}
101
+ }}}
102
+ it "should return false" do
103
+ subject.update_attributes(params).should be_false
104
+ end
105
+ it "should make instance invalid" do
106
+ subject.update_attributes(params)
107
+ subject.should_not be_valid
108
+ end
109
+ it "should let first vjas without any errors" do
110
+ subject.update_attributes(params)
111
+ subject.vehicle_journey_at_stops[0].errors.should be_empty
112
+ end
113
+ it "should add an error on second vjas" do
114
+ subject.update_attributes(params)
115
+ subject.vehicle_journey_at_stops[1].errors[:departure_time].should_not be_blank
116
+ end
117
+ end
118
+ end
119
+
120
+ context "#time_table_tokens=" do
121
+ let!(:tm1){Factory(:time_table, :comment => "TM1")}
122
+ let!(:tm2){Factory(:time_table, :comment => "TM2")}
123
+
124
+ it "should return associated time table ids" do
125
+ subject.update_attributes :time_table_tokens => [tm1.id, tm2.id].join(',')
126
+ subject.time_tables.should include( tm1)
127
+ subject.time_tables.should include( tm2)
128
+ end
129
+ end
130
+ describe "#bounding_dates" do
131
+ before(:each) do
132
+ tm1 = Factory.build(:time_table, :dates =>
133
+ [ Factory.build(:time_table_date, :date => 1.days.ago.to_date, :in_out => true),
134
+ Factory.build(:time_table_date, :date => 2.days.ago.to_date, :in_out => true)])
135
+ tm2 = Factory.build(:time_table, :periods =>
136
+ [ Factory.build(:time_table_period, :period_start => 4.days.ago.to_date, :period_end => 3.days.ago.to_date)])
137
+ tm3 = Factory.build(:time_table)
138
+ subject.time_tables = [ tm1, tm2, tm3]
139
+ end
140
+ it "should return min date from associated calendars" do
141
+ subject.bounding_dates.min.should == 4.days.ago.to_date
142
+ end
143
+ it "should return max date from associated calendars" do
144
+ subject.bounding_dates.max.should == 1.days.ago.to_date
145
+ end
146
+ end
147
+ context "#vehicle_journey_at_stops" do
148
+ it "should be ordered like stop_points on route" do
149
+ route = subject.route
150
+ vj_stop_ids = subject.vehicle_journey_at_stops.map(&:stop_point_id)
151
+ expected_order = route.stop_points.map(&:id).select {|s_id| vj_stop_ids.include?(s_id)}
152
+
153
+ vj_stop_ids.should == expected_order
154
+ end
155
+
156
+ end
157
+
158
+ describe "#transport_mode_name" do
159
+
160
+ def self.legacy_transport_modes
161
+ %w{Air Train LongDistanceTrain LocalTrain RapidTransit Metro Tramway Coach Bus Ferry Waterborne PrivateVehicle Walk Trolleybus Bicycle Shuttle Taxi VAL Other}
162
+ end
163
+
164
+ legacy_transport_modes.each do |transport_mode|
165
+ context "when transport_mode is #{transport_mode}" do
166
+ transport_mode_name = Chouette::TransportMode.new(transport_mode.underscore)
167
+ it "should be #{transport_mode_name}" do
168
+ subject.transport_mode = transport_mode
169
+ subject.transport_mode_name.should == transport_mode_name
170
+ end
171
+ end
172
+ end
173
+ context "when transport_mode is nil" do
174
+ it "should be nil" do
175
+ subject.transport_mode = nil
176
+ subject.transport_mode_name.should be_nil
177
+ end
178
+ end
179
+
180
+ end
181
+
182
+ describe "#transport_mode_name=" do
183
+
184
+ it "should change transport_mode with TransportMode#name" do
185
+ subject.transport_mode_name = "Test"
186
+ subject.transport_mode.should == "Test"
187
+ end
188
+
189
+ end
190
+
191
+ describe ".transport_mode_names" do
192
+
193
+ it "should not include unknown transport_mode_name" do
194
+ Chouette::VehicleJourney.transport_mode_names.should_not include(Chouette::TransportMode.new("unknown"))
195
+ end
196
+
197
+ it "should not include interchange transport_mode" do
198
+ Chouette::VehicleJourney.transport_mode_names.should_not include(Chouette::TransportMode.new("interchange"))
199
+ end
200
+
201
+ end
202
+
203
+ describe "#footnote_ids=" do
204
+ context "when line have footnotes, " do
205
+ let!( :route) { Factory( :route ) }
206
+ let!( :line) { route.line }
207
+ let!( :footnote_first) {Factory( :footnote, :code => "1", :label => "dummy 1", :line => route.line)}
208
+ let!( :footnote_second) {Factory( :footnote, :code => "2", :label => "dummy 2", :line => route.line)}
209
+
210
+
211
+ it "should update vehicle's footnotes" do
212
+ Chouette::VehicleJourney.find(subject.id).footnotes.should be_empty
213
+ subject.footnote_ids = [ footnote_first.id ]
214
+ subject.save
215
+ Chouette::VehicleJourney.find(subject.id).footnotes.count.should == 1
216
+ end
217
+
218
+ end
219
+
220
+ end
221
+
222
+ end
223
+
@@ -0,0 +1,13 @@
1
+ require 'spec_helper'
2
+
3
+ describe Chouette::Geometry::LinePresenter do
4
+ let!(:line) { Factory(:line_with_stop_areas_having_parent) }
5
+ subject { Chouette::Geometry::LinePresenter.new(line)}
6
+
7
+ describe "#routes_localized_commercials" do
8
+ it "should return 3 stop_areas" do
9
+ subject.routes_localized_commercials(line.routes.first).size.should == 5
10
+ end
11
+ end
12
+ end
13
+
@@ -0,0 +1,45 @@
1
+ # Configure Rails Envinronment
2
+ ENV["RAILS_ENV"] = "test"
3
+ require File.expand_path("../dummy/config/environment.rb", __FILE__)
4
+
5
+ require 'rspec/rails'
6
+ require 'rspec/autorun'
7
+
8
+ require 'shoulda-matchers'
9
+ require 'factory_girl_rails'
10
+
11
+ require 'geo_ruby'
12
+
13
+ ENGINE_RAILS_ROOT=File.join(File.dirname(__FILE__), '../')
14
+
15
+ # Requires supporting ruby files with custom matchers and macros, etc,
16
+ # in spec/support/ and its subdirectories.
17
+ Dir[File.join(ENGINE_RAILS_ROOT, "spec/support/**/*.rb")].each {|f| require f }
18
+ Dir[File.join(ENGINE_RAILS_ROOT, "lib/factories/**/*.rb")].each {|f| require f }
19
+
20
+ RSpec.configure do |config|
21
+ # == Mock Framework
22
+ #
23
+ # If you prefer to use mocha, flexmock or RR, uncomment the appropriate line:
24
+ #
25
+ # config.mock_with :mocha
26
+ # config.mock_with :flexmock
27
+ # config.mock_with :rr
28
+ config.mock_with :rspec
29
+
30
+ # Remove this line if you're not using ActiveRecord or ActiveRecord fixtures
31
+ config.fixture_path = "#{::Rails.root}/spec/fixtures"
32
+
33
+ # If you're not using ActiveRecord, or you'd prefer not to run each of your
34
+ # examples within a transaction, remove the following line or assign false
35
+ # instead of true.
36
+ config.use_transactional_fixtures = true
37
+
38
+ # If true, the base class of anonymous controllers will be inferred
39
+ # automatically. This will be the default behavior in future versions of
40
+ # rspec-rails.
41
+ config.infer_base_class_for_anonymous_controllers = false
42
+
43
+ end
44
+
45
+