-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathREADME
71 lines (47 loc) · 2.89 KB
/
README
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
seeded-generation plugin by Mark W. Foster
==========================================
This plugin extends any model and scaffold generators to stub individual seeds
files that correspond to a model and its module directory structure. It also
overrides rake db:seed so that models can be individually seeded
using rake db:seed with the model name as an option. The plugin also includes
a generator that just stubs seeds files for existing models. Finally, the
plugin automatically seeds the test database when tests are run.
The db/seeds.rb file is updated when models are generated to require the individual
model seeds files so that rake db:seed executes all the required seed files. Extended
model and scaffold generators include an option --skip-seeds that blocks stubbing
a seeds file for the model and an option --seeds-only that only stubs a
seeds file for the model.
Two default seeded generators are built as part of the install:
seeded_model and seeded_scaffold.
Type script/generate seeded, script/generate seeds_for, script/seeded_model or
script/seeded_scaffold for more usage information.
Uninstalling the plugin leaves any extended generators and the db:seed
override working. To clear all plugin functionality, refer to the
notes in the ../lib/seeded_generation folder after uninstalling the plugin.
The plugin also installs functionality adapted from the plugin OverrideRakeTask
by Eugene Bolshakov found at: git://github.com/eugene bolshakov/override_rake_task.git
as forked to allow aliasing tasks at: git://github.com/markwfoster/override_rake_task.git
Example
=======
script/generate seeded my_model_generator
creates a new seeded_my_model_generator generator that can then be used just like the
my_model_generator generator it is based on in the following fashion:
script/generate seeded_my_model_generator MyModule::MyModel
creates generates all the standard model directories and stubs and includes
the stub ../db/seeds/my_module/my_model_seeds.rb and adds
require 'my_module/my_model_seeds' to the db/seeds.rb file.
script/generate seeded_my_model_generator MyModule::MyModel --skip-seeds
is just the base generator.
script/generate seeded_my_model_generator MyModule::MyModel --only-seeds
only adds the file ../db/seeds/my_module/my_model_seeds.rb and adds
require 'my_module/my_model_seeds' to the db/seeds.rb file.
This has the same functionality of the included generator seeds_for:
script/generate seeds_for MyModule::MyModel
which creates only a file db/seeds/my_module/my_model_seeds.rb and
adds a require statement to seeds.db.
rake db:seed runs all seed files required in db/seeds.rb and
any other seed code there.
rake db:seed MODELS=MyModule1::MyModel1, MyModule1::MyModel2 only loads seeds for the
specified models if they have corresponding seeds.rb files generated.
Copyright (c) 2009 Mark W. Foster, released under the MIT license
fosterinfo[z]gmail.com (replace [z] with @)