has_messages 0.4.0 → 0.4.1

Sign up to get free protection for your applications and to get access to all the features.
@@ -1,5 +1,11 @@
1
1
  == master
2
2
 
3
+ == 0.4.1 / 2010-03-07
4
+
5
+ * Add a generator for db migrations
6
+ * Release gems via rake-gemcutter instead of rubyforge
7
+ * By default, sort messages newest first [Alexander Lang]
8
+
3
9
  == 0.4.0 / 2009-04-19
4
10
 
5
11
  * Add dependency on Rails 2.3
data/LICENSE CHANGED
@@ -1,4 +1,4 @@
1
- Copyright (c) 2006-2009 Aaron Pfeifer
1
+ Copyright (c) 2006-2010 Aaron Pfeifer
2
2
 
3
3
  Permission is hereby granted, free of charge, to any person obtaining
4
4
  a copy of this software and associated documentation files (the
@@ -33,6 +33,17 @@ demonstrating a reference implementation of these features.
33
33
 
34
34
  == Usage
35
35
 
36
+ === Installation
37
+
38
+ +has_messages+ requires additional database tables to work. You can generate
39
+ a migration for these tables like so:
40
+
41
+ script/generate has_messages
42
+
43
+ Then simply migrate your database:
44
+
45
+ rake db:migrate
46
+
36
47
  === Adding message support
37
48
 
38
49
  class User < ActiveRecord::Base
data/Rakefile CHANGED
@@ -1,15 +1,17 @@
1
+ require 'rubygems'
2
+ require 'rake'
1
3
  require 'rake/testtask'
2
4
  require 'rake/rdoctask'
3
5
  require 'rake/gempackagetask'
4
- require 'rake/contrib/sshpublisher'
5
6
 
6
7
  spec = Gem::Specification.new do |s|
7
8
  s.name = 'has_messages'
8
- s.version = '0.4.0'
9
+ s.version = '0.4.1'
9
10
  s.platform = Gem::Platform::RUBY
10
- s.summary = 'Demonstrates a reference implementation for sending messages between users.'
11
+ s.summary = 'Demonstrates a reference implementation for sending messages between users in ActiveRecord'
12
+ s.description = s.summary
11
13
 
12
- s.files = FileList['{app,db,lib,test}/**/*'] + %w(CHANGELOG.rdoc init.rb LICENSE Rakefile README.rdoc) - FileList['test/app_root/{log,log/*,script,script/*}']
14
+ s.files = FileList['{app,generators,lib,test}/**/*'] + %w(CHANGELOG.rdoc init.rb LICENSE Rakefile README.rdoc) - FileList['test/app_root/{log,log/*,script,script/*}']
13
15
  s.require_path = 'lib'
14
16
  s.has_rdoc = true
15
17
  s.test_files = Dir['test/**/*_test.rb']
@@ -53,20 +55,27 @@ Rake::RDocTask.new(:rdoc) do |rdoc|
53
55
  rdoc.options << '--line-numbers' << '--inline-source'
54
56
  rdoc.rdoc_files.include('README.rdoc', 'CHANGELOG.rdoc', 'LICENSE', 'lib/**/*.rb', 'app/**/*.rb')
55
57
  end
56
-
58
+
59
+ desc 'Generate a gemspec file.'
60
+ task :gemspec do
61
+ File.open("#{spec.name}.gemspec", 'w') do |f|
62
+ f.write spec.to_ruby
63
+ end
64
+ end
65
+
57
66
  Rake::GemPackageTask.new(spec) do |p|
58
67
  p.gem_spec = spec
59
- p.need_tar = true
60
- p.need_zip = true
61
68
  end
62
69
 
63
70
  desc 'Publish the beta gem.'
64
71
  task :pgem => [:package] do
72
+ require 'rake/contrib/sshpublisher'
65
73
  Rake::SshFilePublisher.new('aaron@pluginaweek.org', '/home/aaron/gems.pluginaweek.org/public/gems', 'pkg', "#{spec.name}-#{spec.version}.gem").upload
66
74
  end
67
75
 
68
76
  desc 'Publish the API documentation.'
69
77
  task :pdoc => [:rdoc] do
78
+ require 'rake/contrib/sshpublisher'
70
79
  Rake::SshDirPublisher.new('aaron@pluginaweek.org', "/home/aaron/api.pluginaweek.org/public/#{spec.name}", 'rdoc').upload
71
80
  end
72
81
 
@@ -75,15 +84,8 @@ task :publish => [:pgem, :pdoc, :release]
75
84
 
76
85
  desc 'Publish the release files to RubyForge.'
77
86
  task :release => [:gem, :package] do
78
- require 'rubyforge'
79
-
80
- ruby_forge = RubyForge.new.configure
81
- ruby_forge.login
87
+ require 'rake/gemcutter'
82
88
 
83
- %w(gem tgz zip).each do |ext|
84
- file = "pkg/#{spec.name}-#{spec.version}.#{ext}"
85
- puts "Releasing #{File.basename(file)}..."
86
-
87
- ruby_forge.add_release(spec.rubyforge_project, spec.name, spec.version, file)
88
- end
89
+ Rake::Gemcutter::Tasks.new(spec)
90
+ Rake::Task['gem:push'].invoke
89
91
  end
@@ -0,0 +1,5 @@
1
+ Usage:
2
+
3
+ script/generate has_messages
4
+
5
+ This will create migrations that will add the proper tables to store messages.
@@ -0,0 +1,9 @@
1
+ class HasMessagesGenerator < Rails::Generator::Base
2
+ def manifest
3
+ record do |m|
4
+ m.migration_template '001_create_messages.rb', 'db/migrate', :migration_file_name => 'create_messages'
5
+ m.sleep 1
6
+ m.migration_template '002_create_message_recipients.rb', 'db/migrate', :migration_file_name => 'create_message_recipients'
7
+ end
8
+ end
9
+ end
@@ -40,13 +40,13 @@ module HasMessages
40
40
  :as => :sender,
41
41
  :class_name => 'Message',
42
42
  :conditions => {:hidden_at => nil},
43
- :order => 'messages.created_at ASC'
43
+ :order => 'messages.created_at DESC'
44
44
  has_many :received_messages,
45
45
  :as => :receiver,
46
46
  :class_name => 'MessageRecipient',
47
47
  :include => :message,
48
48
  :conditions => ['message_recipients.hidden_at IS NULL AND messages.state = ?', 'sent'],
49
- :order => 'messages.created_at ASC'
49
+ :order => 'messages.created_at DESC'
50
50
 
51
51
  include HasMessages::InstanceMethods
52
52
  end
@@ -1,12 +1,12 @@
1
1
  class MigrateHasMessagesToVersion2 < ActiveRecord::Migration
2
2
  def self.up
3
- ActiveRecord::Migrator.new(:up, "#{Rails.root}/../../db/migrate", 0).migrations.each do |migration|
3
+ ActiveRecord::Migrator.new(:up, "#{Rails.root}/../../generators/has_messages/templates", 0).migrations.each do |migration|
4
4
  migration.migrate(:up)
5
5
  end
6
6
  end
7
7
 
8
8
  def self.down
9
- ActiveRecord::Migrator.new(:up, "#{Rails.root}/../../db/migrate", 0).migrations.each do |migration|
9
+ ActiveRecord::Migrator.new(:down, "#{Rails.root}/../../generators/has_messages/templates", 0).migrations.each do |migration|
10
10
  migration.migrate(:down)
11
11
  end
12
12
  end
@@ -37,7 +37,8 @@ module Factory
37
37
  attributes[:sender] = create_user unless attributes.include?(:sender)
38
38
  attributes.reverse_merge!(
39
39
  :subject => 'New features',
40
- :body => 'Lots of new things to talk about... come to the meeting tonight to find out!'
40
+ :body => 'Lots of new things to talk about... come to the meeting tonight to find out!',
41
+ :created_at => Time.current + Message.count
41
42
  )
42
43
  end
43
44
 
@@ -50,11 +50,11 @@ class UserWithUnsentMessages < ActiveSupport::TestCase
50
50
  end
51
51
 
52
52
  def test_should_have_unsent_messages
53
- assert_equal [@first_draft, @second_draft], @user.unsent_messages
53
+ assert_equal [@second_draft, @first_draft], @user.unsent_messages
54
54
  end
55
55
 
56
56
  def test_should_include_unsent_messages_in_messages
57
- assert_equal [@sent_message, @first_draft, @second_draft], @user.messages
57
+ assert_equal [@second_draft, @first_draft, @sent_message], @user.messages
58
58
  end
59
59
  end
60
60
 
@@ -63,6 +63,7 @@ class UserWithSentMessages < ActiveSupport::TestCase
63
63
  @user = create_user
64
64
  @to = create_user(:login => 'you')
65
65
  @draft = create_message(:sender => @user)
66
+ @draft.save!
66
67
 
67
68
  @first_sent_message = create_message(:sender => @user, :to => @to)
68
69
  @first_sent_message.deliver
@@ -72,11 +73,11 @@ class UserWithSentMessages < ActiveSupport::TestCase
72
73
  end
73
74
 
74
75
  def test_should_have_sent_messages
75
- assert_equal [@first_sent_message, @second_sent_message], @user.sent_messages
76
+ assert_equal [@second_sent_message, @first_sent_message], @user.sent_messages
76
77
  end
77
78
 
78
79
  def test_should_include_sent_messages_in_messages
79
- assert_equal [@draft, @first_sent_message, @second_sent_message], @user.messages
80
+ assert_equal [@second_sent_message, @first_sent_message, @draft], @user.messages
80
81
  end
81
82
  end
82
83
 
@@ -95,7 +96,7 @@ class UserWithReceivedMessages < ActiveSupport::TestCase
95
96
  end
96
97
 
97
98
  def test_should_have_received_messages
98
- assert_equal [@first_sent_message, @second_sent_message], @user.received_messages.map(&:message)
99
+ assert_equal [@second_sent_message, @first_sent_message], @user.received_messages.map(&:message)
99
100
  end
100
101
  end
101
102
 
@@ -122,7 +123,7 @@ class UserWithHiddenMessagesTest < ActiveSupport::TestCase
122
123
  end
123
124
 
124
125
  def test_should_not_include_hidden_messages_in_messages
125
- assert_equal [@unsent_message, @sent_message], @user.messages
126
+ assert_equal [@sent_message, @unsent_message], @user.messages
126
127
  end
127
128
 
128
129
  def test_should_not_include_hidden_messages_in_unsent_messages
metadata CHANGED
@@ -1,7 +1,7 @@
1
1
  --- !ruby/object:Gem::Specification
2
2
  name: has_messages
3
3
  version: !ruby/object:Gem::Version
4
- version: 0.4.0
4
+ version: 0.4.1
5
5
  platform: ruby
6
6
  authors:
7
7
  - Aaron Pfeifer
@@ -9,7 +9,7 @@ autorequire:
9
9
  bindir: bin
10
10
  cert_chain: []
11
11
 
12
- date: 2009-04-19 00:00:00 -04:00
12
+ date: 2010-03-07 00:00:00 -05:00
13
13
  default_executable:
14
14
  dependencies:
15
15
  - !ruby/object:Gem::Dependency
@@ -22,7 +22,7 @@ dependencies:
22
22
  - !ruby/object:Gem::Version
23
23
  version: 0.7.0
24
24
  version:
25
- description:
25
+ description: Demonstrates a reference implementation for sending messages between users in ActiveRecord
26
26
  email: aaron@pluginaweek.org
27
27
  executables: []
28
28
 
@@ -31,30 +31,22 @@ extensions: []
31
31
  extra_rdoc_files: []
32
32
 
33
33
  files:
34
- - app/models
35
- - app/models/message_recipient.rb
36
34
  - app/models/message.rb
37
- - db/migrate
38
- - db/migrate/001_create_messages.rb
39
- - db/migrate/002_create_message_recipients.rb
35
+ - app/models/message_recipient.rb
36
+ - generators/has_messages/USAGE
37
+ - generators/has_messages/has_messages_generator.rb
38
+ - generators/has_messages/templates/001_create_messages.rb
39
+ - generators/has_messages/templates/002_create_message_recipients.rb
40
40
  - lib/has_messages.rb
41
- - test/factory.rb
42
- - test/test_helper.rb
43
- - test/functional
44
- - test/functional/has_messages_test.rb
45
- - test/unit
46
- - test/unit/message_test.rb
47
41
  - test/unit/message_recipient_test.rb
48
- - test/app_root
49
- - test/app_root/db
50
- - test/app_root/db/migrate
42
+ - test/unit/message_test.rb
51
43
  - test/app_root/db/migrate/002_migrate_has_messages_to_version_2.rb
52
44
  - test/app_root/db/migrate/001_create_users.rb
53
- - test/app_root/config
54
- - test/app_root/config/environment.rb
55
- - test/app_root/app
56
- - test/app_root/app/models
57
45
  - test/app_root/app/models/user.rb
46
+ - test/app_root/config/environment.rb
47
+ - test/test_helper.rb
48
+ - test/factory.rb
49
+ - test/functional/has_messages_test.rb
58
50
  - CHANGELOG.rdoc
59
51
  - init.rb
60
52
  - LICENSE
@@ -62,6 +54,8 @@ files:
62
54
  - README.rdoc
63
55
  has_rdoc: true
64
56
  homepage: http://www.pluginaweek.org
57
+ licenses: []
58
+
65
59
  post_install_message:
66
60
  rdoc_options: []
67
61
 
@@ -82,11 +76,11 @@ required_rubygems_version: !ruby/object:Gem::Requirement
82
76
  requirements: []
83
77
 
84
78
  rubyforge_project: pluginaweek
85
- rubygems_version: 1.3.1
79
+ rubygems_version: 1.3.5
86
80
  signing_key:
87
- specification_version: 2
88
- summary: Demonstrates a reference implementation for sending messages between users.
81
+ specification_version: 3
82
+ summary: Demonstrates a reference implementation for sending messages between users in ActiveRecord
89
83
  test_files:
90
- - test/functional/has_messages_test.rb
91
- - test/unit/message_test.rb
92
84
  - test/unit/message_recipient_test.rb
85
+ - test/unit/message_test.rb
86
+ - test/functional/has_messages_test.rb