devise_ldap_authenticatable 0.4.0 → 0.4.1
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 +5 -0
- data/MIT-LICENSE +20 -0
- data/README.md +4 -1
- data/Rakefile +52 -0
- data/VERSION +1 -0
- data/devise_ldap_authenticatable.gemspec +166 -0
- data/lib/devise_ldap_authenticatable.rb +3 -0
- data/lib/devise_ldap_authenticatable/ldap_adapter.rb +14 -4
- data/lib/devise_ldap_authenticatable/model.rb +26 -26
- data/lib/devise_ldap_authenticatable/version.rb +1 -1
- data/lib/generators/devise_ldap_authenticatable/install_generator.rb +2 -0
- data/rails/init.rb +2 -0
- data/test/devise_ldap_authenticatable_test.rb +8 -0
- data/test/ldap/base.ldif +54 -0
- data/test/ldap/clear.ldif +20 -0
- data/test/ldap/local.schema +6 -0
- data/test/ldap/run-server.sh +4 -0
- data/test/ldap/slapd-test.conf +106 -0
- data/test/rails_app/Gemfile +22 -0
- data/test/rails_app/Rakefile +7 -0
- data/test/rails_app/app/controllers/application_controller.rb +4 -0
- data/test/rails_app/app/controllers/posts_controller.rb +15 -0
- data/test/rails_app/app/helpers/application_helper.rb +2 -0
- data/test/rails_app/app/helpers/posts_helper.rb +2 -0
- data/test/rails_app/app/models/post.rb +2 -0
- data/test/rails_app/app/models/user.rb +10 -0
- data/test/rails_app/app/views/layouts/application.html.erb +26 -0
- data/test/rails_app/app/views/posts/index.html.erb +2 -0
- data/test/rails_app/config.ru +4 -0
- data/test/rails_app/config/application.rb +46 -0
- data/test/rails_app/config/boot.rb +13 -0
- data/test/rails_app/config/cucumber.yml +8 -0
- data/test/rails_app/config/database.yml +25 -0
- data/test/rails_app/config/environment.rb +5 -0
- data/test/rails_app/config/environments/development.rb +22 -0
- data/test/rails_app/config/environments/production.rb +46 -0
- data/test/rails_app/config/environments/test.rb +34 -0
- data/test/rails_app/config/initializers/backtrace_silencers.rb +7 -0
- data/test/rails_app/config/initializers/devise.rb +140 -0
- data/test/rails_app/config/initializers/inflections.rb +10 -0
- data/test/rails_app/config/initializers/mime_types.rb +5 -0
- data/test/rails_app/config/initializers/secret_token.rb +7 -0
- data/test/rails_app/config/initializers/session_store.rb +8 -0
- data/test/rails_app/config/ldap.yml +33 -0
- data/test/rails_app/config/ldap_with_uid.yml +30 -0
- data/test/rails_app/config/locales/devise.en.yml +39 -0
- data/test/rails_app/config/locales/en.yml +5 -0
- data/test/rails_app/config/routes.rb +64 -0
- data/test/rails_app/db/migrate/20100708120302_create_posts.rb +14 -0
- data/test/rails_app/db/migrate/20100708120448_devise_create_users.rb +26 -0
- data/test/rails_app/db/schema.rb +41 -0
- data/test/rails_app/db/seeds.rb +7 -0
- data/test/rails_app/features/manage_logins.feature +34 -0
- data/test/rails_app/features/step_definitions/login_steps.rb +16 -0
- data/test/rails_app/features/step_definitions/web_steps.rb +219 -0
- data/test/rails_app/features/support/env.rb +58 -0
- data/test/rails_app/features/support/paths.rb +38 -0
- data/test/rails_app/lib/tasks/.gitkeep +0 -0
- data/test/rails_app/lib/tasks/cucumber.rake +53 -0
- data/test/rails_app/public/404.html +26 -0
- data/test/rails_app/public/422.html +26 -0
- data/test/rails_app/public/500.html +26 -0
- data/test/rails_app/public/images/rails.png +0 -0
- data/test/rails_app/public/javascripts/application.js +2 -0
- data/test/rails_app/public/javascripts/controls.js +965 -0
- data/test/rails_app/public/javascripts/dragdrop.js +974 -0
- data/test/rails_app/public/javascripts/effects.js +1123 -0
- data/test/rails_app/public/javascripts/prototype.js +4874 -0
- data/test/rails_app/public/javascripts/rails.js +118 -0
- data/test/rails_app/public/stylesheets/.gitkeep +0 -0
- data/test/rails_app/script/cucumber +10 -0
- data/test/rails_app/script/rails +6 -0
- data/test/rails_app/test/factories/users.rb +9 -0
- data/test/rails_app/test/functional/posts_controller_test.rb +58 -0
- data/test/rails_app/test/performance/browsing_test.rb +9 -0
- data/test/rails_app/test/test_helper.rb +22 -0
- data/test/rails_app/test/unit/helpers/posts_helper_test.rb +4 -0
- data/test/rails_app/test/unit/post_test.rb +8 -0
- data/test/rails_app/test/unit/user_test.rb +172 -0
- data/test/test_helper.rb +3 -0
- metadata +140 -30
| @@ -0,0 +1,26 @@ | |
| 1 | 
            +
            class DeviseCreateUsers < ActiveRecord::Migration
         | 
| 2 | 
            +
              def self.up
         | 
| 3 | 
            +
                create_table(:users) do |t|
         | 
| 4 | 
            +
                  t.database_authenticatable :null => false
         | 
| 5 | 
            +
                  t.recoverable
         | 
| 6 | 
            +
                  t.rememberable
         | 
| 7 | 
            +
                  t.trackable
         | 
| 8 | 
            +
                  t.string :uid
         | 
| 9 | 
            +
             | 
| 10 | 
            +
                  # t.confirmable
         | 
| 11 | 
            +
                  # t.lockable :lock_strategy => :failed_attempts, :unlock_strategy => :both
         | 
| 12 | 
            +
                  # t.token_authenticatable
         | 
| 13 | 
            +
             | 
| 14 | 
            +
                  t.timestamps
         | 
| 15 | 
            +
                end
         | 
| 16 | 
            +
             | 
| 17 | 
            +
                add_index :users, :email,                :unique => true
         | 
| 18 | 
            +
                add_index :users, :reset_password_token, :unique => true
         | 
| 19 | 
            +
                # add_index :users, :confirmation_token,   :unique => true
         | 
| 20 | 
            +
                # add_index :users, :unlock_token,         :unique => true
         | 
| 21 | 
            +
              end
         | 
| 22 | 
            +
             | 
| 23 | 
            +
              def self.down
         | 
| 24 | 
            +
                drop_table :users
         | 
| 25 | 
            +
              end
         | 
| 26 | 
            +
            end
         | 
| @@ -0,0 +1,41 @@ | |
| 1 | 
            +
            # This file is auto-generated from the current state of the database. Instead of editing this file, 
         | 
| 2 | 
            +
            # please use the migrations feature of Active Record to incrementally modify your database, and
         | 
| 3 | 
            +
            # then regenerate this schema definition.
         | 
| 4 | 
            +
            #
         | 
| 5 | 
            +
            # Note that this schema.rb definition is the authoritative source for your database schema. If you need
         | 
| 6 | 
            +
            # to create the application database on another system, you should be using db:schema:load, not running
         | 
| 7 | 
            +
            # all the migrations from scratch. The latter is a flawed and unsustainable approach (the more migrations
         | 
| 8 | 
            +
            # you'll amass, the slower it'll run and the greater likelihood for issues).
         | 
| 9 | 
            +
            #
         | 
| 10 | 
            +
            # It's strongly recommended to check this file into your version control system.
         | 
| 11 | 
            +
             | 
| 12 | 
            +
            ActiveRecord::Schema.define(:version => 20100708120448) do
         | 
| 13 | 
            +
             | 
| 14 | 
            +
              create_table "posts", :force => true do |t|
         | 
| 15 | 
            +
                t.string   "title"
         | 
| 16 | 
            +
                t.text     "body"
         | 
| 17 | 
            +
                t.datetime "created_at"
         | 
| 18 | 
            +
                t.datetime "updated_at"
         | 
| 19 | 
            +
              end
         | 
| 20 | 
            +
             | 
| 21 | 
            +
              create_table "users", :force => true do |t|
         | 
| 22 | 
            +
                t.string   "email",                               :default => "", :null => false
         | 
| 23 | 
            +
                t.string   "encrypted_password",   :limit => 128, :default => "", :null => false
         | 
| 24 | 
            +
                t.string   "password_salt",                       :default => "", :null => false
         | 
| 25 | 
            +
                t.string   "reset_password_token"
         | 
| 26 | 
            +
                t.string   "remember_token"
         | 
| 27 | 
            +
                t.datetime "remember_created_at"
         | 
| 28 | 
            +
                t.integer  "sign_in_count",                       :default => 0
         | 
| 29 | 
            +
                t.datetime "current_sign_in_at"
         | 
| 30 | 
            +
                t.datetime "last_sign_in_at"
         | 
| 31 | 
            +
                t.string   "current_sign_in_ip"
         | 
| 32 | 
            +
                t.string   "last_sign_in_ip"
         | 
| 33 | 
            +
                t.string   "uid"
         | 
| 34 | 
            +
                t.datetime "created_at"
         | 
| 35 | 
            +
                t.datetime "updated_at"
         | 
| 36 | 
            +
              end
         | 
| 37 | 
            +
             | 
| 38 | 
            +
              add_index "users", ["email"], :name => "index_users_on_email", :unique => true
         | 
| 39 | 
            +
              add_index "users", ["reset_password_token"], :name => "index_users_on_reset_password_token", :unique => true
         | 
| 40 | 
            +
             | 
| 41 | 
            +
            end
         | 
| @@ -0,0 +1,7 @@ | |
| 1 | 
            +
            # This file should contain all the record creation needed to seed the database with its default values.
         | 
| 2 | 
            +
            # The data can then be loaded with the rake db:seed (or created alongside the db with db:setup).
         | 
| 3 | 
            +
            #
         | 
| 4 | 
            +
            # Examples:
         | 
| 5 | 
            +
            #
         | 
| 6 | 
            +
            #   cities = City.create([{ :name => 'Chicago' }, { :name => 'Copenhagen' }])
         | 
| 7 | 
            +
            #   Mayor.create(:name => 'Daley', :city => cities.first)
         | 
| @@ -0,0 +1,34 @@ | |
| 1 | 
            +
            Feature: Manage logins
         | 
| 2 | 
            +
              In order to login with Devise LDAP Authenticatable
         | 
| 3 | 
            +
              As a user
         | 
| 4 | 
            +
              I want to login with LDAP
         | 
| 5 | 
            +
             | 
| 6 | 
            +
              Background:
         | 
| 7 | 
            +
                Given the following logins:
         | 
| 8 | 
            +
                  | email                 | password |
         | 
| 9 | 
            +
                  | example.user@test.com | secret  |
         | 
| 10 | 
            +
              
         | 
| 11 | 
            +
              Scenario: Login with valid user
         | 
| 12 | 
            +
                Given I am on the login page
         | 
| 13 | 
            +
                When I fill in "Email" with "example.user@test.com"
         | 
| 14 | 
            +
                And I fill in "Password" with "secret"
         | 
| 15 | 
            +
                And I press "Sign in"
         | 
| 16 | 
            +
                Then I should see "posts#index"
         | 
| 17 | 
            +
                
         | 
| 18 | 
            +
              Scenario: Login with invalid user
         | 
| 19 | 
            +
                Given I am on the login page
         | 
| 20 | 
            +
                When I fill in "Email" with "example.user@test.com"
         | 
| 21 | 
            +
                And I fill in "Password" with "wrong"
         | 
| 22 | 
            +
                And I press "Sign in"
         | 
| 23 | 
            +
                Then I should see "Invalid email or password"
         | 
| 24 | 
            +
              
         | 
| 25 | 
            +
              Scenario: Get redirected to the login page and then login
         | 
| 26 | 
            +
                When I go to the new post page
         | 
| 27 | 
            +
                Then I should be on the login page
         | 
| 28 | 
            +
                When I fill in "Email" with "example.user@test.com"
         | 
| 29 | 
            +
                And I fill in "Password" with "secret"
         | 
| 30 | 
            +
                And I press "Sign in"
         | 
| 31 | 
            +
                Then I should be on the new post page
         | 
| 32 | 
            +
              
         | 
| 33 | 
            +
              
         | 
| 34 | 
            +
              
         | 
| @@ -0,0 +1,16 @@ | |
| 1 | 
            +
            Given /^the following logins:$/ do |logins|
         | 
| 2 | 
            +
              logins.hashes.each do |user|
         | 
| 3 | 
            +
                User.create(:email => user["email"], :password => user["password"])
         | 
| 4 | 
            +
              end
         | 
| 5 | 
            +
            end
         | 
| 6 | 
            +
             | 
| 7 | 
            +
            When /^I delete the (\d+)(?:st|nd|rd|th) login$/ do |pos|
         | 
| 8 | 
            +
              visit logins_path
         | 
| 9 | 
            +
              within("table tr:nth-child(#{pos.to_i+1})") do
         | 
| 10 | 
            +
                click_link "Destroy"
         | 
| 11 | 
            +
              end
         | 
| 12 | 
            +
            end
         | 
| 13 | 
            +
             | 
| 14 | 
            +
            Then /^I should see the following logins:$/ do |expected_logins_table|
         | 
| 15 | 
            +
              expected_logins_table.diff!(tableish('table tr', 'td,th'))
         | 
| 16 | 
            +
            end
         | 
| @@ -0,0 +1,219 @@ | |
| 1 | 
            +
            # IMPORTANT: This file is generated by cucumber-rails - edit at your own peril.
         | 
| 2 | 
            +
            # It is recommended to regenerate this file in the future when you upgrade to a 
         | 
| 3 | 
            +
            # newer version of cucumber-rails. Consider adding your own code to a new file 
         | 
| 4 | 
            +
            # instead of editing this one. Cucumber will automatically load all features/**/*.rb
         | 
| 5 | 
            +
            # files.
         | 
| 6 | 
            +
             | 
| 7 | 
            +
             | 
| 8 | 
            +
            require 'uri'
         | 
| 9 | 
            +
            require 'cgi'
         | 
| 10 | 
            +
            require File.expand_path(File.join(File.dirname(__FILE__), "..", "support", "paths"))
         | 
| 11 | 
            +
             | 
| 12 | 
            +
            module WithinHelpers
         | 
| 13 | 
            +
              def with_scope(locator)
         | 
| 14 | 
            +
                locator ? within(locator) { yield } : yield
         | 
| 15 | 
            +
              end
         | 
| 16 | 
            +
            end
         | 
| 17 | 
            +
            World(WithinHelpers)
         | 
| 18 | 
            +
             | 
| 19 | 
            +
            Given /^(?:|I )am on (.+)$/ do |page_name|
         | 
| 20 | 
            +
              visit path_to(page_name)
         | 
| 21 | 
            +
            end
         | 
| 22 | 
            +
             | 
| 23 | 
            +
            When /^(?:|I )go to (.+)$/ do |page_name|
         | 
| 24 | 
            +
              visit path_to(page_name)
         | 
| 25 | 
            +
            end
         | 
| 26 | 
            +
             | 
| 27 | 
            +
            When /^(?:|I )press "([^"]*)"(?: within "([^"]*)")?$/ do |button, selector|
         | 
| 28 | 
            +
              with_scope(selector) do
         | 
| 29 | 
            +
                click_button(button)
         | 
| 30 | 
            +
              end
         | 
| 31 | 
            +
            end
         | 
| 32 | 
            +
             | 
| 33 | 
            +
            When /^(?:|I )follow "([^"]*)"(?: within "([^"]*)")?$/ do |link, selector|
         | 
| 34 | 
            +
              with_scope(selector) do
         | 
| 35 | 
            +
                click_link(link)
         | 
| 36 | 
            +
              end
         | 
| 37 | 
            +
            end
         | 
| 38 | 
            +
             | 
| 39 | 
            +
            When /^(?:|I )fill in "([^"]*)" with "([^"]*)"(?: within "([^"]*)")?$/ do |field, value, selector|
         | 
| 40 | 
            +
              with_scope(selector) do
         | 
| 41 | 
            +
                fill_in(field, :with => value)
         | 
| 42 | 
            +
              end
         | 
| 43 | 
            +
            end
         | 
| 44 | 
            +
             | 
| 45 | 
            +
            When /^(?:|I )fill in "([^"]*)" for "([^"]*)"(?: within "([^"]*)")?$/ do |value, field, selector|
         | 
| 46 | 
            +
              with_scope(selector) do
         | 
| 47 | 
            +
                fill_in(field, :with => value)
         | 
| 48 | 
            +
              end
         | 
| 49 | 
            +
            end
         | 
| 50 | 
            +
             | 
| 51 | 
            +
            # Use this to fill in an entire form with data from a table. Example:
         | 
| 52 | 
            +
            #
         | 
| 53 | 
            +
            #   When I fill in the following:
         | 
| 54 | 
            +
            #     | Account Number | 5002       |
         | 
| 55 | 
            +
            #     | Expiry date    | 2009-11-01 |
         | 
| 56 | 
            +
            #     | Note           | Nice guy   |
         | 
| 57 | 
            +
            #     | Wants Email?   |            |
         | 
| 58 | 
            +
            #
         | 
| 59 | 
            +
            # TODO: Add support for checkbox, select og option
         | 
| 60 | 
            +
            # based on naming conventions.
         | 
| 61 | 
            +
            #
         | 
| 62 | 
            +
            When /^(?:|I )fill in the following(?: within "([^"]*)")?:$/ do |selector, fields|
         | 
| 63 | 
            +
              with_scope(selector) do
         | 
| 64 | 
            +
                fields.rows_hash.each do |name, value|
         | 
| 65 | 
            +
                  When %{I fill in "#{name}" with "#{value}"}
         | 
| 66 | 
            +
                end
         | 
| 67 | 
            +
              end
         | 
| 68 | 
            +
            end
         | 
| 69 | 
            +
             | 
| 70 | 
            +
            When /^(?:|I )select "([^"]*)" from "([^"]*)"(?: within "([^"]*)")?$/ do |value, field, selector|
         | 
| 71 | 
            +
              with_scope(selector) do
         | 
| 72 | 
            +
                select(value, :from => field)
         | 
| 73 | 
            +
              end
         | 
| 74 | 
            +
            end
         | 
| 75 | 
            +
             | 
| 76 | 
            +
            When /^(?:|I )check "([^"]*)"(?: within "([^"]*)")?$/ do |field, selector|
         | 
| 77 | 
            +
              with_scope(selector) do
         | 
| 78 | 
            +
                check(field)
         | 
| 79 | 
            +
              end
         | 
| 80 | 
            +
            end
         | 
| 81 | 
            +
             | 
| 82 | 
            +
            When /^(?:|I )uncheck "([^"]*)"(?: within "([^"]*)")?$/ do |field, selector|
         | 
| 83 | 
            +
              with_scope(selector) do
         | 
| 84 | 
            +
                uncheck(field)
         | 
| 85 | 
            +
              end
         | 
| 86 | 
            +
            end
         | 
| 87 | 
            +
             | 
| 88 | 
            +
            When /^(?:|I )choose "([^"]*)"(?: within "([^"]*)")?$/ do |field, selector|
         | 
| 89 | 
            +
              with_scope(selector) do
         | 
| 90 | 
            +
                choose(field)
         | 
| 91 | 
            +
              end
         | 
| 92 | 
            +
            end
         | 
| 93 | 
            +
             | 
| 94 | 
            +
            When /^(?:|I )attach the file "([^"]*)" to "([^"]*)"(?: within "([^"]*)")?$/ do |path, field, selector|
         | 
| 95 | 
            +
              with_scope(selector) do
         | 
| 96 | 
            +
                attach_file(field, path)
         | 
| 97 | 
            +
              end
         | 
| 98 | 
            +
            end
         | 
| 99 | 
            +
             | 
| 100 | 
            +
            Then /^(?:|I )should see JSON:$/ do |expected_json|
         | 
| 101 | 
            +
              require 'json'
         | 
| 102 | 
            +
              expected = JSON.pretty_generate(JSON.parse(expected_json))
         | 
| 103 | 
            +
              actual   = JSON.pretty_generate(JSON.parse(response.body))
         | 
| 104 | 
            +
              expected.should == actual
         | 
| 105 | 
            +
            end
         | 
| 106 | 
            +
             | 
| 107 | 
            +
            Then /^(?:|I )should see "([^"]*)"(?: within "([^"]*)")?$/ do |text, selector|
         | 
| 108 | 
            +
              with_scope(selector) do
         | 
| 109 | 
            +
                if page.respond_to? :should
         | 
| 110 | 
            +
                  page.should have_content(text)
         | 
| 111 | 
            +
                else
         | 
| 112 | 
            +
                  assert page.has_content?(text)
         | 
| 113 | 
            +
                end
         | 
| 114 | 
            +
              end
         | 
| 115 | 
            +
            end
         | 
| 116 | 
            +
             | 
| 117 | 
            +
            Then /^(?:|I )should see \/([^\/]*)\/(?: within "([^"]*)")?$/ do |regexp, selector|
         | 
| 118 | 
            +
              regexp = Regexp.new(regexp)
         | 
| 119 | 
            +
              with_scope(selector) do
         | 
| 120 | 
            +
                if page.respond_to? :should
         | 
| 121 | 
            +
                  page.should have_xpath('//*', :text => regexp)
         | 
| 122 | 
            +
                else
         | 
| 123 | 
            +
                  assert page.has_xpath?('//*', :text => regexp)
         | 
| 124 | 
            +
                end
         | 
| 125 | 
            +
              end
         | 
| 126 | 
            +
            end
         | 
| 127 | 
            +
             | 
| 128 | 
            +
            Then /^(?:|I )should not see "([^"]*)"(?: within "([^"]*)")?$/ do |text, selector|
         | 
| 129 | 
            +
              with_scope(selector) do
         | 
| 130 | 
            +
                if page.respond_to? :should
         | 
| 131 | 
            +
                  page.should have_no_content(text)
         | 
| 132 | 
            +
                else
         | 
| 133 | 
            +
                  assert page.has_no_content?(text)
         | 
| 134 | 
            +
                end
         | 
| 135 | 
            +
              end
         | 
| 136 | 
            +
            end
         | 
| 137 | 
            +
             | 
| 138 | 
            +
            Then /^(?:|I )should not see \/([^\/]*)\/(?: within "([^"]*)")?$/ do |regexp, selector|
         | 
| 139 | 
            +
              regexp = Regexp.new(regexp)
         | 
| 140 | 
            +
              with_scope(selector) do
         | 
| 141 | 
            +
                if page.respond_to? :should
         | 
| 142 | 
            +
                  page.should have_no_xpath('//*', :text => regexp)
         | 
| 143 | 
            +
                else
         | 
| 144 | 
            +
                  assert page.has_no_xpath?('//*', :text => regexp)
         | 
| 145 | 
            +
                end
         | 
| 146 | 
            +
              end
         | 
| 147 | 
            +
            end
         | 
| 148 | 
            +
             | 
| 149 | 
            +
            Then /^the "([^"]*)" field(?: within "([^"]*)")? should contain "([^"]*)"$/ do |field, selector, value|
         | 
| 150 | 
            +
              with_scope(selector) do
         | 
| 151 | 
            +
                field = find_field(field)
         | 
| 152 | 
            +
                field_value = (field.tag_name == 'textarea') ? field.text : field.value
         | 
| 153 | 
            +
                if field_value.respond_to? :should
         | 
| 154 | 
            +
                  field_value.should =~ /#{value}/
         | 
| 155 | 
            +
                else
         | 
| 156 | 
            +
                  assert_match(/#{value}/, field_value)
         | 
| 157 | 
            +
                end
         | 
| 158 | 
            +
              end
         | 
| 159 | 
            +
            end
         | 
| 160 | 
            +
             | 
| 161 | 
            +
            Then /^the "([^"]*)" field(?: within "([^"]*)")? should not contain "([^"]*)"$/ do |field, selector, value|
         | 
| 162 | 
            +
              with_scope(selector) do
         | 
| 163 | 
            +
                field = find_field(field)
         | 
| 164 | 
            +
                field_value = (field.tag_name == 'textarea') ? field.text : field.value
         | 
| 165 | 
            +
                if field_value.respond_to? :should_not
         | 
| 166 | 
            +
                  field_value.should_not =~ /#{value}/
         | 
| 167 | 
            +
                else
         | 
| 168 | 
            +
                  assert_no_match(/#{value}/, field_value)
         | 
| 169 | 
            +
                end
         | 
| 170 | 
            +
              end
         | 
| 171 | 
            +
            end
         | 
| 172 | 
            +
             | 
| 173 | 
            +
            Then /^the "([^"]*)" checkbox(?: within "([^"]*)")? should be checked$/ do |label, selector|
         | 
| 174 | 
            +
              with_scope(selector) do
         | 
| 175 | 
            +
                field_checked = find_field(label)['checked']
         | 
| 176 | 
            +
                if field_checked.respond_to? :should
         | 
| 177 | 
            +
                  field_checked.should be_true
         | 
| 178 | 
            +
                else
         | 
| 179 | 
            +
                  assert field_checked
         | 
| 180 | 
            +
                end
         | 
| 181 | 
            +
              end
         | 
| 182 | 
            +
            end
         | 
| 183 | 
            +
             | 
| 184 | 
            +
            Then /^the "([^"]*)" checkbox(?: within "([^"]*)")? should not be checked$/ do |label, selector|
         | 
| 185 | 
            +
              with_scope(selector) do
         | 
| 186 | 
            +
                field_checked = find_field(label)['checked']
         | 
| 187 | 
            +
                if field_checked.respond_to? :should
         | 
| 188 | 
            +
                  field_checked.should be_false
         | 
| 189 | 
            +
                else
         | 
| 190 | 
            +
                  assert !field_checked
         | 
| 191 | 
            +
                end
         | 
| 192 | 
            +
              end
         | 
| 193 | 
            +
            end
         | 
| 194 | 
            +
             
         | 
| 195 | 
            +
            Then /^(?:|I )should be on (.+)$/ do |page_name|
         | 
| 196 | 
            +
              current_path = URI.parse(current_url).path
         | 
| 197 | 
            +
              if current_path.respond_to? :should
         | 
| 198 | 
            +
                current_path.should == path_to(page_name)
         | 
| 199 | 
            +
              else
         | 
| 200 | 
            +
                assert_equal path_to(page_name), current_path
         | 
| 201 | 
            +
              end
         | 
| 202 | 
            +
            end
         | 
| 203 | 
            +
             | 
| 204 | 
            +
            Then /^(?:|I )should have the following query string:$/ do |expected_pairs|
         | 
| 205 | 
            +
              query = URI.parse(current_url).query
         | 
| 206 | 
            +
              actual_params = query ? CGI.parse(query) : {}
         | 
| 207 | 
            +
              expected_params = {}
         | 
| 208 | 
            +
              expected_pairs.rows_hash.each_pair{|k,v| expected_params[k] = v.split(',')} 
         | 
| 209 | 
            +
              
         | 
| 210 | 
            +
              if actual_params.respond_to? :should
         | 
| 211 | 
            +
                actual_params.should == expected_params
         | 
| 212 | 
            +
              else
         | 
| 213 | 
            +
                assert_equal expected_params, actual_params
         | 
| 214 | 
            +
              end
         | 
| 215 | 
            +
            end
         | 
| 216 | 
            +
             | 
| 217 | 
            +
            Then /^show me the page$/ do
         | 
| 218 | 
            +
              save_and_open_page
         | 
| 219 | 
            +
            end
         | 
| @@ -0,0 +1,58 @@ | |
| 1 | 
            +
            # IMPORTANT: This file is generated by cucumber-rails - edit at your own peril.
         | 
| 2 | 
            +
            # It is recommended to regenerate this file in the future when you upgrade to a 
         | 
| 3 | 
            +
            # newer version of cucumber-rails. Consider adding your own code to a new file 
         | 
| 4 | 
            +
            # instead of editing this one. Cucumber will automatically load all features/**/*.rb
         | 
| 5 | 
            +
            # files.
         | 
| 6 | 
            +
             | 
| 7 | 
            +
            ENV["RAILS_ENV"] ||= "test"
         | 
| 8 | 
            +
            require File.expand_path(File.dirname(__FILE__) + '/../../config/environment')
         | 
| 9 | 
            +
             | 
| 10 | 
            +
            require 'cucumber/formatter/unicode' # Remove this line if you don't want Cucumber Unicode support
         | 
| 11 | 
            +
            require 'cucumber/rails/world'
         | 
| 12 | 
            +
            require 'cucumber/rails/active_record'
         | 
| 13 | 
            +
            require 'cucumber/web/tableish'
         | 
| 14 | 
            +
             | 
| 15 | 
            +
            require 'capybara/rails'
         | 
| 16 | 
            +
            require 'capybara/cucumber'
         | 
| 17 | 
            +
            require 'capybara/session'
         | 
| 18 | 
            +
            require 'cucumber/rails/capybara_javascript_emulation' # Lets you click links with onclick javascript handlers without using @culerity or @javascript
         | 
| 19 | 
            +
            # Capybara defaults to XPath selectors rather than Webrat's default of CSS3. In
         | 
| 20 | 
            +
            # order to ease the transition to Capybara we set the default here. If you'd
         | 
| 21 | 
            +
            # prefer to use XPath just remove this line and adjust any selectors in your
         | 
| 22 | 
            +
            # steps to use the XPath syntax.
         | 
| 23 | 
            +
            Capybara.default_selector = :css
         | 
| 24 | 
            +
            Capybara.save_and_open_page_path = File.join('/tmp')
         | 
| 25 | 
            +
             | 
| 26 | 
            +
            # If you set this to false, any error raised from within your app will bubble 
         | 
| 27 | 
            +
            # up to your step definition and out to cucumber unless you catch it somewhere
         | 
| 28 | 
            +
            # on the way. You can make Rails rescue errors and render error pages on a
         | 
| 29 | 
            +
            # per-scenario basis by tagging a scenario or feature with the @allow-rescue tag.
         | 
| 30 | 
            +
            #
         | 
| 31 | 
            +
            # If you set this to true, Rails will rescue all errors and render error
         | 
| 32 | 
            +
            # pages, more or less in the same way your application would behave in the
         | 
| 33 | 
            +
            # default production environment. It's not recommended to do this for all
         | 
| 34 | 
            +
            # of your scenarios, as this makes it hard to discover errors in your application.
         | 
| 35 | 
            +
            ActionController::Base.allow_rescue = false
         | 
| 36 | 
            +
             | 
| 37 | 
            +
            # If you set this to true, each scenario will run in a database transaction.
         | 
| 38 | 
            +
            # You can still turn off transactions on a per-scenario basis, simply tagging 
         | 
| 39 | 
            +
            # a feature or scenario with the @no-txn tag. If you are using Capybara,
         | 
| 40 | 
            +
            # tagging with @culerity or @javascript will also turn transactions off.
         | 
| 41 | 
            +
            #
         | 
| 42 | 
            +
            # If you set this to false, transactions will be off for all scenarios,
         | 
| 43 | 
            +
            # regardless of whether you use @no-txn or not.
         | 
| 44 | 
            +
            #
         | 
| 45 | 
            +
            # Beware that turning transactions off will leave data in your database 
         | 
| 46 | 
            +
            # after each scenario, which can lead to hard-to-debug failures in 
         | 
| 47 | 
            +
            # subsequent scenarios. If you do this, we recommend you create a Before
         | 
| 48 | 
            +
            # block that will explicitly put your database in a known state.
         | 
| 49 | 
            +
            Cucumber::Rails::World.use_transactional_fixtures = true
         | 
| 50 | 
            +
            # How to clean your database when transactions are turned off. See
         | 
| 51 | 
            +
            # http://github.com/bmabey/database_cleaner for more info.
         | 
| 52 | 
            +
            if defined?(ActiveRecord::Base)
         | 
| 53 | 
            +
              begin
         | 
| 54 | 
            +
                require 'database_cleaner'
         | 
| 55 | 
            +
                DatabaseCleaner.strategy = :truncation
         | 
| 56 | 
            +
              rescue LoadError => ignore_if_database_cleaner_not_present
         | 
| 57 | 
            +
              end
         | 
| 58 | 
            +
            end
         | 
| @@ -0,0 +1,38 @@ | |
| 1 | 
            +
            module NavigationHelpers
         | 
| 2 | 
            +
              # Maps a name to a path. Used by the
         | 
| 3 | 
            +
              #
         | 
| 4 | 
            +
              #   When /^I go to (.+)$/ do |page_name|
         | 
| 5 | 
            +
              #
         | 
| 6 | 
            +
              # step definition in web_steps.rb
         | 
| 7 | 
            +
              #
         | 
| 8 | 
            +
              def path_to(page_name)
         | 
| 9 | 
            +
                case page_name
         | 
| 10 | 
            +
             | 
| 11 | 
            +
                when /the home\s?page/
         | 
| 12 | 
            +
                  '/'
         | 
| 13 | 
            +
                when /the login page/
         | 
| 14 | 
            +
                  new_user_session_path
         | 
| 15 | 
            +
             | 
| 16 | 
            +
                when /the new post page/
         | 
| 17 | 
            +
                  new_post_path
         | 
| 18 | 
            +
             | 
| 19 | 
            +
                # Add more mappings here.
         | 
| 20 | 
            +
                # Here is an example that pulls values out of the Regexp:
         | 
| 21 | 
            +
                #
         | 
| 22 | 
            +
                #   when /^(.*)'s profile page$/i
         | 
| 23 | 
            +
                #     user_profile_path(User.find_by_login($1))
         | 
| 24 | 
            +
             | 
| 25 | 
            +
                else
         | 
| 26 | 
            +
                  begin
         | 
| 27 | 
            +
                    page_name =~ /the (.*) page/
         | 
| 28 | 
            +
                    path_components = $1.split(/\s+/)
         | 
| 29 | 
            +
                    self.send(path_components.push('path').join('_').to_sym)
         | 
| 30 | 
            +
                  rescue Object => e
         | 
| 31 | 
            +
                    raise "Can't find mapping from \"#{page_name}\" to a path.\n" +
         | 
| 32 | 
            +
                      "Now, go and add a mapping in #{__FILE__}"
         | 
| 33 | 
            +
                  end
         | 
| 34 | 
            +
                end
         | 
| 35 | 
            +
              end
         | 
| 36 | 
            +
            end
         | 
| 37 | 
            +
             | 
| 38 | 
            +
            World(NavigationHelpers)
         |