amos 0.0.3 → 0.0.4
Sign up to get free protection for your applications and to get access to all the features.
- data/README.rdoc +20 -3
- data/app/controllers/amos_controller.rb +36 -1
- data/config/initializers/per_page.rb +5 -0
- data/config/routes.rb +1 -0
- data/lib/amos.rb +1 -0
- data/lib/amos/pagination.rb +18 -0
- data/spec/controllers/amos_controller_spec.rb +680 -0
- data/spec/factories.rb +13 -0
- data/spec/models/per_page_spec.rb +29 -0
- data/test/dummy/app/controllers/application_controller.rb +3 -0
- data/test/dummy/app/helpers/application_helper.rb +2 -0
- data/test/dummy/app/models/ability.rb +13 -0
- data/test/dummy/app/models/recipe.rb +3 -0
- data/test/dummy/app/models/user.rb +4 -0
- data/test/dummy/app/views/layouts/application.html.erb +14 -0
- data/test/dummy/config/application.rb +45 -0
- data/test/dummy/config/boot.rb +10 -0
- data/test/dummy/config/cucumber.yml +8 -0
- data/test/dummy/config/database.yml +25 -0
- data/test/dummy/config/environment.rb +5 -0
- data/test/dummy/config/environments/development.rb +26 -0
- data/test/dummy/config/environments/production.rb +49 -0
- data/test/dummy/config/environments/test.rb +35 -0
- data/test/dummy/config/initializers/backtrace_silencers.rb +7 -0
- data/test/dummy/config/initializers/inflections.rb +10 -0
- data/test/dummy/config/initializers/mime_types.rb +5 -0
- data/test/dummy/config/initializers/secret_token.rb +7 -0
- data/test/dummy/config/initializers/session_store.rb +8 -0
- data/test/dummy/config/locales/en.yml +5 -0
- data/test/dummy/config/routes.rb +2 -0
- data/test/dummy/db/migrate/20110930092258_create_user.rb +15 -0
- data/test/dummy/db/migrate/20111002092333_create_recipes.rb +16 -0
- data/test/dummy/db/migrate/20111003063458_add_user_id_to_recipe.rb +9 -0
- data/test/dummy/features/amos.feature +160 -0
- data/test/dummy/features/paginate.feature +119 -0
- data/test/dummy/features/security.feature +59 -0
- data/test/dummy/features/step_definitions/pickle_steps.rb +100 -0
- data/test/dummy/features/step_definitions/user_steps.rb +57 -0
- data/test/dummy/features/support/env.rb +50 -0
- data/test/dummy/features/support/pickle.rb +26 -0
- data/test/spec_helper.rb +37 -0
- data/test/support/integration_case.rb +5 -0
- data/test/test_helper.rb +17 -0
- metadata +74 -18
data/spec/factories.rb
ADDED
@@ -0,0 +1,29 @@
|
|
1
|
+
require File.expand_path(File.dirname(__FILE__) + '/../../test/spec_helper')
|
2
|
+
require 'lib/amos/pagination'
|
3
|
+
|
4
|
+
class ActiveRecord::Base
|
5
|
+
include AmosPagination
|
6
|
+
end
|
7
|
+
|
8
|
+
class User < ActiveRecord::Base
|
9
|
+
end
|
10
|
+
|
11
|
+
describe User do
|
12
|
+
|
13
|
+
let(:user) {User.new(:email => 'smith@smith.com')}
|
14
|
+
|
15
|
+
it "should response to items_per_page" do
|
16
|
+
User.should respond_to('per_page')
|
17
|
+
end
|
18
|
+
|
19
|
+
describe 'paginate_results' do
|
20
|
+
it "should response to method" do
|
21
|
+
User.should respond_to('paginate_results')
|
22
|
+
end
|
23
|
+
|
24
|
+
it "should set the default actions" do
|
25
|
+
User.paginate_results
|
26
|
+
User.paginate_actions.should == ['index', 'find']
|
27
|
+
end
|
28
|
+
end
|
29
|
+
end
|
@@ -0,0 +1,45 @@
|
|
1
|
+
require File.expand_path('../boot', __FILE__)
|
2
|
+
|
3
|
+
require "active_model/railtie"
|
4
|
+
require "active_record/railtie"
|
5
|
+
require "action_controller/railtie"
|
6
|
+
require "action_view/railtie"
|
7
|
+
require "action_mailer/railtie"
|
8
|
+
|
9
|
+
Bundler.require
|
10
|
+
require "amos"
|
11
|
+
|
12
|
+
module Dummy
|
13
|
+
class Application < Rails::Application
|
14
|
+
# Settings in config/environments/* take precedence over those specified here.
|
15
|
+
# Application configuration should go into files in config/initializers
|
16
|
+
# -- all .rb files in that directory are automatically loaded.
|
17
|
+
|
18
|
+
# Custom directories with classes and modules you want to be autoloadable.
|
19
|
+
# config.autoload_paths += %W(#{config.root}/extras)
|
20
|
+
|
21
|
+
# Only load the plugins named here, in the order given (default is alphabetical).
|
22
|
+
# :all can be used as a placeholder for all plugins not explicitly named.
|
23
|
+
# config.plugins = [ :exception_notification, :ssl_requirement, :all ]
|
24
|
+
|
25
|
+
# Activate observers that should always be running.
|
26
|
+
# config.active_record.observers = :cacher, :garbage_collector, :forum_observer
|
27
|
+
|
28
|
+
# Set Time.zone default to the specified zone and make Active Record auto-convert to this zone.
|
29
|
+
# Run "rake -D time" for a list of tasks for finding time zone names. Default is UTC.
|
30
|
+
# config.time_zone = 'Central Time (US & Canada)'
|
31
|
+
|
32
|
+
# The default locale is :en and all translations from config/locales/*.rb,yml are auto loaded.
|
33
|
+
# config.i18n.load_path += Dir[Rails.root.join('my', 'locales', '*.{rb,yml}').to_s]
|
34
|
+
# config.i18n.default_locale = :de
|
35
|
+
|
36
|
+
# JavaScript files you want as :defaults (application.js is always included).
|
37
|
+
# config.action_view.javascript_expansions[:defaults] = %w(jquery rails)
|
38
|
+
|
39
|
+
# Configure the default encoding used in templates for Ruby 1.9.
|
40
|
+
config.encoding = "utf-8"
|
41
|
+
|
42
|
+
# Configure sensitive parameters which will be filtered from the log file.
|
43
|
+
config.filter_parameters += [:password]
|
44
|
+
end
|
45
|
+
end
|
@@ -0,0 +1,8 @@
|
|
1
|
+
<%
|
2
|
+
rerun = File.file?('rerun.txt') ? IO.read('rerun.txt') : ""
|
3
|
+
rerun_opts = rerun.to_s.strip.empty? ? "--format #{ENV['CUCUMBER_FORMAT'] || 'progress'} features" : "--format #{ENV['CUCUMBER_FORMAT'] || 'pretty'} #{rerun}"
|
4
|
+
std_opts = "--format #{ENV['CUCUMBER_FORMAT'] || 'pretty'} --strict --tags ~@wip"
|
5
|
+
%>
|
6
|
+
default: <%= std_opts %> features
|
7
|
+
wip: --tags @wip:3 --wip features
|
8
|
+
rerun: <%= rerun_opts %> --format rerun --out rerun.txt --strict --tags ~@wip
|
@@ -0,0 +1,25 @@
|
|
1
|
+
# SQLite version 3.x
|
2
|
+
# gem install sqlite3
|
3
|
+
development:
|
4
|
+
adapter: sqlite3
|
5
|
+
database: db/development.sqlite3
|
6
|
+
pool: 5
|
7
|
+
timeout: 5000
|
8
|
+
|
9
|
+
# Warning: The database defined as "test" will be erased and
|
10
|
+
# re-generated from your development database when you run "rake".
|
11
|
+
# Do not set this db to the same as development or production.
|
12
|
+
test: &test
|
13
|
+
adapter: sqlite3
|
14
|
+
database: db/test.sqlite3
|
15
|
+
pool: 5
|
16
|
+
timeout: 5000
|
17
|
+
|
18
|
+
production:
|
19
|
+
adapter: sqlite3
|
20
|
+
database: db/production.sqlite3
|
21
|
+
pool: 5
|
22
|
+
timeout: 5000
|
23
|
+
|
24
|
+
cucumber:
|
25
|
+
<<: *test
|
@@ -0,0 +1,26 @@
|
|
1
|
+
Dummy::Application.configure do
|
2
|
+
# Settings specified here will take precedence over those in config/application.rb
|
3
|
+
|
4
|
+
# In the development environment your application's code is reloaded on
|
5
|
+
# every request. This slows down response time but is perfect for development
|
6
|
+
# since you don't have to restart the webserver when you make code changes.
|
7
|
+
config.cache_classes = false
|
8
|
+
|
9
|
+
# Log error messages when you accidentally call methods on nil.
|
10
|
+
config.whiny_nils = true
|
11
|
+
|
12
|
+
# Show full error reports and disable caching
|
13
|
+
config.consider_all_requests_local = true
|
14
|
+
config.action_view.debug_rjs = true
|
15
|
+
config.action_controller.perform_caching = false
|
16
|
+
|
17
|
+
# Don't care if the mailer can't send
|
18
|
+
config.action_mailer.raise_delivery_errors = false
|
19
|
+
|
20
|
+
# Print deprecation notices to the Rails logger
|
21
|
+
config.active_support.deprecation = :log
|
22
|
+
|
23
|
+
# Only use best-standards-support built into browsers
|
24
|
+
config.action_dispatch.best_standards_support = :builtin
|
25
|
+
end
|
26
|
+
|
@@ -0,0 +1,49 @@
|
|
1
|
+
Dummy::Application.configure do
|
2
|
+
# Settings specified here will take precedence over those in config/application.rb
|
3
|
+
|
4
|
+
# The production environment is meant for finished, "live" apps.
|
5
|
+
# Code is not reloaded between requests
|
6
|
+
config.cache_classes = true
|
7
|
+
|
8
|
+
# Full error reports are disabled and caching is turned on
|
9
|
+
config.consider_all_requests_local = false
|
10
|
+
config.action_controller.perform_caching = true
|
11
|
+
|
12
|
+
# Specifies the header that your server uses for sending files
|
13
|
+
config.action_dispatch.x_sendfile_header = "X-Sendfile"
|
14
|
+
|
15
|
+
# For nginx:
|
16
|
+
# config.action_dispatch.x_sendfile_header = 'X-Accel-Redirect'
|
17
|
+
|
18
|
+
# If you have no front-end server that supports something like X-Sendfile,
|
19
|
+
# just comment this out and Rails will serve the files
|
20
|
+
|
21
|
+
# See everything in the log (default is :info)
|
22
|
+
# config.log_level = :debug
|
23
|
+
|
24
|
+
# Use a different logger for distributed setups
|
25
|
+
# config.logger = SyslogLogger.new
|
26
|
+
|
27
|
+
# Use a different cache store in production
|
28
|
+
# config.cache_store = :mem_cache_store
|
29
|
+
|
30
|
+
# Disable Rails's static asset server
|
31
|
+
# In production, Apache or nginx will already do this
|
32
|
+
config.serve_static_assets = false
|
33
|
+
|
34
|
+
# Enable serving of images, stylesheets, and javascripts from an asset server
|
35
|
+
# config.action_controller.asset_host = "http://assets.example.com"
|
36
|
+
|
37
|
+
# Disable delivery errors, bad email addresses will be ignored
|
38
|
+
# config.action_mailer.raise_delivery_errors = false
|
39
|
+
|
40
|
+
# Enable threaded mode
|
41
|
+
# config.threadsafe!
|
42
|
+
|
43
|
+
# Enable locale fallbacks for I18n (makes lookups for any locale fall back to
|
44
|
+
# the I18n.default_locale when a translation can not be found)
|
45
|
+
config.i18n.fallbacks = true
|
46
|
+
|
47
|
+
# Send deprecation notices to registered listeners
|
48
|
+
config.active_support.deprecation = :notify
|
49
|
+
end
|
@@ -0,0 +1,35 @@
|
|
1
|
+
Dummy::Application.configure do
|
2
|
+
# Settings specified here will take precedence over those in config/application.rb
|
3
|
+
|
4
|
+
# The test environment is used exclusively to run your application's
|
5
|
+
# test suite. You never need to work with it otherwise. Remember that
|
6
|
+
# your test database is "scratch space" for the test suite and is wiped
|
7
|
+
# and recreated between test runs. Don't rely on the data there!
|
8
|
+
config.cache_classes = true
|
9
|
+
|
10
|
+
# Log error messages when you accidentally call methods on nil.
|
11
|
+
config.whiny_nils = true
|
12
|
+
|
13
|
+
# Show full error reports and disable caching
|
14
|
+
config.consider_all_requests_local = true
|
15
|
+
config.action_controller.perform_caching = false
|
16
|
+
|
17
|
+
# Raise exceptions instead of rendering exception templates
|
18
|
+
config.action_dispatch.show_exceptions = false
|
19
|
+
|
20
|
+
# Disable request forgery protection in test environment
|
21
|
+
config.action_controller.allow_forgery_protection = false
|
22
|
+
|
23
|
+
# Tell Action Mailer not to deliver emails to the real world.
|
24
|
+
# The :test delivery method accumulates sent emails in the
|
25
|
+
# ActionMailer::Base.deliveries array.
|
26
|
+
config.action_mailer.delivery_method = :test
|
27
|
+
|
28
|
+
# Use SQL instead of Active Record's schema dumper when creating the test database.
|
29
|
+
# This is necessary if your schema can't be completely dumped by the schema dumper,
|
30
|
+
# like if you have constraints or database-specific column types
|
31
|
+
# config.active_record.schema_format = :sql
|
32
|
+
|
33
|
+
# Print deprecation notices to the stderr
|
34
|
+
config.active_support.deprecation = :stderr
|
35
|
+
end
|
@@ -0,0 +1,7 @@
|
|
1
|
+
# Be sure to restart your server when you modify this file.
|
2
|
+
|
3
|
+
# You can add backtrace silencers for libraries that you're using but don't wish to see in your backtraces.
|
4
|
+
# Rails.backtrace_cleaner.add_silencer { |line| line =~ /my_noisy_library/ }
|
5
|
+
|
6
|
+
# You can also remove all the silencers if you're trying to debug a problem that might stem from framework code.
|
7
|
+
# Rails.backtrace_cleaner.remove_silencers!
|
@@ -0,0 +1,10 @@
|
|
1
|
+
# Be sure to restart your server when you modify this file.
|
2
|
+
|
3
|
+
# Add new inflection rules using the following format
|
4
|
+
# (all these examples are active by default):
|
5
|
+
# ActiveSupport::Inflector.inflections do |inflect|
|
6
|
+
# inflect.plural /^(ox)$/i, '\1en'
|
7
|
+
# inflect.singular /^(ox)en/i, '\1'
|
8
|
+
# inflect.irregular 'person', 'people'
|
9
|
+
# inflect.uncountable %w( fish sheep )
|
10
|
+
# end
|
@@ -0,0 +1,7 @@
|
|
1
|
+
# Be sure to restart your server when you modify this file.
|
2
|
+
|
3
|
+
# Your secret key for verifying the integrity of signed cookies.
|
4
|
+
# If you change this key, all old signed cookies will become invalid!
|
5
|
+
# Make sure the secret is at least 30 characters and all random,
|
6
|
+
# no regular words or you'll be exposed to dictionary attacks.
|
7
|
+
Dummy::Application.config.secret_token = '5fc85c9913b4b5dab18392c05928ee10328c98f373503d86e95bf0fcc1e369d70ebbc39f8006355f07281af3e6c4d56feca8c267c6520f71f1684a72a032a6f0'
|
@@ -0,0 +1,8 @@
|
|
1
|
+
# Be sure to restart your server when you modify this file.
|
2
|
+
|
3
|
+
Dummy::Application.config.session_store :cookie_store, :key => '_dummy_session'
|
4
|
+
|
5
|
+
# Use the database for sessions instead of the cookie-based default,
|
6
|
+
# which shouldn't be used to store highly confidential information
|
7
|
+
# (create the session table with "rails generate session_migration")
|
8
|
+
# Dummy::Application.config.session_store :active_record_store
|
@@ -0,0 +1,16 @@
|
|
1
|
+
class CreateRecipes < ActiveRecord::Migration
|
2
|
+
def self.up
|
3
|
+
create_table :recipes do |t|
|
4
|
+
t.string :name
|
5
|
+
t.string :description
|
6
|
+
|
7
|
+
t.timestamps
|
8
|
+
end
|
9
|
+
|
10
|
+
Recipe.create(:name => 'Make cake', :description => 'go to shop')
|
11
|
+
end
|
12
|
+
|
13
|
+
def self.down
|
14
|
+
drop_table :recipes
|
15
|
+
end
|
16
|
+
end
|
@@ -0,0 +1,160 @@
|
|
1
|
+
Feature: Standard data access
|
2
|
+
In order access data on the server
|
3
|
+
I need should return some json.
|
4
|
+
|
5
|
+
Background:
|
6
|
+
Given the following users exists
|
7
|
+
| name | email |
|
8
|
+
| J Smith | smith@smith.com |
|
9
|
+
| B Bloggs | b@bloggs.com |
|
10
|
+
And the following recipes exists
|
11
|
+
| name | description |
|
12
|
+
| Shopping | Go to the shops |
|
13
|
+
| Cakes | Buy stuff |
|
14
|
+
| Clean | Hoover room |
|
15
|
+
And "Shopping" belongs to "J Smith"
|
16
|
+
And "Cakes" belongs to "B Bloggs"
|
17
|
+
And "Clean" belongs to "J Smith"
|
18
|
+
And I have setup my ability class
|
19
|
+
"""
|
20
|
+
class Ability
|
21
|
+
include CanCan::Ability
|
22
|
+
|
23
|
+
def initialize(user)
|
24
|
+
can :manage, :all
|
25
|
+
end
|
26
|
+
end
|
27
|
+
"""
|
28
|
+
And I am not logged in
|
29
|
+
|
30
|
+
Scenario: List users
|
31
|
+
When the client requests GET /user
|
32
|
+
Then the response should be JSON:
|
33
|
+
"""
|
34
|
+
[
|
35
|
+
{"name": "J Smith", "email": "smith@smith.com", "id": 1},
|
36
|
+
{"name": "B Bloggs", "email": "b@bloggs.com", "id": 2}
|
37
|
+
]
|
38
|
+
"""
|
39
|
+
|
40
|
+
Scenario: List users with field list
|
41
|
+
When the client requests GET /user?fields=email
|
42
|
+
Then the response should be JSON:
|
43
|
+
"""
|
44
|
+
[
|
45
|
+
{"email": "smith@smith.com"},
|
46
|
+
{"email": "b@bloggs.com"}
|
47
|
+
]
|
48
|
+
"""
|
49
|
+
|
50
|
+
Scenario: List recipes using a dynamic finder
|
51
|
+
Given the following recipes exists
|
52
|
+
| name | description |
|
53
|
+
| Shopping2 | Go to the shops |
|
54
|
+
| Cakes2 | Buy stuff |
|
55
|
+
| Clean2 | Hoover room |
|
56
|
+
| Shopping3 | Go to the shops |
|
57
|
+
And "Shopping2" belongs to "J Smith"
|
58
|
+
And "Shopping3" belongs to "B Bloggs"
|
59
|
+
When the client requests GET /recipes/find/by_description?term=Go%20to%20the%20shops
|
60
|
+
Then the response should be JSON:
|
61
|
+
"""
|
62
|
+
[
|
63
|
+
{"name" : "Shopping", "description" : "Go to the shops", "id" : 1, "user_id" : 1},
|
64
|
+
{"name" : "Shopping2", "description" : "Go to the shops", "id" : 4, "user_id" : 1},
|
65
|
+
{"name" : "Shopping3", "description" : "Go to the shops", "id" : 7, "user_id" : 2}
|
66
|
+
]
|
67
|
+
"""
|
68
|
+
|
69
|
+
Scenario: List a single user
|
70
|
+
When the client requests GET /users/1
|
71
|
+
Then the response should be JSON:
|
72
|
+
"""
|
73
|
+
{"name" : "J Smith", "email": "smith@smith.com", "id": 1}
|
74
|
+
"""
|
75
|
+
|
76
|
+
Scenario: Tries to access an invalid record
|
77
|
+
When the client requests GET /users/1000000
|
78
|
+
Then the response should be JSON:
|
79
|
+
"""
|
80
|
+
{"error": "Record 1000000 not found"}
|
81
|
+
"""
|
82
|
+
|
83
|
+
Scenario: List a single user with an association
|
84
|
+
When the client requests GET /users/1?association=recipes
|
85
|
+
Then the response should be JSON:
|
86
|
+
"""
|
87
|
+
{"name": "J Smith", "id": 1, "email": "smith@smith.com",
|
88
|
+
"recipes": [
|
89
|
+
{"name": "Shopping", "id": 1, "description": "Go to the shops"},
|
90
|
+
{"name": "Clean", "id": 3, "description": "Hoover room"}
|
91
|
+
]
|
92
|
+
}
|
93
|
+
"""
|
94
|
+
|
95
|
+
Scenario: List a single user with field list
|
96
|
+
When the client requests GET /users/1?fields=email
|
97
|
+
Then the response should be JSON:
|
98
|
+
"""
|
99
|
+
{"email": "smith@smith.com"}
|
100
|
+
"""
|
101
|
+
|
102
|
+
|
103
|
+
Scenario: Successfully update a single user
|
104
|
+
When the client requests PUT /users/1 with name "A Smith" and email "only@smith.com"
|
105
|
+
Then the response should be JSON:
|
106
|
+
"""
|
107
|
+
{"name": "A Smith", "email": "only@smith.com"}
|
108
|
+
"""
|
109
|
+
And the client requests GET /user
|
110
|
+
Then the response should be JSON:
|
111
|
+
"""
|
112
|
+
[
|
113
|
+
{"name": "A Smith", "email": "only@smith.com", "id": 1},
|
114
|
+
{"name": "B Bloggs", "email": "b@bloggs.com", "id": 2}
|
115
|
+
]
|
116
|
+
"""
|
117
|
+
Scenario: Successfully create a new user
|
118
|
+
When the client requests POST /users with name "E Bygumm" and email "eric@bygumm.com"
|
119
|
+
Then the response should be JSON:
|
120
|
+
"""
|
121
|
+
{"name":"E Bygumm", "id":3, "email":"eric@bygumm.com"}
|
122
|
+
"""
|
123
|
+
And the client requests GET /user
|
124
|
+
Then the response should be JSON:
|
125
|
+
"""
|
126
|
+
[
|
127
|
+
{"name": "J Smith", "email": "smith@smith.com", "id": 1},
|
128
|
+
{"name": "B Bloggs", "email": "b@bloggs.com", "id": 2},
|
129
|
+
{"name": "E Bygumm", "email": "eric@bygumm.com", "id": 3}
|
130
|
+
]
|
131
|
+
"""
|
132
|
+
|
133
|
+
Scenario: Successfully delete a single user
|
134
|
+
When the client requests DELETE /users/1
|
135
|
+
Then the response should be JSON:
|
136
|
+
"""
|
137
|
+
{"success": "true"}
|
138
|
+
"""
|
139
|
+
And the client requests GET /user
|
140
|
+
Then the response should be JSON:
|
141
|
+
"""
|
142
|
+
[
|
143
|
+
{"name": "B Bloggs", "email": "b@bloggs.com", "id": 2}
|
144
|
+
]
|
145
|
+
"""
|
146
|
+
|
147
|
+
Scenario: Fails to delete a single user
|
148
|
+
When the client requests DELETE /users/1000000
|
149
|
+
Then the response should be JSON:
|
150
|
+
"""
|
151
|
+
{"error": "Record 1000000 not found"}
|
152
|
+
"""
|
153
|
+
And the client requests GET /user
|
154
|
+
Then the response should be JSON:
|
155
|
+
"""
|
156
|
+
[
|
157
|
+
{"name": "J Smith", "email": "smith@smith.com", "id": 1},
|
158
|
+
{"name": "B Bloggs", "email": "b@bloggs.com", "id": 2}
|
159
|
+
]
|
160
|
+
"""
|