trusty-cms 4.1.5 → 4.2
Sign up to get free protection for your applications and to get access to all the features.
- checksums.yaml +4 -4
- data/Gemfile.lock +122 -115
- data/INSTALL.md +2 -0
- data/app/views/admin/assets/edit.html.haml +3 -0
- data/config/environments/development.rb +2 -0
- data/config/locales/en.yml +1 -0
- data/lib/generators/extension/USAGE +30 -0
- data/lib/generators/extension/extension_generator.rb +97 -0
- data/lib/generators/extension/templates/README.md +6 -0
- data/lib/generators/extension/templates/RSpecRakefile +109 -0
- data/lib/generators/extension/templates/Rakefile +25 -0
- data/lib/generators/extension/templates/cucumber.yml +1 -0
- data/lib/generators/extension/templates/cucumber_env.rb +11 -0
- data/lib/generators/extension/templates/cucumber_paths.rb +22 -0
- data/lib/generators/extension/templates/en.yml +3 -0
- data/lib/generators/extension/templates/extension.rb +21 -0
- data/lib/generators/extension/templates/functional_test.rb +15 -0
- data/lib/generators/extension/templates/gemspec.rb +29 -0
- data/lib/generators/extension/templates/lib.rb +8 -0
- data/lib/generators/extension/templates/migration.rb +9 -0
- data/lib/generators/extension/templates/radiant_config.rb +3 -0
- data/lib/generators/extension/templates/routes.rb +5 -0
- data/lib/generators/extension/templates/spec.opts +6 -0
- data/lib/generators/extension/templates/spec_helper.rb +42 -0
- data/lib/generators/extension/templates/tasks.rake +47 -0
- data/lib/generators/extension/templates/test_helper.rb +26 -0
- data/lib/generators/extension_controller/USAGE +36 -0
- data/lib/generators/extension_controller/extension_controller_generator.rb +84 -0
- data/lib/generators/extension_controller/templates/controller.rb +10 -0
- data/lib/generators/extension_controller/templates/controller_spec.rb +23 -0
- data/lib/generators/extension_controller/templates/functional_test.rb +11 -0
- data/lib/generators/extension_controller/templates/helper.rb +2 -0
- data/lib/generators/extension_controller/templates/helper_spec.rb +11 -0
- data/lib/generators/extension_controller/templates/helper_test.rb +4 -0
- data/lib/generators/extension_controller/templates/view.html.erb +2 -0
- data/lib/generators/extension_controller/templates/view_spec.rb +12 -0
- data/lib/generators/extension_mailer/USAGE +17 -0
- data/lib/generators/extension_mailer/extension_mailer_generator.rb +68 -0
- data/lib/generators/extension_mailer/templates/fixture.erb +3 -0
- data/lib/generators/extension_mailer/templates/mailer.rb +15 -0
- data/lib/generators/extension_mailer/templates/unit_test.rb +21 -0
- data/lib/generators/extension_mailer/templates/view.erb +3 -0
- data/lib/generators/extension_migration/USAGE +34 -0
- data/lib/generators/extension_migration/extension_migration_generator.rb +25 -0
- data/lib/generators/extension_migration/templates/migration.rb +11 -0
- data/lib/generators/extension_model/USAGE +35 -0
- data/lib/generators/extension_model/extension_model_generator.rb +68 -0
- data/lib/generators/extension_model/templates/fixtures.yml +19 -0
- data/lib/generators/extension_model/templates/migration.rb +16 -0
- data/lib/generators/extension_model/templates/model.rb +2 -0
- data/lib/generators/extension_model/templates/model_spec.rb +11 -0
- data/lib/generators/extension_model/templates/unit_test.rb +8 -0
- data/lib/generators/generator_base_extension.rb +18 -0
- data/lib/generators/instance/instance_generator.rb +148 -0
- data/lib/generators/instance/templates/databases/db2.yml +40 -0
- data/lib/generators/instance/templates/databases/mysql.yml +47 -0
- data/lib/generators/instance/templates/databases/postgresql.yml +44 -0
- data/lib/generators/instance/templates/databases/sqlite3.yml +16 -0
- data/lib/generators/instance/templates/databases/sqlserver.yml +21 -0
- data/lib/generators/instance/templates/instance_boot.rb +122 -0
- data/lib/generators/instance/templates/instance_config.ru +2 -0
- data/lib/generators/instance/templates/instance_environment.rb +93 -0
- data/lib/generators/instance/templates/instance_gemfile +78 -0
- data/lib/generators/instance/templates/instance_generate +6 -0
- data/lib/generators/instance/templates/instance_radiant_config.rb +16 -0
- data/lib/generators/instance/templates/instance_rakefile +3 -0
- data/lib/generators/instance/templates/instance_routes.rb +1 -0
- data/lib/generators/language_extension/USAGE +27 -0
- data/lib/generators/language_extension/language_extension_generator.rb +71 -0
- data/lib/generators/language_extension/templates/README +3 -0
- data/lib/generators/language_extension/templates/RSpecRakefile +123 -0
- data/lib/generators/language_extension/templates/Rakefile +25 -0
- data/lib/generators/language_extension/templates/available_tags.yml +553 -0
- data/lib/generators/language_extension/templates/cucumber.yml +1 -0
- data/lib/generators/language_extension/templates/cucumber_env.rb +16 -0
- data/lib/generators/language_extension/templates/cucumber_paths.rb +14 -0
- data/lib/generators/language_extension/templates/extension.rb +12 -0
- data/lib/generators/language_extension/templates/functional_test.rb +15 -0
- data/lib/generators/language_extension/templates/gemspec.rb +24 -0
- data/lib/generators/language_extension/templates/lang.yml +181 -0
- data/lib/generators/language_extension/templates/lib.rb +8 -0
- data/lib/generators/language_extension/templates/spec.opts +6 -0
- data/lib/generators/language_extension/templates/spec_helper.rb +36 -0
- data/lib/generators/language_extension/templates/tasks.rake +28 -0
- data/lib/generators/language_extension/templates/test_helper.rb +26 -0
- data/lib/generators/trusty_cms/USAGE +8 -0
- data/lib/generators/trusty_cms/templates/Rakefile.erb +7 -0
- data/lib/generators/trusty_cms/templates/application.rb.erb +149 -0
- data/lib/generators/trusty_cms/templates/boot.rb.erb +9 -0
- data/lib/generators/trusty_cms/templates/config.ru.erb +4 -0
- data/lib/generators/trusty_cms/templates/database.yml.erb +28 -0
- data/lib/generators/trusty_cms/templates/environment.rb.erb +5 -0
- data/lib/generators/trusty_cms/templates/environments/development.rb.erb +24 -0
- data/lib/generators/trusty_cms/templates/environments/production.rb.erb +26 -0
- data/lib/generators/trusty_cms/templates/environments/test.rb.erb +35 -0
- data/lib/generators/trusty_cms/templates/initializers/secret_token.rb.erb +13 -0
- data/lib/generators/trusty_cms/templates/initializers/session_store.rb.erb +8 -0
- data/lib/generators/trusty_cms/templates/initializers/trusty_cms_config.rb.erb +16 -0
- data/lib/generators/trusty_cms/templates/preinitializer.rb.erb +18 -0
- data/lib/generators/trusty_cms/templates/routes.rb.erb +0 -0
- data/lib/generators/trusty_cms/trusty_cms_generator.rb +32 -0
- data/lib/trusty_cms.rb +1 -1
- data/lib/trusty_cms/setup.rb +7 -7
- data/trusty_cms.gemspec +4 -4
- data/vendor/bundle/ruby/2.6.0/gems/actionview-6.0.3.4/lib/action_view/helpers/tags/base.rb +195 -0
- data/vendor/bundle/ruby/2.6.0/gems/actionview-6.0.3.4/lib/action_view/helpers/tags/check_box.rb +65 -0
- data/vendor/bundle/ruby/2.6.0/gems/actionview-6.0.3.4/lib/action_view/helpers/tags/checkable.rb +18 -0
- data/vendor/bundle/ruby/2.6.0/gems/actionview-6.0.3.4/lib/action_view/helpers/tags/collection_check_boxes.rb +35 -0
- data/vendor/bundle/ruby/2.6.0/gems/actionview-6.0.3.4/lib/action_view/helpers/tags/collection_helpers.rb +118 -0
- data/vendor/bundle/ruby/2.6.0/gems/actionview-6.0.3.4/lib/action_view/helpers/tags/collection_radio_buttons.rb +30 -0
- data/vendor/bundle/ruby/2.6.0/gems/actionview-6.0.3.4/lib/action_view/helpers/tags/collection_select.rb +30 -0
- data/vendor/bundle/ruby/2.6.0/gems/actionview-6.0.3.4/lib/action_view/helpers/tags/color_field.rb +26 -0
- data/vendor/bundle/ruby/2.6.0/gems/actionview-6.0.3.4/lib/action_view/helpers/tags/date_field.rb +14 -0
- data/vendor/bundle/ruby/2.6.0/gems/actionview-6.0.3.4/lib/action_view/helpers/tags/date_select.rb +73 -0
- data/vendor/bundle/ruby/2.6.0/gems/actionview-6.0.3.4/lib/action_view/helpers/tags/datetime_field.rb +31 -0
- data/vendor/bundle/ruby/2.6.0/gems/actionview-6.0.3.4/lib/action_view/helpers/tags/datetime_local_field.rb +20 -0
- data/vendor/bundle/ruby/2.6.0/gems/actionview-6.0.3.4/lib/action_view/helpers/tags/datetime_select.rb +10 -0
- data/vendor/bundle/ruby/2.6.0/gems/actionview-6.0.3.4/lib/action_view/helpers/tags/email_field.rb +10 -0
- data/vendor/bundle/ruby/2.6.0/gems/actionview-6.0.3.4/lib/action_view/helpers/tags/file_field.rb +10 -0
- data/vendor/bundle/ruby/2.6.0/gems/actionview-6.0.3.4/lib/action_view/helpers/tags/grouped_collection_select.rb +31 -0
- data/vendor/bundle/ruby/2.6.0/gems/actionview-6.0.3.4/lib/action_view/helpers/tags/hidden_field.rb +10 -0
- data/vendor/bundle/ruby/2.6.0/gems/actionview-6.0.3.4/lib/action_view/helpers/tags/label.rb +80 -0
- data/vendor/bundle/ruby/2.6.0/gems/actionview-6.0.3.4/lib/action_view/helpers/tags/month_field.rb +14 -0
- data/vendor/bundle/ruby/2.6.0/gems/actionview-6.0.3.4/lib/action_view/helpers/tags/number_field.rb +20 -0
- data/vendor/bundle/ruby/2.6.0/gems/actionview-6.0.3.4/lib/action_view/helpers/tags/password_field.rb +14 -0
- data/vendor/bundle/ruby/2.6.0/gems/actionview-6.0.3.4/lib/action_view/helpers/tags/placeholderable.rb +24 -0
- data/vendor/bundle/ruby/2.6.0/gems/actionview-6.0.3.4/lib/action_view/helpers/tags/radio_button.rb +32 -0
- data/vendor/bundle/ruby/2.6.0/gems/actionview-6.0.3.4/lib/action_view/helpers/tags/range_field.rb +10 -0
- data/vendor/bundle/ruby/2.6.0/gems/actionview-6.0.3.4/lib/action_view/helpers/tags/search_field.rb +27 -0
- data/vendor/bundle/ruby/2.6.0/gems/actionview-6.0.3.4/lib/action_view/helpers/tags/select.rb +42 -0
- data/vendor/bundle/ruby/2.6.0/gems/actionview-6.0.3.4/lib/action_view/helpers/tags/tel_field.rb +10 -0
- data/vendor/bundle/ruby/2.6.0/gems/actionview-6.0.3.4/lib/action_view/helpers/tags/text_area.rb +24 -0
- data/vendor/bundle/ruby/2.6.0/gems/actionview-6.0.3.4/lib/action_view/helpers/tags/text_field.rb +33 -0
- data/vendor/bundle/ruby/2.6.0/gems/actionview-6.0.3.4/lib/action_view/helpers/tags/time_field.rb +14 -0
- data/vendor/bundle/ruby/2.6.0/gems/actionview-6.0.3.4/lib/action_view/helpers/tags/time_select.rb +10 -0
- data/vendor/bundle/ruby/2.6.0/gems/actionview-6.0.3.4/lib/action_view/helpers/tags/time_zone_select.rb +22 -0
- data/vendor/bundle/ruby/2.6.0/gems/actionview-6.0.3.4/lib/action_view/helpers/tags/translator.rb +39 -0
- data/vendor/bundle/ruby/2.6.0/gems/actionview-6.0.3.4/lib/action_view/helpers/tags/url_field.rb +10 -0
- data/vendor/bundle/ruby/2.6.0/gems/actionview-6.0.3.4/lib/action_view/helpers/tags/week_field.rb +14 -0
- data/yarn.lock +3 -3
- metadata +296 -71
- data/spec/spec/dummy/node_modules/yaml/browser/dist/tags/core.js +0 -126
- data/spec/spec/dummy/node_modules/yaml/browser/dist/tags/failsafe/index.js +0 -4
- data/spec/spec/dummy/node_modules/yaml/browser/dist/tags/failsafe/map.js +0 -56
- data/spec/spec/dummy/node_modules/yaml/browser/dist/tags/failsafe/seq.js +0 -43
- data/spec/spec/dummy/node_modules/yaml/browser/dist/tags/failsafe/string.js +0 -28
- data/spec/spec/dummy/node_modules/yaml/browser/dist/tags/index.js +0 -36
- data/spec/spec/dummy/node_modules/yaml/browser/dist/tags/json.js +0 -76
- data/spec/spec/dummy/node_modules/yaml/browser/dist/tags/options.js +0 -23
- data/spec/spec/dummy/node_modules/yaml/browser/dist/tags/yaml-1.1/binary.js +0 -87
- data/spec/spec/dummy/node_modules/yaml/browser/dist/tags/yaml-1.1/index.js +0 -157
- data/spec/spec/dummy/node_modules/yaml/browser/dist/tags/yaml-1.1/omap.js +0 -142
- data/spec/spec/dummy/node_modules/yaml/browser/dist/tags/yaml-1.1/pairs.js +0 -81
- data/spec/spec/dummy/node_modules/yaml/browser/dist/tags/yaml-1.1/set.js +0 -114
- data/spec/spec/dummy/node_modules/yaml/browser/dist/tags/yaml-1.1/timestamp.js +0 -97
- data/spec/spec/dummy/node_modules/yaml/dist/tags/core.js +0 -114
- data/spec/spec/dummy/node_modules/yaml/dist/tags/failsafe/index.js +0 -17
- data/spec/spec/dummy/node_modules/yaml/dist/tags/failsafe/map.js +0 -37
- data/spec/spec/dummy/node_modules/yaml/dist/tags/failsafe/seq.js +0 -34
- data/spec/spec/dummy/node_modules/yaml/dist/tags/failsafe/string.js +0 -40
- data/spec/spec/dummy/node_modules/yaml/dist/tags/index.js +0 -62
- data/spec/spec/dummy/node_modules/yaml/dist/tags/json.js +0 -60
- data/spec/spec/dummy/node_modules/yaml/dist/tags/options.js +0 -35
- data/spec/spec/dummy/node_modules/yaml/dist/tags/yaml-1.1/binary.js +0 -97
- data/spec/spec/dummy/node_modules/yaml/dist/tags/yaml-1.1/index.js +0 -131
- data/spec/spec/dummy/node_modules/yaml/dist/tags/yaml-1.1/omap.js +0 -105
- data/spec/spec/dummy/node_modules/yaml/dist/tags/yaml-1.1/pairs.js +0 -80
- data/spec/spec/dummy/node_modules/yaml/dist/tags/yaml-1.1/set.js +0 -91
- data/spec/spec/dummy/node_modules/yaml/dist/tags/yaml-1.1/timestamp.js +0 -93
@@ -0,0 +1,25 @@
|
|
1
|
+
require 'rails_generator/base'
|
2
|
+
require 'rails_generator/generators/components/migration/migration_generator'
|
3
|
+
|
4
|
+
class ExtensionMigrationGenerator < MigrationGenerator
|
5
|
+
|
6
|
+
attr_accessor :extension_name
|
7
|
+
|
8
|
+
def initialize(runtime_args, runtime_options = {})
|
9
|
+
runtime_args = runtime_args.dup
|
10
|
+
@extension_name = runtime_args.shift
|
11
|
+
super(runtime_args, runtime_options)
|
12
|
+
end
|
13
|
+
|
14
|
+
def banner
|
15
|
+
"Usage: #{$0} extension_migration ExtensionName MigrationName [field:type, field:type]"
|
16
|
+
end
|
17
|
+
|
18
|
+
def extension_path
|
19
|
+
File.join('vendor', 'extensions', @extension_name.underscore)
|
20
|
+
end
|
21
|
+
|
22
|
+
def destination_root
|
23
|
+
File.join(Rails.root, extension_path)
|
24
|
+
end
|
25
|
+
end
|
@@ -0,0 +1,11 @@
|
|
1
|
+
class <%= class_name.underscore.camelize %> < ActiveRecord::Migration[5.2]
|
2
|
+
def self.up<% attributes.each do |attribute| %>
|
3
|
+
<%= migration_action %>_column :<%= table_name %>, :<%= attribute.name %><% if migration_action == 'add' %>, :<%= attribute.type %><% end -%>
|
4
|
+
<%- end %>
|
5
|
+
end
|
6
|
+
|
7
|
+
def self.down<% attributes.reverse.each do |attribute| %>
|
8
|
+
<%= migration_action == 'add' ? 'remove' : 'add' %>_column :<%= table_name %>, :<%= attribute.name %><% if migration_action == 'remove' %>, :<%= attribute.type %><% end -%>
|
9
|
+
<%- end %>
|
10
|
+
end
|
11
|
+
end
|
@@ -0,0 +1,35 @@
|
|
1
|
+
Description:
|
2
|
+
The extension_model generator creates stubs for a new model for an
|
3
|
+
extension.
|
4
|
+
|
5
|
+
The generator takes the extension name and a model name as its arguments.
|
6
|
+
The model name may be given in CamelCase or under_score and should not be
|
7
|
+
suffixed with 'Model'.
|
8
|
+
|
9
|
+
As additional parameters, the generator will take attribute pairs
|
10
|
+
described by name and type. These attributes will be used to prepopulate
|
11
|
+
the migration to create the table for the model and give you a set of
|
12
|
+
predefined fixtures. You don't have to think up all attributes up front,
|
13
|
+
but it's a good idea of adding just the baseline of what's needed to start
|
14
|
+
really working with the resource.
|
15
|
+
|
16
|
+
The generator creates a model class in
|
17
|
+
vendor/extensions/extension_name/app/models, a test suite in
|
18
|
+
vendor/extensions/extension_name/test/unit, test fixtures in
|
19
|
+
vendor/extensions/extension_name/test/fixtures/singular_name.yml, and a
|
20
|
+
migration in vendor/extensions/extension_name/db/migrate.
|
21
|
+
|
22
|
+
Examples:
|
23
|
+
./script/generate extension_model MyExt account
|
24
|
+
|
25
|
+
This will create an Account model:
|
26
|
+
|
27
|
+
Model: vendor/extensions/my_ext/app/models/account.rb
|
28
|
+
Migration: vendor/extensions/my_ext/db/migrate/XXX_add_accounts.rb
|
29
|
+
Spec: vendor/extensions/my_ext/spec/models/account_spec.rb
|
30
|
+
Test: vendor/extensions/my_ext/test/unit/account_test.rb (if extension created with "--with-test-unit")
|
31
|
+
Fixtures: vendor/extensions/my_ext/test/fixtures/accounts.yml (if extension created with "--with-test-unit")
|
32
|
+
|
33
|
+
./script/generate extension_model MyExt post title:string body:text
|
34
|
+
|
35
|
+
Creates post model with predefined attributes.
|
@@ -0,0 +1,68 @@
|
|
1
|
+
require 'rails_generator/base'
|
2
|
+
require 'rails_generator/generators/components/model/model_generator'
|
3
|
+
|
4
|
+
class ExtensionModelGenerator < ModelGenerator
|
5
|
+
|
6
|
+
attr_accessor :extension_name
|
7
|
+
default_options :with_test_unit => false
|
8
|
+
|
9
|
+
def initialize(runtime_args, runtime_options = {})
|
10
|
+
runtime_args = runtime_args.dup
|
11
|
+
@extension_name = runtime_args.shift
|
12
|
+
super(runtime_args, runtime_options)
|
13
|
+
end
|
14
|
+
|
15
|
+
def manifest
|
16
|
+
if extension_uses_rspec?
|
17
|
+
rspec_manifest
|
18
|
+
else
|
19
|
+
super
|
20
|
+
end
|
21
|
+
end
|
22
|
+
|
23
|
+
def rspec_manifest
|
24
|
+
record do |m|
|
25
|
+
# Check for class naming collisions.
|
26
|
+
m.class_collisions class_path, class_name
|
27
|
+
|
28
|
+
# Model, spec, and fixture directories.
|
29
|
+
m.directory File.join('app/models', class_path)
|
30
|
+
m.directory File.join('spec/models', class_path)
|
31
|
+
# m.directory File.join('spec/fixtures', class_path)
|
32
|
+
|
33
|
+
# Model class, spec and fixtures.
|
34
|
+
m.template 'model:model.rb', File.join('app/models', class_path, "#{file_name}.rb")
|
35
|
+
# m.template 'model:fixtures.yml', File.join('spec/fixtures', class_path, "#{table_name}.yml")
|
36
|
+
m.template 'model_spec.rb', File.join('spec/models', class_path, "#{file_name}_spec.rb")
|
37
|
+
|
38
|
+
unless options[:skip_migration]
|
39
|
+
m.migration_template 'model:migration.rb', 'db/migrate', :assigns => {
|
40
|
+
:migration_name => "Create#{class_name.pluralize.gsub(/::/, '')}"
|
41
|
+
}, :migration_file_name => "create_#{file_path.gsub(/\//, '_').pluralize}"
|
42
|
+
end
|
43
|
+
end
|
44
|
+
end
|
45
|
+
|
46
|
+
def banner
|
47
|
+
"Usage: #{$0} extension_model ExtensionName ModelName [field:type, field:type]"
|
48
|
+
end
|
49
|
+
|
50
|
+
def extension_path
|
51
|
+
File.join('vendor', 'extensions', @extension_name.underscore)
|
52
|
+
end
|
53
|
+
|
54
|
+
def destination_root
|
55
|
+
File.join(Rails.root, extension_path)
|
56
|
+
end
|
57
|
+
|
58
|
+
def extension_uses_rspec?
|
59
|
+
File.exists?(File.join(destination_root, 'spec')) && !options[:with_test_unit]
|
60
|
+
end
|
61
|
+
|
62
|
+
def add_options!(opt)
|
63
|
+
opt.separator ''
|
64
|
+
opt.separator 'Options:'
|
65
|
+
opt.on("--with-test-unit",
|
66
|
+
"Use Test::Unit tests instead sof RSpec.") { |v| options[:with_test_unit] = v }
|
67
|
+
end
|
68
|
+
end
|
@@ -0,0 +1,19 @@
|
|
1
|
+
# Read about fixtures at http://ar.rubyonrails.org/classes/Fixtures.html
|
2
|
+
|
3
|
+
<% unless attributes.empty? -%>
|
4
|
+
one:
|
5
|
+
<% for attribute in attributes -%>
|
6
|
+
<%= attribute.name %>: <%= attribute.default %>
|
7
|
+
<% end -%>
|
8
|
+
|
9
|
+
two:
|
10
|
+
<% for attribute in attributes -%>
|
11
|
+
<%= attribute.name %>: <%= attribute.default %>
|
12
|
+
<% end -%>
|
13
|
+
<% else -%>
|
14
|
+
# one:
|
15
|
+
# column: value
|
16
|
+
#
|
17
|
+
# two:
|
18
|
+
# column: value
|
19
|
+
<% end -%>
|
@@ -0,0 +1,16 @@
|
|
1
|
+
class <%= migration_name %> < ActiveRecord::Migration[5.2]
|
2
|
+
def self.up
|
3
|
+
create_table :<%= table_name %> do |t|
|
4
|
+
<% for attribute in attributes -%>
|
5
|
+
t.<%= attribute.type %> :<%= attribute.name %>
|
6
|
+
<% end -%>
|
7
|
+
<% unless options[:skip_timestamps] %>
|
8
|
+
t.timestamps
|
9
|
+
<% end -%>
|
10
|
+
end
|
11
|
+
end
|
12
|
+
|
13
|
+
def self.down
|
14
|
+
drop_table :<%= table_name %>
|
15
|
+
end
|
16
|
+
end
|
@@ -0,0 +1,11 @@
|
|
1
|
+
require File.dirname(__FILE__) + '<%= '/..' * class_nesting_depth %>/../spec_helper'
|
2
|
+
|
3
|
+
describe <%= class_name %> do
|
4
|
+
before(:each) do
|
5
|
+
@<%= file_name %> = <%= class_name %>.new
|
6
|
+
end
|
7
|
+
|
8
|
+
it "should be valid" do
|
9
|
+
@<%= file_name %>.should be_valid
|
10
|
+
end
|
11
|
+
end
|
@@ -0,0 +1,18 @@
|
|
1
|
+
require 'rails_generator'
|
2
|
+
module TrustyCms
|
3
|
+
module GeneratorBaseExtension
|
4
|
+
def self.included(base)
|
5
|
+
base.class_eval {
|
6
|
+
alias_method :existing_migrations_without_extensions, :existing_migrations
|
7
|
+
alias_method :existing_migrations, :existing_migrations_with_extensions
|
8
|
+
}
|
9
|
+
end
|
10
|
+
|
11
|
+
def existing_migrations_with_extensions(file_name)
|
12
|
+
Dir.glob("#{destination_path(@migration_directory)}/[0-9]*_*.rb").grep(/[0-9]+_#{file_name}.rb$/)
|
13
|
+
end
|
14
|
+
|
15
|
+
end
|
16
|
+
end
|
17
|
+
|
18
|
+
Rails::Generator::Commands::Base.class_eval { include TrustyCms::GeneratorBaseExtension }
|
@@ -0,0 +1,148 @@
|
|
1
|
+
require 'rbconfig'
|
2
|
+
|
3
|
+
# Small addition to enable the enqueing of "bundle install"
|
4
|
+
class Rails::Generator::Commands::Create
|
5
|
+
def run_bundler(destination_root)
|
6
|
+
# thanks to http://spectator.in/2011/01/28/bundler-in-subshells/
|
7
|
+
bundler_vars = %w(BUNDLE_GEMFILE RUBYOPT )
|
8
|
+
command = %{"#{Gem.ruby}" -rubygems "#{Gem.bin_path('bundler', 'bundle')}" install --gemfile="#{File.join(File.expand_path(destination_root), 'Gemfile')}"}
|
9
|
+
begin
|
10
|
+
bundled_env = ENV.to_hash
|
11
|
+
bundler_vars.each{ |var| ENV.delete(var) }
|
12
|
+
print `#{command}`
|
13
|
+
ensure
|
14
|
+
ENV.replace(bundled_env)
|
15
|
+
end
|
16
|
+
end
|
17
|
+
end
|
18
|
+
|
19
|
+
class InstanceGenerator < Rails::Generator::Base
|
20
|
+
DEFAULT_SHEBANG = File.join(Config::CONFIG['bindir'],
|
21
|
+
Config::CONFIG['ruby_install_name'])
|
22
|
+
|
23
|
+
DATABASES = %w( mysql postgresql sqlite3 sqlserver db2 )
|
24
|
+
|
25
|
+
MYSQL_SOCKET_LOCATIONS = [
|
26
|
+
"/tmp/mysql.sock", # default
|
27
|
+
"/var/run/mysqld/mysqld.sock", # debian/gentoo
|
28
|
+
"/var/tmp/mysql.sock", # freebsd
|
29
|
+
"/var/lib/mysql/mysql.sock", # fedora
|
30
|
+
"/opt/local/lib/mysql/mysql.sock", # fedora
|
31
|
+
"/opt/local/var/run/mysqld/mysqld.sock", # mac + darwinports + mysql
|
32
|
+
"/opt/local/var/run/mysql4/mysqld.sock", # mac + darwinports + mysql4
|
33
|
+
"/opt/local/var/run/mysql5/mysqld.sock" # mac + darwinports + mysql5
|
34
|
+
]
|
35
|
+
|
36
|
+
default_options :db => "sqlite3", :shebang => DEFAULT_SHEBANG, :freeze => false
|
37
|
+
|
38
|
+
def initialize(runtime_args, runtime_options = {})
|
39
|
+
super
|
40
|
+
usage if args.empty?
|
41
|
+
usage("Databases supported for preconfiguration are: #{DATABASES.join(", ")}") if (options[:db] && !DATABASES.include?(options[:db]))
|
42
|
+
@destination_root = args.shift
|
43
|
+
end
|
44
|
+
|
45
|
+
def manifest
|
46
|
+
# The absolute location of the TrustyCms files
|
47
|
+
root = File.expand_path(TRUSTY_CMS_ROOT)
|
48
|
+
|
49
|
+
# Use /usr/bin/env if no special shebang was specified
|
50
|
+
script_options = { :chmod => 0755, :shebang => options[:shebang] == DEFAULT_SHEBANG ? nil : options[:shebang] }
|
51
|
+
dispatcher_options = { :chmod => 0755, :shebang => options[:shebang] }
|
52
|
+
|
53
|
+
record do |m|
|
54
|
+
# Root directory
|
55
|
+
m.directory ""
|
56
|
+
|
57
|
+
# Standard files and directories
|
58
|
+
base_dirs = %w(config config/environments config/initializers db log script public vendor/plugins vendor/extensions)
|
59
|
+
text_files = %w(CHANGELOG.md CONTRIBUTORS.md LICENSE.md INSTALL.md README.md)
|
60
|
+
environments = Dir["#{root}/config/environments/*.rb"]
|
61
|
+
bundler_compatibility_files = %w{config/preinitializer.rb}
|
62
|
+
schema_file = %w{db/schema.rb}
|
63
|
+
scripts = Dir["#{root}/script/**/*"].reject { |f| f =~ /(destroy|generate|plugin)$/ }
|
64
|
+
public_files = ["public/.htaccess"] + Dir["#{root}/public/**/*"]
|
65
|
+
test_files = ["config/cucumber.yml"]
|
66
|
+
|
67
|
+
files = base_dirs + text_files + environments + bundler_compatibility_files + schema_file + scripts + public_files + test_files
|
68
|
+
files.map! { |f| f = $1 if f =~ %r{^#{root}/(.+)$}; f }
|
69
|
+
files.sort!
|
70
|
+
|
71
|
+
files.each do |file|
|
72
|
+
case
|
73
|
+
when File.directory?("#{root}/#{file}")
|
74
|
+
m.directory file
|
75
|
+
when file =~ %r{^script/}
|
76
|
+
m.file radiant_root(file), file, script_options
|
77
|
+
when file =~ %r{^public/dispatch}
|
78
|
+
m.file radiant_root(file), file, dispatcher_options
|
79
|
+
else
|
80
|
+
m.file radiant_root(file), file
|
81
|
+
end
|
82
|
+
end
|
83
|
+
|
84
|
+
# script/generate
|
85
|
+
m.file "instance_generate", "script/generate", script_options
|
86
|
+
|
87
|
+
# database.yml and .htaccess
|
88
|
+
m.template "databases/#{options[:db]}.yml", "config/database.yml", :assigns => {
|
89
|
+
:app_name => File.basename(File.expand_path(@destination_root)),
|
90
|
+
:socket => options[:db] == "mysql" ? mysql_socket_location : nil
|
91
|
+
}
|
92
|
+
|
93
|
+
# Instance Gemfile
|
94
|
+
m.template "instance_gemfile", "Gemfile", :assigns => {
|
95
|
+
:radiant_version => TrustyCms::VERSION.to_s,
|
96
|
+
:db => options[:db]
|
97
|
+
}
|
98
|
+
|
99
|
+
# Instance Rakefile
|
100
|
+
m.file "instance_rakefile", "Rakefile"
|
101
|
+
|
102
|
+
# Config.ru is useful in rack-based situations like Pow
|
103
|
+
m.file "instance_config.ru", "config.ru"
|
104
|
+
|
105
|
+
# Instance Configurations
|
106
|
+
m.file "instance_routes.rb", "config/routes.rb"
|
107
|
+
m.template "instance_environment.rb", "config/environment.rb", :assigns => {
|
108
|
+
:radiant_environment => File.join(File.dirname(__FILE__), 'templates', radiant_root("config/environment.rb")),
|
109
|
+
:app_name => File.basename(File.expand_path(@destination_root))
|
110
|
+
}
|
111
|
+
m.template "instance_boot.rb", "config/boot.rb"
|
112
|
+
m.file "instance_radiant_config.rb", "config/initializers/radiant_config.rb"
|
113
|
+
|
114
|
+
# Run bundler
|
115
|
+
m.run_bundler @destination_root
|
116
|
+
|
117
|
+
m.readme radiant_root("INSTALL.md")
|
118
|
+
end
|
119
|
+
end
|
120
|
+
|
121
|
+
protected
|
122
|
+
|
123
|
+
def banner
|
124
|
+
"Usage: #{$0} /path/to/trusty_cms/app [options]"
|
125
|
+
end
|
126
|
+
|
127
|
+
def add_options!(opt)
|
128
|
+
opt.separator ''
|
129
|
+
opt.separator 'Options:'
|
130
|
+
opt.on("-r", "--ruby=path", String,
|
131
|
+
"Path to the Ruby binary of your choice (otherwise scripts use env, dispatchers current path).",
|
132
|
+
"Default: #{DEFAULT_SHEBANG}") { |v| options[:shebang] = v }
|
133
|
+
opt.on("-d", "--database=name", String,
|
134
|
+
"Preconfigure for selected database (options: #{DATABASES.join(", ")}).",
|
135
|
+
"Default: sqlite3") { |v| options[:db] = v }
|
136
|
+
end
|
137
|
+
|
138
|
+
def mysql_socket_location
|
139
|
+
RUBY_PLATFORM =~ /mswin32/ ? MYSQL_SOCKET_LOCATIONS.find { |f| File.exists?(f) } : nil
|
140
|
+
end
|
141
|
+
|
142
|
+
private
|
143
|
+
|
144
|
+
def radiant_root(filename = '')
|
145
|
+
File.join("..", "..", "..", "..", filename)
|
146
|
+
end
|
147
|
+
|
148
|
+
end
|
@@ -0,0 +1,40 @@
|
|
1
|
+
# DB2 9.7
|
2
|
+
#
|
3
|
+
# Home Page
|
4
|
+
# http://rubyforge.org/projects/rubyibm/
|
5
|
+
#
|
6
|
+
# To install the ibm_db gem:
|
7
|
+
# On Linux:
|
8
|
+
# $ sudo -s
|
9
|
+
# $ . /home/db2inst1/sqllib/db2profile
|
10
|
+
# $ export IBM_DB_LIB=/opt/ibm/db2/V9.7/lib
|
11
|
+
# $ export IBM_DB_INCLUDE=/opt/ibm/db2/V9.7/include
|
12
|
+
# $ gem install ibm_db
|
13
|
+
#
|
14
|
+
# On Windows:
|
15
|
+
# Issue the command: gem install ibm_db
|
16
|
+
# If prompted, select the mswin32 option
|
17
|
+
#
|
18
|
+
# For more details on the installation and the available connection parameters refer to:
|
19
|
+
# http://rubyforge.org/docman/?group_id=2361
|
20
|
+
|
21
|
+
development:
|
22
|
+
adapter: ibm_db
|
23
|
+
database: <%= app_name[0,4] %>_dev
|
24
|
+
username: db2inst1
|
25
|
+
password:
|
26
|
+
|
27
|
+
# Warning: The database defined as 'test' will be erased and
|
28
|
+
# re-generated from your development database when you run 'rake'.
|
29
|
+
# Do not set this db to the same as development or production.
|
30
|
+
test:
|
31
|
+
adapter: ibm_db
|
32
|
+
database: <%= app_name[0,4] %>_tst
|
33
|
+
username: db2inst1
|
34
|
+
password:
|
35
|
+
|
36
|
+
production:
|
37
|
+
adapter: ibm_db
|
38
|
+
database: <%= app_name[0,4] %>_prd
|
39
|
+
username: db2inst1
|
40
|
+
password:
|
@@ -0,0 +1,47 @@
|
|
1
|
+
# MySQL (default setup). Versions 4.1 and 5.0 are recommended.
|
2
|
+
#
|
3
|
+
# Install the MySQL driver:
|
4
|
+
# gem install mysql
|
5
|
+
# On MacOS X:
|
6
|
+
# gem install mysql -- --include=/usr/local/lib
|
7
|
+
# On Windows:
|
8
|
+
# There is no gem for Windows. Install mysql.so from RubyForApache.
|
9
|
+
# http://rubyforge.org/projects/rubyforapache
|
10
|
+
#
|
11
|
+
# And be sure to use new-style password hashing:
|
12
|
+
# http://dev.mysql.com/doc/refman/5.0/en/old-client.html
|
13
|
+
development:
|
14
|
+
adapter: mysql2
|
15
|
+
database: <%= app_name %>_development
|
16
|
+
username: root
|
17
|
+
password:
|
18
|
+
<% if socket -%>
|
19
|
+
socket: <%= socket %>
|
20
|
+
<% else -%>
|
21
|
+
host: localhost
|
22
|
+
<% end -%>
|
23
|
+
|
24
|
+
# Warning: The database defined as 'test' will be erased and
|
25
|
+
# re-generated from your development database when you run 'rake'.
|
26
|
+
# Do not set this db to the same as development or production.
|
27
|
+
test:
|
28
|
+
adapter: mysql2
|
29
|
+
database: <%= app_name %>_test
|
30
|
+
username: root
|
31
|
+
password:
|
32
|
+
<% if socket -%>
|
33
|
+
socket: <%= socket %>
|
34
|
+
<% else -%>
|
35
|
+
host: localhost
|
36
|
+
<% end -%>
|
37
|
+
|
38
|
+
production:
|
39
|
+
adapter: mysql2
|
40
|
+
database: <%= app_name %>_production
|
41
|
+
username: root
|
42
|
+
password:
|
43
|
+
<% if socket -%>
|
44
|
+
socket: <%= socket %>
|
45
|
+
<% else -%>
|
46
|
+
host: localhost
|
47
|
+
<% end -%>
|