aboutsummaryrefslogtreecommitdiffstats
path: root/railties/CHANGELOG
blob: f560edaa15978699f7e7800bdc66c8d4a8523b47 (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
*CVS*

* 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