From cae0f46eda8a33911f4a903cc58ac1801bc81fd3 Mon Sep 17 00:00:00 2001 From: David Heinemeier Hansson Date: Sat, 19 Feb 2005 23:21:08 +0000 Subject: Fixed a few tests git-svn-id: http://svn-commit.rubyonrails.org/rails/trunk@703 5ecf4fe2-1ee6-0310-87b1-e25e094e27de --- actionpack/test/controller/routing_tests.rb | 47 ++++++++++++++++++++++ .../test/template/form_options_helper_test.rb | 2 +- 2 files changed, 48 insertions(+), 1 deletion(-) (limited to 'actionpack') diff --git a/actionpack/test/controller/routing_tests.rb b/actionpack/test/controller/routing_tests.rb index 91d7eedd21..5b3879f3b1 100644 --- a/actionpack/test/controller/routing_tests.rb +++ b/actionpack/test/controller/routing_tests.rb @@ -192,6 +192,53 @@ class RouteTests < Test::Unit::TestCase verify_generate('clients', {}, {:controller => 'content'}, @defaults) end + def test_regexp_requirements + const_options = {:controller => 'content', :action => 'by_date'} + route ':year/:month/:day', const_options.merge(:year => /\d{4}/, :month => /\d{1,2}/, :day => /\d{1,2}/) + verify_recognize('2004/01/02', const_options.merge(:year => '2004', :month => '01', :day => '02')) + verify_recognize('2004/1/2', const_options.merge(:year => '2004', :month => '1', :day => '2')) + assert_equal nil, @route.recognize(%w{200 10 10})[0] + assert_equal nil, @route.recognize(%w{content show 10})[0] + + verify_generate('2004/01/02', {}, const_options.merge(:year => '2004', :month => '01', :day => '02'), @defaults) + verify_generate('2004/1/2', {}, const_options.merge(:year => '2004', :month => '1', :day => '2'), @defaults) + assert_equal nil, @route.generate(const_options.merge(:year => '12004', :month => '01', :day => '02'), @defaults)[0] + end + + def test_regexp_requirement_not_in_path + assert_raises(ArgumentError) {route 'constant/path', :controller => 'content', :action => 'by_date', :something => /\d+/} + end + + def test_special_hash_names + route ':year/:name', :requirements => {:year => /\d{4}/, :controller => 'content'}, :defaults => {:name => 'ulysses'}, :action => 'show_bio_year' + verify_generate('1984', {}, {:controller => 'content', :action => 'show_bio_year', :year => 1984}, @defaults) + verify_generate('1984', {}, {:controller => 'content', :action => 'show_bio_year', :year => '1984'}, @defaults) + verify_generate('1984/odessys', {}, {:controller => 'content', :action => 'show_bio_year', :year => 1984, :name => 'odessys'}, @defaults) + verify_generate('1984/odessys', {}, {:controller => 'content', :action => 'show_bio_year', :year => '1984', :name => 'odessys'}, @defaults) + + verify_recognize('1984/odessys', {:controller => 'content', :action => 'show_bio_year', :year => '1984', :name => 'odessys'}) + verify_recognize('1984', {:controller => 'content', :action => 'show_bio_year', :year => '1984', :name => 'ulysses'}) + end + + def test_defaults_and_restrictions_for_items_not_in_path + assert_raises(ArgumentError) {route ':year/:name', :requirements => {:year => /\d{4}/}, :defaults => {:name => 'ulysses', :controller => 'content'}, :action => 'show_bio_year'} + assert_raises(ArgumentError) {route ':year/:name', :requirements => {:year => /\d{4}/, :imagine => /./}, :defaults => {:name => 'ulysses'}, :controller => 'content', :action => 'show_bio_year'} + end + + def test_optionals_with_regexp + route ':year/:month/:day', :requirements => {:year => /\d{4}/, :month => /\d{1,2}/, :day => /\d{1,2}/}, + :defaults => {:month => nil, :day => nil}, + :controller => 'content', :action => 'post_by_day' + verify_recognize('2005/06/12', {:controller => 'content', :action => 'post_by_day', :year => '2005', :month => '06', :day => '12'}) + verify_recognize('2005/06', {:controller => 'content', :action => 'post_by_day', :year => '2005', :month => '06'}) + verify_recognize('2005', {:controller => 'content', :action => 'post_by_day', :year => '2005'}) + + verify_generate('2005/06/12', {}, {:controller => 'content', :action => 'post_by_day', :year => '2005', :month => '06', :day => '12'}, @defaults) + verify_generate('2005/06', {}, {:controller => 'content', :action => 'post_by_day', :year => '2005', :month => '06'}, @defaults) + verify_generate('2005', {}, {:controller => 'content', :action => 'post_by_day', :year => '2005'}, @defaults) + end + + def test_basecamp2 route 'clients/:client_name/:project_name/', :controller => 'content', :action => 'start_page_redirect' verify_recognize('clients/projects/2', {:controller => 'content', :client_name => 'projects', :project_name => '2', :action => 'start_page_redirect'}) diff --git a/actionpack/test/template/form_options_helper_test.rb b/actionpack/test/template/form_options_helper_test.rb index fa0a37aa36..8894e46865 100644 --- a/actionpack/test/template/form_options_helper_test.rb +++ b/actionpack/test/template/form_options_helper_test.rb @@ -158,7 +158,7 @@ class FormOptionsHelperTest < Test::Unit::TestCase @post = Post.new @post.origin = "Denmark" assert_equal( - "", + "", country_select("post", "origin") ) end -- cgit v1.2.3