aboutsummaryrefslogtreecommitdiffstats
path: root/railties/CHANGELOG
blob: baa5494f418ef977c397297f7f8df5087fc00bd6 (plain) (blame)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
137
138
139
140
141
142
143
144
145
146
147
148
149
150
151
152
153
154
155
156
157
158
159
160
161
162
163
164
165
166
167
168
169
170
171
172
173
174
175
176
177
178
179
180
181
182
183
184
185
186
187
188
189
190
191
192
193
194
195
196
197
198
199
200
201
202
203
204
205
206
207
208
209
210
211
212
213
214
215
216
217
218
219
220
221
222
223
224
225
226
227
228
229
230
231
232
233
234
235
236
237
238
239
240
241
242
243
244
245
246
247
248
249
250
251
252
253
254
255
256
257
258
259
260
261
262
263
264
265
266
267
268
269
270
271
272
273
274
275
276
277
278
279
280
281
282
283
284
285
286
287
288
289
290
291
292
293
294
295
296
297
298
299
300
301
302
303
304
305
306
307
308
309
310
311
312
313
314
315
316
317
318
319
320
321
322
323
324
325
326
327
328
329
330
331
332
333
334
335
336
337
338
339
340
341
342
343
344
345
346
347
348
349
350
351
352
353
354
355
356
357
358
359
360
361
362
363
364
365
366
367
368
369
370
371
372
373
374
375
376
377
378
379
380
381
382
383
384
385
386
387
388
389
390
391
392
393
394
395
396
397
398
399
400
401
402
*SVN*

* Added Florian Gross' latest version of Breakpointer and friends that fixes a variaty of bugs #441 [Florian Gross]

* Fixed skeleton Rakefile to work with sqlite3 out of the box #521 [rasputnik]

* Fixed that script/breakpointer didn't get the Ruby path rewritten as the other scripts #523 [brandt@kurowski.net]

* Fixed superclass mismatch and other controller related problems by not using dependency reloading for controllers. This means that controller
  hierarchies need to explicitly require the superclass if its not ApplicationController. Example:
  
    # application.rb
    class ApplicationController < ActionController::Base
    end
  
    # base.rb
    class BaseController < ApplicationController
    end
  
    # media_controller.rb
    require_or_load 'base'
    class MediaController < BaseController
    end
  

* Fixed handling of syntax errors in models that had already been succesfully required once in the current interpreter

* Fixed that models that weren't referenced in associations weren't being reloaded in the development mode by reinstating the reload

* Fixed that generate scaffold would produce bad functional tests

* Fixed that FCGI can also display SyntaxErrors


*0.9.4.1* (January 18th, 2005)

* Added 5-second timeout to WordNet alternatives on creating reserved-word models #501 [Marcel Molina]

* Fixed binding of caller #496 [Alexey]

* Upgraded to Active Record 1.5.1, Action Pack 1.3.1, Action Mailer 0.6.1


*0.9.4* (January 17th, 2005)

* Added that ApplicationController will catch a ControllerNotFound exception if someone attempts to access a url pointing to an unexisting controller [Tobias Luetke]

* Flipped code-to-test ratio around to be more readable #468 [Scott Baron]

* Fixed log file permissions to be 666 instead of 777 (so they're not executable) #471 [Lucas Carlson]

* Fixed that auto reloading would some times not work or would reload the models twice #475 [Tobias Luetke]

* Added rewrite rules to deal with caching to public/.htaccess

* Added the option to specify a controller name to "generate scaffold" and made the default controller name the plural form of the model.

* Added that rake clone_structure_to_test, db_structure_dump, and purge_test_database tasks now pick up the source database to use from
  RAILS_ENV instead of just forcing development #424 [Tobias Luetke]

* Fixed script/console to work with Windows (that requires the use of irb.bat) #418 [octopod]

* Fixed WEBrick servlet slowdown over time by restricting the load path reloading to mod_ruby

* Removed Fancy Indexing as a default option on the WEBrick servlet as it made it harder to use various caching schemes

* Upgraded to Active Record 1.5, Action Pack 1.3, Action Mailer 0.6


*0.9.3* (January 4th, 2005)

* Added support for SQLite in the auto-dumping/importing of schemas for development -> test #416

* Added automated rewriting of the shebang lines on installs through the gem rails command #379 [Manfred Stienstra]

* Added ActionMailer::Base.deliver_method = :test to the test environment so that mail objects are available in ActionMailer::Base.deliveries
  for functional testing.

* Added protection for creating a model through the generators with a name of an existing class, like Thread or Date.
  It'll even offer you a synonym using wordnet.princeton.edu as a look-up. No, I'm not kidding :) [Florian Gross]

* Fixed dependency management to happen in a unified fashion for Active Record and Action Pack using the new Dependencies module. This means that
  the environment options needs to change from:
  
    Before in development.rb:
      ActionController::Base.reload_dependencies = true  
      ActiveRecord::Base.reload_associations     = true
    
    Now in development.rb:
      Dependencies.mechanism = :load

    Before in production.rb and test.rb:
      ActionController::Base.reload_dependencies = false
      ActiveRecord::Base.reload_associations     = false

    Now in production.rb and test.rb:
      Dependencies.mechanism = :require

* Fixed problems with dependency caching and controller hierarchies on Ruby 1.8.2 in development mode #351

* Fixed that generated action_mailers doesnt need to require the action_mailer since thats already done in the environment #382 [Lucas Carlson]

* Upgraded to Action Pack 1.2.0 and Active Record 1.4.0


*0.9.2*

* Fixed CTRL-C exists from the Breakpointer to be a clean affair without error dumping [Kent Sibilev]

* Fixed "rake stats" to work with sub-directories in models and controllers and to report the code to test ration [Scott Baron]

* Added that Active Record associations are now reloaded instead of cleared to work with the new const_missing hook in Active Record.

* Added graceful handling of an inaccessible log file by redirecting output to STDERR with a warning #330 [rainmkr]

* Added support for a -h/--help parameter in the generator #331 [Ulysses]

* Fixed that File.expand_path in config/environment.rb would fail when dealing with symlinked public directories [mjobin]

* Upgraded to Action Pack 1.1.0 and Active Record 1.3.0


*0.9.1*

* Upgraded to Action Pack 1.0.1 for important bug fix

* Updated gem dependencies


*0.9.0*

* Renamed public/dispatch.servlet to script/server -- it wasn't really dispatching anyway as its delegating calls to public/dispatch.rb

* Renamed AbstractApplicationController and abstract_application.rb to ApplicationController and application.rb, so that it will be possible
  for the framework to automatically pick up on app/views/layouts/application.rhtml and app/helpers/application.rb

* Added script/console that makes it even easier to start an IRB session for interacting with the domain model. Run with no-args to
  see help.

* Added breakpoint support through the script/breakpointer client. This means that you can break out of execution at any point in
  the code, investigate and change the model, AND then resume execution! Example:
  
    class WeblogController < ActionController::Base
      def index
        @posts = Post.find_all
        breakpoint "Breaking out from the list"
      end
    end
    
  So the controller will accept the action, run the first line, then present you with a IRB prompt in the breakpointer window. 
  Here you can do things like:
  
  Executing breakpoint "Breaking out from the list" at .../webrick_server.rb:16 in 'breakpoint'

    >> @posts.inspect
    => "[#<Post:0x14a6be8 @attributes={\"title\"=>nil, \"body\"=>nil, \"id\"=>\"1\"}>, 
         #<Post:0x14a6620 @attributes={\"title\"=>\"Rails you know!\", \"body\"=>\"Only ten..\", \"id\"=>\"2\"}>]"
    >> @posts.first.title = "hello from a breakpoint"
    => "hello from a breakpoint"

  ...and even better is that you can examine how your runtime objects actually work:

    >> f = @posts.first 
    => #<Post:0x13630c4 @attributes={"title"=>nil, "body"=>nil, "id"=>"1"}>
    >> f.
    Display all 152 possibilities? (y or n)
  
  Finally, when you're ready to resume execution, you press CTRL-D

* Changed environments to be configurable through an environment variable. By default, the environment is "development", but you
  can change that and set your own by configuring the Apache vhost with a string like (mod_env must be available on the server):
  
    SetEnv RAILS_ENV production
  
  ...if you're using WEBrick, you can pick the environment to use with the command-line parameters -e/--environment, like this:
  
    ruby public/dispatcher.servlet -e production

* Added a new default environment called "development", which leaves the production environment to be tuned exclusively for that.

* Added a start_server in the root of the Rails application to make it even easier to get started

* Fixed public/.htaccess to use RewriteBase and share the same rewrite rules for all the dispatch methods

* Fixed webrick_server to handle requests in a serialized manner (the Rails reloading infrastructure is not thread-safe)

* Added support for controllers in directories. So you can have:

    app/controllers/account_controller.rb        # URL: /account/
    app/controllers/admin/account_controller.rb  # URL: /admin/account/
  
  NOTE: You need to update your public/.htaccess with the new rules to pick it up

* Added reloading for associations and dependencies under cached environments like FastCGI and mod_ruby. This makes it possible to use 
  those environments for development. This is turned on by default, but can be turned off with 
  ActiveRecord::Base.reload_associations = false and ActionController::Base.reload_dependencies = false in production environments.

* Added support for sub-directories in app/models. So now you can have something like Basecamp with:

    app/models/accounting
    app/models/project
    app/models/participants
    app/models/settings
  
  It's poor man's namespacing, but only for file-system organization. You still require files just like before.
  Nothing changes inside the files themselves.


* Fixed a few references in the tests generated by new_mailer [bitsweat]

* Added support for mocks in testing with test/mocks

* Cleaned up the environments a bit and added global constant RAILS_ROOT


*0.8.5* (9)

* Made dev-util available to all tests, so you can insert breakpoints in any test case to get an IRB prompt at that point [bitsweat]:

    def test_complex_stuff
      @david.projects << @new_project
      breakpoint "Let's have a closer look at @david"
    end
  
  You need to install dev-utils yourself for this to work ("gem install dev-util").

* Added shared generator behavior so future upgrades should be possible without manually copying over files [bitsweat]

* Added the new helper style to both controller and helper templates [bitsweat]

* Added new_crud generator for creating a model and controller at the same time with explicit scaffolding [bitsweat]

* Added configuration of Test::Unit::TestCase.fixture_path to test_helper to concide with the new AR fixtures style

* Fixed that new_model was generating singular table/fixture names

* Upgraded to Action Mailer 0.4.0

* Upgraded to Action Pack 0.9.5

* Upgraded to Active Record 1.1.0


*0.8.0 (15)*

* Removed custom_table_name option for new_model now that the Inflector is as powerful as it is

* Changed the default rake action to just do testing and separate API generation and coding statistics into a "doc" task.

* Fixed WEBrick dispatcher to handle missing slashes in the URLs gracefully [alexey]

* Added user option for all postgresql tool calls in the rakefile [elvstone]

* Fixed problem with running "ruby public/dispatch.servlet" instead of "cd public; ruby dispatch.servlet" [alexey]

* Fixed WEBrick server so that it no longer hardcodes the ruby interpreter used to "ruby" but will get the one used based
  on the Ruby runtime configuration. [Marcel Molina Jr.]

* Fixed Dispatcher so it'll route requests to magic_beans to MagicBeansController/magic_beans_controller.rb [Caio Chassot]

* "new_controller MagicBeans" and "new_model SubscriptionPayments" will now both behave properly as they use the new Inflector.

* Fixed problem with MySQL foreign key constraint checks in Rake :clone_production_structure_to_test target [Andreas Schwarz]

* Changed WEBrick server to by default be auto-reloading, which is slower but makes source changes instant.
  Class compilation cache can be turned on with "-c" or "--cache-classes".

* Added "-b/--binding" option to WEBrick dispatcher to bind the server to a specific IP address (default: 127.0.0.1) [Kevin Temp]

* dispatch.fcgi now DOESN'T set FCGI_PURE_RUBY as it was slowing things down for now reason [Andreas Schwarz]

* Added new_mailer generator to work with Action Mailer

* Included new framework: Action Mailer 0.3

* Upgraded to Action Pack 0.9.0

* Upgraded to Active Record 1.0.0


*0.7.0*

* Added an optional second argument to the new_model script that allows the programmer to specify the table name, 
  which will used to generate a custom table_name method in the model and will also be used in the creation of fixtures.
  [Kevin Radloff]

* script/new_model now turns AccountHolder into account_holder instead of accountholder [Kevin Radloff]

* Fixed the faulty handleing of static files with WEBrick [Andreas Schwarz]

* Unified function_test_helper and unit_test_helper into test_helper

* Fixed bug with the automated production => test database dropping on PostgreSQL [dhawkins]

* create_fixtures in both the functional and unit test helper now turns off the log during fixture generation
  and can generate more than one fixture at a time. Which makes it possible for assignments like:
  
    @people, @projects, @project_access, @companies, @accounts = 
      create_fixtures "people", "projects", "project_access", "companies", "accounts"

* Upgraded to Action Pack 0.8.5 (locally-scoped variables, partials, advanced send_file)

* Upgraded to Active Record 0.9.5 (better table_name guessing, cloning, find_all_in_collection)


*0.6.5*

* No longer specifies a template for rdoc, so it'll use whatever is default (you can change it in the rakefile)

* The new_model generator will now use the same rules for plural wordings as Active Record 
  (so Category will give categories, not categorys) [Kevin Radloff]

* dispatch.fcgi now sets FCGI_PURE_RUBY to true to ensure that it's the Ruby version that's loaded [danp]

* Made the GEM work with Windows

* Fixed bug where mod_ruby would "forget" the load paths added when switching between controllers

* PostgreSQL are now supported for the automated production => test database dropping [Kevin Radloff]

* Errors thrown by the dispatcher are now properly handled in FCGI.

* Upgraded to Action Pack 0.8.0 (lots and lots and lots of fixes)

* Upgraded to Active Record 0.9.4 (a bunch of fixes)


*0.6.0*

* Added AbstractionApplicationController as a superclass for all controllers generated. This class can be used
  to carry filters and methods that are to be shared by all. It has an accompanying ApplicationHelper that all
  controllers will also automatically have available.

* Added environments that can be included from any script to get the full Active Record and Action Controller
  context running. This can be used by maintenance scripts or to interact with the model through IRB. Example:
  
    require 'config/environments/production'
    
    for account in Account.find_all
      account.recalculate_interests
    end
  
  A short migration script for an account model that had it's interest calculation strategy changed.

* Accessing the index of a controller with "/weblog" will now redirect to "/weblog/" (only on Apache, not WEBrick)

* Simplified the default Apache config so even remote requests are served off CGI as a default.
  You'll now have to do something specific to activate mod_ruby and FCGI (like using the force urls).
  This should make it easier for new comers that start on an external server.

* Added more of the necessary Apache options to .htaccess to make it easier to setup

* Upgraded to Action Pack 0.7.9 (lots of fixes)

* Upgraded to Active Record 0.9.3 (lots of fixes)


*0.5.7*

* Fixed bug in the WEBrick dispatcher that prevented it from getting parameters from the URL
  (through GET requests or otherwise)

* Added lib in root as a place to store app specific libraries

* Added lib and vendor to load_path, so anything store within can be loaded directly. 
  Hence lib/redcloth.rb can be loaded with require "redcloth"

* Upgraded to Action Pack 0.7.8 (lots of fixes)

* Upgraded to Active Record 0.9.2 (minor upgrade)


*0.5.6*

* Upgraded to Action Pack 0.7.7 (multipart form fix)

* Updated the generated template stubs to valid XHTML files

* Ensure that controllers generated are capitalized, so "new_controller TodoLists" 
  gives the same as "new_controller Todolists" and "new_controller todolists".


*0.5.5*

* Works on Windows out of the box! (Dropped symlinks)

* Added webrick dispatcher: Try "ruby public/dispatch.servlet --help" [Florian Gross]

* Report errors about initialization to browser (instead of attempting to use uninitialized logger)

* Upgraded to Action Pack 0.7.6

* Upgraded to Active Record 0.9.1

* Added distinct 500.html instead of reusing 404.html

* Added MIT license


*0.5.0*

* First public release