more diary entry test
[rails.git] / test / functional / diary_entry_controller_test.rb
index 7eebfa57e6d1632e28c4ca8922208aa7349655bf..1dc9026bb2e7c18efb7ab5ca8cb62627c13a2b8a 100644 (file)
@@ -1,6 +1,7 @@
 require File.dirname(__FILE__) + '/../test_helper'
 
 class DiaryEntryControllerTest < ActionController::TestCase
+  fixtures :users, :diary_entries, :diary_comments
   def basic_authorization(user, pass)
     @request.env["HTTP_AUTHORIZATION"] = "Basic %s" % Base64.encode64("#{user}:#{pass}")
   end
@@ -10,11 +11,33 @@ class DiaryEntryControllerTest < ActionController::TestCase
   end
   
   def test_showing_create_diary_entry
+    get :new
+    assert_response 302
+    assert_redirected_to :controller => :user, :action => "login", :referer => "/diary_entry/new"
+    # Now pretend to login by using the session hash, with the 
+    # id of the person we want to login as through session(:user)=user.id
+    get(:new, nil, {'user' => users(:normal_user).id})
+    assert_response :success
+    #print @response.body
     
+    #print @response.to_yaml
+    assert_select "html:root", :count => 1 do
+      assert_select "body" do
+        assert_select "div#content" do
+          assert_select "h1", "New diary entry" 
+          assert_select "form[action='/diary_entry/new']" do
+            assert_select "input[id=diary_entry_title][name='diary_entry[title]']"
+            assert_select "textarea#diary_entry_body[name='diary_entry[body]']"
+          end
+        end
+      end
+    end
+        
   end
   
   def test_editing_diary_entry
-    
+    get :edit
+    assert :not_authorized
   end
   
   def test_editing_creating_diary_comment
@@ -26,6 +49,8 @@ class DiaryEntryControllerTest < ActionController::TestCase
   end
   
   def test_rss
+    get :rss
+    assert :success
     
   end