kickoff 0.0.2
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- data/.gitignore +4 -0
- data/.rspec +1 -0
- data/CHANGELOG +3 -0
- data/Gemfile +4 -0
- data/LICENSE +20 -0
- data/README.md +41 -0
- data/Rakefile +5 -0
- data/features/nifty_authentication.feature +80 -0
- data/features/nifty_config.feature +17 -0
- data/features/nifty_layout.feature +20 -0
- data/features/nifty_scaffold.feature +80 -0
- data/features/step_definitions/common_steps.rb +62 -0
- data/features/step_definitions/rails_setup_steps.rb +6 -0
- data/features/support/env.rb +6 -0
- data/features/support/matchers.rb +7 -0
- data/kickoff.gemspec +24 -0
- data/lib/generators/kickoff/authentication/USAGE +50 -0
- data/lib/generators/kickoff/authentication/authentication_generator.rb +154 -0
- data/lib/generators/kickoff/authentication/templates/authlogic_session.rb +2 -0
- data/lib/generators/kickoff/authentication/templates/controller_authentication.rb +60 -0
- data/lib/generators/kickoff/authentication/templates/fixtures.yml +24 -0
- data/lib/generators/kickoff/authentication/templates/migration.rb +20 -0
- data/lib/generators/kickoff/authentication/templates/sessions_controller.rb +41 -0
- data/lib/generators/kickoff/authentication/templates/sessions_helper.rb +2 -0
- data/lib/generators/kickoff/authentication/templates/tests/rspec/sessions_controller.rb +39 -0
- data/lib/generators/kickoff/authentication/templates/tests/rspec/user.rb +83 -0
- data/lib/generators/kickoff/authentication/templates/tests/rspec/users_controller.rb +56 -0
- data/lib/generators/kickoff/authentication/templates/tests/shoulda/sessions_controller.rb +40 -0
- data/lib/generators/kickoff/authentication/templates/tests/shoulda/user.rb +85 -0
- data/lib/generators/kickoff/authentication/templates/tests/shoulda/users_controller.rb +61 -0
- data/lib/generators/kickoff/authentication/templates/tests/testunit/sessions_controller.rb +36 -0
- data/lib/generators/kickoff/authentication/templates/tests/testunit/user.rb +88 -0
- data/lib/generators/kickoff/authentication/templates/tests/testunit/users_controller.rb +53 -0
- data/lib/generators/kickoff/authentication/templates/user.rb +38 -0
- data/lib/generators/kickoff/authentication/templates/users_controller.rb +32 -0
- data/lib/generators/kickoff/authentication/templates/users_helper.rb +2 -0
- data/lib/generators/kickoff/authentication/templates/views/erb/_form.html.erb +20 -0
- data/lib/generators/kickoff/authentication/templates/views/erb/edit.html.erb +3 -0
- data/lib/generators/kickoff/authentication/templates/views/erb/login.html.erb +30 -0
- data/lib/generators/kickoff/authentication/templates/views/erb/signup.html.erb +5 -0
- data/lib/generators/kickoff/authentication/templates/views/haml/_form.html.haml +16 -0
- data/lib/generators/kickoff/authentication/templates/views/haml/edit.html.haml +3 -0
- data/lib/generators/kickoff/authentication/templates/views/haml/login.html.haml +26 -0
- data/lib/generators/kickoff/authentication/templates/views/haml/signup.html.haml +5 -0
- data/lib/generators/kickoff/layout/USAGE +25 -0
- data/lib/generators/kickoff/layout/layout_generator.rb +38 -0
- data/lib/generators/kickoff/layout/templates/_forms.scss +417 -0
- data/lib/generators/kickoff/layout/templates/_mixins.scss +211 -0
- data/lib/generators/kickoff/layout/templates/_patterns.scss +960 -0
- data/lib/generators/kickoff/layout/templates/_reset.scss +141 -0
- data/lib/generators/kickoff/layout/templates/_scaffolding.scss +137 -0
- data/lib/generators/kickoff/layout/templates/_tables.scss +172 -0
- data/lib/generators/kickoff/layout/templates/_type.scss +185 -0
- data/lib/generators/kickoff/layout/templates/_variables.scss +50 -0
- data/lib/generators/kickoff/layout/templates/application.scss +21 -0
- data/lib/generators/kickoff/layout/templates/error_messages_helper.rb +23 -0
- data/lib/generators/kickoff/layout/templates/layout.html.erb +34 -0
- data/lib/generators/kickoff/layout/templates/layout.html.haml +21 -0
- data/lib/generators/kickoff/layout/templates/layout_helper.rb +22 -0
- data/lib/generators/kickoff/layout/templates/stylesheet.sass +73 -0
- data/lib/generators/kickoff/scaffold/USAGE +51 -0
- data/lib/generators/kickoff/scaffold/scaffold_generator.rb +318 -0
- data/lib/generators/kickoff/scaffold/templates/actions/create.rb +8 -0
- data/lib/generators/kickoff/scaffold/templates/actions/destroy.rb +5 -0
- data/lib/generators/kickoff/scaffold/templates/actions/edit.rb +3 -0
- data/lib/generators/kickoff/scaffold/templates/actions/index.rb +3 -0
- data/lib/generators/kickoff/scaffold/templates/actions/new.rb +3 -0
- data/lib/generators/kickoff/scaffold/templates/actions/show.rb +3 -0
- data/lib/generators/kickoff/scaffold/templates/actions/update.rb +8 -0
- data/lib/generators/kickoff/scaffold/templates/controller.rb +3 -0
- data/lib/generators/kickoff/scaffold/templates/fixtures.yml +9 -0
- data/lib/generators/kickoff/scaffold/templates/helper.rb +2 -0
- data/lib/generators/kickoff/scaffold/templates/migration.rb +16 -0
- data/lib/generators/kickoff/scaffold/templates/model.rb +4 -0
- data/lib/generators/kickoff/scaffold/templates/tests/rspec/actions/create.rb +11 -0
- data/lib/generators/kickoff/scaffold/templates/tests/rspec/actions/destroy.rb +6 -0
- data/lib/generators/kickoff/scaffold/templates/tests/rspec/actions/edit.rb +4 -0
- data/lib/generators/kickoff/scaffold/templates/tests/rspec/actions/index.rb +4 -0
- data/lib/generators/kickoff/scaffold/templates/tests/rspec/actions/new.rb +4 -0
- data/lib/generators/kickoff/scaffold/templates/tests/rspec/actions/show.rb +4 -0
- data/lib/generators/kickoff/scaffold/templates/tests/rspec/actions/update.rb +11 -0
- data/lib/generators/kickoff/scaffold/templates/tests/rspec/controller.rb +8 -0
- data/lib/generators/kickoff/scaffold/templates/tests/rspec/model.rb +7 -0
- data/lib/generators/kickoff/scaffold/templates/tests/shoulda/actions/create.rb +13 -0
- data/lib/generators/kickoff/scaffold/templates/tests/shoulda/actions/destroy.rb +8 -0
- data/lib/generators/kickoff/scaffold/templates/tests/shoulda/actions/edit.rb +6 -0
- data/lib/generators/kickoff/scaffold/templates/tests/shoulda/actions/index.rb +6 -0
- data/lib/generators/kickoff/scaffold/templates/tests/shoulda/actions/new.rb +6 -0
- data/lib/generators/kickoff/scaffold/templates/tests/shoulda/actions/show.rb +6 -0
- data/lib/generators/kickoff/scaffold/templates/tests/shoulda/actions/update.rb +13 -0
- data/lib/generators/kickoff/scaffold/templates/tests/shoulda/controller.rb +5 -0
- data/lib/generators/kickoff/scaffold/templates/tests/shoulda/model.rb +7 -0
- data/lib/generators/kickoff/scaffold/templates/tests/testunit/actions/create.rb +11 -0
- data/lib/generators/kickoff/scaffold/templates/tests/testunit/actions/destroy.rb +6 -0
- data/lib/generators/kickoff/scaffold/templates/tests/testunit/actions/edit.rb +4 -0
- data/lib/generators/kickoff/scaffold/templates/tests/testunit/actions/index.rb +4 -0
- data/lib/generators/kickoff/scaffold/templates/tests/testunit/actions/new.rb +4 -0
- data/lib/generators/kickoff/scaffold/templates/tests/testunit/actions/show.rb +4 -0
- data/lib/generators/kickoff/scaffold/templates/tests/testunit/actions/update.rb +11 -0
- data/lib/generators/kickoff/scaffold/templates/tests/testunit/controller.rb +5 -0
- data/lib/generators/kickoff/scaffold/templates/tests/testunit/model.rb +7 -0
- data/lib/generators/kickoff/scaffold/templates/views/erb/_form.html.erb +10 -0
- data/lib/generators/kickoff/scaffold/templates/views/erb/edit.html.erb +14 -0
- data/lib/generators/kickoff/scaffold/templates/views/erb/index.html.erb +29 -0
- data/lib/generators/kickoff/scaffold/templates/views/erb/new.html.erb +7 -0
- data/lib/generators/kickoff/scaffold/templates/views/erb/show.html.erb +20 -0
- data/lib/generators/kickoff/scaffold/templates/views/haml/_form.html.haml +9 -0
- data/lib/generators/kickoff/scaffold/templates/views/haml/edit.html.haml +14 -0
- data/lib/generators/kickoff/scaffold/templates/views/haml/index.html.haml +25 -0
- data/lib/generators/kickoff/scaffold/templates/views/haml/new.html.haml +7 -0
- data/lib/generators/kickoff/scaffold/templates/views/haml/show.html.haml +20 -0
- data/lib/generators/kickoff/version.rb +3 -0
- data/lib/generators/kickoff.rb +29 -0
- data/spec/spec_helper.rb +1 -0
- metadata +179 -0
|
@@ -0,0 +1,60 @@
|
|
|
1
|
+
# This module is included in your application controller which makes
|
|
2
|
+
# several methods available to all controllers and views. Here's a
|
|
3
|
+
# common example you might add to your application layout file.
|
|
4
|
+
#
|
|
5
|
+
# <%% if logged_in? %>
|
|
6
|
+
# Welcome <%%= current_<%= user_singular_name %>.username %>.
|
|
7
|
+
# <%%= link_to "Edit profile", edit_current_<%= user_singular_name %>_path %> or
|
|
8
|
+
# <%%= link_to "Log out", logout_path %>
|
|
9
|
+
# <%% else %>
|
|
10
|
+
# <%%= link_to "Sign up", signup_path %> or
|
|
11
|
+
# <%%= link_to "log in", login_path %>.
|
|
12
|
+
# <%% end %>
|
|
13
|
+
#
|
|
14
|
+
# You can also restrict unregistered users from accessing a controller using
|
|
15
|
+
# a before filter. For example.
|
|
16
|
+
#
|
|
17
|
+
# before_filter :login_required, :except => [:index, :show]
|
|
18
|
+
module ControllerAuthentication
|
|
19
|
+
def self.included(controller)
|
|
20
|
+
controller.send :helper_method, :current_<%= user_singular_name %>, :logged_in?, :redirect_to_target_or_default
|
|
21
|
+
end
|
|
22
|
+
|
|
23
|
+
<%- if options[:authlogic] -%>
|
|
24
|
+
def current_<%= session_singular_name %>
|
|
25
|
+
return @current_<%= session_singular_name %> if defined?(@current_<%= session_singular_name %>)
|
|
26
|
+
@current_<%= session_singular_name %> = <%= session_class_name %>.find
|
|
27
|
+
end
|
|
28
|
+
|
|
29
|
+
def current_<%= user_singular_name %>
|
|
30
|
+
return @current_<%= user_singular_name %> if defined?(@current_<%= user_singular_name %>)
|
|
31
|
+
@current_<%= user_singular_name %> = current_<%= session_singular_name %> && current_<%= session_singular_name %>.record
|
|
32
|
+
end
|
|
33
|
+
<%- else -%>
|
|
34
|
+
def current_<%= user_singular_name %>
|
|
35
|
+
@current_<%= user_singular_name %> ||= <%= user_class_name %>.find(session[:<%= user_singular_name %>_id]) if session[:<%= user_singular_name %>_id]
|
|
36
|
+
end
|
|
37
|
+
<%- end -%>
|
|
38
|
+
|
|
39
|
+
def logged_in?
|
|
40
|
+
current_<%= user_singular_name %>
|
|
41
|
+
end
|
|
42
|
+
|
|
43
|
+
def login_required
|
|
44
|
+
unless logged_in?
|
|
45
|
+
store_target_location
|
|
46
|
+
redirect_to login_url, :alert => "You must first log in or sign up before accessing this page."
|
|
47
|
+
end
|
|
48
|
+
end
|
|
49
|
+
|
|
50
|
+
def redirect_to_target_or_default(default, *args)
|
|
51
|
+
redirect_to(session[:return_to] || default, *args)
|
|
52
|
+
session[:return_to] = nil
|
|
53
|
+
end
|
|
54
|
+
|
|
55
|
+
private
|
|
56
|
+
|
|
57
|
+
def store_target_location
|
|
58
|
+
session[:return_to] = request.url
|
|
59
|
+
end
|
|
60
|
+
end
|
|
@@ -0,0 +1,24 @@
|
|
|
1
|
+
# password: "secret"
|
|
2
|
+
foo:
|
|
3
|
+
username: foo
|
|
4
|
+
email: foo@example.com
|
|
5
|
+
<%- if options[:authlogic] -%>
|
|
6
|
+
persistence_token: d5ddba13ed4408ea2b0a12ab18ed2d2eda086279736bdc121ca726a11f1e4b99217d9c534c2cc4ebb22729349c8c5fdbe1529e1f2c3c5859c62ef4dd9feea25c
|
|
7
|
+
crypted_password: 3d16c326648cccafe3d4b4cb024475c381dda92f430dfedf6f933e1f61203bacb6bae2437849bdb43b06be335e23790e4aa03902b3c28c3bbbbe27d501e521f3
|
|
8
|
+
password_salt: n6z_wtpWoIsHgQb5IcFd
|
|
9
|
+
<%- else -%>
|
|
10
|
+
password_hash: 3488f5f7efecab14b91eb96169e5e1ee518a569f
|
|
11
|
+
password_salt: bef65e058905c379436d80d1a32e7374b139e7b0
|
|
12
|
+
<%- end -%>
|
|
13
|
+
|
|
14
|
+
bar:
|
|
15
|
+
username: bar
|
|
16
|
+
email: bar@example.com
|
|
17
|
+
<%- if options[:authlogic] -%>
|
|
18
|
+
persistence_token: 19e074bd7cb506ab3e7e53e41f24f0ab3221c8cb68111f4c1aa43965114ad734233979a50a9463537487cdca18c279ac91c4bc83693d589625d446493322394c
|
|
19
|
+
crypted_password: 3bc9f4113ca645a186765df3d31a9352d0067bf2304ba0cdd6b08a7f3d58c6668ab1762fa3e76aef466ea2ff188399d8e6c40244fa59312bb4112292dac9f7f0
|
|
20
|
+
password_salt: UiAh9ejabnKRxqsiK0xO
|
|
21
|
+
<%- else -%>
|
|
22
|
+
password_hash: 3488f5f7efecab14b91eb96169e5e1ee518a569f
|
|
23
|
+
password_salt: bef65e058905c379436d80d1a32e7374b139e7b0
|
|
24
|
+
<%- end -%>
|
|
@@ -0,0 +1,20 @@
|
|
|
1
|
+
class Create<%= user_plural_class_name %> < ActiveRecord::Migration
|
|
2
|
+
def self.up
|
|
3
|
+
create_table :<%= user_plural_name %> do |t|
|
|
4
|
+
t.string :username
|
|
5
|
+
t.string :email
|
|
6
|
+
<%- if options[:authlogic] -%>
|
|
7
|
+
t.string :persistence_token
|
|
8
|
+
t.string :crypted_password
|
|
9
|
+
<%- else -%>
|
|
10
|
+
t.string :password_hash
|
|
11
|
+
<%- end -%>
|
|
12
|
+
t.string :password_salt
|
|
13
|
+
t.timestamps
|
|
14
|
+
end
|
|
15
|
+
end
|
|
16
|
+
|
|
17
|
+
def self.down
|
|
18
|
+
drop_table :<%= user_plural_name %>
|
|
19
|
+
end
|
|
20
|
+
end
|
|
@@ -0,0 +1,41 @@
|
|
|
1
|
+
class <%= session_plural_class_name %>Controller < ApplicationController
|
|
2
|
+
<%- if options[:authlogic] -%>
|
|
3
|
+
def new
|
|
4
|
+
@<%= session_singular_name %> = <%= session_class_name %>.new
|
|
5
|
+
end
|
|
6
|
+
|
|
7
|
+
def create
|
|
8
|
+
@<%= session_singular_name %> = <%= session_class_name %>.new(params[:<%= session_singular_name %>])
|
|
9
|
+
if @<%= session_singular_name %>.save
|
|
10
|
+
redirect_to_target_or_default root_url, :notice => "Logged in successfully."
|
|
11
|
+
else
|
|
12
|
+
render :new
|
|
13
|
+
end
|
|
14
|
+
end
|
|
15
|
+
|
|
16
|
+
def destroy
|
|
17
|
+
@<%= session_singular_name %> = <%= session_class_name %>.find
|
|
18
|
+
@<%= session_singular_name %>.destroy
|
|
19
|
+
redirect_to root_url, :notice => "You have been logged out."
|
|
20
|
+
end
|
|
21
|
+
<%- else -%>
|
|
22
|
+
def new
|
|
23
|
+
end
|
|
24
|
+
|
|
25
|
+
def create
|
|
26
|
+
<%= user_singular_name %> = <%= user_class_name %>.authenticate(params[:login], params[:password])
|
|
27
|
+
if <%= user_singular_name %>
|
|
28
|
+
session[:<%= user_singular_name %>_id] = <%= user_singular_name %>.id
|
|
29
|
+
redirect_to_target_or_default root_url, :notice => "Logged in successfully."
|
|
30
|
+
else
|
|
31
|
+
flash.now[:alert] = "Invalid login or password."
|
|
32
|
+
render :new
|
|
33
|
+
end
|
|
34
|
+
end
|
|
35
|
+
|
|
36
|
+
def destroy
|
|
37
|
+
session[:<%= user_singular_name %>_id] = nil
|
|
38
|
+
redirect_to root_url, :notice => "You have been logged out."
|
|
39
|
+
end
|
|
40
|
+
<%- end -%>
|
|
41
|
+
end
|
|
@@ -0,0 +1,39 @@
|
|
|
1
|
+
require File.dirname(__FILE__) + '/../spec_helper'
|
|
2
|
+
|
|
3
|
+
describe <%= session_plural_class_name %>Controller do
|
|
4
|
+
fixtures :all
|
|
5
|
+
render_views
|
|
6
|
+
|
|
7
|
+
it "new action should render new template" do
|
|
8
|
+
get :new
|
|
9
|
+
response.should render_template(:new)
|
|
10
|
+
end
|
|
11
|
+
|
|
12
|
+
<%- if options[:authlogic] -%>
|
|
13
|
+
it "create action should render new template when authentication is invalid" do
|
|
14
|
+
post :create, :<%= session_singular_name %> => { :username => "foo", :password => "badpassword" }
|
|
15
|
+
response.should render_template(:new)
|
|
16
|
+
<%= session_class_name %>.find.should be_nil
|
|
17
|
+
end
|
|
18
|
+
|
|
19
|
+
it "create action should redirect when authentication is valid" do
|
|
20
|
+
post :create, :<%= session_singular_name %> => { :username => "foo", :password => "secret" }
|
|
21
|
+
response.should redirect_to(root_url)
|
|
22
|
+
<%= session_class_name %>.find.<%= user_singular_name %>.should == <%= user_plural_name %>(:foo)
|
|
23
|
+
end
|
|
24
|
+
<%- else -%>
|
|
25
|
+
it "create action should render new template when authentication is invalid" do
|
|
26
|
+
<%= user_class_name %>.stubs(:authenticate).returns(nil)
|
|
27
|
+
post :create
|
|
28
|
+
response.should render_template(:new)
|
|
29
|
+
session['<%= user_singular_name %>_id'].should be_nil
|
|
30
|
+
end
|
|
31
|
+
|
|
32
|
+
it "create action should redirect when authentication is valid" do
|
|
33
|
+
<%= user_class_name %>.stubs(:authenticate).returns(<%= user_class_name %>.first)
|
|
34
|
+
post :create
|
|
35
|
+
response.should redirect_to(root_url)
|
|
36
|
+
session['<%= user_singular_name %>_id'].should == <%= user_class_name %>.first.id
|
|
37
|
+
end
|
|
38
|
+
<%- end -%>
|
|
39
|
+
end
|
|
@@ -0,0 +1,83 @@
|
|
|
1
|
+
require File.dirname(__FILE__) + '/../spec_helper'
|
|
2
|
+
|
|
3
|
+
describe <%= user_class_name %> do
|
|
4
|
+
<%- unless options[:authlogic] -%>
|
|
5
|
+
def new_<%= user_singular_name %>(attributes = {})
|
|
6
|
+
attributes[:username] ||= 'foo'
|
|
7
|
+
attributes[:email] ||= 'foo@example.com'
|
|
8
|
+
attributes[:password] ||= 'abc123'
|
|
9
|
+
attributes[:password_confirmation] ||= attributes[:password]
|
|
10
|
+
<%= user_class_name %>.new(attributes)
|
|
11
|
+
end
|
|
12
|
+
|
|
13
|
+
before(:each) do
|
|
14
|
+
<%= user_class_name %>.delete_all
|
|
15
|
+
end
|
|
16
|
+
|
|
17
|
+
it "should be valid" do
|
|
18
|
+
new_<%= user_singular_name %>.should be_valid
|
|
19
|
+
end
|
|
20
|
+
|
|
21
|
+
it "should require username" do
|
|
22
|
+
new_<%= user_singular_name %>(:username => '').should have(1).error_on(:username)
|
|
23
|
+
end
|
|
24
|
+
|
|
25
|
+
it "should require password" do
|
|
26
|
+
new_<%= user_singular_name %>(:password => '').should have(1).error_on(:password)
|
|
27
|
+
end
|
|
28
|
+
|
|
29
|
+
it "should require well formed email" do
|
|
30
|
+
new_<%= user_singular_name %>(:email => 'foo@bar@example.com').should have(1).error_on(:email)
|
|
31
|
+
end
|
|
32
|
+
|
|
33
|
+
it "should validate uniqueness of email" do
|
|
34
|
+
new_<%= user_singular_name %>(:email => 'bar@example.com').save!
|
|
35
|
+
new_<%= user_singular_name %>(:email => 'bar@example.com').should have(1).error_on(:email)
|
|
36
|
+
end
|
|
37
|
+
|
|
38
|
+
it "should validate uniqueness of username" do
|
|
39
|
+
new_<%= user_singular_name %>(:username => 'uniquename').save!
|
|
40
|
+
new_<%= user_singular_name %>(:username => 'uniquename').should have(1).error_on(:username)
|
|
41
|
+
end
|
|
42
|
+
|
|
43
|
+
it "should not allow odd characters in username" do
|
|
44
|
+
new_<%= user_singular_name %>(:username => 'odd ^&(@)').should have(1).error_on(:username)
|
|
45
|
+
end
|
|
46
|
+
|
|
47
|
+
it "should validate password is longer than 3 characters" do
|
|
48
|
+
new_<%= user_singular_name %>(:password => 'bad').should have(1).error_on(:password)
|
|
49
|
+
end
|
|
50
|
+
|
|
51
|
+
it "should require matching password confirmation" do
|
|
52
|
+
new_<%= user_singular_name %>(:password_confirmation => 'nonmatching').should have(1).error_on(:password)
|
|
53
|
+
end
|
|
54
|
+
|
|
55
|
+
it "should generate password hash and salt on create" do
|
|
56
|
+
<%= user_singular_name %> = new_<%= user_singular_name %>
|
|
57
|
+
<%= user_singular_name %>.save!
|
|
58
|
+
<%= user_singular_name %>.password_hash.should_not be_nil
|
|
59
|
+
<%= user_singular_name %>.password_salt.should_not be_nil
|
|
60
|
+
end
|
|
61
|
+
|
|
62
|
+
it "should authenticate by username" do
|
|
63
|
+
<%= user_singular_name %> = new_<%= user_singular_name %>(:username => 'foobar', :password => 'secret')
|
|
64
|
+
<%= user_singular_name %>.save!
|
|
65
|
+
<%= user_class_name %>.authenticate('foobar', 'secret').should == <%= user_singular_name %>
|
|
66
|
+
end
|
|
67
|
+
|
|
68
|
+
it "should authenticate by email" do
|
|
69
|
+
<%= user_singular_name %> = new_<%= user_singular_name %>(:email => 'foo@bar.com', :password => 'secret')
|
|
70
|
+
<%= user_singular_name %>.save!
|
|
71
|
+
<%= user_class_name %>.authenticate('foo@bar.com', 'secret').should == <%= user_singular_name %>
|
|
72
|
+
end
|
|
73
|
+
|
|
74
|
+
it "should not authenticate bad username" do
|
|
75
|
+
<%= user_class_name %>.authenticate('nonexisting', 'secret').should be_nil
|
|
76
|
+
end
|
|
77
|
+
|
|
78
|
+
it "should not authenticate bad password" do
|
|
79
|
+
new_<%= user_singular_name %>(:username => 'foobar', :password => 'secret').save!
|
|
80
|
+
<%= user_class_name %>.authenticate('foobar', 'badpassword').should be_nil
|
|
81
|
+
end
|
|
82
|
+
<%- end -%>
|
|
83
|
+
end
|
|
@@ -0,0 +1,56 @@
|
|
|
1
|
+
require File.dirname(__FILE__) + '/../spec_helper'
|
|
2
|
+
|
|
3
|
+
describe <%= user_plural_class_name %>Controller do
|
|
4
|
+
fixtures :all
|
|
5
|
+
render_views
|
|
6
|
+
|
|
7
|
+
it "new action should render new template" do
|
|
8
|
+
get :new
|
|
9
|
+
response.should render_template(:new)
|
|
10
|
+
end
|
|
11
|
+
|
|
12
|
+
it "create action should render new template when model is invalid" do
|
|
13
|
+
<%= user_class_name %>.any_instance.stubs(:valid?).returns(false)
|
|
14
|
+
post :create
|
|
15
|
+
response.should render_template(:new)
|
|
16
|
+
end
|
|
17
|
+
|
|
18
|
+
it "create action should redirect when model is valid" do
|
|
19
|
+
<%= user_class_name %>.any_instance.stubs(:valid?).returns(true)
|
|
20
|
+
post :create
|
|
21
|
+
response.should redirect_to(root_url)
|
|
22
|
+
<%- unless options[:authlogic] -%>
|
|
23
|
+
session['<%= user_singular_name %>_id'].should == assigns['<%= user_singular_name %>'].id
|
|
24
|
+
<%- end -%>
|
|
25
|
+
end
|
|
26
|
+
|
|
27
|
+
it "edit action should redirect when not logged in" do
|
|
28
|
+
get :edit, :id => "ignored"
|
|
29
|
+
response.should redirect_to(login_url)
|
|
30
|
+
end
|
|
31
|
+
|
|
32
|
+
it "edit action should render edit template" do
|
|
33
|
+
@controller.stubs(:current_<%= user_singular_name %>).returns(<%= user_class_name %>.first)
|
|
34
|
+
get :edit, :id => "ignored"
|
|
35
|
+
response.should render_template(:edit)
|
|
36
|
+
end
|
|
37
|
+
|
|
38
|
+
it "update action should redirect when not logged in" do
|
|
39
|
+
put :update, :id => "ignored"
|
|
40
|
+
response.should redirect_to(login_url)
|
|
41
|
+
end
|
|
42
|
+
|
|
43
|
+
it "update action should render edit template when <%= user_singular_name %> is invalid" do
|
|
44
|
+
@controller.stubs(:current_<%= user_singular_name %>).returns(<%= user_class_name %>.first)
|
|
45
|
+
<%= user_class_name %>.any_instance.stubs(:valid?).returns(false)
|
|
46
|
+
put :update, :id => "ignored"
|
|
47
|
+
response.should render_template(:edit)
|
|
48
|
+
end
|
|
49
|
+
|
|
50
|
+
it "update action should redirect when <%= user_singular_name %> is valid" do
|
|
51
|
+
@controller.stubs(:current_<%= user_singular_name %>).returns(<%= user_class_name %>.first)
|
|
52
|
+
<%= user_class_name %>.any_instance.stubs(:valid?).returns(true)
|
|
53
|
+
put :update, :id => "ignored"
|
|
54
|
+
response.should redirect_to(root_url)
|
|
55
|
+
end
|
|
56
|
+
end
|
|
@@ -0,0 +1,40 @@
|
|
|
1
|
+
require 'test_helper'
|
|
2
|
+
|
|
3
|
+
class <%= session_plural_class_name %>ControllerTest < ActionController::TestCase
|
|
4
|
+
context "new action" do
|
|
5
|
+
should "render new template" do
|
|
6
|
+
get :new
|
|
7
|
+
assert_template 'new'
|
|
8
|
+
end
|
|
9
|
+
end
|
|
10
|
+
|
|
11
|
+
context "create action" do
|
|
12
|
+
<%- if options[:authlogic] -%>
|
|
13
|
+
should "render new template when authentication is invalid" do
|
|
14
|
+
post :create, :<%= session_singular_name %> => { :username => "foo", :password => "badpassword" }
|
|
15
|
+
assert_template 'new'
|
|
16
|
+
assert_nil <%= session_class_name %>.find
|
|
17
|
+
end
|
|
18
|
+
|
|
19
|
+
should "redirect when authentication is valid" do
|
|
20
|
+
post :create, :<%= session_singular_name %> => { :username => "foo", :password => "secret" }
|
|
21
|
+
assert_redirected_to root_url
|
|
22
|
+
assert_equal <%= user_plural_name %>(:foo), <%= session_class_name %>.find.<%= user_singular_name %>
|
|
23
|
+
end
|
|
24
|
+
<%- else -%>
|
|
25
|
+
should "render new template when authentication is invalid" do
|
|
26
|
+
<%= user_class_name %>.stubs(:authenticate).returns(nil)
|
|
27
|
+
post :create
|
|
28
|
+
assert_template 'new'
|
|
29
|
+
assert_nil session['<%= user_singular_name %>_id']
|
|
30
|
+
end
|
|
31
|
+
|
|
32
|
+
should "redirect when authentication is valid" do
|
|
33
|
+
<%= user_class_name %>.stubs(:authenticate).returns(<%= user_class_name %>.first)
|
|
34
|
+
post :create
|
|
35
|
+
assert_redirected_to root_url
|
|
36
|
+
assert_equal <%= user_class_name %>.first.id, session['<%= user_singular_name %>_id']
|
|
37
|
+
end
|
|
38
|
+
<%- end -%>
|
|
39
|
+
end
|
|
40
|
+
end
|
|
@@ -0,0 +1,85 @@
|
|
|
1
|
+
require 'test_helper'
|
|
2
|
+
|
|
3
|
+
class <%= user_class_name %>Test < ActiveSupport::TestCase
|
|
4
|
+
<%- unless options[:authlogic] -%>
|
|
5
|
+
def new_<%= user_singular_name %>(attributes = {})
|
|
6
|
+
attributes[:username] ||= 'foo'
|
|
7
|
+
attributes[:email] ||= 'foo@example.com'
|
|
8
|
+
attributes[:password] ||= 'abc123'
|
|
9
|
+
attributes[:password_confirmation] ||= attributes[:password]
|
|
10
|
+
<%= user_singular_name %> = <%= user_class_name %>.new(attributes)
|
|
11
|
+
<%= user_singular_name %>.valid? # run validations
|
|
12
|
+
<%= user_singular_name %>
|
|
13
|
+
end
|
|
14
|
+
|
|
15
|
+
def setup
|
|
16
|
+
<%= user_class_name %>.delete_all
|
|
17
|
+
end
|
|
18
|
+
|
|
19
|
+
should "be valid" do
|
|
20
|
+
assert new_<%= user_singular_name %>.valid?
|
|
21
|
+
end
|
|
22
|
+
|
|
23
|
+
should "require username" do
|
|
24
|
+
assert_equal ["can't be blank"], new_<%= user_singular_name %>(:username => '').errors[:username]
|
|
25
|
+
end
|
|
26
|
+
|
|
27
|
+
should "require password" do
|
|
28
|
+
assert_equal ["can't be blank"], new_<%= user_singular_name %>(:password => '').errors[:password]
|
|
29
|
+
end
|
|
30
|
+
|
|
31
|
+
should "require well formed email" do
|
|
32
|
+
assert_equal ["is invalid"], new_<%= user_singular_name %>(:email => 'foo@bar@example.com').errors[:email]
|
|
33
|
+
end
|
|
34
|
+
|
|
35
|
+
should "validate uniqueness of email" do
|
|
36
|
+
new_<%= user_singular_name %>(:email => 'bar@example.com').save!
|
|
37
|
+
assert_equal ["has already been taken"], new_<%= user_singular_name %>(:email => 'bar@example.com').errors[:email]
|
|
38
|
+
end
|
|
39
|
+
|
|
40
|
+
should "validate uniqueness of username" do
|
|
41
|
+
new_<%= user_singular_name %>(:username => 'uniquename').save!
|
|
42
|
+
assert_equal ["has already been taken"], new_<%= user_singular_name %>(:username => 'uniquename').errors[:username]
|
|
43
|
+
end
|
|
44
|
+
|
|
45
|
+
should "not allow odd characters in username" do
|
|
46
|
+
assert_equal ["should only contain letters, numbers, or .-_@"], new_<%= user_singular_name %>(:username => 'odd ^&(@)').errors[:username]
|
|
47
|
+
end
|
|
48
|
+
|
|
49
|
+
should "validate password is longer than 3 characters" do
|
|
50
|
+
assert_equal ["is too short (minimum is 4 characters)"], new_<%= user_singular_name %>(:password => 'bad').errors[:password]
|
|
51
|
+
end
|
|
52
|
+
|
|
53
|
+
should "require matching password confirmation" do
|
|
54
|
+
assert_equal ["doesn't match confirmation"], new_<%= user_singular_name %>(:password_confirmation => 'nonmatching').errors[:password]
|
|
55
|
+
end
|
|
56
|
+
|
|
57
|
+
should "generate password hash and salt on create" do
|
|
58
|
+
<%= user_singular_name %> = new_<%= user_singular_name %>
|
|
59
|
+
<%= user_singular_name %>.save!
|
|
60
|
+
assert <%= user_singular_name %>.password_hash
|
|
61
|
+
assert <%= user_singular_name %>.password_salt
|
|
62
|
+
end
|
|
63
|
+
|
|
64
|
+
should "authenticate by username" do
|
|
65
|
+
<%= user_singular_name %> = new_<%= user_singular_name %>(:username => 'foobar', :password => 'secret')
|
|
66
|
+
<%= user_singular_name %>.save!
|
|
67
|
+
assert_equal <%= user_singular_name %>, <%= user_class_name %>.authenticate('foobar', 'secret')
|
|
68
|
+
end
|
|
69
|
+
|
|
70
|
+
should "authenticate by email" do
|
|
71
|
+
<%= user_singular_name %> = new_<%= user_singular_name %>(:email => 'foo@bar.com', :password => 'secret')
|
|
72
|
+
<%= user_singular_name %>.save!
|
|
73
|
+
assert_equal <%= user_singular_name %>, <%= user_class_name %>.authenticate('foo@bar.com', 'secret')
|
|
74
|
+
end
|
|
75
|
+
|
|
76
|
+
should "not authenticate bad username" do
|
|
77
|
+
assert_nil <%= user_class_name %>.authenticate('nonexisting', 'secret')
|
|
78
|
+
end
|
|
79
|
+
|
|
80
|
+
should "not authenticate bad password" do
|
|
81
|
+
new_<%= user_singular_name %>(:username => 'foobar', :password => 'secret').save!
|
|
82
|
+
assert_nil <%= user_class_name %>.authenticate('foobar', 'badpassword')
|
|
83
|
+
end
|
|
84
|
+
<%- end -%>
|
|
85
|
+
end
|
|
@@ -0,0 +1,61 @@
|
|
|
1
|
+
require 'test_helper'
|
|
2
|
+
|
|
3
|
+
class <%= user_plural_class_name %>ControllerTest < ActionController::TestCase
|
|
4
|
+
context "new action" do
|
|
5
|
+
should "render new template" do
|
|
6
|
+
get :new
|
|
7
|
+
assert_template 'new'
|
|
8
|
+
end
|
|
9
|
+
end
|
|
10
|
+
|
|
11
|
+
context "create action" do
|
|
12
|
+
should "render new template when <%= user_singular_name %> is invalid" do
|
|
13
|
+
<%= user_class_name %>.any_instance.stubs(:valid?).returns(false)
|
|
14
|
+
post :create
|
|
15
|
+
assert_template 'new'
|
|
16
|
+
end
|
|
17
|
+
|
|
18
|
+
should "redirect when <%= user_singular_name %> is valid" do
|
|
19
|
+
<%= user_class_name %>.any_instance.stubs(:valid?).returns(true)
|
|
20
|
+
post :create
|
|
21
|
+
assert_redirected_to root_url
|
|
22
|
+
<%- unless options[:authlogic] -%>
|
|
23
|
+
assert_equal assigns['<%= user_singular_name %>'].id, session['<%= user_singular_name %>_id']
|
|
24
|
+
<%- end -%>
|
|
25
|
+
end
|
|
26
|
+
end
|
|
27
|
+
|
|
28
|
+
context "edit action" do
|
|
29
|
+
should "redirect when not logged in" do
|
|
30
|
+
get :edit, :id => "ignored"
|
|
31
|
+
assert_redirected_to login_url
|
|
32
|
+
end
|
|
33
|
+
|
|
34
|
+
should "render edit template" do
|
|
35
|
+
@controller.stubs(:current_<%= user_singular_name %>).returns(<%= user_class_name %>.first)
|
|
36
|
+
get :edit, :id => "ignored"
|
|
37
|
+
assert_template 'edit'
|
|
38
|
+
end
|
|
39
|
+
end
|
|
40
|
+
|
|
41
|
+
context "update action" do
|
|
42
|
+
should "redirect when not logged in" do
|
|
43
|
+
put :update, :id => "ignored"
|
|
44
|
+
assert_redirected_to login_url
|
|
45
|
+
end
|
|
46
|
+
|
|
47
|
+
should "render edit template when <%= user_singular_name %> is invalid" do
|
|
48
|
+
@controller.stubs(:current_<%= user_singular_name %>).returns(<%= user_class_name %>.first)
|
|
49
|
+
<%= user_class_name %>.any_instance.stubs(:valid?).returns(false)
|
|
50
|
+
put :update, :id => "ignored"
|
|
51
|
+
assert_template 'edit'
|
|
52
|
+
end
|
|
53
|
+
|
|
54
|
+
should "redirect when <%= user_singular_name %> is valid" do
|
|
55
|
+
@controller.stubs(:current_<%= user_singular_name %>).returns(<%= user_class_name %>.first)
|
|
56
|
+
<%= user_class_name %>.any_instance.stubs(:valid?).returns(true)
|
|
57
|
+
put :update, :id => "ignored"
|
|
58
|
+
assert_redirected_to root_url
|
|
59
|
+
end
|
|
60
|
+
end
|
|
61
|
+
end
|
|
@@ -0,0 +1,36 @@
|
|
|
1
|
+
require 'test_helper'
|
|
2
|
+
|
|
3
|
+
class <%= session_plural_class_name %>ControllerTest < ActionController::TestCase
|
|
4
|
+
def test_new
|
|
5
|
+
get :new
|
|
6
|
+
assert_template 'new'
|
|
7
|
+
end
|
|
8
|
+
|
|
9
|
+
<%- if options[:authlogic] -%>
|
|
10
|
+
def test_create_invalid
|
|
11
|
+
post :create, :<%= session_singular_name %> => { :username => "foo", :password => "badpassword" }
|
|
12
|
+
assert_template 'new'
|
|
13
|
+
assert_nil <%= session_class_name %>.find
|
|
14
|
+
end
|
|
15
|
+
|
|
16
|
+
def test_create_valid
|
|
17
|
+
post :create, :<%= session_singular_name %> => { :username => "foo", :password => "secret" }
|
|
18
|
+
assert_redirected_to root_url
|
|
19
|
+
assert_equal <%= user_plural_name %>(:foo), <%= session_class_name %>.find.<%= user_singular_name %>
|
|
20
|
+
end
|
|
21
|
+
<%- else -%>
|
|
22
|
+
def test_create_invalid
|
|
23
|
+
<%= user_class_name %>.stubs(:authenticate).returns(nil)
|
|
24
|
+
post :create
|
|
25
|
+
assert_template 'new'
|
|
26
|
+
assert_nil session['<%= user_singular_name %>_id']
|
|
27
|
+
end
|
|
28
|
+
|
|
29
|
+
def test_create_valid
|
|
30
|
+
<%= user_class_name %>.stubs(:authenticate).returns(<%= user_class_name %>.first)
|
|
31
|
+
post :create
|
|
32
|
+
assert_redirected_to root_url
|
|
33
|
+
assert_equal <%= user_class_name %>.first.id, session['<%= user_singular_name %>_id']
|
|
34
|
+
end
|
|
35
|
+
<%- end -%>
|
|
36
|
+
end
|
|
@@ -0,0 +1,88 @@
|
|
|
1
|
+
require 'test_helper'
|
|
2
|
+
|
|
3
|
+
class <%= user_class_name %>Test < ActiveSupport::TestCase
|
|
4
|
+
<%- unless options[:authlogic] -%>
|
|
5
|
+
def new_<%= user_singular_name %>(attributes = {})
|
|
6
|
+
attributes[:username] ||= 'foo'
|
|
7
|
+
attributes[:email] ||= 'foo@example.com'
|
|
8
|
+
attributes[:password] ||= 'abc123'
|
|
9
|
+
attributes[:password_confirmation] ||= attributes[:password]
|
|
10
|
+
<%= user_singular_name %> = <%= user_class_name %>.new(attributes)
|
|
11
|
+
<%= user_singular_name %>.valid? # run validations
|
|
12
|
+
<%= user_singular_name %>
|
|
13
|
+
end
|
|
14
|
+
|
|
15
|
+
def setup
|
|
16
|
+
<%= user_class_name %>.delete_all
|
|
17
|
+
end
|
|
18
|
+
|
|
19
|
+
def test_valid
|
|
20
|
+
assert new_<%= user_singular_name %>.valid?
|
|
21
|
+
end
|
|
22
|
+
|
|
23
|
+
def test_require_username
|
|
24
|
+
assert_equal ["can't be blank"], new_<%= user_singular_name %>(:username => '').errors[:username]
|
|
25
|
+
end
|
|
26
|
+
|
|
27
|
+
def test_require_password
|
|
28
|
+
assert_equal ["can't be blank"], new_<%= user_singular_name %>(:password => '').errors[:password]
|
|
29
|
+
end
|
|
30
|
+
|
|
31
|
+
def test_require_well_formed_email
|
|
32
|
+
assert_equal ["is invalid"], new_<%= user_singular_name %>(:email => 'foo@bar@example.com').errors[:email]
|
|
33
|
+
end
|
|
34
|
+
|
|
35
|
+
def test_validate_uniqueness_of_email
|
|
36
|
+
new_<%= user_singular_name %>(:email => 'bar@example.com').save!
|
|
37
|
+
assert_equal ["has already been taken"], new_<%= user_singular_name %>(:email => 'bar@example.com').errors[:email]
|
|
38
|
+
end
|
|
39
|
+
|
|
40
|
+
def test_validate_uniqueness_of_username
|
|
41
|
+
new_<%= user_singular_name %>(:username => 'uniquename').save!
|
|
42
|
+
assert_equal ["has already been taken"], new_<%= user_singular_name %>(:username => 'uniquename').errors[:username]
|
|
43
|
+
end
|
|
44
|
+
|
|
45
|
+
def test_validate_odd_characters_in_username
|
|
46
|
+
assert_equal ["should only contain letters, numbers, or .-_@"], new_<%= user_singular_name %>(:username => 'odd ^&(@)').errors[:username]
|
|
47
|
+
end
|
|
48
|
+
|
|
49
|
+
def test_validate_password_length
|
|
50
|
+
assert_equal ["is too short (minimum is 4 characters)"], new_<%= user_singular_name %>(:password => 'bad').errors[:password]
|
|
51
|
+
end
|
|
52
|
+
|
|
53
|
+
def test_require_matching_password_confirmation
|
|
54
|
+
assert_equal ["doesn't match confirmation"], new_<%= user_singular_name %>(:password_confirmation => 'nonmatching').errors[:password]
|
|
55
|
+
end
|
|
56
|
+
|
|
57
|
+
def test_generate_password_hash_and_salt_on_create
|
|
58
|
+
<%= user_singular_name %> = new_<%= user_singular_name %>
|
|
59
|
+
<%= user_singular_name %>.save!
|
|
60
|
+
assert <%= user_singular_name %>.password_hash
|
|
61
|
+
assert <%= user_singular_name %>.password_salt
|
|
62
|
+
end
|
|
63
|
+
|
|
64
|
+
def test_authenticate_by_username
|
|
65
|
+
<%= user_class_name %>.delete_all
|
|
66
|
+
<%= user_singular_name %> = new_<%= user_singular_name %>(:username => 'foobar', :password => 'secret')
|
|
67
|
+
<%= user_singular_name %>.save!
|
|
68
|
+
assert_equal <%= user_singular_name %>, <%= user_class_name %>.authenticate('foobar', 'secret')
|
|
69
|
+
end
|
|
70
|
+
|
|
71
|
+
def test_authenticate_by_email
|
|
72
|
+
<%= user_class_name %>.delete_all
|
|
73
|
+
<%= user_singular_name %> = new_<%= user_singular_name %>(:email => 'foo@bar.com', :password => 'secret')
|
|
74
|
+
<%= user_singular_name %>.save!
|
|
75
|
+
assert_equal <%= user_singular_name %>, <%= user_class_name %>.authenticate('foo@bar.com', 'secret')
|
|
76
|
+
end
|
|
77
|
+
|
|
78
|
+
def test_authenticate_bad_username
|
|
79
|
+
assert_nil <%= user_class_name %>.authenticate('nonexisting', 'secret')
|
|
80
|
+
end
|
|
81
|
+
|
|
82
|
+
def test_authenticate_bad_password
|
|
83
|
+
<%= user_class_name %>.delete_all
|
|
84
|
+
new_<%= user_singular_name %>(:username => 'foobar', :password => 'secret').save!
|
|
85
|
+
assert_nil <%= user_class_name %>.authenticate('foobar', 'badpassword')
|
|
86
|
+
end
|
|
87
|
+
<%- end -%>
|
|
88
|
+
end
|