aboutsummaryrefslogtreecommitdiffstats
path: root/spec/fake_app.rb
blob: 29c18dc5b9e85b40453f58ada0f0e565c466c0ac (plain)
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
require 'active_record'
require 'action_controller/railtie'
# require 'action_view/railtie'

# require "cancan"
# require "cancan/ability"
# require "cancan/controller_resource"
# require "cancan/controller_additions"

require 'devise'
require 'devise/orm/active_record'

# database
if ENV['TRAVIS'].present?
  ActiveRecord::Base.configurations = {'test' => {:adapter => 'postgresql', :database => 'inboxes_test', :username => "postgres"}}
else
  ActiveRecord::Base.configurations = {'test' => {:adapter => 'sqlite3', :database => ':memory:'}}
end
ActiveRecord::Base.establish_connection('test')

# config
app = Class.new(Rails::Application)
app.config.secret_token = "3b7cd727ee24e8444053437c36cc66c4"
app.config.session_store :cookie_store, :key => "_myapp_session"
app.config.active_support.deprecation = :log
app.initialize!

require 'devise_config'

# models
class User < ActiveRecord::Base
  devise :database_authenticatable, :registerable,
         :recoverable, :rememberable, :trackable, :validatable
  attr_accessible :email, :password, :password_confirmation, :remember_me, :name
  validates :name, :presence => true
  has_inboxes
end

# routes
app.routes.draw do
  devise_for :users
end

#migrations
ActiveRecord::Base.silence do
  ActiveRecord::Migration.verbose = false
  ActiveRecord::Schema.define :version => 0 do
    create_table "users", :force => true do |t|
      t.string   "email",                                 :default => "", :null => false
      t.string   "encrypted_password",     :limit => 128, :default => "", :null => false
      t.string   "reset_password_token"
      t.datetime "reset_password_sent_at"
      t.datetime "remember_created_at"
      t.integer  "sign_in_count",                         :default => 0
      t.datetime "current_sign_in_at"
      t.datetime "last_sign_in_at"
      t.string   "current_sign_in_ip"
      t.string   "last_sign_in_ip"
      t.datetime "created_at"
      t.datetime "updated_at"
      t.string   "name"
    end
    
    create_table "discussions", :force => true do |t|
      t.integer  "user_id"
      t.integer  "messages_count", :default => 0
      t.boolean  "is_private",     :default => true
      t.datetime "created_at"
      t.datetime "updated_at"
    end

    create_table "messages", :force => true do |t|
      t.integer  "user_id"
      t.integer  "discussion_id"
      t.text     "body"
      t.datetime "created_at"
      t.datetime "updated_at"
    end

    create_table "speakers", :force => true do |t|
      t.integer  "user_id"
      t.integer  "discussion_id"
      t.datetime "created_at"
      t.datetime "updated_at"
    end
  end
end

# controllers
class ApplicationController < ActionController::Base
  before_filter :assign_unread_discussions
  
  private
  
  def assign_unread_discussions
    @unread_discussions_count = Discussion.unread_for(current_user).count if user_signed_in?
  end
end

# helpers
Object.const_set(:ApplicationHelper, Module.new)