Migration to Ruby on Rails 5.1

This commit is contained in:
echarp 2017-10-21 22:12:19 +02:00
parent e3a012fcdf
commit 4b7dfa2772
22 changed files with 390 additions and 321 deletions

67
Gemfile
View File

@ -1,25 +1,19 @@
source 'https://rubygems.org' source 'https://rubygems.org'
git_source(:github) do |repo_name|
repo_name = "#{repo_name}/#{repo_name}" unless repo_name.include?('/')
"https://github.com/#{repo_name}.git"
end
# The central piece of this application: the month calendar view # The central piece of this application: the month calendar view
gem 'simple_calendar' gem 'simple_calendar'
# The recurrence management library # The recurrence management library
gem 'ice_cube' gem 'ice_cube'
# Rails engine for static pages
gem 'high_voltage'
gem 'rails' gem 'rails', '~> 5.1.4'
# Use ActiveModel has_secure_password
# gem 'bcrypt', '~> 3.1.7'
# Use Unicorn as the app server
# gem 'unicorn'
# Use Capistrano for deployment
# gem 'capistrano-rails', group: :development
# Build JSON APIs with ease. Read more: https://github.com/rails/jbuilder # Build JSON APIs with ease. Read more: https://github.com/rails/jbuilder
gem 'jbuilder' gem 'jbuilder', '~> 2.5'
gem 'haml-rails' gem 'haml-rails'
@ -56,25 +50,41 @@ gem 'geocoder'
gem 'tinymce-rails' gem 'tinymce-rails'
gem 'tinymce-rails-langs' gem 'tinymce-rails-langs'
# The newer 5th version requires a newer ruby > 2.1 gem 'acts-as-taggable-on'
gem 'acts-as-taggable-on', '< 5'
gem 'tagsinput-rails' gem 'tagsinput-rails'
# Rails engine for static pages
gem 'high_voltage'
# SEO optimisations # SEO optimisations
gem 'meta-tags' gem 'meta-tags'
gem 'twitter' gem 'twitter'
group :development do group :development, :test do
gem 'quiet_assets' # Use sqlite3 as the database for Active Record
gem 'webrick' gem 'sqlite3'
# Access an IRB console on exception pages or by using <%= console %> in views
gem 'web-console'
# Call 'byebug' anywhere in the code to stop execution and get a debugger # Call 'byebug' anywhere in the code to stop execution and get a debugger
# console # console
gem 'byebug' gem 'byebug', platforms: %i[mri mingw x64_mingw]
# Adds support for Capybara system testing and selenium driver
gem 'capybara', '~> 2.13'
gem 'selenium-webdriver'
end
group :development do
gem 'listen', '>= 3.0.5', '< 3.2'
# Access an IRB console on exception pages or by using <%= console %>
# anywhere in the code.
gem 'web-console', '>= 3.3.0'
# Spring speeds up development by keeping your application
# running in the background. Read more:
# https://github.com/rails/spring
gem 'spring'
gem 'spring-watcher-listen', '~> 2.0.0'
# Use Puma as the app server
gem 'puma', '~> 3.7'
# Scanning the Gemfile for insecure dependencies based on published CVEs # Scanning the Gemfile for insecure dependencies based on published CVEs
gem 'bundler-audit' gem 'bundler-audit'
@ -92,14 +102,6 @@ group :development do
gem 'guard-rails', require: false gem 'guard-rails', require: false
end end
group :test do
gem 'simplecov'
end
group :development, :test do
gem 'sqlite3'
end
group :development, :test, :assets do group :development, :test, :assets do
# Use CoffeeScript for .coffee assets and views # Use CoffeeScript for .coffee assets and views
gem 'coffee-rails' gem 'coffee-rails'
@ -140,3 +142,6 @@ group :production do
# Use mysql as the database for Active Record # Use mysql as the database for Active Record
gem 'mysql2' gem 'mysql2'
end end
# Windows does not include zoneinfo files, so bundle the tzinfo-data gem
gem 'tzinfo-data', platforms: %i[mingw mswin x64_mingw jruby]

View File

@ -2,24 +2,28 @@ GEM
remote: https://rubygems.org/ remote: https://rubygems.org/
remote: https://rails-assets.org/ remote: https://rails-assets.org/
specs: specs:
actionmailer (4.2.10) actioncable (5.1.4)
actionpack (= 4.2.10) actionpack (= 5.1.4)
actionview (= 4.2.10) nio4r (~> 2.0)
activejob (= 4.2.10) websocket-driver (~> 0.6.1)
actionmailer (5.1.4)
actionpack (= 5.1.4)
actionview (= 5.1.4)
activejob (= 5.1.4)
mail (~> 2.5, >= 2.5.4) mail (~> 2.5, >= 2.5.4)
rails-dom-testing (~> 1.0, >= 1.0.5) rails-dom-testing (~> 2.0)
actionpack (4.2.10) actionpack (5.1.4)
actionview (= 4.2.10) actionview (= 5.1.4)
activesupport (= 4.2.10) activesupport (= 5.1.4)
rack (~> 1.6) rack (~> 2.0)
rack-test (~> 0.6.2) rack-test (>= 0.6.3)
rails-dom-testing (~> 1.0, >= 1.0.5) rails-dom-testing (~> 2.0)
rails-html-sanitizer (~> 1.0, >= 1.0.2) rails-html-sanitizer (~> 1.0, >= 1.0.2)
actionview (4.2.10) actionview (5.1.4)
activesupport (= 4.2.10) activesupport (= 5.1.4)
builder (~> 3.1) builder (~> 3.1)
erubis (~> 2.7.0) erubi (~> 1.4)
rails-dom-testing (~> 1.0, >= 1.0.5) rails-dom-testing (~> 2.0)
rails-html-sanitizer (~> 1.0, >= 1.0.3) rails-html-sanitizer (~> 1.0, >= 1.0.3)
actionview-encoded_mail_to (1.0.9) actionview-encoded_mail_to (1.0.9)
rails rails
@ -35,30 +39,30 @@ GEM
ransack (~> 1.3) ransack (~> 1.3)
sass (~> 3.1) sass (~> 3.1)
sprockets (< 4.1) sprockets (< 4.1)
activejob (4.2.10) activejob (5.1.4)
activesupport (= 4.2.10) activesupport (= 5.1.4)
globalid (>= 0.3.0) globalid (>= 0.3.6)
activemodel (4.2.10) activemodel (5.1.4)
activesupport (= 4.2.10) activesupport (= 5.1.4)
builder (~> 3.1) activerecord (5.1.4)
activerecord (4.2.10) activemodel (= 5.1.4)
activemodel (= 4.2.10) activesupport (= 5.1.4)
activesupport (= 4.2.10) arel (~> 8.0)
arel (~> 6.0) activesupport (5.1.4)
activesupport (4.2.10) concurrent-ruby (~> 1.0, >= 1.0.2)
i18n (~> 0.7) i18n (~> 0.7)
minitest (~> 5.1) minitest (~> 5.1)
thread_safe (~> 0.3, >= 0.3.4)
tzinfo (~> 1.1) tzinfo (~> 1.1)
acts-as-taggable-on (4.0.0) acts-as-taggable-on (5.0.0)
activerecord (>= 4.0) activerecord (>= 4.2.8)
addressable (2.5.2) addressable (2.5.2)
public_suffix (>= 2.0.2, < 4.0) public_suffix (>= 2.0.2, < 4.0)
arbre (1.1.1) arbre (1.1.1)
activesupport (>= 3.0.0) activesupport (>= 3.0.0)
arel (6.0.4) arel (8.0.0)
ast (2.3.0) ast (2.3.0)
bcrypt (3.1.11) bcrypt (3.1.11)
bindex (0.5.0)
brakeman (4.0.1) brakeman (4.0.1)
buftok (0.2.0) buftok (0.2.0)
builder (3.2.3) builder (3.2.3)
@ -66,6 +70,15 @@ GEM
bundler (~> 1.2) bundler (~> 1.2)
thor (~> 0.18) thor (~> 0.18)
byebug (9.1.0) byebug (9.1.0)
capybara (2.15.4)
addressable
mini_mime (>= 0.1.3)
nokogiri (>= 1.3.3)
rack (>= 1.0.0)
rack-test (>= 0.5.4)
xpath (~> 2.0)
childprocess (0.8.0)
ffi (~> 1.0, >= 1.0.11)
coderay (1.1.2) coderay (1.1.2)
coffee-rails (4.2.2) coffee-rails (4.2.2)
coffee-script (>= 2.2.0) coffee-script (>= 2.2.0)
@ -76,7 +89,6 @@ GEM
coffee-script-source (1.12.2) coffee-script-source (1.12.2)
concurrent-ruby (1.0.5) concurrent-ruby (1.0.5)
crass (1.0.2) crass (1.0.2)
debug_inspector (0.0.3)
devise (4.3.0) devise (4.3.0)
bcrypt (~> 3.0) bcrypt (~> 3.0)
orm_adapter (~> 0.1) orm_adapter (~> 0.1)
@ -86,7 +98,6 @@ GEM
devise-i18n (1.3.0) devise-i18n (1.3.0)
devise (>= 2.0) devise (>= 2.0)
differ (0.1.2) differ (0.1.2)
docile (1.1.5)
domain_name (0.5.20170404) domain_name (0.5.20170404)
unf (>= 0.0.5, < 1.0.0) unf (>= 0.0.5, < 1.0.0)
em-websocket (0.5.1) em-websocket (0.5.1)
@ -95,6 +106,7 @@ GEM
email_validator (1.6.0) email_validator (1.6.0)
activemodel activemodel
equalizer (0.0.11) equalizer (0.0.11)
erubi (1.7.0)
erubis (2.7.0) erubis (2.7.0)
eventmachine (1.2.5) eventmachine (1.2.5)
execjs (2.7.0) execjs (2.7.0)
@ -181,7 +193,8 @@ GEM
http-form_data (1.0.3) http-form_data (1.0.3)
http_accept_language (2.1.1) http_accept_language (2.1.1)
http_parser.rb (0.6.0) http_parser.rb (0.6.0)
i18n (0.8.6) i18n (0.9.0)
concurrent-ruby (~> 1.0)
i18n-active_record (0.2.0) i18n-active_record (0.2.0)
i18n (>= 0.5.0) i18n (>= 0.5.0)
ice_cube (0.16.2) ice_cube (0.16.2)
@ -232,7 +245,7 @@ GEM
mime-types (3.1) mime-types (3.1)
mime-types-data (~> 3.2015) mime-types-data (~> 3.2015)
mime-types-data (3.2016.0521) mime-types-data (3.2016.0521)
mini_portile2 (2.3.0) mini_mime (0.1.4)
minitest (5.10.3) minitest (5.10.3)
modernizr-rails (2.7.1) modernizr-rails (2.7.1)
multi_json (1.12.2) multi_json (1.12.2)
@ -240,8 +253,8 @@ GEM
mysql2 (0.4.9) mysql2 (0.4.9)
naught (1.1.0) naught (1.1.0)
nenv (0.3.0) nenv (0.3.0)
nio4r (2.1.0)
nokogiri (1.8.1) nokogiri (1.8.1)
mini_portile2 (~> 2.3.0)
notiffany (0.1.1) notiffany (0.1.1)
nenv (~> 0.1) nenv (~> 0.1)
shellany (~> 0.0) shellany (~> 0.0)
@ -259,46 +272,44 @@ GEM
polyamorous (1.3.1) polyamorous (1.3.1)
activerecord (>= 3.0) activerecord (>= 3.0)
powerpack (0.1.1) powerpack (0.1.1)
pry (0.11.1) pry (0.11.2)
coderay (~> 1.1.0) coderay (~> 1.1.0)
method_source (~> 0.9.0) method_source (~> 0.9.0)
public_suffix (3.0.0) public_suffix (3.0.0)
quiet_assets (1.1.0) puma (3.10.0)
railties (>= 3.1, < 5.0) rack (2.0.3)
rack (1.6.8)
rack-livereload (0.3.16) rack-livereload (0.3.16)
rack rack
rack-test (0.6.3) rack-test (0.7.0)
rack (>= 1.0) rack (>= 1.0, < 3)
rails (4.2.10) rails (5.1.4)
actionmailer (= 4.2.10) actioncable (= 5.1.4)
actionpack (= 4.2.10) actionmailer (= 5.1.4)
actionview (= 4.2.10) actionpack (= 5.1.4)
activejob (= 4.2.10) actionview (= 5.1.4)
activemodel (= 4.2.10) activejob (= 5.1.4)
activerecord (= 4.2.10) activemodel (= 5.1.4)
activesupport (= 4.2.10) activerecord (= 5.1.4)
bundler (>= 1.3.0, < 2.0) activesupport (= 5.1.4)
railties (= 4.2.10) bundler (>= 1.3.0)
sprockets-rails railties (= 5.1.4)
sprockets-rails (>= 2.0.0)
rails-assets-jquery-sparkline (2.1.3) rails-assets-jquery-sparkline (2.1.3)
rails-assets-leaflet (1.2.0) rails-assets-leaflet (1.2.0)
rails-assets-leaflet.markercluster (1.1.0) rails-assets-leaflet.markercluster (1.1.0)
rails-assets-leaflet (>= 1.0.3) rails-assets-leaflet (>= 1.0.3)
rails-deprecated_sanitizer (1.0.3) rails-dom-testing (2.0.3)
activesupport (>= 4.2.0.alpha) activesupport (>= 4.2.0)
rails-dom-testing (1.0.8) nokogiri (>= 1.6)
activesupport (>= 4.2.0.beta, < 5.0)
nokogiri (~> 1.6)
rails-deprecated_sanitizer (>= 1.0.1)
rails-html-sanitizer (1.0.3) rails-html-sanitizer (1.0.3)
loofah (~> 2.0) loofah (~> 2.0)
rails-i18n (4.0.9) rails-i18n (5.0.4)
i18n (~> 0.7) i18n (~> 0.7)
railties (~> 4.0) railties (~> 5.0)
railties (4.2.10) railties (5.1.4)
actionpack (= 4.2.10) actionpack (= 5.1.4)
activesupport (= 4.2.10) activesupport (= 5.1.4)
method_source
rake (>= 0.8.7) rake (>= 0.8.7)
thor (>= 0.18.1, < 2.0) thor (>= 0.18.1, < 2.0)
rainbow (2.2.2) rainbow (2.2.2)
@ -319,7 +330,7 @@ GEM
responders (2.4.0) responders (2.4.0)
actionpack (>= 4.2.0, < 5.3) actionpack (>= 4.2.0, < 5.3)
railties (>= 4.2.0, < 5.3) railties (>= 4.2.0, < 5.3)
rubocop (0.50.0) rubocop (0.51.0)
parallel (~> 1.10) parallel (~> 1.10)
parser (>= 2.3.3.1, < 3.0) parser (>= 2.3.3.1, < 3.0)
powerpack (~> 0.1) powerpack (~> 0.1)
@ -330,6 +341,7 @@ GEM
ruby_dep (1.5.0) ruby_dep (1.5.0)
ruby_parser (3.10.1) ruby_parser (3.10.1)
sexp_processor (~> 4.9) sexp_processor (~> 4.9)
rubyzip (1.2.1)
sass (3.5.2) sass (3.5.2)
sass-listen (~> 4.0.0) sass-listen (~> 4.0.0)
sass-listen (4.0.0) sass-listen (4.0.0)
@ -344,16 +356,19 @@ GEM
sdoc (0.4.2) sdoc (0.4.2)
json (~> 1.7, >= 1.7.7) json (~> 1.7, >= 1.7.7)
rdoc (~> 4.0) rdoc (~> 4.0)
selenium-webdriver (3.6.0)
childprocess (~> 0.5)
rubyzip (~> 1.0)
sexp_processor (4.10.0) sexp_processor (4.10.0)
shellany (0.0.1) shellany (0.0.1)
simple_calendar (2.2.7) simple_calendar (2.2.7)
rails (>= 3.0) rails (>= 3.0)
simple_oauth (0.3.1) simple_oauth (0.3.1)
simplecov (0.15.1) spring (2.0.2)
docile (~> 1.1.0) activesupport (>= 4.2)
json (>= 1.8, < 3) spring-watcher-listen (2.0.1)
simplecov-html (~> 0.10.0) listen (>= 2.7, < 4.0)
simplecov-html (0.10.2) spring (>= 1.2, < 3.0)
sprockets (3.7.1) sprockets (3.7.1)
concurrent-ruby (~> 1.0) concurrent-ruby (~> 1.0)
rack (> 1, < 3) rack (> 1, < 3)
@ -374,7 +389,7 @@ GEM
thor (0.20.0) thor (0.20.0)
thread_safe (0.3.6) thread_safe (0.3.6)
tilt (2.0.8) tilt (2.0.8)
tinymce-rails (4.6.7) tinymce-rails (4.7.1)
railties (>= 3.1.1) railties (>= 3.1.1)
tinymce-rails-langs (4.20160310) tinymce-rails-langs (4.20160310)
tinymce-rails (~> 4.1, >= 4.1.10) tinymce-rails (~> 4.1, >= 4.1.10)
@ -401,11 +416,16 @@ GEM
unicode-display_width (1.3.0) unicode-display_width (1.3.0)
warden (1.2.7) warden (1.2.7)
rack (>= 1.0) rack (>= 1.0)
web-console (3.3.0) web-console (3.5.1)
activemodel (>= 4.2) actionview (>= 5.0)
debug_inspector activemodel (>= 5.0)
railties (>= 4.2) bindex (>= 0.4.0)
webrick (1.3.1) railties (>= 5.0)
websocket-driver (0.6.5)
websocket-extensions (>= 0.1.0)
websocket-extensions (0.1.2)
xpath (2.1.0)
nokogiri (~> 1.3)
PLATFORMS PLATFORMS
ruby ruby
@ -413,10 +433,11 @@ PLATFORMS
DEPENDENCIES DEPENDENCIES
actionview-encoded_mail_to actionview-encoded_mail_to
activeadmin activeadmin
acts-as-taggable-on (< 5) acts-as-taggable-on
brakeman brakeman
bundler-audit bundler-audit
byebug byebug
capybara (~> 2.13)
coffee-rails coffee-rails
devise devise
devise-i18n devise-i18n
@ -439,25 +460,28 @@ DEPENDENCIES
http_accept_language http_accept_language
i18n-active_record i18n-active_record
ice_cube ice_cube
jbuilder jbuilder (~> 2.5)
jquery-ui-rails jquery-ui-rails
kramdown kramdown
listen (>= 3.0.5, < 3.2)
meta-tags meta-tags
modernizr-rails modernizr-rails
mysql2 mysql2
paper_trail paper_trail
piwik_analytics piwik_analytics
quiet_assets puma (~> 3.7)
rack-livereload rack-livereload
rails rails (~> 5.1.4)
rails-assets-jquery-sparkline! rails-assets-jquery-sparkline!
rails-assets-leaflet! rails-assets-leaflet!
rails-assets-leaflet.markercluster! rails-assets-leaflet.markercluster!
rails-i18n rails-i18n
sass-rails sass-rails
sdoc sdoc
selenium-webdriver
simple_calendar simple_calendar
simplecov spring
spring-watcher-listen (~> 2.0.0)
sqlite3 sqlite3
strip_attributes strip_attributes
tagsinput-rails tagsinput-rails
@ -466,9 +490,9 @@ DEPENDENCIES
tinymce-rails-langs tinymce-rails-langs
turbolinks turbolinks
twitter twitter
tzinfo-data
uglifier uglifier
web-console web-console (>= 3.3.0)
webrick
BUNDLED WITH BUNDLED WITH
1.15.1 1.15.1

View File

@ -66,6 +66,11 @@ input, textarea, select, a.button, .actions > button, .mce-tinymce, div.tagsinpu
letter-spacing: 2px letter-spacing: 2px
background-color: #9CC5EE background-color: #9CC5EE
.mce-tinymce
box-shadow: none !important
.mce-top-part:before
box-shadow: 0 1px lightgray !important
.field_with_errors .field_with_errors
display: inline display: inline
input, textarea, select, a.button input, textarea, select, a.button

View File

@ -20,8 +20,8 @@ class DigestsController < ApplicationController
private private
def set_week def set_week
@week = DateTime.commercial params[:period][:year].to_i, @week = Time.commercial params[:period][:year].to_i,
params[:period][:week].to_i params[:period][:week].to_i
end end
def set_events def set_events

View File

@ -10,8 +10,8 @@ class Event < ApplicationRecord
decision_time latitude longitude] decision_time latitude longitude]
belongs_to :region belongs_to :region
# This is the scheduled first event # This is the eventual scheduled first event
belongs_to :event belongs_to :event, optional: true
has_many :notes, dependent: :destroy has_many :notes, dependent: :destroy
has_many :events, dependent: :destroy has_many :events, dependent: :destroy
@ -59,7 +59,7 @@ class Event < ApplicationRecord
start_date.to_date.end_of_month.end_of_week.end_of_day start_date.to_date.end_of_month.end_of_week.end_of_day
end) end)
scope :period, (lambda do |year, week| scope :period, (lambda do |year, week|
start_date = DateTime.commercial(year.to_i, week.to_i) start_date = Time.commercial(year.to_i, week.to_i)
where '? <= end_time and start_time <= ?', where '? <= end_time and start_time <= ?',
start_date, start_date.end_of_week.end_of_day start_date, start_date.end_of_week.end_of_day
end) end)

View File

@ -14,7 +14,7 @@ class EventCallbacks
end end
def self.before_update(event) def self.before_update(event)
return unless event.moderated_changed? && event.moderated? return unless event.will_save_change_to_moderated? && event.moderated?
event.decision_time = Time.zone.now event.decision_time = Time.zone.now
create_repeats event if event.repeat > 0 && event.rule create_repeats event if event.repeat > 0 && event.rule
end end

View File

@ -1,7 +1,7 @@
# Manages data related to events' moderation # Manages data related to events' moderation
class Note < ApplicationRecord class Note < ApplicationRecord
belongs_to :event belongs_to :event
belongs_to :author, class_name: User belongs_to :author, class_name: 'User'
validates :contents, presence: true validates :contents, presence: true

View File

@ -1,4 +1,4 @@
#!/usr/bin/env ruby #!/usr/bin/env ruby
APP_PATH = File.expand_path('../../config/application', __FILE__) APP_PATH = File.expand_path('../config/application', __dir__)
require_relative '../config/boot' require_relative '../config/boot'
require 'rails/commands' require 'rails/commands'

View File

@ -1,29 +1,37 @@
#!/usr/bin/env ruby #!/usr/bin/env ruby
require 'pathname' require 'pathname'
require 'fileutils'
include FileUtils
# path to your application root. # path to your application root.
APP_ROOT = Pathname.new File.expand_path('../../', __FILE__) APP_ROOT = Pathname.new File.expand_path('../../', __FILE__)
Dir.chdir APP_ROOT do def system!(*args)
system(*args) || abort("\n== Command #{args} failed ==")
end
chdir APP_ROOT do
# This script is a starting point to setup your application. # This script is a starting point to setup your application.
# Add necessary setup steps to this file: # Add necessary setup steps to this file.
puts '== Installing dependencies ==' puts '== Installing dependencies =='
system 'gem install bundler --conservative' system! 'gem install bundler --conservative'
system 'bundle check || bundle install' system('bundle check') || system!('bundle install')
# Install JavaScript dependencies if using Yarn
# system('bin/yarn')
# puts "\n== Copying sample files ==" # puts "\n== Copying sample files =="
# unless File.exist?("config/database.yml") # unless File.exist?('config/database.yml')
# system "cp config/database.yml.sample config/database.yml" # cp 'config/database.yml.sample', 'config/database.yml'
# end # end
puts '\n== Preparing database ==' puts "\n== Preparing database =="
system 'bin/rake db:setup' system! 'bin/rails db:setup'
puts '\n== Removing old logs and tempfiles ==' puts "\n== Removing old logs and tempfiles =="
system 'rm -f log/*' system! 'bin/rails log:clear tmp:clear'
system 'rm -rf tmp/cache'
puts '\n== Restarting application server ==' puts "\n== Restarting application server =="
system 'touch tmp/restart.txt' system! 'bin/rails restart'
end end

View File

@ -10,6 +10,8 @@ Bundler.require(*Rails.groups)
module AgendaDuLibreRails module AgendaDuLibreRails
# All the specific configuraton for ADL # All the specific configuraton for ADL
class Application < Rails::Application class Application < Rails::Application
# Initialize configuration defaults for originally generated Rails version.
config.load_defaults 5.1
# Settings in config/environments/* take precedence over those specified # Settings in config/environments/* take precedence over those specified
# here. # here.
# Application configuration should go into files in config/initializers # Application configuration should go into files in config/initializers
@ -36,12 +38,8 @@ module AgendaDuLibreRails
to: 'moderateurs@agendadulibre.org' to: 'moderateurs@agendadulibre.org'
} }
# config.quiet_assets = false
config.action_dispatch.default_headers['X-Frame-Options'] = 'ALLOWALL' config.action_dispatch.default_headers['X-Frame-Options'] = 'ALLOWALL'
config.active_record.raise_in_transactional_callbacks = true
# In rails 4, plugin and vendor images need to be precompiled # In rails 4, plugin and vendor images need to be precompiled
config.assets.precompile += %w[*.png *.jpg *.jpeg *.gif] config.assets.precompile += %w[*.png *.jpg *.jpeg *.gif]
end end

View File

@ -1,3 +1,3 @@
ENV['BUNDLE_GEMFILE'] ||= File.expand_path('../../Gemfile', __FILE__) ENV['BUNDLE_GEMFILE'] ||= File.expand_path('../Gemfile', __dir__)
require 'bundler/setup' # Set up gems listed in the Gemfile. require 'bundler/setup' # Set up gems listed in the Gemfile.

View File

@ -1,5 +1,5 @@
# Load the Rails application. # Load the Rails application.
require File.expand_path('../application', __FILE__) require_relative 'application'
# Initialize the Rails application. # Initialize the Rails application.
Rails.application.initialize! Rails.application.initialize!

View File

@ -10,13 +10,28 @@ Rails.application.configure do
# Do not eager load code on boot. # Do not eager load code on boot.
config.eager_load = false config.eager_load = false
# Show full error reports and disable caching. # Show full error reports.
config.consider_all_requests_local = true config.consider_all_requests_local = true
config.action_controller.perform_caching = false
# Enable/disable caching. By default caching is disabled.
if Rails.root.join('tmp', 'caching-dev.txt').exist?
config.action_controller.perform_caching = true
config.cache_store = :memory_store
config.public_file_server.headers = {
'Cache-Control' => "public, max-age=#{2.days.seconds.to_i}"
}
else
config.action_controller.perform_caching = false
config.cache_store = :null_store
end
# Don't care if the mailer can't send. # Don't care if the mailer can't send.
config.action_mailer.raise_delivery_errors = false config.action_mailer.raise_delivery_errors = false
config.action_mailer.perform_caching = false
# Print deprecation notices to the Rails logger. # Print deprecation notices to the Rails logger.
config.active_support.deprecation = :log config.active_support.deprecation = :log
@ -28,24 +43,18 @@ Rails.application.configure do
# number of complex assets. # number of complex assets.
config.assets.debug = true config.assets.debug = true
# Asset digests allow you to set far-future HTTP expiration dates on all # Suppress logger output for asset requests.
# assets, yet still be able to expire them through the digest params. config.assets.quiet = true
config.assets.digest = true
# Adds additional error checking when serving assets at runtime.
# Checks for improperly declared sprockets dependencies.
# Raises helpful error messages.
config.assets.raise_runtime_errors = true
# Raises error for missing translations # Raises error for missing translations
# config.action_view.raise_on_missing_translations = true # config.action_view.raise_on_missing_translations = true
# Add Rack::LiveReload to the bottom of the middleware stack with the default
# options.
config.middleware.insert_after ActionDispatch::Static, Rack::LiveReload
# To have assets Local Precompilation, we need to use another path in dev # To have assets Local Precompilation, we need to use another path in dev
config.assets.prefix = '/dev-assets' config.assets.prefix = '/dev-assets'
config.sass.preferred_syntax = :sass config.sass.preferred_syntax = :sass
# Use an evented file watcher to asynchronously detect changes in source code,
# routes, locales, etc. This feature depends on the listen gem.
config.file_watcher = ActiveSupport::EventedFileUpdateChecker
end end

View File

@ -15,15 +15,14 @@ Rails.application.configure do
config.consider_all_requests_local = false config.consider_all_requests_local = false
config.action_controller.perform_caching = true config.action_controller.perform_caching = true
# Enable Rack::Cache to put a simple HTTP cache in front of your application # Attempt to read encrypted secrets from `config/secrets.yml.enc`.
# Add `rack-cache` to your Gemfile before enabling this. # Requires an encryption key in `ENV["RAILS_MASTER_KEY"]` or
# For large-scale production use, consider using a caching reverse proxy like # `config/secrets.yml.key`.
# NGINX, varnish or squid. config.read_encrypted_secrets = true
# config.action_dispatch.rack_cache = true
# Disable serving static files from the `/public` folder by default since # Disable serving static files from the `/public` folder by default since
# Apache or NGINX already handles this. # Apache or NGINX already handles this.
config.serve_static_files = ENV['RAILS_SERVE_STATIC_FILES'].present? config.public_file_server.enabled = ENV['RAILS_SERVE_STATIC_FILES'].present?
# Compress JavaScripts and CSS. # Compress JavaScripts and CSS.
config.assets.js_compressor = :uglifier config.assets.js_compressor = :uglifier
@ -32,43 +31,46 @@ Rails.application.configure do
# Do not fallback to assets pipeline if a precompiled asset is missed. # Do not fallback to assets pipeline if a precompiled asset is missed.
config.assets.compile = false config.assets.compile = false
# Asset digests allow you to set far-future HTTP expiration dates on all
# assets, yet still be able to expire them through the digest params.
config.assets.digest = true
# `config.assets.precompile` and `config.assets.version` have moved to # `config.assets.precompile` and `config.assets.version` have moved to
# config/initializers/assets.rb # config/initializers/assets.rb
# Enable serving of images, stylesheets, and JavaScripts from an asset server.
# config.action_controller.asset_host = 'http://assets.example.com'
# Specifies the header that your server uses for sending files. # Specifies the header that your server uses for sending files.
# config.action_dispatch.x_sendfile_header = 'X-Sendfile' # for Apache # config.action_dispatch.x_sendfile_header = 'X-Sendfile' # for Apache
# config.action_dispatch.x_sendfile_header = 'X-Accel-Redirect' # for NGINX # config.action_dispatch.x_sendfile_header = 'X-Accel-Redirect' # for NGINX
# Mount Action Cable outside main process or domain
# config.action_cable.mount_path = nil
# config.action_cable.url = 'wss://example.com/cable'
# config.action_cable.allowed_request_origins = [ 'http://example.com',
# /http:\/\/example.*/ ]
# Force all access to the app over SSL, use Strict-Transport-Security, and # Force all access to the app over SSL, use Strict-Transport-Security, and
# use secure cookies. # use secure cookies.
# config.force_ssl = true # config.force_ssl = true
# Use the lowest log level to ensure availability of diagnostic information # Use the lowest log level to ensure availability of diagnostic information
# when problems arise. # when problems arise.
config.log_level = :warn config.log_level = :debug
# Prepend all log lines with the following tags. # Prepend all log lines with the following tags.
# config.log_tags = [ :subdomain, :uuid ] config.log_tags = [:request_id]
# Use a different logger for distributed setups.
# config.logger = ActiveSupport::TaggedLogging.new(SyslogLogger.new)
# Use a different cache store in production. # Use a different cache store in production.
# config.cache_store = :mem_cache_store # config.cache_store = :mem_cache_store
# Enable serving of images, stylesheets, and JavaScripts from an asset server. # Use a real queuing backend for Active Job (and separate queues per
# config.action_controller.asset_host = 'http://assets.example.com' # environment)
# config.action_controller.asset_host = '//assets%d.agendadulibre.org' # config.active_job.queue_adapter = :resque
# config.active_job.queue_name_prefix = "agenda_du_libre_rails_#{Rails.env}"
config.action_mailer.perform_caching = false
# Ignore bad email addresses and do not raise email delivery errors. # Ignore bad email addresses and do not raise email delivery errors.
# Set this to true and configure the email server for immediate delivery to # Set this to true and configure the email server for immediate delivery to
# raise delivery errors. # raise delivery errors.
# config.action_mailer.raise_delivery_errors = false # config.action_mailer.raise_delivery_errors = false
config.action_mailer.smtp_settings = { openssl_verify_mode: 'none' }
# Enable locale fallbacks for I18n (makes lookups for any locale fall back to # Enable locale fallbacks for I18n (makes lookups for any locale fall back to
# the I18n.default_locale when a translation cannot be found). # the I18n.default_locale when a translation cannot be found).
@ -80,6 +82,17 @@ Rails.application.configure do
# Use default logging formatter so that PID and timestamp are not suppressed. # Use default logging formatter so that PID and timestamp are not suppressed.
config.log_formatter = ::Logger::Formatter.new config.log_formatter = ::Logger::Formatter.new
# Use a different logger for distributed setups.
# require 'syslog/logger'
# config.logger = ActiveSupport::TaggedLogging.new(Syslog::Logger.new
# 'app-name')
if ENV['RAILS_LOG_TO_STDOUT'].present?
logger = ActiveSupport::Logger.new(STDOUT)
logger.formatter = config.log_formatter
config.logger = ActiveSupport::TaggedLogging.new(logger)
end
# Do not dump schema after migrations. # Do not dump schema after migrations.
config.active_record.dump_schema_after_migration = false config.active_record.dump_schema_after_migration = false
end end

View File

@ -13,9 +13,11 @@ Rails.application.configure do
# preloads Rails for running tests, you may have to set it to true. # preloads Rails for running tests, you may have to set it to true.
config.eager_load = false config.eager_load = false
# Configure static file server for tests with Cache-Control for performance. # Configure public file server for tests with Cache-Control for performance.
config.serve_static_files = true config.public_file_server.enabled = true
config.static_cache_control = 'public, max-age=3600' config.public_file_server.headers = {
'Cache-Control' => "public, max-age=#{1.hour.seconds.to_i}"
}
# Show full error reports and disable caching. # Show full error reports and disable caching.
config.consider_all_requests_local = true config.consider_all_requests_local = true
@ -26,15 +28,13 @@ Rails.application.configure do
# Disable request forgery protection in test environment. # Disable request forgery protection in test environment.
config.action_controller.allow_forgery_protection = false config.action_controller.allow_forgery_protection = false
config.action_mailer.perform_caching = false
# Tell Action Mailer not to deliver emails to the real world. # Tell Action Mailer not to deliver emails to the real world.
# The :test delivery method accumulates sent emails in the # The :test delivery method accumulates sent emails in the
# ActionMailer::Base.deliveries array. # ActionMailer::Base.deliveries array.
config.action_mailer.delivery_method = :test config.action_mailer.delivery_method = :test
# Randomize the order test cases are executed.
config.active_support.test_order = :random
# Print deprecation notices to the stderr. # Print deprecation notices to the stderr.
config.active_support.deprecation = :stderr config.active_support.deprecation = :stderr

View File

@ -3,10 +3,12 @@
# Version of your assets, change this if you want to expire all your assets. # Version of your assets, change this if you want to expire all your assets.
Rails.application.config.assets.version = '1.0' Rails.application.config.assets.version = '1.0'
# Add additional assets to the asset load path # Add additional assets to the asset load path.
# Rails.application.config.assets.paths << Emoji.images_path # Rails.application.config.assets.paths << Emoji.images_path
# Add Yarn node_modules folder to the asset load path.
Rails.application.config.assets.paths << Rails.root.join('node_modules')
# Precompile additional assets. # Precompile additional assets.
# application.js, application.css, and all non-JS/CSS in app/assets folder are # application.js, application.css, and all non-JS/CSS in the app/assets
# already added. # folder are already added.
# Rails.application.config.assets.precompile += %w( search.js ) # Rails.application.config.assets.precompile += %w( admin.js admin.css )

View File

@ -1,3 +1,5 @@
# Be sure to restart your server when you modify this file. # Be sure to restart your server when you modify this file.
# Specify a serializer for the signed and encrypted cookie jars.
# Valid options are :json, :marshal, and :hybrid.
Rails.application.config.action_dispatch.cookies_serializer = :json Rails.application.config.action_dispatch.cookies_serializer = :json

View File

@ -1,7 +1,6 @@
# Be sure to restart your server when you modify this file. # Be sure to restart your server when you modify this file.
# Add new mime types for use in respond_to blocks: # Add new mime types for use in respond_to blocks:
# Mime::Type.register 'text/richtext', :rtf # Mime::Type.register "text/richtext", :rtf
# Necessary for the /ical.php redirect to /events.ics # Necessary for the /ical.php redirect to /events.ics
Mime::Type.register 'text/calendar', :ics, [], %w[ical] Mime::Type.register 'text/calendar', :ics, [], %w[ical]

View File

@ -6,10 +6,10 @@
# Enable parameter wrapping for JSON. You can disable this by setting :format # Enable parameter wrapping for JSON. You can disable this by setting :format
# to an empty array. # to an empty array.
ActiveSupport.on_load(:action_controller) do ActiveSupport.on_load(:action_controller) do
wrap_parameters format: [:json] if respond_to?(:wrap_parameters) wrap_parameters format: [:json]
end end
# To enable root element in JSON for ActiveRecord objects. # To enable root element in JSON for ActiveRecord objects.
# ActiveSupport.on_load(:active_record) do # ActiveSupport.on_load(:active_record) do
# self.include_root_in_json = true # self.include_root_in_json = true
# end # end

View File

@ -5,11 +5,18 @@
# Make sure the secret is at least 30 characters and all random, # Make sure the secret is at least 30 characters and all random,
# no regular words or you'll be exposed to dictionary attacks. # no regular words or you'll be exposed to dictionary attacks.
# You can use `rake secret` to generate a secure secret key. # You can use `rails secret` to generate a secure secret key.
# Make sure the secrets in this file are kept private # Make sure the secrets in this file are kept private
# if you're sharing your code publicly. # if you're sharing your code publicly.
# Shared secrets are available across all environments.
# shared:
# api_key: a1B2c3D4e5F6
# Environmental secrets are only available for that specific environment.
development: development:
secret_key_base: dbe66d64011b60f265d7425be28bb09900e9b92dc858127490ac7c4294352aa360a562f60ee3efc554b7ce449b0244c04c5bed57cb28ca1df1e6a6e368ee5b9f secret_key_base: dbe66d64011b60f265d7425be28bb09900e9b92dc858127490ac7c4294352aa360a562f60ee3efc554b7ce449b0244c04c5bed57cb28ca1df1e6a6e368ee5b9f
@ -19,8 +26,11 @@ test:
assets: assets:
secret_key_base: hello world secret_key_base: hello world
# Do not keep production secrets in the repository, # Do not keep production secrets in the unencrypted secrets file.
# instead read values from the environment. # Instead, either read values from the environment.
# Or, use `bin/rails secrets:setup` to configure encrypted secrets
# and move the `production:` environment over there.
production: production:
secret_key_base: <%= ENV['SECRET_KEY_BASE'] || 'hello world' %> secret_key_base: <%= ENV['SECRET_KEY_BASE'] || 'hello world' %>
production_communs: production_communs:

View File

@ -1,4 +1,3 @@
# encoding: UTF-8
# This file is auto-generated from the current state of the database. Instead # This file is auto-generated from the current state of the database. Instead
# of editing this file, please use the migrations feature of Active Record to # of editing this file, please use the migrations feature of Active Record to
# incrementally modify your database, and then regenerate this schema definition. # incrementally modify your database, and then regenerate this schema definition.
@ -11,189 +10,186 @@
# #
# It's strongly recommended that you check this file into your version control system. # It's strongly recommended that you check this file into your version control system.
ActiveRecord::Schema.define(version: 20170701161358) do ActiveRecord::Schema.define(version: 20171015143615) do
create_table "active_admin_comments", force: :cascade do |t| create_table "active_admin_comments", force: :cascade do |t|
t.string "namespace" t.string "namespace"
t.text "body" t.text "body"
t.string "resource_id", null: false t.string "resource_id", null: false
t.string "resource_type", null: false t.string "resource_type", null: false
t.integer "author_id" t.integer "author_id"
t.string "author_type" t.string "author_type"
t.datetime "created_at" t.datetime "created_at"
t.datetime "updated_at" t.datetime "updated_at"
t.index ["author_type", "author_id"], name: "index_active_admin_comments_on_author_type_and_author_id"
t.index ["namespace"], name: "index_active_admin_comments_on_namespace"
t.index ["resource_type", "resource_id"], name: "index_active_admin_comments_on_resource_type_and_resource_id"
end end
add_index "active_admin_comments", ["author_type", "author_id"], name: "index_active_admin_comments_on_author_type_and_author_id"
add_index "active_admin_comments", ["namespace"], name: "index_active_admin_comments_on_namespace"
add_index "active_admin_comments", ["resource_type", "resource_id"], name: "index_active_admin_comments_on_resource_type_and_resource_id"
create_table "admin_users", force: :cascade do |t| create_table "admin_users", force: :cascade do |t|
t.string "email", default: "", null: false t.string "email", default: "", null: false
t.string "encrypted_password", default: "", null: false t.string "encrypted_password", default: "", null: false
t.string "reset_password_token" t.string "reset_password_token"
t.datetime "reset_password_sent_at" t.datetime "reset_password_sent_at"
t.datetime "remember_created_at" t.datetime "remember_created_at"
t.integer "sign_in_count", default: 0, null: false t.integer "sign_in_count", default: 0, null: false
t.datetime "current_sign_in_at" t.datetime "current_sign_in_at"
t.datetime "last_sign_in_at" t.datetime "last_sign_in_at"
t.string "current_sign_in_ip" t.string "current_sign_in_ip"
t.string "last_sign_in_ip" t.string "last_sign_in_ip"
t.datetime "created_at" t.datetime "created_at"
t.datetime "updated_at" t.datetime "updated_at"
t.index ["email"], name: "index_admin_users_on_email", unique: true
t.index ["reset_password_token"], name: "index_admin_users_on_reset_password_token", unique: true
end end
add_index "admin_users", ["email"], name: "index_admin_users_on_email", unique: true
add_index "admin_users", ["reset_password_token"], name: "index_admin_users_on_reset_password_token", unique: true
create_table "cities", force: :cascade do |t| create_table "cities", force: :cascade do |t|
t.string "name", limit: 255, default: "", null: false t.string "name", limit: 255, default: "", null: false
t.string "majname", limit: 255, default: "", null: false t.string "majname", limit: 255, default: "", null: false
t.integer "postalcode", limit: 4 t.integer "postalcode", limit: 4
t.integer "inseecode", limit: 4 t.integer "inseecode", limit: 4
t.integer "regioncode", limit: 4 t.integer "regioncode", limit: 4
t.float "latitude", limit: 24 t.float "latitude", limit: 24
t.float "longitude", limit: 24 t.float "longitude", limit: 24
t.index ["name"], name: "cities_name"
end end
add_index "cities", ["name"], name: "cities_name"
create_table "events", force: :cascade do |t| create_table "events", force: :cascade do |t|
t.string "title", limit: 255, default: "", null: false t.string "title", limit: 255, default: "", null: false
t.text "description", limit: 65535, null: false t.text "description", limit: 65535, null: false
t.datetime "start_time", null: false t.datetime "start_time", null: false
t.datetime "end_time", null: false t.datetime "end_time", null: false
t.string "city", limit: 255, default: "" t.string "city", limit: 255, default: ""
t.integer "region_id", limit: 4, default: 0, null: false t.integer "region_id", limit: 4, default: 0, null: false
t.integer "locality", limit: 4, default: 0, null: false t.integer "locality", limit: 4, default: 0, null: false
t.string "url", limit: 255, default: "" t.string "url", limit: 255, default: ""
t.string "contact", limit: 255, default: "", null: false t.string "contact", limit: 255, default: "", null: false
t.string "submitter", limit: 255, default: "", null: false t.string "submitter", limit: 255, default: "", null: false
t.integer "moderated", limit: 4, default: 0, null: false t.integer "moderated", limit: 4, default: 0, null: false
t.text "tags", limit: 255, default: "" t.text "tags", limit: 255, default: ""
t.string "secret", limit: 255, default: "", null: false t.string "secret", limit: 255, default: "", null: false
t.datetime "decision_time" t.datetime "decision_time"
t.datetime "submission_time" t.datetime "submission_time"
t.string "moderator_mail_id", limit: 32 t.string "moderator_mail_id", limit: 32
t.string "submitter_mail_id", limit: 32 t.string "submitter_mail_id", limit: 32
t.text "address", limit: 65535 t.text "address", limit: 65535
t.float "latitude", limit: 24 t.float "latitude", limit: 24
t.float "longitude", limit: 24 t.float "longitude", limit: 24
t.integer "lock_version", limit: 4, default: 0, null: false t.integer "lock_version", limit: 4, default: 0, null: false
t.string "place_name", limit: 255 t.string "place_name", limit: 255
t.integer "count", default: 1 t.integer "count", default: 1
t.integer "repeat", default: 0 t.integer "repeat", default: 0
t.text "rule" t.text "rule"
t.integer "event_id" t.integer "event_id"
t.index ["event_id"], name: "index_events_on_event_id"
t.index ["start_time", "end_time"], name: "events_date"
end end
add_index "events", ["event_id"], name: "index_events_on_event_id"
add_index "events", ["start_time", "end_time"], name: "events_date"
create_table "kinds", force: :cascade do |t| create_table "kinds", force: :cascade do |t|
t.string "name", null: false t.string "name", null: false
t.string "icon" t.string "icon"
t.datetime "created_at", null: false t.datetime "created_at", null: false
t.datetime "updated_at", null: false t.datetime "updated_at", null: false
end end
create_table "notes", force: :cascade do |t| create_table "notes", force: :cascade do |t|
t.text "contents", limit: 65535, null: false t.text "contents", limit: 65535, null: false
t.datetime "date", null: false t.datetime "date", null: false
t.integer "event_id", limit: 4 t.integer "event_id", limit: 4
t.integer "author_id", limit: 4 t.integer "author_id", limit: 4
end end
create_table "orgas", force: :cascade do |t| create_table "orgas", force: :cascade do |t|
t.integer "region_id", limit: 4, default: 0, null: false t.integer "region_id", limit: 4, default: 0, null: false
t.string "department", limit: 4, default: "0", null: false t.string "department", limit: 4, default: "0", null: false
t.string "name", limit: 255, default: "", null: false t.string "name", limit: 255, default: "", null: false
t.string "url", limit: 255, default: "", null: false t.string "url", limit: 255, default: "", null: false
t.string "city", limit: 255, default: "" t.string "city", limit: 255, default: ""
t.integer "kind_id", limit: 4 t.integer "kind_id", limit: 4
t.string "feed", limit: 255 t.string "feed", limit: 255
t.string "contact", limit: 255 t.string "contact", limit: 255
t.string "submitter", limit: 255 t.string "submitter", limit: 255
t.boolean "moderated", limit: 1, default: false t.boolean "moderated", limit: 1, default: false
t.datetime "submission_time" t.datetime "submission_time"
t.datetime "decision_time" t.datetime "decision_time"
t.string "secret", limit: 255 t.string "secret", limit: 255
t.boolean "deleted", limit: 1, default: false, null: false t.boolean "deleted", limit: 1, default: false, null: false
t.boolean "active", default: true, null: false t.boolean "active", default: true, null: false
t.text "description" t.text "description"
t.datetime "created_at" t.datetime "created_at"
t.datetime "updated_at" t.datetime "updated_at"
t.text "tag" t.text "tag"
t.text "tags", default: "" t.text "tags", default: ""
t.text "diaspora" t.text "diaspora"
t.text "object_changes" t.text "object_changes"
t.text "place_name" t.text "place_name"
t.text "address" t.text "address"
t.float "latitude" t.float "latitude"
t.float "longitude" t.float "longitude"
t.index ["kind_id"], name: "index_orgas_on_kind_id"
end end
add_index "orgas", ["kind_id"], name: "index_orgas_on_kind_id"
create_table "regions", force: :cascade do |t| create_table "regions", force: :cascade do |t|
t.string "name", limit: 255, default: "", null: false t.string "name", limit: 255, default: "", null: false
t.integer "region_id" t.integer "region_id"
t.string "code" t.string "code"
t.string "url" t.string "url"
t.index ["region_id"], name: "index_regions_on_region_id"
end end
add_index "regions", ["region_id"], name: "index_regions_on_region_id"
create_table "taggings", force: :cascade do |t| create_table "taggings", force: :cascade do |t|
t.integer "tag_id" t.integer "tag_id"
t.integer "taggable_id" t.integer "taggable_id"
t.string "taggable_type" t.string "taggable_type"
t.integer "tagger_id" t.integer "tagger_id"
t.string "tagger_type" t.string "tagger_type"
t.string "context", limit: 128 t.string "context", limit: 128
t.datetime "created_at" t.datetime "created_at"
t.index ["context"], name: "index_taggings_on_context"
t.index ["tag_id"], name: "index_taggings_on_tag_id"
t.index ["taggable_id", "taggable_type", "context"], name: "index_taggings_on_taggable_id_and_taggable_type_and_context"
t.index ["taggable_id", "taggable_type", "tagger_id", "context"], name: "taggings_idy"
t.index ["taggable_id"], name: "index_taggings_on_taggable_id"
t.index ["taggable_type"], name: "index_taggings_on_taggable_type"
t.index ["tagger_id", "tagger_type"], name: "index_taggings_on_tagger_id_and_tagger_type"
t.index ["tagger_id"], name: "index_taggings_on_tagger_id"
end end
add_index "taggings", ["tag_id"], name: "index_taggings_on_tag_id"
add_index "taggings", ["taggable_id", "taggable_type", "context"], name: "index_taggings_on_taggable_id_and_taggable_type_and_context"
create_table "tags", force: :cascade do |t| create_table "tags", force: :cascade do |t|
t.string "name" t.string "name"
t.integer "taggings_count", default: 0 t.integer "taggings_count", default: 0
end end
create_table "translations", force: :cascade do |t| create_table "translations", force: :cascade do |t|
t.string "locale", limit: 255 t.string "locale", limit: 255
t.string "key", limit: 255 t.string "key", limit: 255
t.text "value", limit: 65535 t.text "value", limit: 65535
t.text "interpolations", limit: 65535 t.text "interpolations", limit: 65535
t.boolean "is_proc", limit: 1, default: false t.boolean "is_proc", limit: 1, default: false
end end
create_table "users", force: :cascade do |t| create_table "users", force: :cascade do |t|
t.string "login", limit: 255, default: "", null: false t.string "login", limit: 255, default: "", null: false
t.string "password", limit: 255, default: "", null: false t.string "password", limit: 255, default: "", null: false
t.string "email", limit: 255, default: "", null: false t.string "email", limit: 255, default: "", null: false
t.string "lastname", limit: 255, default: "", null: false t.string "lastname", limit: 255, default: "", null: false
t.string "firstname", limit: 255, default: "", null: false t.string "firstname", limit: 255, default: "", null: false
t.string "confirmation_token" t.string "confirmation_token"
t.datetime "confirmed_at" t.datetime "confirmed_at"
t.datetime "confirmation_sent_at" t.datetime "confirmation_sent_at"
t.datetime "remember_created_at" t.datetime "remember_created_at"
t.index ["confirmation_token"], name: "index_users_on_confirmation_token", unique: true
end end
add_index "users", ["confirmation_token"], name: "index_users_on_confirmation_token", unique: true
create_table "versions", force: :cascade do |t| create_table "versions", force: :cascade do |t|
t.string "item_type", null: false t.string "item_type", null: false
t.integer "item_id", null: false t.integer "item_id", null: false
t.string "event", null: false t.string "event", null: false
t.string "whodunnit" t.string "whodunnit"
t.text "object" t.text "object"
t.datetime "created_at" t.datetime "created_at"
t.text "object_changes", limit: 1073741823 t.text "object_changes", limit: 1073741823
t.index ["item_type", "item_id"], name: "index_versions_on_item_type_and_item_id"
end end
add_index "versions", ["item_type", "item_id"], name: "index_versions_on_item_type_and_item_id"
end end

View File

@ -4,12 +4,10 @@ require 'test_helper'
class EventCallbacksTest < ActiveSupport::TestCase class EventCallbacksTest < ActiveSupport::TestCase
setup do setup do
ActionMailer::Base.default_url_options[:host] = 'localhost:3000' ActionMailer::Base.default_url_options[:host] = 'localhost:3000'
@event = events :one
end end
test 'schedule' do test 'schedule' do
@event = Event.new( event = Event.new(
title: 'hello world', title: 'hello world',
start_time: Time.zone.now, end_time: Time.zone.now + 1.hour, start_time: Time.zone.now, end_time: Time.zone.now + 1.hour,
description: 'et hop!', description: 'et hop!',
@ -19,12 +17,12 @@ class EventCallbacksTest < ActiveSupport::TestCase
tag_list: 'hello world' tag_list: 'hello world'
) )
assert_difference 'Event.count' do assert_difference 'Event.count' do
assert @event.save, @event.errors.messages assert event.save, event.errors.messages
end end
end end
test 'moderation' do test 'moderation' do
@event = Event.new( event = Event.new(
title: 'hello world', title: 'hello world',
start_time: Time.zone.now + 1.hour, end_time: Time.zone.now + 2.hours, start_time: Time.zone.now + 1.hour, end_time: Time.zone.now + 2.hours,
repeat: 1, rule: 'monthly', repeat: 1, rule: 'monthly',
@ -35,13 +33,13 @@ class EventCallbacksTest < ActiveSupport::TestCase
tag_list: 'hello world' tag_list: 'hello world'
) )
assert @event.save, @event.errors.messages assert event.save, event.errors.messages
assert_not @event.moderated? assert_not event.moderated?
assert_difference 'Event.count' do assert_difference 'Event.count' do
@event.update moderated: 1 event.update moderated: 1
end end
assert @event.moderated?, @event.errors.messages assert event.moderated?, event.errors.messages
end end
end end