shakespeare 0.1.0
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/README.md +85 -0
- data/Rakefile +43 -0
- data/app/controllers/admin/pages_controller.rb +47 -0
- data/app/controllers/pages_controller.rb +5 -0
- data/app/models/page.rb +10 -0
- data/app/views/admin/pages/_form.html.erb +38 -0
- data/app/views/admin/pages/edit.html.erb +3 -0
- data/app/views/admin/pages/index.html.erb +24 -0
- data/app/views/admin/pages/new.html.erb +3 -0
- data/app/views/layouts/admin.html.erb +9 -0
- data/app/views/pages/show.html.erb +3 -0
- data/config/cucumber.yml +7 -0
- data/config/routes.rb +8 -0
- data/features/admin_pages.feature +38 -0
- data/features/public_pages.feature +12 -0
- data/features/step_definitions/page_steps.rb +7 -0
- data/features/step_definitions/web_steps.rb +259 -0
- data/features/support/env.rb +55 -0
- data/features/support/paths.rb +32 -0
- data/features/support/shakespeare_env.rb +3 -0
- data/generators/definition.txt +0 -0
- data/generators/shakespeare/USAGE +5 -0
- data/generators/shakespeare/shakespeare_generator.rb +8 -0
- data/generators/shakespeare/templates/20091230095600_create_pages.rb +25 -0
- data/lib/shakespeare.rb +7 -0
- data/lib/shakespeare/helpers.rb +16 -0
- data/lib/shakespeare/settings.rb +30 -0
- data/lib/shakespeare/shakespeare.rb +8 -0
- data/lib/shakespeare/view_helpers.rb +29 -0
- data/rails/init.rb +1 -0
- data/rerun.txt +1 -0
- data/spec/blueprints.rb +9 -0
- data/spec/controllers/admin/pages_controller_spec.rb +35 -0
- data/spec/database.yml +21 -0
- data/spec/debug.log +1937 -0
- data/spec/helpers_spec.rb +19 -0
- data/spec/models/page_spec.rb +28 -0
- data/spec/schema.rb +16 -0
- data/spec/shakespeare_generator_spec.rb +36 -0
- data/spec/shakespeare_spec.rb +3 -0
- data/spec/spec_helper.rb +41 -0
- data/spec/view_helpers_spec.rb +103 -0
- metadata +104 -0
data/README.md
ADDED
@@ -0,0 +1,85 @@
|
|
1
|
+
Shakespeare
|
2
|
+
===========
|
3
|
+
|
4
|
+
Shakespeare is a Ruby on Rails content manager plugin.
|
5
|
+
|
6
|
+
Shakespeare allows:
|
7
|
+
|
8
|
+
- User-editable page titles, descriptions, meta info and content blocks for dynamic requests
|
9
|
+
- User editable content-only pages
|
10
|
+
|
11
|
+
Shakespeare is a super simple bolt-on CMS for any Rails app.
|
12
|
+
|
13
|
+
Installation
|
14
|
+
============
|
15
|
+
|
16
|
+
Shakespeare is easy to install.
|
17
|
+
|
18
|
+
As a plugin:
|
19
|
+
|
20
|
+
./script/plugin install git://github.com/paulca/shakespeare.git
|
21
|
+
|
22
|
+
Or as a gem. Add this to your environment.rb:
|
23
|
+
|
24
|
+
config.gem 'shakespeare'
|
25
|
+
|
26
|
+
Then generate the migration to create the pages table:
|
27
|
+
|
28
|
+
./script/generate shakespeare
|
29
|
+
|
30
|
+
And run the migration:
|
31
|
+
|
32
|
+
rake db:migrate
|
33
|
+
|
34
|
+
Basic Usage
|
35
|
+
===========
|
36
|
+
|
37
|
+
Once Shakespeare is installed, every controller action can now have its own content. You an access this content in the controller or the view with the `page_content` method.
|
38
|
+
|
39
|
+
View Helpers
|
40
|
+
============
|
41
|
+
|
42
|
+
In your views, you have access to a number of helpers for generating your page meta-data.
|
43
|
+
|
44
|
+
- `page_title` is the title of the page
|
45
|
+
- `keywords_meta_tag` generates a <meta> tag for the page keywords, or returns nil if it's left blank
|
46
|
+
- `description_meta_tag` generates a <meta> tag for the page description, or returns nil if it's left blank
|
47
|
+
- `robots_meta_tag` generates a <meta> tag for the robots no-index and/or nofollow meta tag options, or returns nil if it's left blank
|
48
|
+
- `canonical_link_tag` generates a <link> tag with the canonical URL for the page, if `enable_canonical` is set to true
|
49
|
+
|
50
|
+
Web Interface
|
51
|
+
=============
|
52
|
+
|
53
|
+
Using Rails' Engines feature, Shakespeare comes with a web interface that is available to your app straight away at `http://localhost:3000/admin/pages`.
|
54
|
+
|
55
|
+
By default, this comes with no styling, but you can create a layout in `app/layouts/admin.html.erb`, or set a layout by setting `Shakespare::Settings.layout`
|
56
|
+
|
57
|
+
For example, to use your standard application layout, create a `config/initializers/shakespeare.rb` like this:
|
58
|
+
|
59
|
+
Shakespeare::Settings.layout = 'application'
|
60
|
+
|
61
|
+
You can also add before_filters to protect the controller from outsiders:
|
62
|
+
|
63
|
+
Shakespeare::Settings.before_filters << 'require_admin_user'
|
64
|
+
|
65
|
+
By default, in production, if `Shakespeare::Settings.before_filters` is empty, `/admin/pages` is protected. You can disable this protection by setting `Behavior::Settings.allow_anonymous` to true.
|
66
|
+
|
67
|
+
Running the tests
|
68
|
+
=================
|
69
|
+
|
70
|
+
You can run the tests by checking out the code into vendor/plugins of a Rails app and running:
|
71
|
+
|
72
|
+
rake
|
73
|
+
|
74
|
+
It also comes with a set of cucumber features:
|
75
|
+
|
76
|
+
cucumber
|
77
|
+
|
78
|
+
About me
|
79
|
+
========
|
80
|
+
|
81
|
+
I'm Paul Campbell. I'm an avid Ruby on Rails web developer. Follow my ramblings at [http://www.pabcas.com](http://www.pabcas.com)
|
82
|
+
|
83
|
+
Follow me on Twitter [http://twitter.com/paulca](http://twitter.com/paulca)
|
84
|
+
|
85
|
+
Copyright (c) 2009 Paul Campbell, released under the MIT license
|
data/Rakefile
ADDED
@@ -0,0 +1,43 @@
|
|
1
|
+
require 'rake'
|
2
|
+
require 'spec/rake/spectask'
|
3
|
+
|
4
|
+
desc 'Default: run specs.'
|
5
|
+
task :default => :spec
|
6
|
+
|
7
|
+
desc 'Run the specs'
|
8
|
+
Spec::Rake::SpecTask.new(:spec) do |t|
|
9
|
+
t.spec_opts = ['--colour --format progress --loadby mtime --reverse']
|
10
|
+
t.spec_files = FileList['spec/**/*_spec.rb']
|
11
|
+
end
|
12
|
+
|
13
|
+
PKG_FILES = FileList[
|
14
|
+
'[a-zA-Z]*',
|
15
|
+
'app/**/*',
|
16
|
+
'generators/**/*',
|
17
|
+
'config/*',
|
18
|
+
'lib/**/*',
|
19
|
+
'rails/**/*',
|
20
|
+
'spec/**/*',
|
21
|
+
'features/**/*'
|
22
|
+
]
|
23
|
+
|
24
|
+
begin
|
25
|
+
require 'jeweler'
|
26
|
+
Jeweler::Tasks.new do |s|
|
27
|
+
s.name = "shakespeare"
|
28
|
+
s.version = "0.1.0"
|
29
|
+
s.author = "Paul Campbell"
|
30
|
+
s.email = "paul@rslw.com"
|
31
|
+
s.homepage = "http://www.github.com/paulca/shakespeare"
|
32
|
+
s.platform = Gem::Platform::RUBY
|
33
|
+
s.summary = "A Rails drop in CMS."
|
34
|
+
s.files = PKG_FILES.to_a
|
35
|
+
s.require_path = "lib"
|
36
|
+
s.has_rdoc = false
|
37
|
+
s.extra_rdoc_files = ["README.md"]
|
38
|
+
end
|
39
|
+
rescue LoadError
|
40
|
+
puts "Jeweler not available. Install it with: sudo gem install jeweler"
|
41
|
+
end
|
42
|
+
|
43
|
+
Jeweler::GemcutterTasks.new
|
@@ -0,0 +1,47 @@
|
|
1
|
+
class Admin::PagesController < ApplicationController
|
2
|
+
|
3
|
+
|
4
|
+
Shakespeare::Settings.before_filters.each do |filter|
|
5
|
+
before_filter filter
|
6
|
+
end
|
7
|
+
before_filter :protect_in_production if Shakespeare::Settings.before_filters.empty?
|
8
|
+
|
9
|
+
layout Shakespeare::Settings.layout
|
10
|
+
|
11
|
+
def index
|
12
|
+
@pages = Page.all
|
13
|
+
end
|
14
|
+
|
15
|
+
def new
|
16
|
+
@page = Page.new
|
17
|
+
end
|
18
|
+
|
19
|
+
def create
|
20
|
+
@page = Page.new(params[:page])
|
21
|
+
if @page.save
|
22
|
+
redirect_to admin_pages_path
|
23
|
+
else
|
24
|
+
render :new
|
25
|
+
end
|
26
|
+
end
|
27
|
+
|
28
|
+
def edit
|
29
|
+
@page = Page.find(params[:id])
|
30
|
+
end
|
31
|
+
|
32
|
+
def update
|
33
|
+
@page = Page.find(params[:id])
|
34
|
+
if @page.update_attributes(params[:page])
|
35
|
+
redirect_to admin_pages_path
|
36
|
+
else
|
37
|
+
render :edit
|
38
|
+
end
|
39
|
+
end
|
40
|
+
|
41
|
+
def destroy
|
42
|
+
@page = Page.find(params[:id])
|
43
|
+
@page.destroy
|
44
|
+
redirect_to admin_pages_path
|
45
|
+
end
|
46
|
+
|
47
|
+
end
|
data/app/models/page.rb
ADDED
@@ -0,0 +1,38 @@
|
|
1
|
+
<% form_for [:admin, @page] do |f| -%>
|
2
|
+
|
3
|
+
<%= f.error_messages %>
|
4
|
+
|
5
|
+
<fieldset>
|
6
|
+
<%= f.label :url, "URL" %> <%= f.text_field :url %> <em><%= t('page.maps_to') %></em> <br />
|
7
|
+
</fieldset>
|
8
|
+
|
9
|
+
<fieldset>
|
10
|
+
<%= f.label :title, "Title" %>
|
11
|
+
<%= f.text_field :title %> <br />
|
12
|
+
<fieldset>
|
13
|
+
<legend>Robots</legend>
|
14
|
+
|
15
|
+
<%= f.check_box :noindex %>
|
16
|
+
<%= f.label :noindex, "No-Index", :class => 'inline' %>
|
17
|
+
|
18
|
+
<%= f.check_box :nofollow %>
|
19
|
+
<%= f.label :nofollow, "No-follow", :class => 'inline' %>
|
20
|
+
|
21
|
+
<%= f.check_box :enable_canonical %>
|
22
|
+
<%= f.label :enable_canonical, "Set Canonical Tag?", :class => 'inline' %>
|
23
|
+
|
24
|
+
<%= f.label :canonical, "Canonical URL" %>
|
25
|
+
<%= f.text_field :canonical %> <br />
|
26
|
+
|
27
|
+
|
28
|
+
<%= f.label :description, "Description" %> <%= f.text_area :description, :class => "small-text" %> <br />
|
29
|
+
<%= f.label :keywords, "Keywords" %> <%= f.text_field :keywords %> <br />
|
30
|
+
</fieldset>
|
31
|
+
|
32
|
+
<fieldset>
|
33
|
+
<%= f.label :content, "Content" %> <%= f.text_area :content %> <br />
|
34
|
+
</fieldset>
|
35
|
+
|
36
|
+
|
37
|
+
<%= f.submit "Save" %> or <%= link_to "Cancel", admin_pages_path %>
|
38
|
+
<% end -%>
|
@@ -0,0 +1,24 @@
|
|
1
|
+
<h2>Pages</h2>
|
2
|
+
|
3
|
+
<ul>
|
4
|
+
<li><%= link_to "Add a New Page", new_admin_page_path %></li>
|
5
|
+
</ul>
|
6
|
+
|
7
|
+
<%- if @pages.empty? -%>
|
8
|
+
<p>No pages have been added yet.</p>
|
9
|
+
<%- else -%>
|
10
|
+
<table>
|
11
|
+
<tr>
|
12
|
+
<th>Title</th>
|
13
|
+
<th> </th>
|
14
|
+
</tr>
|
15
|
+
|
16
|
+
<%- @pages.each do |page| -%>
|
17
|
+
<tr>
|
18
|
+
<td><%= page.title %> (<%= link_to "Edit", edit_admin_page_path(page) %>)</td>
|
19
|
+
<td><%= link_to "Delete", admin_page_path(page), :method => :delete %></td>
|
20
|
+
</tr>
|
21
|
+
<%- end -%>
|
22
|
+
|
23
|
+
</table>
|
24
|
+
<%- end -%>
|
data/config/cucumber.yml
ADDED
@@ -0,0 +1,7 @@
|
|
1
|
+
<%
|
2
|
+
rerun = File.file?('rerun.txt') ? IO.read('rerun.txt') : ""
|
3
|
+
rerun_opts = rerun.to_s.strip.empty? ? "--format progress features" : "--format #{ENV['CUCUMBER_FORMAT'] || 'pretty'} #{rerun}"
|
4
|
+
std_opts = "#{rerun_opts} --format rerun --out rerun.txt --strict --tags ~@wip"
|
5
|
+
%>
|
6
|
+
default: <%= std_opts %>
|
7
|
+
wip: --tags @wip:3 --wip features
|
data/config/routes.rb
ADDED
@@ -0,0 +1,38 @@
|
|
1
|
+
Feature: Managing Pages
|
2
|
+
In order to update the site
|
3
|
+
As an admin
|
4
|
+
I want to add, edit and delete pages
|
5
|
+
|
6
|
+
Scenario: I'm on the admin layout
|
7
|
+
When I am on the pages admin page
|
8
|
+
Then I should see "Admin"
|
9
|
+
|
10
|
+
Scenario: New Page
|
11
|
+
Given I am on the pages admin page
|
12
|
+
When I follow "Add a New Page"
|
13
|
+
And I fill in "Title" with "Harry and the Hendersons"
|
14
|
+
And I fill in "Keywords" with "80s, movie"
|
15
|
+
And I check "No-index"
|
16
|
+
And I check "No-follow"
|
17
|
+
And I check "Set Canonical Tag?"
|
18
|
+
And I fill in "Canonical URL" with "http://hendersons.com"
|
19
|
+
And I press "Save"
|
20
|
+
Then I should see "Harry and the Hendersons"
|
21
|
+
|
22
|
+
Scenario: Edit Page
|
23
|
+
Given a page titled "Harry and the Hendersons"
|
24
|
+
And I am on the pages admin page
|
25
|
+
When I follow "Edit"
|
26
|
+
And I fill in "Title" with "Three Men and a Baby"
|
27
|
+
And I press "Save"
|
28
|
+
Then I should see "Three Men and a Baby"
|
29
|
+
And I should not see "Harry and the Hendersons"
|
30
|
+
|
31
|
+
Scenario: Delete Page
|
32
|
+
Given a page titled "The Departed"
|
33
|
+
When I am on the pages admin page
|
34
|
+
Then I should see "The Departed"
|
35
|
+
|
36
|
+
When I follow "Delete"
|
37
|
+
Then I should not see "The Departed"
|
38
|
+
|
@@ -0,0 +1,12 @@
|
|
1
|
+
Feature: Public Pages
|
2
|
+
In order to find out more information
|
3
|
+
As a user
|
4
|
+
I want to be able to see what's on a page
|
5
|
+
|
6
|
+
Scenario: A public page
|
7
|
+
Given a page titled "Mr. MacAllister's Christmas"
|
8
|
+
And page "Mr. MacAllister's Christmas" has content "I was Home Alone"
|
9
|
+
|
10
|
+
When I am on the page for "Mr. MacAllister's Christmas"
|
11
|
+
|
12
|
+
Then I should see "I was Home Alone"
|
@@ -0,0 +1,259 @@
|
|
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 File.expand_path(File.join(File.dirname(__FILE__), "..", "support", "paths"))
|
9
|
+
|
10
|
+
# Commonly used webrat steps
|
11
|
+
# http://github.com/brynary/webrat
|
12
|
+
|
13
|
+
Given /^(?:|I )am on (.+)$/ do |page_name|
|
14
|
+
visit path_to(page_name)
|
15
|
+
end
|
16
|
+
|
17
|
+
When /^(?:|I )go to (.+)$/ do |page_name|
|
18
|
+
visit path_to(page_name)
|
19
|
+
end
|
20
|
+
|
21
|
+
When /^(?:|I )press "([^\"]*)"$/ do |button|
|
22
|
+
click_button(button)
|
23
|
+
end
|
24
|
+
|
25
|
+
When /^(?:|I )follow "([^\"]*)"$/ do |link|
|
26
|
+
click_link(link)
|
27
|
+
end
|
28
|
+
|
29
|
+
When /^(?:|I )follow "([^\"]*)" within "([^\"]*)"$/ do |link, parent|
|
30
|
+
click_link_within(parent, link)
|
31
|
+
end
|
32
|
+
|
33
|
+
When /^(?:|I )fill in "([^\"]*)" with "([^\"]*)"$/ do |field, value|
|
34
|
+
fill_in(field, :with => value)
|
35
|
+
end
|
36
|
+
|
37
|
+
When /^(?:|I )fill in "([^\"]*)" for "([^\"]*)"$/ do |value, field|
|
38
|
+
fill_in(field, :with => value)
|
39
|
+
end
|
40
|
+
|
41
|
+
# Use this to fill in an entire form with data from a table. Example:
|
42
|
+
#
|
43
|
+
# When I fill in the following:
|
44
|
+
# | Account Number | 5002 |
|
45
|
+
# | Expiry date | 2009-11-01 |
|
46
|
+
# | Note | Nice guy |
|
47
|
+
# | Wants Email? | |
|
48
|
+
#
|
49
|
+
# TODO: Add support for checkbox, select og option
|
50
|
+
# based on naming conventions.
|
51
|
+
#
|
52
|
+
When /^(?:|I )fill in the following:$/ do |fields|
|
53
|
+
fields.rows_hash.each do |name, value|
|
54
|
+
When %{I fill in "#{name}" with "#{value}"}
|
55
|
+
end
|
56
|
+
end
|
57
|
+
|
58
|
+
When /^(?:|I )select "([^\"]*)" from "([^\"]*)"$/ do |value, field|
|
59
|
+
select(value, :from => field)
|
60
|
+
end
|
61
|
+
|
62
|
+
# Use this step in conjunction with Rail's datetime_select helper. For example:
|
63
|
+
# When I select "December 25, 2008 10:00" as the date and time
|
64
|
+
When /^(?:|I )select "([^\"]*)" as the date and time$/ do |time|
|
65
|
+
select_datetime(time)
|
66
|
+
end
|
67
|
+
|
68
|
+
# Use this step when using multiple datetime_select helpers on a page or
|
69
|
+
# you want to specify which datetime to select. Given the following view:
|
70
|
+
# <%= f.label :preferred %><br />
|
71
|
+
# <%= f.datetime_select :preferred %>
|
72
|
+
# <%= f.label :alternative %><br />
|
73
|
+
# <%= f.datetime_select :alternative %>
|
74
|
+
# The following steps would fill out the form:
|
75
|
+
# When I select "November 23, 2004 11:20" as the "Preferred" date and time
|
76
|
+
# And I select "November 25, 2004 10:30" as the "Alternative" date and time
|
77
|
+
When /^(?:|I )select "([^\"]*)" as the "([^\"]*)" date and time$/ do |datetime, datetime_label|
|
78
|
+
select_datetime(datetime, :from => datetime_label)
|
79
|
+
end
|
80
|
+
|
81
|
+
# Use this step in conjunction with Rail's time_select helper. For example:
|
82
|
+
# When I select "2:20PM" as the time
|
83
|
+
# Note: Rail's default time helper provides 24-hour time-- not 12 hour time. Webrat
|
84
|
+
# will convert the 2:20PM to 14:20 and then select it.
|
85
|
+
When /^(?:|I )select "([^\"]*)" as the time$/ do |time|
|
86
|
+
select_time(time)
|
87
|
+
end
|
88
|
+
|
89
|
+
# Use this step when using multiple time_select helpers on a page or you want to
|
90
|
+
# specify the name of the time on the form. For example:
|
91
|
+
# When I select "7:30AM" as the "Gym" time
|
92
|
+
When /^(?:|I )select "([^\"]*)" as the "([^\"]*)" time$/ do |time, time_label|
|
93
|
+
select_time(time, :from => time_label)
|
94
|
+
end
|
95
|
+
|
96
|
+
# Use this step in conjunction with Rail's date_select helper. For example:
|
97
|
+
# When I select "February 20, 1981" as the date
|
98
|
+
When /^(?:|I )select "([^\"]*)" as the date$/ do |date|
|
99
|
+
select_date(date)
|
100
|
+
end
|
101
|
+
|
102
|
+
# Use this step when using multiple date_select helpers on one page or
|
103
|
+
# you want to specify the name of the date on the form. For example:
|
104
|
+
# When I select "April 26, 1982" as the "Date of Birth" date
|
105
|
+
When /^(?:|I )select "([^\"]*)" as the "([^\"]*)" date$/ do |date, date_label|
|
106
|
+
select_date(date, :from => date_label)
|
107
|
+
end
|
108
|
+
|
109
|
+
When /^(?:|I )check "([^\"]*)"$/ do |field|
|
110
|
+
check(field)
|
111
|
+
end
|
112
|
+
|
113
|
+
When /^(?:|I )uncheck "([^\"]*)"$/ do |field|
|
114
|
+
uncheck(field)
|
115
|
+
end
|
116
|
+
|
117
|
+
When /^(?:|I )choose "([^\"]*)"$/ do |field|
|
118
|
+
choose(field)
|
119
|
+
end
|
120
|
+
|
121
|
+
# Adds support for validates_attachment_content_type. Without the mime-type getting
|
122
|
+
# passed to attach_file() you will get a "Photo file is not one of the allowed file types."
|
123
|
+
# error message
|
124
|
+
When /^(?:|I )attach the file "([^\"]*)" to "([^\"]*)"$/ do |path, field|
|
125
|
+
type = path.split(".")[1]
|
126
|
+
|
127
|
+
case type
|
128
|
+
when "jpg"
|
129
|
+
type = "image/jpg"
|
130
|
+
when "jpeg"
|
131
|
+
type = "image/jpeg"
|
132
|
+
when "png"
|
133
|
+
type = "image/png"
|
134
|
+
when "gif"
|
135
|
+
type = "image/gif"
|
136
|
+
end
|
137
|
+
|
138
|
+
attach_file(field, path, type)
|
139
|
+
end
|
140
|
+
|
141
|
+
Then /^(?:|I )should see "([^\"]*)"$/ do |text|
|
142
|
+
if defined?(Spec::Rails::Matchers)
|
143
|
+
response.should contain(text)
|
144
|
+
else
|
145
|
+
assert_contain text
|
146
|
+
end
|
147
|
+
end
|
148
|
+
|
149
|
+
Then /^(?:|I )should see "([^\"]*)" within "([^\"]*)"$/ do |text, selector|
|
150
|
+
within(selector) do |content|
|
151
|
+
if defined?(Spec::Rails::Matchers)
|
152
|
+
content.should contain(text)
|
153
|
+
else
|
154
|
+
assert content.include?(text)
|
155
|
+
end
|
156
|
+
end
|
157
|
+
end
|
158
|
+
|
159
|
+
Then /^(?:|I )should see \/([^\/]*)\/$/ do |regexp|
|
160
|
+
regexp = Regexp.new(regexp)
|
161
|
+
if defined?(Spec::Rails::Matchers)
|
162
|
+
response.should contain(regexp)
|
163
|
+
else
|
164
|
+
assert_contain regexp
|
165
|
+
end
|
166
|
+
end
|
167
|
+
|
168
|
+
Then /^(?:|I )should see \/([^\/]*)\/ within "([^\"]*)"$/ do |regexp, selector|
|
169
|
+
within(selector) do |content|
|
170
|
+
regexp = Regexp.new(regexp)
|
171
|
+
if defined?(Spec::Rails::Matchers)
|
172
|
+
content.should contain(regexp)
|
173
|
+
else
|
174
|
+
assert content =~ regexp
|
175
|
+
end
|
176
|
+
end
|
177
|
+
end
|
178
|
+
|
179
|
+
Then /^(?:|I )should not see "([^\"]*)"$/ do |text|
|
180
|
+
if defined?(Spec::Rails::Matchers)
|
181
|
+
response.should_not contain(text)
|
182
|
+
else
|
183
|
+
assert_not_contain text
|
184
|
+
end
|
185
|
+
end
|
186
|
+
|
187
|
+
Then /^(?:|I )should not see "([^\"]*)" within "([^\"]*)"$/ do |text, selector|
|
188
|
+
within(selector) do |content|
|
189
|
+
if defined?(Spec::Rails::Matchers)
|
190
|
+
content.should_not contain(text)
|
191
|
+
else
|
192
|
+
assert !content.include?(text)
|
193
|
+
end
|
194
|
+
end
|
195
|
+
end
|
196
|
+
|
197
|
+
Then /^(?:|I )should not see \/([^\/]*)\/$/ do |regexp|
|
198
|
+
regexp = Regexp.new(regexp)
|
199
|
+
if defined?(Spec::Rails::Matchers)
|
200
|
+
response.should_not contain(regexp)
|
201
|
+
else
|
202
|
+
assert_not_contain regexp
|
203
|
+
end
|
204
|
+
end
|
205
|
+
|
206
|
+
Then /^(?:|I )should not see \/([^\/]*)\/ within "([^\"]*)"$/ do |regexp, selector|
|
207
|
+
within(selector) do |content|
|
208
|
+
regexp = Regexp.new(regexp)
|
209
|
+
if defined?(Spec::Rails::Matchers)
|
210
|
+
content.should_not contain(regexp)
|
211
|
+
else
|
212
|
+
assert content !~ regexp
|
213
|
+
end
|
214
|
+
end
|
215
|
+
end
|
216
|
+
|
217
|
+
Then /^the "([^\"]*)" field should contain "([^\"]*)"$/ do |field, value|
|
218
|
+
if defined?(Spec::Rails::Matchers)
|
219
|
+
field_labeled(field).value.should =~ /#{value}/
|
220
|
+
else
|
221
|
+
assert_match(/#{value}/, field_labeled(field).value)
|
222
|
+
end
|
223
|
+
end
|
224
|
+
|
225
|
+
Then /^the "([^\"]*)" field should not contain "([^\"]*)"$/ do |field, value|
|
226
|
+
if defined?(Spec::Rails::Matchers)
|
227
|
+
field_labeled(field).value.should_not =~ /#{value}/
|
228
|
+
else
|
229
|
+
assert_no_match(/#{value}/, field_labeled(field).value)
|
230
|
+
end
|
231
|
+
end
|
232
|
+
|
233
|
+
Then /^the "([^\"]*)" checkbox should be checked$/ do |label|
|
234
|
+
if defined?(Spec::Rails::Matchers)
|
235
|
+
field_labeled(label).should be_checked
|
236
|
+
else
|
237
|
+
assert field_labeled(label).checked?
|
238
|
+
end
|
239
|
+
end
|
240
|
+
|
241
|
+
Then /^the "([^\"]*)" checkbox should not be checked$/ do |label|
|
242
|
+
if defined?(Spec::Rails::Matchers)
|
243
|
+
field_labeled(label).should_not be_checked
|
244
|
+
else
|
245
|
+
assert !field_labeled(label).checked?
|
246
|
+
end
|
247
|
+
end
|
248
|
+
|
249
|
+
Then /^(?:|I )should be on (.+)$/ do |page_name|
|
250
|
+
if defined?(Spec::Rails::Matchers)
|
251
|
+
URI.parse(current_url).path.should == path_to(page_name)
|
252
|
+
else
|
253
|
+
assert_equal path_to(page_name), URI.parse(current_url).path
|
254
|
+
end
|
255
|
+
end
|
256
|
+
|
257
|
+
Then /^show me the page$/ do
|
258
|
+
save_and_open_page
|
259
|
+
end
|