Compare commits
No commits in common. "5bce31baf283a051d1213c30601355494939d8d5" and "f8499a79c2c8cd6b5e495886dc436010945bd55a" have entirely different histories.
5bce31baf2
...
f8499a79c2
11
app.rb
11
app.rb
|
|
@ -19,10 +19,11 @@ class App < Roda
|
||||||
|
|
||||||
r.get String do | url_code |
|
r.get String do | url_code |
|
||||||
link = links.filter(:code => url_code)
|
link = links.filter(:code => url_code)
|
||||||
r.redirect link.first[:url] unless link.first.nil?
|
if link.first.nil?
|
||||||
@message = "Link #{url_code} doesn't exist"
|
flash['message'] = "Link #{url_code} doesn't exist"
|
||||||
response.status = 404
|
r.redirect '/'
|
||||||
view :home
|
end
|
||||||
|
r.redirect link.first[:url]
|
||||||
end
|
end
|
||||||
|
|
||||||
r.post "create" do
|
r.post "create" do
|
||||||
|
|
@ -31,7 +32,7 @@ class App < Roda
|
||||||
flash['message'] = "Please enter a valid URL";
|
flash['message'] = "Please enter a valid URL";
|
||||||
r.redirect '/'
|
r.redirect '/'
|
||||||
end
|
end
|
||||||
if links.filter(:url => url).first.nil?
|
if nil == links.filter(:url => url).first
|
||||||
code = SecureRandom.urlsafe_base64 4
|
code = SecureRandom.urlsafe_base64 4
|
||||||
links.insert(url: url, code: code)
|
links.insert(url: url, code: code)
|
||||||
@message = "Link created"
|
@message = "Link created"
|
||||||
|
|
|
||||||
|
|
@ -42,8 +42,5 @@ Feature: Homepage
|
||||||
|
|
||||||
Scenario: Accessing a nonexistent URL code
|
Scenario: Accessing a nonexistent URL code
|
||||||
Given I visit the "/aaaaaa" location
|
Given I visit the "/aaaaaa" location
|
||||||
Then I should be on "/aaaaaa" page
|
Then I should be on "/" page
|
||||||
And The status code should be 404
|
|
||||||
And I should see the message "Link aaaaaa doesn't exist"
|
And I should see the message "Link aaaaaa doesn't exist"
|
||||||
And I should see a form field "url"
|
|
||||||
And I should see a "Submit" button
|
|
||||||
|
|
|
||||||
|
|
@ -3,7 +3,6 @@ Before('@db-test') do
|
||||||
@links = Sequel.sqlite("db/#{ENV['DB_NAME']}")[:links]
|
@links = Sequel.sqlite("db/#{ENV['DB_NAME']}")[:links]
|
||||||
end
|
end
|
||||||
|
|
||||||
|
|
||||||
# GIVEN
|
# GIVEN
|
||||||
|
|
||||||
Given('I visit the {string} page') do |string|
|
Given('I visit the {string} page') do |string|
|
||||||
|
|
@ -18,7 +17,6 @@ Given('A link already exists with the url {string} and code {string}') do |url,
|
||||||
@links.insert(url: url, code: code)
|
@links.insert(url: url, code: code)
|
||||||
end
|
end
|
||||||
|
|
||||||
|
|
||||||
# WHEN
|
# WHEN
|
||||||
|
|
||||||
When('I click the {string} button') do |string|
|
When('I click the {string} button') do |string|
|
||||||
|
|
@ -33,7 +31,6 @@ When('I visit the {string} location') do |string|
|
||||||
visit string
|
visit string
|
||||||
end
|
end
|
||||||
|
|
||||||
|
|
||||||
# THEN
|
# THEN
|
||||||
|
|
||||||
Then('I should see text {string}') do |string|
|
Then('I should see text {string}') do |string|
|
||||||
|
|
@ -61,12 +58,6 @@ Then('I should be redirected to {string}') do |string|
|
||||||
location = actual.index(string)
|
location = actual.index(string)
|
||||||
location.should equal(0)
|
location.should equal(0)
|
||||||
end
|
end
|
||||||
|
|
||||||
Then('The status code should be {int}') do |code|
|
|
||||||
puts page.status_code.should eq(code)
|
|
||||||
end
|
|
||||||
|
|
||||||
|
|
||||||
# AFTER
|
# AFTER
|
||||||
|
|
||||||
After('@db-test') do
|
After('@db-test') do
|
||||||
|
|
|
||||||
Loading…
Reference in New Issue