nilly_vanilly 0.1.0 → 0.2.0

Sign up to get free protection for your applications and to get access to all the features.
data/.gitignore ADDED
@@ -0,0 +1,9 @@
1
+ spec/debug.log
2
+ nilly_vanilly.sqlite3
3
+ coverage
4
+ rdoc
5
+ doc
6
+ .yardoc
7
+ .bundle
8
+ pkg
9
+ spec/db/database.yml
data/.rspec ADDED
@@ -0,0 +1,2 @@
1
+ --color
2
+ --format documentation
data/CHANGELOG.md ADDED
@@ -0,0 +1,9 @@
1
+ ## 0.1.0 (January 2011)
2
+
3
+ Initial release
4
+ Made the plugin available as a gem.
5
+
6
+ Features:
7
+
8
+ - Nillyfily Active Record plugins
9
+ - Rake task to identify attributes to be nillified
data/Gemfile ADDED
@@ -0,0 +1,7 @@
1
+ source "http://rubygems.org"
2
+
3
+ gemspec
4
+
5
+ gem 'activerecord', '>= 2'
6
+ gem 'rspec'
7
+ gem 'sqlite3'
data/Gemfile.lock ADDED
@@ -0,0 +1,30 @@
1
+ PATH
2
+ remote: .
3
+ specs:
4
+ nilly_vanilly (0.2.0)
5
+
6
+ GEM
7
+ remote: http://rubygems.org/
8
+ specs:
9
+ activerecord (2.3.12)
10
+ activesupport (= 2.3.12)
11
+ activesupport (2.3.12)
12
+ diff-lcs (1.1.2)
13
+ rspec (2.6.0)
14
+ rspec-core (~> 2.6.0)
15
+ rspec-expectations (~> 2.6.0)
16
+ rspec-mocks (~> 2.6.0)
17
+ rspec-core (2.6.4)
18
+ rspec-expectations (2.6.0)
19
+ diff-lcs (~> 1.1.2)
20
+ rspec-mocks (2.6.0)
21
+ sqlite3 (1.3.3)
22
+
23
+ PLATFORMS
24
+ ruby
25
+
26
+ DEPENDENCIES
27
+ activerecord (>= 2)
28
+ nilly_vanilly!
29
+ rspec
30
+ sqlite3
data/README.markdown CHANGED
@@ -1,7 +1,7 @@
1
1
  NillyVanilly
2
2
  ============
3
3
 
4
- This plugin stores NULL in your database when you try to store an empty string.
4
+ This Rails gem/plugin stores NULL in your database when you try to store an empty string.
5
5
 
6
6
  It only works for columns you explicitly mention inside your model. It comes
7
7
  with a rake task which prints out all the columns eligible for nillification.
@@ -25,8 +25,26 @@ Example
25
25
  Installation
26
26
  ============
27
27
 
28
+ The preferred method of installation is now as a gem.
29
+
30
+ config.gem 'nilly_vanilly'
31
+
32
+ or, for Rails 3 with Bundler in your Gemfile:
33
+
34
+ gem 'nilly_vanilly'
35
+
36
+ Previous versions of Nilly Vanilly were distributed as a Rails plugin. For Rails
37
+ 2 apps this might still work, but is not supported. If you absolutely need the
38
+ Rake task in your Rails 2 app, you can:
39
+
28
40
  ./script/plugin install git://github.com/tilsammans/nilly_vanilly.git
29
41
 
42
+ Installation as a plugin in Rails 2 adds a rake task you can run to find suitable
43
+ columns for nillification. For Rails 3, I will add this task in a future version.
44
+ Until then you can find the same information by running:
45
+
46
+ ./script/runner "NillyVanilly::Inspect.print"
47
+
30
48
 
31
49
  Inspection
32
50
  ==========
@@ -43,6 +61,26 @@ This does not take into account any validations you might have.
43
61
  When a column has already been nillified, it will be indicated with [OK].
44
62
 
45
63
 
64
+ But WHY?!!
65
+ ==========
66
+
67
+ You: who cares that empty strings are stored in the database?
68
+ Me: if you don't care, just move along. And would I recommend you nillify
69
+ every attribute in your application? No. But beside from the fact that NULL
70
+ is the "correct" value for something you don't know, enforcing this is
71
+ required if you have a unique index on that column. Unique indexes are the
72
+ fastest you can have, and they deal great with NULL values. Empty strings?
73
+ Not so much so.
74
+
75
+
76
+ Contributing
77
+ ============
78
+
79
+ Fork and clone the repo and hack away.
80
+
81
+ It is very important you *must* run the specs before sending a pull request.
82
+
83
+
46
84
  Author
47
85
  ======
48
86
 
data/Rakefile CHANGED
@@ -1,63 +1,7 @@
1
- require 'rake'
2
- require 'rake/rdoctask'
1
+ require 'bundler/gem_tasks'
3
2
 
4
- desc 'Default: run specs.'
5
- task :default => :spec
6
-
7
- require 'jeweler'
8
- Jeweler::Tasks.new do |gem|
9
- gem.name = "nilly_vanilly"
10
- gem.homepage = "http://github.com/tilsammans/nilly_vanilly"
11
- gem.summary = %Q{This plugin stores NULL in your database when you try to store an empty string.}
12
- gem.email = "joost@spacebabies.nl"
13
- gem.authors = ["Joost Baaij"]
14
- gem.add_runtime_dependency 'activerecord', '~> 2.3'
15
- gem.add_development_dependency 'rspec', '~> 1.3.1'
16
- gem.add_development_dependency 'jeweler', '~> 0.5.2'
17
- end
18
- Jeweler::RubygemsDotOrgTasks.new
19
-
20
- begin
21
- # Rspec 1.3.0
22
- require 'spec/rake/spectask'
23
-
24
- desc 'Default: run specs'
25
- task :default => :spec
26
- Spec::Rake::SpecTask.new do |t|
27
- t.spec_files = FileList["spec/**/*_spec.rb"]
28
- end
3
+ require 'rspec/core/rake_task'
29
4
 
30
- Spec::Rake::SpecTask.new('rcov') do |t|
31
- t.spec_files = FileList["spec/**/*_spec.rb"]
32
- t.rcov = true
33
- t.rcov_opts = ['--exclude', 'spec']
34
- end
35
-
36
- rescue LoadError
37
- # Rspec 2.0
38
- require 'rspec/core/rake_task'
5
+ RSpec::Core::RakeTask.new('spec')
39
6
 
40
- desc 'Default: run specs'
41
- task :default => :spec
42
- Rspec::Core::RakeTask.new do |t|
43
- t.pattern = "spec/**/*_spec.rb"
44
- end
45
-
46
- Rspec::Core::RakeTask.new('rcov') do |t|
47
- t.pattern = "spec/**/*_spec.rb"
48
- t.rcov = true
49
- t.rcov_opts = ['--exclude', 'spec']
50
- end
51
-
52
- rescue LoadError
53
- puts "Rspec not available. Install it with: gem install rspec"
54
- end
55
-
56
- desc 'Generate documentation for the nilly_vanilly plugin.'
57
- Rake::RDocTask.new(:rdoc) do |rdoc|
58
- rdoc.rdoc_dir = 'rdoc'
59
- rdoc.title = 'NillyVanilly'
60
- rdoc.options << '--line-numbers' << '--inline-source'
61
- rdoc.rdoc_files.include('README')
62
- rdoc.rdoc_files.include('lib/**/*.rb')
63
- end
7
+ task :default => :spec
data/lib/nilly_vanilly.rb CHANGED
@@ -1,5 +1,6 @@
1
1
  require "active_record"
2
2
  require 'nilly_vanilly/nillify'
3
+ require 'nilly_vanilly/inspect'
3
4
 
4
5
  if defined?(ActiveRecord::Base)
5
6
  ActiveRecord::Base.send :include, NillyVanilly::Nillify
@@ -0,0 +1,35 @@
1
+ module NillyVanilly
2
+ # Inspect the database schema, in a quest to find columns suitable for nillification.
3
+ class Inspect
4
+ def initialize
5
+ @results = []
6
+ end
7
+
8
+ # A nested array with one row for each column suitable for nillification.
9
+ def results
10
+ ActiveRecord::Base.connection.tables.each do |table|
11
+ model = table.classify.constantize rescue next
12
+
13
+ model.columns.each do |column|
14
+ present = model.respond_to?(:nillify_attributes) && model.nillify_attributes.include?(column.name.to_sym)
15
+
16
+ @results << [present, model.name, column.name] if include_column(column)
17
+ end
18
+ end
19
+
20
+ @results
21
+ end
22
+
23
+ # Print an inspection report to stdout.
24
+ def self.print
25
+ new.results.each do |result|
26
+ puts [result[0] ? "[OK]" : "[ ]", result[1].ljust(20), result[2]].join(" ")
27
+ end
28
+ end
29
+
30
+ private
31
+ def include_column(column)
32
+ column.text? && column.null && column.default.nil?
33
+ end
34
+ end
35
+ end
@@ -0,0 +1,3 @@
1
+ module NillyVanilly
2
+ VERSION = "0.2.0"
3
+ end
@@ -1,21 +1,7 @@
1
1
  namespace :nilly do
2
2
  namespace :vanilly do
3
3
  task :inspect => :environment do
4
- ActiveRecord::Base.connection.tables.each do |table|
5
- model = table.classify.constantize rescue next
6
-
7
- model.columns.each do |column|
8
- if model.respond_to?(:nillify_attributes) && model.nillify_attributes.include?(column.name.to_sym)
9
- present = "[OK]"
10
- else
11
- present = "[ ]"
12
- end
13
-
14
- if column.text? && column.null && column.default.nil?
15
- puts [present, model.name.ljust(20), column.name].join(" ")
16
- end
17
- end
18
- end
4
+ NillyVanilly::Inspect.print
19
5
  end
20
6
  end
21
7
  end
@@ -0,0 +1,18 @@
1
+ # -*- encoding: utf-8 -*-
2
+ $:.push File.expand_path("../lib", __FILE__)
3
+ require "nilly_vanilly/version"
4
+
5
+ Gem::Specification.new do |s|
6
+ s.name = "nilly_vanilly"
7
+ s.version = NillyVanilly::VERSION
8
+ s.authors = ["Joost Baaij"]
9
+ s.email = ["joost@spacebabies.nl"]
10
+ s.homepage = "https://github.com/tilsammans/nilly_vanilly"
11
+ s.summary = %q{This plugin stores NULL in your database when you try to store an empty string.}
12
+ s.description = %q{This plugin stores NULL in your database when you try to store an empty string.}
13
+
14
+ s.files = `git ls-files`.split("\n")
15
+ s.test_files = `git ls-files -- {test,spec,features}/*`.split("\n")
16
+ s.executables = `git ls-files -- bin/*`.split("\n").map{ |f| File.basename(f) }
17
+ s.require_paths = ["lib"]
18
+ end
File without changes
File without changes
File without changes
@@ -0,0 +1,7 @@
1
+ require 'spec_helper'
2
+
3
+ describe NillyVanilly::Inspect do
4
+ it "returns array of models/columns" do
5
+ subject.results.first.should == [true, "Post", "title"]
6
+ end
7
+ end
data/spec/spec_helper.rb CHANGED
@@ -1,32 +1,12 @@
1
- $LOAD_PATH << "." unless $LOAD_PATH.include?(".")
1
+ require 'rubygems'
2
+ require 'bundler/setup'
2
3
 
3
- require 'yaml'
4
- require File.dirname(__FILE__) + '/../rails/init.rb'
4
+ require 'nilly_vanilly'
5
5
 
6
- ENV['DB'] ||= 'sqlite3'
6
+ # Requires supporting files with custom matchers and macros, etc,
7
+ # in ./support/ and its subdirectories.
8
+ Dir["#{File.dirname(__FILE__)}/support/**/*.rb"].each {|f| require f}
7
9
 
8
- database_yml = File.expand_path('../database.yml', __FILE__)
9
- if File.exists?(database_yml)
10
- active_record_configuration = YAML.load_file(database_yml)[ENV['DB']]
11
-
12
- ActiveRecord::Base.establish_connection(active_record_configuration)
13
- ActiveRecord::Base.logger = Logger.new(File.join(File.dirname(__FILE__), "debug.log"))
14
-
15
- ActiveRecord::Base.silence do
16
- ActiveRecord::Migration.verbose = false
17
-
18
- load(File.dirname(__FILE__) + '/schema.rb')
19
- load(File.dirname(__FILE__) + '/models.rb')
20
- end
21
-
22
- else
23
- raise "Please create #{database_yml} first to configure your database. Take a look at: #{database_yml}.sample"
24
- end
25
-
26
- def clean_database!
27
- [Post, Comment].each do |model|
28
- ActiveRecord::Base.connection.execute "DELETE FROM #{model.table_name}"
29
- end
30
- end
31
-
32
- clean_database!
10
+ RSpec.configure do |config|
11
+ # some (optional) config here
12
+ end
@@ -0,0 +1,29 @@
1
+ require 'yaml'
2
+
3
+ ENV['DB'] ||= 'sqlite3'
4
+
5
+ database_yml = File.expand_path('../../db/database.yml', __FILE__)
6
+ if File.exists?(database_yml)
7
+ active_record_configuration = YAML.load_file(database_yml)[ENV['DB']]
8
+
9
+ ActiveRecord::Base.establish_connection(active_record_configuration)
10
+ ActiveRecord::Base.logger = Logger.new(File.join(File.dirname(__FILE__), "../debug.log"))
11
+
12
+ ActiveRecord::Base.silence do
13
+ ActiveRecord::Migration.verbose = false
14
+
15
+ load(File.dirname(__FILE__) + '/../db/schema.rb')
16
+ load(File.dirname(__FILE__) + '/../db/models.rb')
17
+ end
18
+
19
+ else
20
+ raise "Please create #{database_yml} first to configure your database. Take a look at: #{database_yml}.example"
21
+ end
22
+
23
+ def clean_database!
24
+ [Post, Comment].each do |model|
25
+ ActiveRecord::Base.connection.execute "DELETE FROM #{model.table_name}"
26
+ end
27
+ end
28
+
29
+ clean_database!
metadata CHANGED
@@ -1,13 +1,8 @@
1
1
  --- !ruby/object:Gem::Specification
2
2
  name: nilly_vanilly
3
3
  version: !ruby/object:Gem::Version
4
- hash: 27
5
- prerelease: false
6
- segments:
7
- - 0
8
- - 1
9
- - 0
10
- version: 0.1.0
4
+ prerelease:
5
+ version: 0.2.0
11
6
  platform: ruby
12
7
  authors:
13
8
  - Joost Baaij
@@ -15,79 +10,42 @@ autorequire:
15
10
  bindir: bin
16
11
  cert_chain: []
17
12
 
18
- date: 2011-01-21 00:00:00 +01:00
13
+ date: 2011-08-12 00:00:00 +02:00
19
14
  default_executable:
20
- dependencies:
21
- - !ruby/object:Gem::Dependency
22
- name: activerecord
23
- prerelease: false
24
- requirement: &id001 !ruby/object:Gem::Requirement
25
- none: false
26
- requirements:
27
- - - ~>
28
- - !ruby/object:Gem::Version
29
- hash: 5
30
- segments:
31
- - 2
32
- - 3
33
- version: "2.3"
34
- type: :runtime
35
- version_requirements: *id001
36
- - !ruby/object:Gem::Dependency
37
- name: rspec
38
- prerelease: false
39
- requirement: &id002 !ruby/object:Gem::Requirement
40
- none: false
41
- requirements:
42
- - - ~>
43
- - !ruby/object:Gem::Version
44
- hash: 25
45
- segments:
46
- - 1
47
- - 3
48
- - 1
49
- version: 1.3.1
50
- type: :development
51
- version_requirements: *id002
52
- - !ruby/object:Gem::Dependency
53
- name: jeweler
54
- prerelease: false
55
- requirement: &id003 !ruby/object:Gem::Requirement
56
- none: false
57
- requirements:
58
- - - ~>
59
- - !ruby/object:Gem::Version
60
- hash: 15
61
- segments:
62
- - 0
63
- - 5
64
- - 2
65
- version: 0.5.2
66
- type: :development
67
- version_requirements: *id003
68
- description:
69
- email: joost@spacebabies.nl
15
+ dependencies: []
16
+
17
+ description: This plugin stores NULL in your database when you try to store an empty string.
18
+ email:
19
+ - joost@spacebabies.nl
70
20
  executables: []
71
21
 
72
22
  extensions: []
73
23
 
74
- extra_rdoc_files:
75
- - README.markdown
24
+ extra_rdoc_files: []
25
+
76
26
  files:
27
+ - .gitignore
28
+ - .rspec
29
+ - CHANGELOG.md
30
+ - Gemfile
31
+ - Gemfile.lock
77
32
  - README.markdown
78
33
  - Rakefile
79
- - VERSION
80
34
  - lib/nilly_vanilly.rb
35
+ - lib/nilly_vanilly/inspect.rb
81
36
  - lib/nilly_vanilly/nillify.rb
37
+ - lib/nilly_vanilly/version.rb
82
38
  - lib/tasks/nilly_vanilly.rake
83
- - rails/init.rb
84
- - spec/database.yml
85
- - spec/models.rb
39
+ - nilly_vanilly.gemspec
40
+ - spec/db/database.yml.example
41
+ - spec/db/models.rb
42
+ - spec/db/schema.rb
43
+ - spec/nilly_vanilly/inspect_spec.rb
86
44
  - spec/nilly_vanilly_spec.rb
87
- - spec/schema.rb
88
45
  - spec/spec_helper.rb
46
+ - spec/support/database.rb
89
47
  has_rdoc: true
90
- homepage: http://github.com/tilsammans/nilly_vanilly
48
+ homepage: https://github.com/tilsammans/nilly_vanilly
91
49
  licenses: []
92
50
 
93
51
  post_install_message:
@@ -100,28 +58,25 @@ required_ruby_version: !ruby/object:Gem::Requirement
100
58
  requirements:
101
59
  - - ">="
102
60
  - !ruby/object:Gem::Version
103
- hash: 3
104
- segments:
105
- - 0
106
61
  version: "0"
107
62
  required_rubygems_version: !ruby/object:Gem::Requirement
108
63
  none: false
109
64
  requirements:
110
65
  - - ">="
111
66
  - !ruby/object:Gem::Version
112
- hash: 3
113
- segments:
114
- - 0
115
67
  version: "0"
116
68
  requirements: []
117
69
 
118
70
  rubyforge_project:
119
- rubygems_version: 1.3.7
71
+ rubygems_version: 1.6.2
120
72
  signing_key:
121
73
  specification_version: 3
122
74
  summary: This plugin stores NULL in your database when you try to store an empty string.
123
75
  test_files:
124
- - spec/models.rb
76
+ - spec/db/database.yml.example
77
+ - spec/db/models.rb
78
+ - spec/db/schema.rb
79
+ - spec/nilly_vanilly/inspect_spec.rb
125
80
  - spec/nilly_vanilly_spec.rb
126
- - spec/schema.rb
127
81
  - spec/spec_helper.rb
82
+ - spec/support/database.rb
data/VERSION DELETED
@@ -1 +0,0 @@
1
- 0.1.0
data/rails/init.rb DELETED
@@ -1 +0,0 @@
1
- require 'nilly_vanilly'